Contributing¶
Contributions are welcome! Please open an issue to discuss significant changes before opening a PR.
Prerequisites¶
- Pixi — manages all environments and dependencies
- Git
Install Pixi, then clone and set up:
git clone https://github.com/BioVisionCenter/ngio
cd ngio
pixi install
Development¶
Work in the dev environment, which includes linters, type checker, and test dependencies:
pixi shell -e dev # activate shell
# or prefix individual commands:
pixi run -e dev <cmd>
Running Tests¶
pixi run -e test pytest # single run (Python 3.11)
pixi run -e test13 pytest # specific Python version (3.11–3.14)
Coverage is reported automatically. The full CI matrix covers test11, test12, test13, test14 across Linux, macOS, and Windows.
Linting & Formatting¶
pixi run pre-commit # run all hooks on all files
This runs Ruff (lint + format), typos (spell check), YAML/TOML validation, and notebook output stripping. Hooks also run automatically on git commit.
Commit Conventions¶
Please follow Conventional Commits — this is not enforced by a hook (yet), but helps maintain a clean history and enables automated changelog generation.
Examples:
feat: add support for multiscale labels
fix: correct axis order in NgffImage
docs: update contributing guide
Opening a Pull Request¶
- Fork the repo and create a branch from
main. - Make your changes with tests where relevant.
- Run
pixi run pre-commitand ensure all checks pass. - Open a PR against
mainwith a clear description of what and why.
CI will run the full test matrix and linters automatically.
Releasing (maintainers only)¶
Versions are derived from git tags via hatch-vcs. Use the Pixi bump tasks in the dev environment:
pixi run bump-patch # 0.5.7 → 0.5.8
pixi run bump-minor # 0.5.7 → 0.6.0
pixi run bump-major # 0.5.7 → 1.0.0
pixi run bump-alpha # → 0.6.0a1 (pre-release)
Append -- --dry-run to preview without creating a tag. Once tagged, CI builds and publishes to PyPI automatically.