Contributions to PiSCAT are always welcome, and they are greatly appreciated! A list of open problems can be found here. Of course, it is also always appreciated to bring own ideas and problems to the community!
Please submit all contributions to the official Github repository in the form of a Merge Request. Please do not submit git diffs or files containing the changes.
PiSCAT
is an open-source python package under the license of GNUv3. Thus we consider the act of contributing to the code by submitting a Merge Request as the "Sign off" or agreement to the GNUv3 license.
You can contribute in many different ways:
Report bugs at https://github.com/SandoghdarLab/PiSCAT/issues.
Look through the Github issues. Different tags are indicating the status of the issues. The "bug" tag indicates problems with PiSCAT, while the "enhancement" tag shows ideas that should be added in the future.
The documentation of PiSCAT can be found here. Jupyter notebooks and GUI are used to provide an interactive start to PiSCAT. It is always appreciated if new document notebooks are provided since this helps others a lot.
Ready to contribute? Here is how to set up PiSCAT
for local development.
- Fork the
PiSCAT
repo on GitHub. - Clone your fork locally:
$ git clone https://github.com/USERNAME/PiSCAT.git
$ cd PiSCAT
- Install your local copy into a virtualenv.
$ pip install virtualenvwrapper-win (windows)/ pip install virtualenvwrapper (linux)
$ mkvirtualenv PiSCAT
$ pip install -e .
By following the comments, you can also install all dependencies with the specific versions that we tested for Python 3.9.7:
$ pip install -r requirements.txt
- Create a branch for local development:
$ git checkout -b name-of-your-bugfix-or-feature
Now you can make your changes locally.
To get all packages needed for development, a requirements list can be found here.
- Commit your changes and push your branch to GitHub::
$ git add .
$ git commit -m "Your detailed description of your changes."
$ git push origin name-of-your-bugfix-or-feature
- Submit a Merge Request on Github.
Before you submit a Merge Request, check that it meets these guidelines:
- All functionality that is implemented through this Merge Request should be covered by unit tests. These are implemented in
PiSCAT\tests
. It would be necessary to add your unit test if the new implementation has some features that are not covered by our unit tests. - If the Merge Request adds functionality, the docs should be updated. Put your new functionality into a function with a docstring.
- If you have a maintainer status for
PiSCAT
, you can merge Merge Requests to the master branch. However, every Merge Request needs to be reviewed by another developer. Thus it is not allowed to merge a Merge Request, which is submitted by oneself.