Contributing to python-package-template¶
🎉 Thank you for your interest in contributing to python-package-template!
Your ideas, fixes, and improvements are welcome and appreciated.
Whether you’re fixing a typo, reporting a bug, suggesting a feature, or submitting a pull request—this guide will help you get started.
How to Contribute¶
-
Open an Issue
- Have a question, bug report, or feature suggestion? Open an issue and describe your idea clearly.
- Check for existing issues before opening a new one.
-
Fork and Clone the Repository
git clone git@github.com:<username>/python-package-template.git cd python-package-template -
Set Up Your Environment
We recommend using uv to manage virtual environments for installing
python-package-template. If you don't have uv installed, you can install it with pip. See the project pages for more details:- Install via pip:
pip install --upgrade pip && pip install uv - Project pages: uv on PyPI | uv on GitHub
- Full documentation and usage guide: uv docs
uv sync --extra dev - Install via pip:
-
Set Up Pre-commit Hooks
We use pre-commit to ensure code quality and consistency. After syncing dependencies, run:
uv run pre-commit installThis installs hooks so formatting, linting, and other checks run when you commit.
Pull request titles are validated in GitHub Actions (see
.github/workflows/semantic_pull_request.yml) using the same Conventional Commit vocabulary described under Commit Message Guidelines.Important
The changelog is auto-generated from commits. Use Conventional Commits locally so
git-cliffcan classify changes, and match that style in PR titles so CI passes. -
Create a New Branch
Give it a meaningful name like fix-typo-in-docs or feature-add-summary-option.
-
Make Changes
- Write clear, concise, and well-documented code.
- Follow PEP 8 style conventions.
- Add or update unit tests when applicable.
- Keep changes atomic and focused: one type of change per commit (e.g., do not mix refactoring with feature addition).
-
Run Tests
Ensure that all tests pass before opening a pull request:
uv run pytest -
Open a Pull Request
Clearly describe the motivation and scope of your change. Link it to the relevant issue if applicable. The pull request titles should match the Conventional Commits spec.
Commit Message Guidelines¶
Why this matters: Our changelog is automatically generated from commit messages using git-cliff. Commit messages must follow the Conventional Commits format and adhere to strict rules.
Rules¶
-
One type of change per commit
- Do not mix different types of changes (e.g., bug fixes, features, refactoring) in a single commit.
- Example: if you refactor code AND add a feature, make two separate commits.
-
Descriptive and meaningful messages
- Describe what changed and why, not just what was edited.
- Avoid vague messages like "fix bug" or "update code"; instead use "fix: prevent signal saturation in noise simulation" or "feat: add support for multi-detector frame merging".
-
Follow Conventional Commits format
- All commit messages must follow the Conventional Commits standard.
- Format:
<type>(<scope>): <subject> - Allowed types:
- build: Changes that affect the build system or external dependencies
- ci: Changes to our CI configuration files and scripts
- docs: Documentation only changes
- feat: A new feature
- fix: A bug fix
- perf: A code change that improves performance
- refactor: A code change that neither fixes a bug nor adds a feature
- style: Changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc.)
- test: Adding missing tests or correcting existing tests
-
Example:
feat(signal): add BBH waveform generation for aligned-spin systems This commit introduces support for aligned-spin binary black hole waveforms using PyCBC, enabling more realistic simulations. -
PR titles are checked automatically in the Lint PR workflow.
Examples¶
âś… Good commits:
feat(parser): add support for YAML configuration files
fix(logger): prevent crash on empty log messages
docs(readme): update installation instructions for clarity
refactor(utils): simplify data processing pipeline
❌ Bad commits:
fixed stuff
wip: many changes
update code
more fixes (no type/scope)
đź’ˇ Tips¶
- Be kind and constructive in your communication.
- Keep PRs focused and atomic—smaller changes are easier to review.
- Document new features and update existing docs if needed.
- Tag your PR with relevant labels if you can.
Licensing¶
By contributing, you agree that your contributions will be licensed under the project’s 3-Clause BSD License.
Thanks again for being part of the python-package-template community!