Skip to content
This repository has been archived by the owner on Feb 27, 2024. It is now read-only.

Latest commit

 

History

History
51 lines (34 loc) · 1.96 KB

DEVELOPMENT.rst

File metadata and controls

51 lines (34 loc) · 1.96 KB

How to develop and contribute

sphinx-multiversion-contrib is an open source Python project. You can contribute by creating GitHub issues to report bugs or request new features, or by opening a pull request to submit your own improvements to the codebase.

To start developing the project, clone GitHub repository and install it in editable mode with all the extras:

$ git clone git@github.com:iqm-finland/sphinx-multiversion-contrib.git
$ cd sphinx-multiversion-contrib
$ pip install -e ".[dev,docs,testing]"

Now that the package is installed in editable mode, you can run it:

$ sphinx-multiversion --help

Build and view the docs:

$ tox -e docs

To view the documentation, open the file build/sphinx/html/index.html in a browser.

Run the tests:

$ tox

Tagging and releasing

After implementing changes to sphinx-multiversion-contrib one usually wants to release a new version. This means that after the changes are merged to the main branch -

  1. the repository should have an updated CHANGELOG with information about the new changes,
  2. the latest commit should be tagged with the new version number,
  3. and a release should be created based on that tag.

The last two steps are automated, so one needs to worry only about properly updating the CHANGELOG. It should be done along with the pull request which is introducing the main changes. The new version must be added on top of all existing versions and the title must be "Version MAJOR.MINOR", where MAJOR.MINOR represents the new version number. Please take a look at already existing versions and format the rest of your new CHANGELOG section similarly. Once the pull request is merged into main, a new tag and a release will be created automatically based on the latest version definition in the CHANGELOG.