To reduce the workload maintaining the staging
branch in a good shape where
it is close to the main branch with only a few patches applied, some discipline is needed:
- We squash every patch into a single commit, and
- if the patch belongs to an open PR,
- we mention the PR number and title in the commit message, and
- we mention the commit id and message of the latest commit in that PR in the commit message body
This way, looking at the commits on staging
via git log
or the GitHub UI, it is obvious where each commit is coming from and what its purpose is. Additionally, this ensures that rebasing on an updated
main
branch remains simple.
Example: Assuming a PR lies in branch <pr-branch>
(e.g. fix-issue-42
) and has number <pr-num>
in GitHub (e.g. 43 in
https://https://github.com/ocaml/ocaml.org/pull/43), and origin
is
ocaml/ocaml.org.git
at GitHub, here are the steps:
- Squash a PR directly onto staging:
$ git checkout staging
$ git merge --squash <pr-branch>
$ git commit -m "<title of PR on GitHub> #<pr-num>"
- Set the commit message to:
<title of PR on GitHub> #<pr-num>
<message of last commit> <last commit id>
An alternative method to get a squashed PR onto staging is this:
- On the PR branch: create a new branch from the PR branch and squash with
git reset
:
$ git checkout -b <new-branch-name>
$ git reset <commit id before the first commit of the patch>
$ git commit
- Set the commit message to:
<title of PR on GitHub> #<pr-num>
<message of last commit> <last commit id>
- Cherry-pick the commit to staging
$ git checkout staging
$ git cherry-pick <commit id>
To remove a commit from staging
, a simple method is to git rebase -i main
. This gives you a list of commits that you can edit to remove the commit.