mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
installing-solidity.rst: Add a section about Static binaries and solc-bin
This commit is contained in:
parent
be5143bbec
commit
c58341022f
@ -189,6 +189,110 @@ Install it using ``brew``:
|
||||
# eg. Install 0.4.8
|
||||
brew install solidity.rb
|
||||
|
||||
Static Binaries
|
||||
===============
|
||||
|
||||
We maintain a repository containing static builds of past and current compiler versions for all
|
||||
supported platforms at `solc-bin`_. This is also the location where you can find the nightly builds.
|
||||
|
||||
The repository is not only a quick and easy way for end users to get binaries ready to be used
|
||||
out-of-the-box but it is also meant to be friendly to third-party tools:
|
||||
|
||||
- The content is mirrored to https://binaries.soliditylang.org where it can be easily downloaded over
|
||||
HTTPS without any authentication, rate limiting or the need to use git.
|
||||
- Content is served with correct `Content-Type` headers and lenient CORS configuration so that it
|
||||
can be directly loaded by tools running in the browser.
|
||||
- Binaries do not require installation or unpacking (with the exception of older Windows builds
|
||||
bundled with necessary DLLs).
|
||||
- We strive for a high level of backwards-compatibility. Files, once added, are not removed or moved
|
||||
without providing a symlink/redirect at the old location. They are also never modified
|
||||
in place and should always match the original checksum. The only exception would be broken or
|
||||
unusable files with a potential to cause more harm than good if left as is.
|
||||
- Files are served over both HTTP and HTTPS. As long as you obtain the file list in a secure way
|
||||
(via git, HTTPS, IPFS or just have it cached locally) and verify hashes of the binaries
|
||||
after downloading them, you do not have to use HTTPS for the binaries themselves.
|
||||
|
||||
The same binaries are in most cases available on the `Solidity release page on Github`_. The
|
||||
difference is that we do not generally update old releases on the Github release page. This means
|
||||
that we do not rename them if the naming convention changes and we do not add builds for platforms
|
||||
that were not supported at the time of release. This only happens in ``solc-bin``.
|
||||
|
||||
The ``solc-bin`` repository contains several top-level directories, each representing a single platform.
|
||||
Each one contains a ``list.json`` file listing the available binaries. For example in
|
||||
``emscripten-wasm32/list.json`` you will find the following information about version 0.7.4:
|
||||
|
||||
.. code-block:: json
|
||||
|
||||
{
|
||||
"path": "solc-emscripten-wasm32-v0.7.4+commit.3f05b770.js",
|
||||
"version": "0.7.4",
|
||||
"build": "commit.3f05b770",
|
||||
"longVersion": "0.7.4+commit.3f05b770",
|
||||
"keccak256": "0x300330ecd127756b824aa13e843cb1f43c473cb22eaf3750d5fb9c99279af8c3",
|
||||
"urls": [
|
||||
"bzzr://16c5f09109c793db99fe35f037c6092b061bd39260ee7a677c8a97f18c955ab1",
|
||||
"dweb:/ipfs/QmTLs5MuLEWXQkths41HiACoXDiH8zxyqBHGFDRSzVE5CS"
|
||||
]
|
||||
}
|
||||
|
||||
This means that:
|
||||
|
||||
- You can find the binary in the same directory under the name
|
||||
`solc-emscripten-wasm32-v0.7.4+commit.3f05b770.js <https://github.com/ethereum/solc-bin/blob/gh-pages/emscripten-wasm32/solc-emscripten-wasm32-v0.7.4+commit.3f05b770.js>`_.
|
||||
Note that the file might be a symlink, and you will need to resolve it yourself if you are not using
|
||||
git to download it or your file system does not support symlinks.
|
||||
- The binary is also mirrored at https://binaries.soliditylang.org/emscripten-wasm32/solc-emscripten-wasm32-v0.7.4+commit.3f05b770.js.
|
||||
In this case git is not necessary and symlinks are resolved transparently, either by serving a copy
|
||||
of the file or returning a HTTP redirect.
|
||||
- The file is also available on IPFS at `QmTLs5MuLEWXQkths41HiACoXDiH8zxyqBHGFDRSzVE5CS`_.
|
||||
- The file might in future be available on Swarm at `16c5f09109c793db99fe35f037c6092b061bd39260ee7a677c8a97f18c955ab1`_.
|
||||
- You can verify the integrity of the binary by comparing its keccak256 hash to
|
||||
``0x300330ecd127756b824aa13e843cb1f43c473cb22eaf3750d5fb9c99279af8c3``. The hash can be computed
|
||||
on the command line using ``keccak256sum`` utility provided by `sha3sum`_ or `keccak256() function
|
||||
from ethereumjs-util`_ in JavaScript.
|
||||
|
||||
.. warning::
|
||||
|
||||
Due to the strong backwards compatibility requirement the repository contains some legacy elements
|
||||
but you should avoid using them when writing new tools:
|
||||
|
||||
- Use ``emscripten-wasm32/`` (with a fallback to ``emscripten-asmjs/``) instead of ``bin/`` if
|
||||
you want the best performance. Until version 0.6.1 we only provided asm.js binaries.
|
||||
Starting with 0.6.2 we switched to `WebAssembly builds`_ with much better performance. We have
|
||||
rebuilt the older versions for wasm but the original asm.js files remain in ``bin/``.
|
||||
The new ones had to be placed in a separate directory to avoid name clashes.
|
||||
- Use ``emscripten-asmjs/`` and ``emscripten-wasm32/`` instead of ``bin/`` and ``wasm/`` directories
|
||||
if you want to be sure whether you are downloading a wasm or an asm.js binary.
|
||||
- Use ``list.json`` instead of ``list.js`` and ``list.txt``. The JSON list format contains all
|
||||
the information from the old ones and more.
|
||||
- Use https://binaries.soliditylang.org instead of https://solc-bin.ethereum.org. To keep things
|
||||
simple we moved almost everything related to the compiler under the new ``soliditylang.org``
|
||||
domain and this applies to ``solc-bin`` too. While the new domain is recommended, the old one
|
||||
is still fully supported and guaranteed to point at the same location.
|
||||
|
||||
.. warning::
|
||||
|
||||
The binaries are also available at https://ethereum.github.io/solc-bin/ but this page
|
||||
stopped being updated just after the release of version 0.7.2, will not receive any new releases
|
||||
or nightly builds for any platform and does not serve the new directory structure, including
|
||||
non-emscripten builds.
|
||||
|
||||
If you are using it, please switch to https://binaries.soliditylang.org, which is a drop-in
|
||||
replacement. This allows us to make changes to the underlying hosting in a transparent way and
|
||||
minimize disruption. Unlike the ``ethereum.github.io`` domain, which we do not have any control
|
||||
over, ``binaries.soliditylang.org`` is guaranteed to work and maintain the same URL structure
|
||||
in the long-term.
|
||||
|
||||
.. _IPFS: https://ipfs.io
|
||||
.. _Swarm: https://swarm-gateways.net/bzz:/swarm.eth
|
||||
.. _solc-bin: https://github.com/ethereum/solc-bin/
|
||||
.. _Solidity release page on github: https://github.com/ethereum/solidity/releases
|
||||
.. _sha3sum: https://github.com/maandree/sha3sum
|
||||
.. _keccak256() function from ethereumjs-util: https://github.com/ethereumjs/ethereumjs-util/blob/master/docs/modules/_hash_.md#const-keccak256
|
||||
.. _WebAssembly builds: https://emscripten.org/docs/compiling/WebAssembly.html
|
||||
.. _QmTLs5MuLEWXQkths41HiACoXDiH8zxyqBHGFDRSzVE5CS: https://gateway.ipfs.io/ipfs/QmTLs5MuLEWXQkths41HiACoXDiH8zxyqBHGFDRSzVE5CS
|
||||
.. _16c5f09109c793db99fe35f037c6092b061bd39260ee7a677c8a97f18c955ab1: https://swarm-gateways.net/bzz:/16c5f09109c793db99fe35f037c6092b061bd39260ee7a677c8a97f18c955ab1/
|
||||
|
||||
.. _building-from-source:
|
||||
|
||||
Building from Source
|
||||
|
Loading…
Reference in New Issue
Block a user