Contributing
Thank you for your interest in contributing!
This file covers:
- Workflow for bug reports, feature requests and documentation improvements
- Workflow for code contributions (bug fixes, enhancements)
- Development and testing
- Updating the package
- Code of conduct
Workflow for bug reports, feature requests and documentation improvements
Before opening an issue, please search existing issues to avoid duplicates. If an issue exists, you can add a comment with additional details and/or upvote (👍) the issue. If there is not an existing issue, please open one and provide as much detail as possible.
- For feature requests or documentation improvements, please describe your suggestion clearly.
- For bugs, include:
- Steps to reproduce.
- Expected and actual behaviour.
- Environment details (operating system, python version, dependencies).
- Relevant files (e.g. problematic
.qmdfiles).
Handling bug reports (for maintainers):
- Confirm reproducibility by following the reported steps.
- Label the issue appropriately (e.g.
bug). - Request additional information if necessary.
- Link related issues or pull requests.
- Once resolved, close the issue with a brief summary of the fix.
Workflow for code contributions (bug fixes, enhancements)
Fork the repository and clone your fork.
Create a new branch for your feature or fix:
git checkout -b my-featureMake your changes and commit them with clear, descriptive messages using the conventional commits standard.
Push your branch to your fork:
git push origin my-feature- Open a pull request against the main branch. Describe your changes and reference any related issues.
Development and testing
Dependencies
If you want to contribute to lintquarto or run its tests, you’ll need some additional tools:
| Tool | Purpose |
|---|---|
| check-dependencies | Test for undeclared dependencies |
| flit | Packaging and publishing |
| genbadge | Create coverage badge (README) |
| grayskull | Uploading to conda-forge |
| jupyter | Run python code in docs |
| pre-commit | To make pre-commit hook that lints files |
| pytest | Run tests |
| pytest-cov | Calculate coverage |
| twine | Upload to PyPI |
| types-toml | Required by mypy |
| quartodoc | Generate API docs |
-e .[all] |
Editable install + all linters |
These are listed in requirements-dev.txt for convenience. To set up your development environment, create an environment (e.g. virtualenv) and run:
pip install -r requirements-dev.txtFor testing only (used by GitHub actions):
pip install -r requirements-test.txtYou can also install the packages in requirements-dev.txt when you install lintquarto by running:
pip install lintquarto[dev]Quarto (used for the docs) is a standalone tool - install it from https://quarto.org/docs/get-started/.
Dependency versions
Contributors are encouraged to install and use the latest versions of development tools. This helps keep the project compatible with current tooling and catches issues early.
If you need a fully reproducible and stable setup, use the provided Conda environment file. This file pins all development tool versions, including Python:
conda env create -f requirements-stable.ymlTo update the stable environment, run conda update --all and test thoroughly (running tests, building documentation), and then update requirements-stable.yml with any changes.
Docstrings
We follow the numpydoc style for docstrings, and check these using pydoclint.
Tests
Run all tests (with coverage):
pytest --covRun an individual test file:
pytest tests/test_back.pyRun a specific test:
pytest tests/test_linters.py::test_supported_errorLinting
Make scripts executable (first time only):
chmod +x lint_package.sh
chmod +x lint_docs.shLint the package:
lint_package.shLint the documentation:
lint_docs.shThere is a pre-commit hook provided which will lint the package and documentation with every commit. To make it executable, run:
pre-commit installNot running in the right environment? You may find the pre-commit fails if it is using the wrong environment - I’ve found this to be the case in VSCode. I’ve found the simplest way to fix this is to work on the command line, activate the environment, and then either do the commit directly there (i.e., git add, git commit) or launch VS Code (code .) which ensures it inherits the environment.
Documentation
Build and preview the documentation locally:
make -C docsWhen running this, function documentation will be automatically generated from the codebase using quartodoc
Updating the package
Preparation
Before proceeding, you will need to have cloned the lintquarto/staged-recipes repository which is used to push updates to conda.
git clone https://github.com/lintquarto/staged-recipesWorkflow for updates
If you are a maintainer and need to publish a new release:
Update the
CHANGELOG.md.Update the version number in
__init__.py,CITATION.cffandREADME.mdcitation, and update the date inCITATION.cff.Create a release on GitHub, which will automatically archive to Zenodo.
Build and publish using flit or twine.
To upload to PyPI using flit:
flit publishTo upload to PyPI using twine: remove any existing builds, then build the package locally and push with twine, entering the API token when prompted:
rm -rf dist/
flit build
twine upload --repository pypi dist/*For test runs, you can use the same method with test PyPI:
rm -rf dist/
flit build
twine upload --repository testpypi dist/*- If you haven’t already, fork the lintquarto feedstock (conda-forge/lintquarto-feedstock). This fork must be to your personal GitHub account and not an organisation account. Clone it to your local machine.
If you already have a fork, make sure it is up-to-date:
- With the
conda-forgefeedstock - on your forkedmainbranch, click “🔄 Sync fork”. - Locally on your
mainbranch (git checkout main), rungit pull.
- Create and checkout a branch - e.g.
update_0_5_0.
git checkout -b update_0_5_0- Use
grayskullto update the recipe (recipe/meta.yaml). It will pull the metadata about the package from PyPI, and will not use your local installation of the package.
grayskull pypi lintquartoIt will create lintquarto/meta.yaml. You will need to copy over the contents into recipe/meta.yaml. When you do so, make sure to keep the two fixes made to the meta.yaml file which are…
Fix A: The addition of a home element within about.
home: https://lintquarto.github.io/lintquarto/Fix B: Correct python version requirements syntax as per the conda-forge documentation, using python_min for host (fixed version), run (minimum version) and requires (fixed version).
Note: Don’t need to set the python_min anywhere unless it differs from conda default (currently 3.7).
host:
- python {{ python_min }}
...
run:
- python >={{ python_min }}
...
requires:
- python {{ python_min }}- Create a commit with the updated feedstock - for example:
git add --all
git commit -m "updated feedstock to version 0.5.0"
git push- Use the GitHub website to open a pull request. Completed the provided checklist -
- Personal account? Yes, if you used your GitHub and not an organisation.
- Bump? Not relevant as doing a version update, can remove.
- Reset base? Yes, should show as
number: 0inmeta.yamlby default. - Re-render? Add the command
@conda-forge-admin, please rerenderto the end of the pull request.
- Wait for the CI actions to run. If all pass, then you can click “Merge pull request”.
Code of conduct
Please be respectful and considerate. See the code of conduct for details.