First of all, thanks for considering contributing to pywaterinfo! It's people like you that make it rewarding for us - the project :ref:`authors` - to work on pywaterinfo.
pywaterinfo is an open source project, maintained by people who care.
Please note that this project is released with a :ref:`code_conduct`. By participating in this project you agree to abide by its terms.
There are several ways you can contribute to this project. If you want to know more about why and how to contribute to open source projects like this one, see this Open Source Guide.
Think pywaterinfo is useful? Let others discover it, by telling them in person, via Twitter or a blog post.
Using pywaterinfo for a paper you are writing? Consider citing it:
#TODO
Using pywaterinfo and got stuck? Browse the documentation to see if you can find a solution. Still stuck? Post your question as a new issue on GitHub. While we cannot offer user support, we'll try to do our best to address it, as questions often lead to better documentation or the discovery of bugs.
Have an idea for a new pywaterinfo feature? Take a look at the documentation and issue list to see if it isn't included or suggested yet. If not, suggest your idea as a new issue on GitHub. While we can't promise to implement your idea, it helps to:
- Explain in detail how it would work.
- Keep the scope as narrow as possible.
See :ref:`dev-guidelines`, if you want to contribute code for your idea as well.
Using pywaterinfo and discovered a bug? That's annoying! Don't let others have the same experience and report it as a new issue so we can fix it. A good bug report makes it easier for us to do so, so please include:
- Your operating system name and version (e.g. Mac OS 10.13.6).
- Any details about your local setup that might be helpful in troubleshooting.
- Detailed steps to reproduce the bug.
The issue template will provide tom guidance on the required information.
Noticed a typo on the website? Think a function could use a better example? Good documentation makes all the difference, so your help to improve it is very welcome! Maybe you've written a good introduction tutorial or example case, these are typically very popular sections for new users.
The website
This website is generated with Sphinx. That means we don't have to
write any html. Content is pulled together from documentation in the code,
reStructuredText files and the package conf.py
settings. If you
know your way around Sphinx, you can propose a file change to improve
documentation. If not, report an issue and we can point you in the right direction.
Function documentation
Functions are described as comments near their code and translated to documentation using the numpy docstring standard. If you want to improve a function description:
- Go to
pywaterinfo/
directory in the code repository. - Look for the file with the name of the function.
- Propose a file change to update the function documentation in the docstring (in between the triple quotes).
Care to fix bugs or implement new functionality for pywaterinfo? Awesome! Have a look at the issue list and leave a comment on the things you want to work on. See also the development guidelines below.
It's good practice to create a separate development environment for your package development. Use your preferred system (or maybe integrated in your IDE) to setup a Python environment and see those docs to setup an environment (conda, pyenv, virtualenv,,...). Once created, you can install the package with all the developer dependencies using pip:
pip install -e .[develop]
Alternatively, if you are already familiar with tox
, run the dev
tox command, which will create a venv
with a
development install of the package and it will register the environment as a ipykernel (for usage
inside a jupyter notebook):
tox -e dev
For development purposes using conda, make sure to first run pip install -e .[develop]
environment
to prepare the development environment and install all development tools. (When using tox -e dev
this
is already done).
When starting on the development of the pywaterinfo
package, makes sure to be familiar with the following tools. Do
not hesitate to ask the other contributors when having trouble using these tools.
To ensure a more common code formatting and limit the git diff, make sure to install the pre-commit hooks. For example,
black. is used to make the code formatting as consistent as possible.The
required dependencies are included in the development requirements installed when running ``pip install -e .[develop]
.
Warning
Install and update the pre-commit
hooks before your first git commit to the package!
pre-commit install pre-commit autoupdate
on the main level of the package (pywaterinfo
folder, location where the file .pre-commit-config.yaml
is located)
If you just want to run the hooks on your files to see the effect (not during a git commit), you can use the command at any time:
pre-commit run --all-files
Run the test suite using the pytest package, from within the main package folder (pyhdas):
pytest
Or using tox (i.e. in a separate environment)
tox
You will receive information on the test status and the test coverage of the unit tests.
In order to run all the tests, you need a HIC&VMM token, defined as an environmental variables HIC_TOKEN
and ``VMM_TOKEN` respectively. When you do not have a HIC token, you can ignore the token tests for HIC webservice,
be defining to not run the tests marked with the notoken label:
pytest -m 'not notoken'
The Github actions CI does have the token stored as a secret, so you do not really need a token for local testing, as eventual failures will be noticed by the Github Actions CI. Although, PRs from forks will not have access to these Github secrets, so these tests are ignored when running from fork.
Build the documentation locally with Sphinx:
tox -e docs
which will create the docs in the docs/_build/html
folder. The docs/_build
directory itself is
left out of version control (and we rather keep it as such ;-)). Double click the index.html to see the
website on your local computer.
The following are some guidelines on how new code should be written. Of course, there are special cases and there will be exceptions to these rules. However, following these rules when submitting new code makes the review easier so new code can be integrated in less time.
Uniformly formatted code makes it easier to share code ownership. The pywaterinfo project tries to closely follow the official Python guidelines detailed in PEP8 which detail how code should be formatted and indented. Please read it and follow it.
In addition, we add the following guidelines:
- Use underscores to separate words in non class names:
n_samples
rather thannsamples
. - Avoid multiple statements on one line. Prefer a line return after a control flow statement (
if/for
). - Please don’t use
import *
in any case. It is considered harmful by the official Python recommendations. It makes the code harder to read as the origin of symbols is no longer explicitly referenced, but most important, it prevents using a static analysis tool like pyflakes to automatically find bugs. - Use the numpy docstring standard in all your docstrings.
- The attributes for specific classes are Pandas data.frames, please use lowercase names (eventually with _) as column names.