Inspired by dwyl's contribution workflow.
- Search this repo's issues to see if an issue exists for the problem you are solving.
- If the issue does not exist, create it. Include a descriptive body.
- If your new issue relates to any others, reference those issues in the body by typing a
#
followed by the issue number. This enables others to follow the history of the topic. - Assign the appropriate label.
- Indicate on the issue that you would like to take it on. Assign one of the reviewers above if you need a response.
- Once you are sure of what you need to do and that it is needed, assign yourself to the issue.
- Clone, and create a new branch for your work
week-<name-here>
- if your new issue relates to a specific week of the course (e.g. week-toolkit
)
bug
- something in this repo is broken (e.g. a link)
discuss
- you'd like the community's input before you start any work
question
- you're not actually sure whether this is an issue or not and would like confirmation
help wanted
- you would like some help in completing work on this issue
The commit history of each file should tell a story
- Describe your changes well
- Commits should be granular
- It is important that you reference an issue in each commit - use multiline messages
You will want to space your commit messages over more than one line. Commit without the -m
to bring up a text editor in which to write the commit message.
You may want to configure git to use your preferred text editor, if you do not like the default. ie. Set atom to be default commit message editor.
The message should have the following format:
short description under 50 chars.
[newline]
more detailed description (may be bullet points)
[newline]
related #[issue number]
or
short description under 50 chars.
[newline]
related #[issue number]
Once you have finished your work, push up your branch and make a pull request. Remember, a pull request should be as small as possible. This makes the review process quick and easy.
Make sure your PR has the following
- A descriptive title - distinct from others and therefore searchable
- A body with details of everything in the pull.
- Reference to any/all related issues in description
- Assignees - add yourself, as well as anyone else who has worked on, or is involved in the PR
- Reviewers
- add the maintainers of
master-reference
to every PR - add anyone else that you think should be aware of the contents of your PR before it is merged (e.g. anyone mentioned in the file you are uploading, or mentors delivering this material in another campus)
- if your PR requires a review from a particular person / people before it is ready to be merged, specify this within the body of your PR
- add the maintainers of
- This means that in general, assignees are those responsible for the code itself, while reviewers (i.e. the maintainers) are responsible for review and merging.
Once a pull request has been approved by two maintainers it can be merged. In time critical situations, one approval may suffice, as long a the pull request is small and is not suggesting any major change.
P.S. please star this repo.