Solidity ======== .. image:: logo.svg :width: 120px :alt: Solidity logo :align: center Solidity is an object-oriented, high-level language for implementing smart contracts. Smart contracts are programs which govern the behaviour of accounts within the Ethereum state. Solidity was influenced by C++, Python and JavaScript and is designed to target the Ethereum Virtual Machine (EVM). Solidity is statically typed, supports inheritance, libraries and complex user-defined types among other features. With Solidity you can create contracts for uses such as voting, crowdfunding, blind auctions, and multi-signature wallets. When deploying contracts, you should use the latest released version of Solidity. This is because breaking changes as well as new features and bug fixes are introduced regularly. We currently use a 0.x version number `to indicate this fast pace of change `_. .. warning:: Solidity recently released the 0.6.x version that introduced a lot of breaking changes. Make sure you read :doc:`the full list <060-breaking-changes>`. Language Documentation ---------------------- If you are new to the concept of smart contracts we recommend you start with :ref:`an example smart contract ` written in Solidity. When you are ready for more detail, we recommend you read the :doc:`"Solidity by Example" ` and "Language Description" sections to learn the core concepts of the language. For further reading, try :ref:`the basics of blockchains ` and details of the :ref:`Ethereum Virtual Machine `. .. hint:: You can always try out code examples in your browser with the `Remix IDE `_. Remix is a web browser based IDE that allows you to write Solidity smart contracts, then deploy and run the smart contracts. It can take a while to load, so please be patient. .. warning:: As humans write software, it can have bugs. You should follow established software development best-practices when writing your smart contracts, this includes code review, testing, audits, and correctness proofs. Smart contract users are sometimes more confident with code than their authors, and blockchains and smart contracts have their own unique issues to watch out for, so before working on production code, make sure you read the :ref:`security_considerations` section. If you have any questions, you can try searching for answers or asking on the `Ethereum Stackexchange `_, or our `gitter channel `_. Ideas for improving Solidity or this documentation are always welcome, read our :doc:`contributors guide ` for more details. .. _translations: Translations ------------ Community volunteers help translate this documentation into several languages. They have varying degrees of completeness and up-to-dateness. The English version stands as a reference. * `French `_ (in progress) * `Italian `_ (in progress) * `Japanese `_ * `Korean `_ (in progress) * `Russian `_ (rather outdated) * `Simplified Chinese `_ (in progress) * `Spanish `_ * `Turkish `_ (partial) Contents ======== :ref:`Keyword Index `, :ref:`Search Page ` .. toctree:: :maxdepth: 2 :caption: Basics introduction-to-smart-contracts.rst installing-solidity.rst solidity-by-example.rst .. toctree:: :maxdepth: 2 :caption: Language Description layout-of-source-files.rst structure-of-a-contract.rst types.rst units-and-global-variables.rst control-structures.rst contracts.rst assembly.rst cheatsheet.rst grammar.rst .. toctree:: :maxdepth: 2 :caption: Internals internals/layout_in_storage.rst internals/layout_in_memory.rst internals/layout_in_calldata.rst internals/variable_cleanup.rst internals/source_mappings.rst internals/optimiser.rst metadata.rst abi-spec.rst .. toctree:: :maxdepth: 2 :caption: Additional Material 050-breaking-changes.rst 060-breaking-changes.rst 070-breaking-changes.rst 080-breaking-changes.rst natspec-format.rst security-considerations.rst resources.rst using-the-compiler.rst yul.rst style-guide.rst common-patterns.rst bugs.rst contributing.rst brand-guide.rst