This will provide you with contribution guidelines. You can contribute in two ways:
- Raising a bug report or making a feature request in an issue
- Suggesting a change by submitting a pull request
- Use the template provided when you create an issue. Follow this template as closely as possible (including the output from
devtools::session_info()
) - It is ok to submit a stump issue (title only) to ensure something is recorded as long as you subsequently complete it. Issues will not be actioned if they are not complete.
- You must submit code that follows a common code style. PRs that do not follow this style will not be accepted. You may use existing code as inspiration if that is the way you learn.
- Files containing classes should follow the convention
<name>-class.R
wherename
is the class name. Use hyphens to separate words in a file name. - Use the template that is provided to you when you create a PR.
- New code should be accompanied by test cases. If it does not, then you must explain why in the PR and create an issue (assigned to yourself) to subsequently submit the test casess.
- New code should be documented when the object to exported (available to the user). Make sure that you roxygenise the package before submitting the PR if you have added or updated any roxygen blocks by invoking
devtools::document()
. - Add an item to the
NEWS
file that reflects the FIX, CHANGE or NEW functionality. Include any issue numbers that are relevant (e.g.(#XX)
) whereXX
is the issue number. - Add your name to the authors list in the
DESCRIPTION
file if you aren't already represented therein - Only the package maintainer should merge PRs into the master branch. The template PR request includes a ping to the package maintainer.
- Run
devtools::check()
before submitting the PR.
- Adopt the Github Flow branch based workflow.
- Branches must almost always be created from master and you will be responsible for resolving any future conflicts with master prior to your PR being submitted.
- Ideally, branch names should follow the following conventions:
- Bug fix branches should be named something like
fix-issue-XX
whereXX
is the corresponding issue number. - Branches that introduce new features should be named something like
feature-new-class-XX
whereXX
is the corresponding issue number
- Bug fix branches should be named something like
- Commit early and commit often. Other good Git practices can be found here
- Be nice to other contributors.