The official Bitcoin ABC guide to backporting code from Bitcoin Core. When searching for items to backport, especially be on the lookout for bug fixes, code cleanup, and important refactors, as these help improve Bitcoin ABC despite consensus-level differences between eCash and Bitcoin Core.
fork-commit
. Bitcoin ABC was forked from Bitcoin Core
at commit 964a185cc83af34587194a6ecda3ed9cf6b49263
.
> git tag -a fork-commit 964a185 -m 'Where the fun started'
git log --topo-order --graph fork-commit..HEAD -- <file or folder of interest>
commit d083bd9b9c5249f21b8b7e4abd7aee48a25806b1
Merge: b3eb0d648 279fde58e
Author: Wladimir J. van der Laan <[email protected]>
Date: Wed Jun 21 14:26:10 2017 +0200
Merge #10533: [tests] Use cookie auth instead of rpcuser and rpcpassword
279fde5 Check for rpcuser/rpcpassword first then for cookie (Andrew Chow)
3ec5ad8 Add test for rpcuser/rpcpassword (Andrew Chow)
c53c983 Replace cookie auth in tests (Andrew Chow)
Tree-SHA512: 21efb84c87080a895cac8a7fe4766738c34eebe9686c7d10af1bf91ed4ae422e2d5dbbebffd00d34744eb6bb2d0195ea3aca86deebf085bbdeeb1d8b474241ed
If you saw that commit c53c983
was a good idea to backport, this merge
commit would indicate that there are two other commits that are associated
with this PR and likely to be needed.
When trying to find a patch worth backporting, it’s generally a good idea to backport significant refactors or bugfixes. This will help clean up the code in the ABC repository, fix bugs, and make future backports significantly easier. Backports are easiest done in topological order of commits.
Before you begin backporting commits, you will need to add an additional remote to your Bitcoin ABC repo. For Bitcoin Core, this repository would be added as:
git remote add core [email protected]:bitcoin/bitcoin.git
git fetch core
(Assuming you have github ssh auth setup. The second command is required to obtain refs for cherry-picking.)
Once you have identified your commit, or commits on question to backport you have two choices:
In either case, you will find there are likely merge conflicts.
git checkout -b <name-of-branch>
git cherry-pick <commit-of-interest>
git status
and fix conflicts.git add -u && git cherry-pick --continue
git show
side-by-side with git show <commit-of-interest>
and verify that the changes are reasonable.
If there are additional changes caused by the merge conflictarc diff
and at the bottom of the summary note: Backport of core#XXXXX
1.
the PR# can be obtained by searching on github for the commit you are backporting.
If you are backporting a commit which depends on another commit from the same PR,
note that you are backporting Part 1 of X
. Additionally, if it is the second or
more of a series of commits in a backport, note which other phabricator revision this
diff depends on by typing Depends on DXXXX
at the bottom of the summary.git checkout -b PRXXXXX
git rebase -i origin/master
and squash the commits together.arc diff
and at the bottom of the summary note: Backport of core#XXXXX
1.
The title of the diff should be: [Backport] <Description of the included changes>
[1]: besides core
, the prefixes core-gui
and secp256k1
will also include a
hyperlink to the appropriate pull request in the summary automatically, as long as they are in the
format [prefix]#[pr_number]
. No spaces, all lowercase.
The Bitcoin ABC monorepo includes subprojects that are stored in subdirectories of the main repository.
To backport commits for these subprojects, you can add the corresponding additional remotes and use the
-Xsubtree
option for git cherry-pick
.
For instance to backport Electron-Cash commits, you can do:
git remote add electroncash [email protected]:Electron-Cash/Electron-Cash.git
git fetch electroncash
git cherry-pick -Xsubtree=electrum <commit hash>
You can also add git aliases to your ~/.gitconfig
file so that you don’t need to remember the
-Xsubtree
option:
[alias]
cpsecp256k1 = cherry-pick -Xsubtree=src/secp256k1
cpelectrum = cherry-pick -Xsubtree=electrum
This allows you to then backport commits using the following shortcuts:
git cpelectrum <commit hash>
git cpsecp256k1 <commit hash>