Patch submission guidelines [1]
Here are some guidelines about how you can contribute to Nikola:
If your contribution is a new feature, you should make sure an issue exists for it, and perhaps discuss it on the mailing list. If you’re fixing a bug you just noticed, or are making a minor change, creating an issue is optional, but please search for existing issues.
Create a new Git branch specific to your change(s). For example, if you’re adding a new feature to foo the bars, do something like the following:
$ git checkout master $ git pull $ git checkout -b foo-the-bars <hack hack hack> $ git push origin HEAD <submit pull request based on your new 'foo-the-bars' branch>
This makes life much easier for maintainers if you have (or ever plan to have) additional changes in your own
master
branch.Also, if you have commit rights to the main Nikola repository, we suggest having your branch there, instead of a personal fork.
A corollary:
Please don’t put multiple fixes/features in the same branch/pull request! In other words, if you’re hacking on new feature X and find a bugfix that doesn’t require new feature X, make a new distinct branch and PR for the bugfix.
You may want to use the Tim Pope’s Git commit messages standard. It’s not necessary, but if you are doing something big, we recommend describing it in the commit message.
While working, rebase instead of merging (if possible). You can use rebase instead of merge by default with
git config pull.rebase true
. If rebases fail, you can just usegit pull --no-rebase
.Make sure documentation is updated — at the very least, keep docstrings current, and if necessary, update the reStructuredText documentation in
docs/
.Add a CHANGELOG entry at the top of
CHANGES.txt
mentioning issue number and in the correct Features/Bugfixes section. Put it under New in master. Create that section if it does not exist yet. Do not add an entry if the change is trivial (documentation, typo fixes) or if the change is internal (not noticeable to end users in any way).Add your name to
AUTHORS.txt
if the change is non-trivial.If you are fixing an issue, include the issue number in commit and/or pull request text (eg.
fix #1234
) so the issue is automatically closed.Run
flake8 nikola
for style consistency.Ensure your Git name and e-mail are set correctly (they will be public) and added to GitHub
Try writing some tests if possible — again, following existing tests is often easiest, and a good way to tell whether the feature you are modifying is easily testable.
Test your code. If you can, run the test suite with
pytest tests/
(you will need to install pytest and some other requirements, seerequirements-tests.txt
). Alternatively, you can push, make a PR and wait for our CI to pick up and test your changes. Test results will appear at the bottom of the PR page, and you can get notifications about failed runs if you configure them on GitHub.If running tests is not feasible before you push, please at least confirm that:
- the demo site (created with
nikola init -qd demosite
) builds without errors - the bugs you were trying to fix do not occur anymore (if applicable)
- the features you added work properly (if applicable)
- the demo site (created with
There are some quirks to how Nikola’s codebase is structured, and to how some things need to be done [2] but don’t worry, we’ll guide you!
[1] | Very inspired by fabric’s — thanks! |
[2] | For example, logging or always making sure directories are created using utils.makedirs() . |