From b2ba0d0c42b1f4f000e941620b9b27d54b7da613 Mon Sep 17 00:00:00 2001 From: tangxifan Date: Wed, 22 Dec 2021 15:12:14 -0800 Subject: [PATCH] [Doc] Add version naming convention to developer guidelines --- docs/source/dev_manual/index.rst | 2 + docs/source/dev_manual/version_number.rst | 45 +++++++++++++++++++++++ 2 files changed, 47 insertions(+) create mode 100644 docs/source/dev_manual/version_number.rst diff --git a/docs/source/dev_manual/index.rst b/docs/source/dev_manual/index.rst index c728d39b7..6e7acec12 100644 --- a/docs/source/dev_manual/index.rst +++ b/docs/source/dev_manual/index.rst @@ -3,3 +3,5 @@ :maxdepth: 1 ci_cd_setup/index + + version_number diff --git a/docs/source/dev_manual/version_number.rst b/docs/source/dev_manual/version_number.rst new file mode 100644 index 000000000..612f15721 --- /dev/null +++ b/docs/source/dev_manual/version_number.rst @@ -0,0 +1,45 @@ +.. dev_manual_version_number:: + +Version Number +============== + +Convention +---------- + +OpenFPGA follows the `semantic versioning `_, where the version number is in the form of + +.. code-block:: + + [Major].[Minor].[Patch] + +For example, version ``1.2.300`` denotes + +- One major milestone is achieved. +- Two minor milestone is achieved after the major revision ``1.0.0`` +- ``300`` patches has been applied after the minor revision ``1.2.0`` + +Version Update Rules +-------------------- + +.. warning:: Please discuss with maintainers before modifying major and minor numbers. + +.. warning:: Please do not modify patch number manually. + +To update the version number, please follow the rules: + +- Major and minor version number are defined by maintainers +- Patch number is automatically updated through github actions. See detailed in the `workflow file `_ + +Version updates are made in the following scenario + +- When a minor milestone is achieved, the minor revision number can be increased by 1. The following condition is considered as a minor milestone: + - a new feature has been developed. + - a critical patch has been applied. + - a sufficient number of small patches has been applied in the past quarter. In other words, the minor revision will be updated by the end of each quarter as long as there are patches. + +- When several minor milestones are achieved, the major revision number can be increased by 1. The following condition is considered as a major milestone: + - significant improvements on Quality-of-Results (QoR). + - significant changes on user interface. + - a techical feature is developed and validated by the community, which can impact the complete design flow. + +