diff options
author | chriseth <c@ethdev.com> | 2017-03-13 20:29:34 +0800 |
---|---|---|
committer | chriseth <c@ethdev.com> | 2017-03-13 20:30:23 +0800 |
commit | c65d50681117edb96f6b1387f5a88de160811d38 (patch) | |
tree | ea1c3c046a06f4850a86af8f70bae86455719e88 /docs/contracts.rst | |
parent | bdbd3b158eb68d36a56e0220c7b02960bc71ccb1 (diff) | |
download | dexon-solidity-c65d50681117edb96f6b1387f5a88de160811d38.tar dexon-solidity-c65d50681117edb96f6b1387f5a88de160811d38.tar.gz dexon-solidity-c65d50681117edb96f6b1387f5a88de160811d38.tar.bz2 dexon-solidity-c65d50681117edb96f6b1387f5a88de160811d38.tar.lz dexon-solidity-c65d50681117edb96f6b1387f5a88de160811d38.tar.xz dexon-solidity-c65d50681117edb96f6b1387f5a88de160811d38.tar.zst dexon-solidity-c65d50681117edb96f6b1387f5a88de160811d38.zip |
Documentation update.
Diffstat (limited to 'docs/contracts.rst')
-rw-r--r-- | docs/contracts.rst | 21 |
1 files changed, 13 insertions, 8 deletions
diff --git a/docs/contracts.rst b/docs/contracts.rst index 890745ce..9145f016 100644 --- a/docs/contracts.rst +++ b/docs/contracts.rst @@ -428,17 +428,22 @@ change by overriding). Constant State Variables ************************ -State variables can be declared as constant. In this case, they have to be -assigned a value or expression which is a constant at compile time. Expressions +State variables can be declared as ``constant``. In this case, they have to be +assigned from an expression which is a constant at compile time. Any expression +that accesses storage, blockchain data (e.g. ``now``, ``this.balance`` or +``block.number``) or +execution data (``msg.gas``) or make calls to external contracts are disallowed. Expressions that might have a side-effect on memory allocation are allowed, but those that -might have a side-effect on other memory objects are not. This makes it possible -to create constant memory arrays as lookup-tables -(although this is not yet fully implemented). -Expressions that depend on blockchain data like `now`, `this.balance` or -`block.number` or perform any storage access are disallowed. +might have a side-effect on other memory objects are not. The built-in functions +``keccak256``, ``sha256``, ``ripemd160``, ``ecrecover``, ``addmod`` and ``mulmod`` +are allowed (ever though they do call external contracts). + +The reason behind allowing side-effects on the memory allocator is that it +should be possible to construct complex objects like e.g. lookup-tables. +This feature is not yet fully usable. The compiler does not reserve a storage slot for these variables and every occurrence is -replaced by their constant value (which might be computed by the optimizer). +replaced by the respective constant expression (which might be computed to a single value by the optimizer). Not all types for constants are implemented at this time. The only supported types are value types and strings. |