Thank you for taking the time to make Embox better! This makes you awesome by default, but there are some rules to adhere, and following this guide will help you make the whole thing about 20% cooler.
This is just an excerpt to check with from time to time, and it is mostly based on the Git workflow wiki article. There are also the Git cheatsheet article on fixing some common problems and rewriting the history.
Experienced Git users will likely be happy with just this guide though.
(More details on our Wiki)
We use GitHub flow for the development, which is basically about committing into branches and merging through pull requests. TL; DR:
-
Git setup: real name and email; Editors/IDE: proper indentation, auto strip trailing whitespaces
-
Never push to
master
; start each new feature in a branch:- Branch naming:
short-name-through-hyphens
; useNNNN-bug-name
to refer an issue - Within a branch, please keep the history linear, i.e.
rebase
instead ofmerge
to keep the branch up-to-date
- Branch naming:
-
Atomic commits; no "oops" commits, squash if needed; Git commit message agreements
-
Respect those who will review your changes: prepare your branch before opening a PR, cleanup commits and rebase to catch-up recent changes from
upstream/master
-
Do not rebase already published changes and force-push until review is over: push
fixup!
commits, then rebase one last time once getting LGTM from maintainers
For each commit, besides the above, please also be sure that:
-
You used your real name and email to commit
-
The commit is atomic:
- Commit each fix or task as a separate change; only commit when a block of work is complete (or commit and squash afterwards)
- Layer changes, e.g. first make a separate commit formatting the code or refactoring, then commit the actual logic change. This way, the latter commit contains the only minimal diff, which is to be reviewed
-
That is, the commit don't mix together:
- Whitespace changes or code formatting with functional code changes
- Large refactorings and logic changes
- Two unrelated functional changes
The commit log message follows the agreements
-
Start the subject by specifying the subsystem / module
subsys:
is where the change belongs to:arch:
/kernel:
/stm32:
/util:
/mk:
/...
(label)
is what kind of change it is:(docs)
/(template)
/(refactor)
/(minor)
/(MAJOR)
-
Use the imperative mood in the subject line:
Fix
instead of fixing/ fixed -
Capitalize the sentence after the subsystem / labels
-
Do not end the subject line with a period
-
Separate subject from body with a blank line
-
Wrap the body at 72 characters: stopwritingramblingcommitmessages.com
Except for code blocks, long URLs, references to other commits: paste these verbatim, but indent with 4 spaces and surround with empty lines.
-
Subject: what is changed; body: why that, but not how (the diff tells how)
-
Compare:
Good Bad fs: Add missing 'foo -> bar' dependence Fix build arm/stm32: (template) Decrease thread pool size to fit RAM Fix arm/stm32 template util: (refactor) Extract foo_check_xxx() from foo_func() util: Work on foo refactoring
Before proposing a new Pull Request, please check that:
-
None of the commits introduce whitespace errors
- Rebase with
--whitespace=fix
to fix them, if any; see the cheatsheet
- Rebase with
-
There are no merge commits, e.g. you didn't accidentally
pull
without--rebase
-
There are no "oops" or fixup commits; don't forget to squash them
-
(ideally) The whole set of commits is bisectable, i.e. the code builds and runs fine after applying each commit one by one
- Run
git rebase upstream/master -i --exec make
to check that
- Run
Everything's OK? Now create the PR:
- Provide the title and the description
- Follow commit message agreements as a rule of thumb
-
Do not rebase already published changes and force-push until review is over
- Push
fixup!
commits instead [cheatsheet], then rebase one last time once getting LGTM from maintainers
- Push
-
For maintainers: Travis CI has finishes building the PR
- Don't merge until receiving the green mark, even if you believe everything's OK. No need to hurry.