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 on GitHub.
If you are reporting a bug, please include:
- Your TorchIO 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.
TorchIO could always use more documentation, whether as part of the official TorchIO docs, in docstrings, or even on the web in blog posts, articles, and such.
The best way to send feedback is to file an issue at https://github.com/fepegar/torchio/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? Here's how to set up torchio
for local development.
It's good practice to first discuss the proposed changes as the feature might already be implemented.
git clone git@github.com:your_github_username_here/torchio.git
cd torchio
If you use conda
, this is how you can set up your fork for local development:
conda create --name torchioenv python --yes
conda activate torchioenv
pip install --editable .
pip install -r requirements-dev.txt
pre-commit install
For example, if the issue number is 55:
git checkout -b 55-name-of-your-bugfix-or-feature
Now you can make your changes locally.
When you're done making changes, check that your changes pass the tests
using pytest
:
pytest -x
Here's some great advice to write good commit messages, and here's some more):
git add .
git commit -m "Fix nasty bug"
git push origin 55-name-of-your-bugfix-or-feature
If you have modified the documentation or some docstrings, build the docs and verify that everything looks good:
cd docs
make html
You can also use livehtml
instead, to automatically build the docs every
time you modify them and reload them in the browser:
make livehtml
To run a subset of tests:
pytest tests/data/test_image.py