Contributing¶
We welcome anyone interested in contributing to this project, be it with new ideas, suggestions, by filing bug reports or contributing code to our GitHub repository.
Where to start¶
- If you already have some code changes, you can submit them directly as a pull request.
- If you are wondering where we would greatly appreciate your efforts, check out the
help wantedtag in the issues list and initiate a discussion there. - If you start working on a feature in the code, let us know by opening an issue or a draft pull request. This helps all of us to keep an overview on what is being done and helps to avoid a situation where we are doing the same work twice in parallel.
Setting up the development environment¶
For linting, formatting and checking your code contributions against our guidelines (e.g. we use Black as code style use pre-commit:
- Install pixi.
- Usage:
- To automatically activate
pre-commiton everygit commit: Runpre-commit install - To manually run it:
pre-commit run --all
- To automatically activate
Note
Note that installing pre-commit locally is not strictly necessary. If you create a Pull Request the pre-commit CI will be triggered automatically and take care of the checks.
For all code contributions we follow the four eyes principle (two person principle), i.e. all suggested code including our own are reviewed by a second person before they are incorporated into our repository.
If you are unfamiliar with pull requests, the GitHub help pages have a nice guide.
To discuss with other PyPSA users, organise projects, share news, and get in touch with the community you can use the Discord server.
Contributing to the documentation¶
We strive to keep documentation useful and up to date for all PyPSA users. If you encounter an area where documentation is not available or insufficient, we very much welcome your contribution. Here is How To:
- Install pixi.
- Make your changes in the corresponding
.mdfile underpypsa-eur/doc. - Compile your changes by running
pixi run build-docs sitefrom the project root. You can also preview live withmkdocs serve. HTML files to review can be found undersite/. - Contribute your documentation in a pull request (here is a guide).