If you find bugs, typos, or other problems that can be fixed with a few changes, you are more than welcome to contribute these fixes with a pull request as follows. For big changes, such as adding a smart contract, we recommend to discuss with one of the core developers first.
- Create your own fork of this repository on GitHub.
- Clone your fork on your local machine. Your remote repository on GitHub is called origin.
- Add the original GitHub repository as a remote called upstream.
- If you have created your fork a while ago, pull upstream changes into your local repository.
- Create a new branch from
develop
. - Fix the bug, correct the typo, solve the problem, etc. Make sure to follow the coding guidelines below.
- Commit your changes to your new branch. Make sure to use a concise but meaningful commit message.
- Push your branch to the remote origin (your fork on Github).
- From your fork on GitHub, open a pull request (PR) in your new branch targeting the
develop
branch of the original repo. In the PR, describe the problem and how your changes solve it. - If the PR reviewer requests further changes, push them to your branch. The PR will be updated automatically.
- When your PR is approved and merged, you can pull the changes from upstream to your local repo and delete your extra branch.
For developing a smart contract, also see contracts.md.
We use a mixture of GitFlow and a trunk-based-process with the following branches:
-
main
: The code base that is officially deployed. Further Releases are created from this branch. Changes should NOT be committed here directly but merged from other branches after testing. Exception: If the current release (such as v1.191.0) has a critical bug, the fix may be committed to the main branch directly (followed by creating a bugfix release such as v1.191.1 after testing the fix). -
develop
: Our current testing branch, which will be automatically deployed to the testnet once active. Most changes should either be committed here or in feature branches. Feature branches should be created fromdevelop
and pull requests (PR) should targetdevelop
. Before committing to this branch or creating a PR, please check that everything compiles and the automated tests (gtest) run successfully. -
feature/YYYY-MM-DD-FeatureName
: When we are working on a specific feature that is quite complex and/or requires code review, a feature branch should be created fromdevelop
. The commits in this branch do not need to be fully functional, but before creating a pull request, you should check that the final commit compiles and the automated tests (gtest) run successfully. If the code passes the PR review, it can be merged to the 'develop' branch for testing. (The idea is to test the changes in an accumulated way in the testnet, assuming that most changes work and do not require debugging. This should be easier than deploying each feature branch in the testnet separately.) The branch should be deleted after merging with the PR. -
testnet/YYYY-MM-DD-FeatureOrReleaseName
: This is a temporary branch used for the testnet, building on feature branches or thedevelop
branch. It contains at least one commit that adapts the code as required for running in the testnet. We will delete testnet branches that have not been changed for one month or longer. And they may be cleaned up before by their owner (the developer who created it) to avoid cluttering the repository with unused branches. -
release/v1.XYZ
: This is a release branch for a specific version, usually for a new epoch. It should be created from the 'develop' branch after testing the new features and agreeing on what is supposed to be included in the release. This branch is then merged to the main branch via PR before creating the release on the main branch. The branch may be deleted after merging. However, it may be necessary to later recreate the branch if an old release needs to be fixed or updated, such as for creating the rollback version v1.190.1 for epoch 94.
For each release, there will be a tag like v1.XYZ.N
.
The release description should contain the target epoch number and a short change log.
Mandatory update releases like adding SC or IPO should be published before Sunday (1/2 of the epoch), so that computors can catch up with AUX&MAIN mode and have the new version running the next epoch seamlessly (the following Wednesday).
TODO
vX.Y.Z
Starting with v1.225.0
naming follows this scheme:
If two versions' X
s and Y
s are the same, the versions are compatible and can tick together. Z
is incremented for changes that do not break compatibility.
If X
or Y
change, compatibility is broken and computor operators MUST update their nodes.
Examples changes that require increment of X
or Y
:
- adding a contract
- changing a contract procedure
- anything that may influence digests