Document our version policy w/r/t SemVer

This commit is contained in:
William Entriken 2022-01-25 18:46:27 -05:00
parent 597426bd1c
commit 8c6f80aa03

View File

@ -9,11 +9,22 @@ Installing the Solidity Compiler
Versioning Versioning
========== ==========
Solidity versions follow `semantic versioning <https://semver.org>`_ and in addition to Solidity versions follow `Semantic Versioning <https://semver.org>`_. In
releases, **nightly development builds** are also made available. The nightly builds addition, patch level releases with major release 0 (i.e. 0.x.y) will not
are not guaranteed to be working and despite best efforts they might contain undocumented contain breaking changes. That means code that compiles with version 0.x.y
and/or broken changes. We recommend using the latest release. Package installers below can be expected to compile with 0.x.z where z > y.
will use the latest release.
In addition to releases, we provide **nightly development builds** with the
intention of making it easy for developers to try out upcoming features and
provide early feedback. Note, however, that while the nightly builds are usually
very stable, they contain bleeding-edge code from the development branch and are
not guaranteed to be always working. Despite our best efforts, they might
contain undocumented and/or broken changes that will not become a part of an
actual release. They are not meant for production use.
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](https://semver.org/#spec-item-4).
Remix Remix
===== =====
@ -551,10 +562,10 @@ of the current nightly build, but without the ``prerelease`` specifier.
Example: Example:
0. The 0.4.0 release is made. 1. The 0.4.0 release is made.
1. The nightly build has a version of 0.4.1 from now on. 2. The nightly build has a version of 0.4.1 from now on.
2. Non-breaking changes are introduced --> no change in version. 3. Non-breaking changes are introduced --> no change in version.
3. A breaking change is introduced --> version is bumped to 0.5.0. 4. A breaking change is introduced --> version is bumped to 0.5.0.
4. The 0.5.0 release is made. 5. The 0.5.0 release is made.
This behaviour works well with the :ref:`version pragma <version_pragma>`. This behaviour works well with the :ref:`version pragma <version_pragma>`.