aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorchriseth <chris@ethereum.org>2018-09-14 00:29:14 +0800
committerchriseth <chris@ethereum.org>2018-09-18 21:16:40 +0800
commit2c613127c92ab96ca8b02ff7b1866df1ad9ad1c0 (patch)
tree8d65745bd60e5520397c705f5a7278cd0a459d84
parentfcb48bceffa54cf8cb79f6d8e03d875277f535ff (diff)
downloaddexon-solidity-2c613127c92ab96ca8b02ff7b1866df1ad9ad1c0.tar
dexon-solidity-2c613127c92ab96ca8b02ff7b1866df1ad9ad1c0.tar.gz
dexon-solidity-2c613127c92ab96ca8b02ff7b1866df1ad9ad1c0.tar.bz2
dexon-solidity-2c613127c92ab96ca8b02ff7b1866df1ad9ad1c0.tar.lz
dexon-solidity-2c613127c92ab96ca8b02ff7b1866df1ad9ad1c0.tar.xz
dexon-solidity-2c613127c92ab96ca8b02ff7b1866df1ad9ad1c0.tar.zst
dexon-solidity-2c613127c92ab96ca8b02ff7b1866df1ad9ad1c0.zip
Explain pragmas.
-rw-r--r--docs/installing-solidity.rst2
-rw-r--r--docs/layout-of-source-files.rst52
2 files changed, 51 insertions, 3 deletions
diff --git a/docs/installing-solidity.rst b/docs/installing-solidity.rst
index 3332a83b..ba373b8f 100644
--- a/docs/installing-solidity.rst
+++ b/docs/installing-solidity.rst
@@ -303,6 +303,8 @@ CMake options
If you are interested what CMake options are available run ``cmake .. -LH``.
+.. _smt_solvers_build:
+
SMT Solvers
-----------
Solidity can be built against SMT solvers and will do so by default if
diff --git a/docs/layout-of-source-files.rst b/docs/layout-of-source-files.rst
index b88e7e45..11f85aac 100644
--- a/docs/layout-of-source-files.rst
+++ b/docs/layout-of-source-files.rst
@@ -2,15 +2,23 @@
Layout of a Solidity Source File
********************************
-Source files can contain an arbitrary number of contract definitions, include directives
-and pragma directives.
+Source files can contain an arbitrary number of
+:ref:`contract definitions<contract_structure>`, import_ directives
+and :ref:`pragma directives<pragma>`.
+
+.. index:: ! pragma
+
+.. _pragma:
+
+Pragmas
+=======
.. index:: ! pragma, version
.. _version_pragma:
Version Pragma
-==============
+--------------
Source files can (and should) be annotated with a so-called version pragma to reject
being compiled with future compiler versions that might introduce incompatible
@@ -35,6 +43,44 @@ the exact version of the compiler, so that bugfix releases are still possible.
It is possible to specify much more complex rules for the compiler version,
the expression follows those used by `npm <https://docs.npmjs.com/misc/semver>`_.
+.. index:: ! pragma, experimental
+
+.. _experimental_pragma:
+
+Experimental Pragma
+-------------------
+
+The second pragma is the experimental pragma. It can be used to enable
+features of the compiler or language that are not yet enabled by default.
+The following experimental pragmas are currently supported:
+
+
+ABIEncoderV2
+~~~~~~~~~~~~
+
+The new ABI encoder is able to encode and decode arbitrarily nested
+arrays and structs. It produces less optimal code (the optimizer
+for this part of the code is still under development) and has not
+received as much testing as the old encoder. You can activate it
+using ``pragma experimental ABIEncoderV2;``.
+
+SMTChecker
+~~~~~~~~~~
+
+This component has to be enabled when the Solidity compiler is built
+and therefore it is not available in all Solidity binaries.
+The :ref:`build instructions<smt_solvers_build>` explain how to activate this option.
+It is activated for the Ubuntu PPA releases in most versions,
+but not for solc-js, the Docker images, Windows binaries or the
+statically-built Linux binaries.
+
+If you use
+``pragma experimental SMTChecker;``, then you get additional
+safety warnings which are obtained by querying an SMT solver.
+The component does not yet support all features of the Solidity language
+and likely outputs many warnings. In case it reports unsupported
+features, the analysis may not be fully sound.
+
.. index:: source file, ! import
.. _import: