We're really glad you're reading this, because we need volunteer developers to help maintain this project.
Some of the resources to look at if you're interested in contributing:
- Look at open issues tagged with "help wanted" and "good first issue"
- Look at the contributing guide in our documentation
By contributing to PAM, i.e. through opening a pull request, you represent that your contributions are your own original work and that you have the right to license them, and you agree that your contributions are licensed under the MIT license.
You can open an issue on GitHub to report bugs or request new PAM features. Follow these links to submit your issue:
-
Report bugs or other problems while running PAM. If reporting an error, please include a full traceback in your issue.
-
Report missing or inconsistent information in our documentation.
Look at the development guide in our documentation for information on how to get set up for development.
To contribute changes:
- Fork the project on GitHub.
- Create a feature branch to work on in your fork (
git checkout -b new-fix-or-feature
). - Test your changes using
pytest
. - Commit your changes to the feature branch (you should have
pre-commit
installed to ensure your code is correctly formatted when you commit changes). - Push the branch to GitHub (
git push origin new-fix-or-feature
). - On GitHub, create a new pull request from the feature branch.
Before submitting a pull request, check whether you have:
- Added your changes to
CHANGELOG.md
. - Added or updated documentation for your changes.
- Added tests if you implemented new functionality.
When opening a pull request, please provide a clear summary of your changes!
Please try to write clear commit messages. One-line messages are fine for small changes, but bigger changes should look like this:
A brief summary of the commit (max 50 characters)
A paragraph or bullet-point list describing what changed and its impact,
covering as many lines as needed.
Start reading our code and you'll get the hang of it.
We mostly follow the official Style Guide for Python Code (PEP8).
We have chosen to use the uncompromising code formatter black
and the linter ruff
.
When run from the root directory of this repo, pyproject.toml
should ensure that formatting and linting fixes are in line with our custom preferences (e.g., 100 character maximum line length).
The philosophy behind using black
is to have uniform style throughout the project dictated by code.
Since black
is designed to minimise diffs, and make patches more human readable, this also makes code reviews more efficient.
To make this a smooth experience, you should run pre-commit install
after setting up your development environment, so that black
makes all the necessary fixes to your code each time you commit, and so that ruff
will highlight any errors in your code.
If you prefer, you can also set up your IDE to run these two tools whenever you save your files, and to have ruff
highlight erroneous code directly as you type.
Take a look at their documentation for more information on configuring this.
We require all new contributions to have docstrings for all modules, classes and methods. When adding docstrings, we request you use the Google docstring style.
- Re-run tutorial Jupyter notebooks (
pytest examples/ --overwrite
). - Make sure documentation builds without errors (
mike deploy [version]
, where[version]
is the current patch release of the formX.Y.Z
). - Make sure the [changelog][changelog] is up-to-date, especially that new features and backward incompatible changes are clearly marked.
- Bump the version number in
src/pam/__init__.py
- Update the [changelog][changelog] with final version number of the form
vX.Y.Z
, release date, and githubcompare
link (at the bottom of the page). - Commit with message
Release vX.Y.Z
, then add avX.Y.Z
tag. - Create a release pull request to verify that the conda package builds successfully.
- Once the PR is approved and merged, create a release through the GitHub web interface, using the same tag, titling it
Release vX.Y.Z
and include all the changelog elements that are not flagged as internal.
- Update the changelog, adding a new
[Unreleased]
heading. - Update
src/pam/__init__.py
to the next version appended with.dev0
, in preparation for the next main commit.
The layout and content of this document is partially based on the Calliope project's contribution guidelines.