Contributions are welcome, and they are greatly appreciated! Every little bit helps, and credit will always be given.
You can contribute in many ways:
Report bugs at https://github.com/ClimateImpactLab/impactlab-tools/issues.
If you are reporting a bug, please include:
- Your operating system name and version.
- Any details about your local setup that might be helpful in troubleshooting.
- Detailed steps to reproduce the bug.
Look through the GitHub issues for bugs. Anything tagged with "bug" and "help wanted" is open to whoever wants to implement it.
Look through the GitHub issues for features. Anything tagged with "enhancement" and "help wanted" is open to whoever wants to implement it.
impactlab-tools could always use more documentation, whether as part of the official docs, in docstrings, or even on the web in blog posts, articles, and such.
To test the documentation you write, run the command:
$ sphinx-build -W -b html -d docs/_build/doctrees docs/. docs/_build/html
The best way to send feedback is to file an issue at https://github.com/ClimateImpactLab/impactlab-tools/issues.
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, and that contributions are welcome :)
Ready to contribute? Great! There are a couple steps to follow when contributing code.
Install your local copy into a virtual environment. For example, using venv, this is how you set up your fork for local development:
$ cd impactlab-tools/
$ python3 -m venv .venv
$ source .venv/bin/activate
$ python3 -m pip install -r requirements.txt
$ python3 -m pip install -e .
When making any changes to the impactlab-tools codebase, follow the following steps:
Check for issues on our issues page. If no issue exists for the feature you would like to add, add one! Make sure the scope of the issue is limited and precise, so anyone can understand the behaviour/feature you would like to see.
Fork the impactlab-tools repo on GitHub.
Clone your fork locally:
$ git clone git@github.com:your_name_here/impactlab-tools.git
Create a branch for local development:
$ git checkout -b name-of-your-bugfix-or-feature
Now you can make your changes locally.
Write tests for your feature first. Think through all the use cases and make sure your tests cover all the ways your code might be used. Include the issue number you are addressing in the docstring of your tests:
def test_my_new_feature(): ''' Test my_new_feature. Addresses :issue:`1234` ''' # test code
Implement your feature, writing as little code as is required to satisfy the tests you just wrote. Run tests frequently to make sure you are maintaining compatibility with the rest of the package:
$ python3 -m pytest $ python3 -m ruff check .
You can run only the tests you wrote using pytest's expression matching syntax, e.g.:
$ python3 -m pytest -k test_my_new_feature
When you are passing all of your tests, run the full test suite.
Make changes to the docs describing your new feature if necessary.
Add an entry to the latest whatsnew document describing your changes. Make sure to reference the issue number in your entry.
Commit your changes and push your branch to GitHub:
$ git add . $ git commit -m "Your detailed description of your changes." $ git push origin name-of-your-bugfix-or-feature
Submit a pull request through the GitHub website.
Happy hunting!