Thank you for being interested in contributing to sphinx-autobuild
!
This page contains information to help you get started with development on this project.
If you are proposing a feature:
- Explain in detail how it would work.
- Keep the scope as narrow as possible, to make it easier to implement.
- Remember that this is a volunteer-driven project. :)
Fork the
sphinx-autobuild
repo on GitHub.Clone your fork locally.
$ git clone https://github.com/YOUR_USERNAME_HERE/sphinx-autobuild
To work on this project, you need Python 3.9 or newer. Most of this project's development workflow commands use nox.
If you're not sure how to install nox, it is recommended to set it up in an isolated environment with pipx:
pip install pipx
pipx ensurepath
pipx install nox
This project has a test suite to ensure that things work properly. The tests can be run using:
nox -s tests
This will run tests against all supported version of Python that are installed.
If you want to run tests for a specific version of Python (say, 3.12), you can do so using:
nox -s tests-3.12
The code style in this project is enforced with multiple automated linters. You can run them using:
nox -s lint
You can test your local copy of this project, by building this project's docs/ directory with it.
nox -s docs-live
Before you submit a pull request, check that it meets these guidelines:
- The pull request has code, it should include tests.
- If the pull request adds functionality, the docs should be updated.
- Make sure that the tests pass for all supported Python versions (see the GitHub Actions builds for details).
- Update the
NEWS.rst
file (replace the unreleased title with the current date). - Bump the version in the
src/sphinx_autobuild/__init__.py
file. - Update the AUTHORS file (
git shortlog -s -e -n | cut -f 2- > AUTHORS
on *nix). - Push everything and make sure the Travis tests still pass.
- Run
flit publish
to build the package and release it on PyPI. - Add a new unreleased section to the top of the
NEWS.rst
file.