aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorchriseth <chris@ethereum.org>2017-03-16 22:52:10 +0800
committerGitHub <noreply@github.com>2017-03-16 22:52:10 +0800
commit58334cf4ac1cf61e5296b82ada48a2eb690ed369 (patch)
treecc7b6c7a14d6b15cc88dc30189f697dfb2eb0833
parent6d4cb24842b5955d921a8b6323b2c154ff0b83cb (diff)
parent17443f458a311def7131dcaef00195dff3778da1 (diff)
downloaddexon-solidity-58334cf4ac1cf61e5296b82ada48a2eb690ed369.tar
dexon-solidity-58334cf4ac1cf61e5296b82ada48a2eb690ed369.tar.gz
dexon-solidity-58334cf4ac1cf61e5296b82ada48a2eb690ed369.tar.bz2
dexon-solidity-58334cf4ac1cf61e5296b82ada48a2eb690ed369.tar.lz
dexon-solidity-58334cf4ac1cf61e5296b82ada48a2eb690ed369.tar.xz
dexon-solidity-58334cf4ac1cf61e5296b82ada48a2eb690ed369.tar.zst
dexon-solidity-58334cf4ac1cf61e5296b82ada48a2eb690ed369.zip
Merge pull request #1787 from ethereum/docs-gasvalue
Document the .value() and .gas() modifiers
-rw-r--r--docs/control-structures.rst10
-rw-r--r--docs/types.rst2
2 files changed, 7 insertions, 5 deletions
diff --git a/docs/control-structures.rst b/docs/control-structures.rst
index a3af41dd..a2d34274 100644
--- a/docs/control-structures.rst
+++ b/docs/control-structures.rst
@@ -113,8 +113,8 @@ actual contract has not been created yet.
Functions of other contracts have to be called externally. For an external call,
all function arguments have to be copied to memory.
-When calling functions
-of other contracts, the amount of Wei sent with the call and the gas can be specified::
+When calling functions of other contracts, the amount of Wei sent with the call and
+the gas can be specified with special options ``.value()`` and ``.gas()``, respectively::
contract InfoFeed {
function info() payable returns (uint ret) { return 42; }
@@ -127,8 +127,8 @@ of other contracts, the amount of Wei sent with the call and the gas can be spec
function callFeed() { feed.info.value(10).gas(800)(); }
}
-The modifier ``payable`` has to be used for ``info``, because otherwise,
-we would not be able to send Ether to it in the call ``feed.info.value(10).gas(800)()``.
+The modifier ``payable`` has to be used for ``info``, because otherwise, the `.value()`
+option would not be available.
Note that the expression ``InfoFeed(addr)`` performs an explicit type conversion stating
that "we know that the type of the contract at the given address is ``InfoFeed``" and
@@ -235,7 +235,7 @@ creation-dependencies are not possible.
}
}
-As seen in the example, it is possible to forward Ether to the creation,
+As seen in the example, it is possible to forward Ether to the creation using the ``.value()`` option,
but it is not possible to limit the amount of gas. If the creation fails
(due to out-of-stack, not enough balance or other problems), an exception
is thrown.
diff --git a/docs/types.rst b/docs/types.rst
index 6379f01c..60235ad2 100644
--- a/docs/types.rst
+++ b/docs/types.rst
@@ -123,6 +123,8 @@ In a similar way, the function ``delegatecall`` can be used: The difference is t
All three functions ``call``, ``delegatecall`` and ``callcode`` are very low-level functions and should only be used as a *last resort* as they break the type-safety of Solidity.
+The ``.gas()`` option is available on all three methods, while the ``.value()`` option is not supported for ``delegatecall``.
+
.. note::
All contracts inherit the members of address, so it is possible to query the balance of the
current contract using ``this.balance``.