aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlex Beregszaszi <alex@rtfs.hu>2018-09-20 18:24:58 +0800
committerGitHub <noreply@github.com>2018-09-20 18:24:58 +0800
commitc3dd413c344e1c37dd6f47e8b1f56ca47edebcb5 (patch)
tree66ef3488800b39c8ab5b0f2dfe2b96d0025fcff8
parent420807b8713c434a9c5b14254075d595b89171e0 (diff)
parent92112799d4b56e2bef7b8e07a4dfb96d2181d5f0 (diff)
downloaddexon-solidity-c3dd413c344e1c37dd6f47e8b1f56ca47edebcb5.tar
dexon-solidity-c3dd413c344e1c37dd6f47e8b1f56ca47edebcb5.tar.gz
dexon-solidity-c3dd413c344e1c37dd6f47e8b1f56ca47edebcb5.tar.bz2
dexon-solidity-c3dd413c344e1c37dd6f47e8b1f56ca47edebcb5.tar.lz
dexon-solidity-c3dd413c344e1c37dd6f47e8b1f56ca47edebcb5.tar.xz
dexon-solidity-c3dd413c344e1c37dd6f47e8b1f56ca47edebcb5.tar.zst
dexon-solidity-c3dd413c344e1c37dd6f47e8b1f56ca47edebcb5.zip
Merge pull request #4808 from ethereum/4259-evm-version
[DOCS] Add details on using the compiler --version flag
-rw-r--r--docs/using-the-compiler.rst50
1 files changed, 50 insertions, 0 deletions
diff --git a/docs/using-the-compiler.rst b/docs/using-the-compiler.rst
index 0a64d840..1e4bbecc 100644
--- a/docs/using-the-compiler.rst
+++ b/docs/using-the-compiler.rst
@@ -45,6 +45,56 @@ If ``solc`` is called with the option ``--link``, all input files are interprete
If ``solc`` is called with the option ``--standard-json``, it will expect a JSON input (as explained below) on the standard input, and return a JSON output on the standard output.
+.. _evm-version:
+.. index:: ! EVM version, compile target
+
+Setting the EVM version to target
+*********************************
+
+When you compile your contract code you can specify the Ethereum virtual machine
+version to compile for to avoid particular features or behaviours.
+
+.. warning::
+
+ Compiling for the wrong EVM version can result in wrong, strange and failing
+ behaviour. Please ensure, especially if running a private chain, that you
+ use matching EVM versions.
+
+You use the ``--evm-version`` option on the command line:
+
+.. code-block:: shell
+
+ solc --evm-version <VERSION> contract.sol
+
+Or if using the :ref:`standard JSON interface <compiler-api>`, with the ``evmVersion`` key:
+
+.. code-block:: json
+
+ {
+ "evmVersion": "<VERSION>"
+ }
+
+Target options
+--------------
+
+Below is a list of target EVM versions and the compiler-relevant changes introduced
+at each version. Backward compatibility is not guaranteed between each version.
+
+- ``homestead``
+- ``tangerineWhistle``
+ - gas cost for access to other accounts increased, relevant for gas estimation and the optimizer.
+ - all gas sent by default for external calls, previously a certain amount had to be retained.
+- ``spuriousDragon``
+ - gas cost for the ``exp`` opcode increased, relevant for gas estimation and the optimizer.
+- ``byzantium`` (**default**)
+ - opcodes ``returndatacopy``, ``returndatasize`` and ``staticcall`` are available in assembly.
+ - the ``staticcall`` opcode is used when calling view or pure functions, which prevents the functions from modifying state at the EVM level, i.e., even applies when you use invalid type conversions.
+ - it is possible to access dynamic data returned from function calls.
+ - ``revert`` opcode introduced, which means that ``revert()`` will not waste gas.
+- ``constantinople`` (still in progress)
+ - opcodes ``shl``, ``shr`` and ``sar`` are available in assembly.
+ - shifting operators use shifting opcodes and thus need less gas.
+
.. _compiler-api:
Compiler Input and Output JSON Description