This is a micro project with a small code base, few contributors and hobby maintainership. For this reason, please don't expect immediate responses to bug reports and pull requests. They will all be responded to eventually.
We follow common conventions and code of conduct for Open Source collaboration on GitHub.
Some additional simple guidelines:
Please include
- release or Git commit for the version of Darkgraylib, Darker and/or Graylint you're using
- Python version
- your Darker or Graylint command line
- file to be formatted or linted as an attachment, if possible – also great if squeezed down to a minimal example
- resulting output or error message
- expected output
To speed up review and increase odds for the PR to be accepted, please
keep all modified code black & isort formatted (with help from Darker)
don't reformat unmodified code
include a test case for new or modified code
use type hinting
make sure the test suite passes
verify that mypy static type checking passes
document new features or changed behavior in
README.rst
summarize end-user affecting changes in
CHANGES.rst
add your information in
contributors.yaml
contributor information will be updated to
CONTRIBUTORS.rst
andREADME.rst
in the next release; however, if you have a GitHub personal access token and want to do this yourself, you can run:python release_tools/update_contributors.py \ generate \ --token=<your GitHub personal access token> \ --modify-readme \ --modify-contributors
GitHub is configured to use Github Actions on each pull request to
- run the test suite using Pytest
- do static type checking using Mypy
- lint the code using various linters
- check code formatting using Black
Below are the necessary steps to create a GitHub token. You can either go interactively step by step, or start straight at step 6. by clicking on the Generate new token link. For more information, see Creating a fine-grained personal access token in GitHub Docs.
Verify your email address, if it hasn't been verified yet.
In the upper-right corner of any page, click your profile photo, then click Settings.
In the left sidebar, click Developer settings.
In the left sidebar, under Personal access tokens, click Fine-grained tokens.
Click Generate new token.
Under Token name, enter "
Update Darkgraylib contributors
".Under Expiration, select an expiration for the token.
Under Description, type "
Allow darkgraylib/release_tools/update_contributors.py to retrieve any user's login, full name and link to avatar picture.
"Click Generate token.
Copy and save the token (you won't be able to see it again), and use it on the
update_contributors.py
command line as shown above.
To set up an isolated virtualenv for Darkgraylib, Darker and/or Graylint development, modify code in your own branch, run the test suite and lint modified code on a Unix-like system:
git clone [email protected]:akaihola/darkgraylib.git python -m venv .venv-darkgraylib source .venv-darkgraylib/bin/activate cd darkgraylib pip install -e '.[test]' darker flake8 mypy pydocstyle pylint ruff git checkout -b my-feature-branch # modify code git commit -m "My feature" pytest darker
Darker will fix formatting on modified lines and list any linting errors your changes
may have introduced compared to the branching point of your feature branch from
main
.
Darker is configured in pyproject.toml
to do the following on modified lines:
- reformat using Black
- sort imports using isort
- run Flake8
- run Mypy
- run Pydocstyle
- run Pylint
- run Ruff
Those tools have also been configured to match the conventions in the Darkgraylib code base.