Thank you for taking the time to contribute!
We can't think of everything. If you've got a good idea for a feature, then please let us know!
Feature suggestions are embraced, but will often be filed for a rainy day. If you require a feature urgently it's best to write it yourself. Don't forget to share :)
When suggesting a feature, make sure to:
- Check the code on repo to make sure it's not already hiding in an unreleased version ;)
- Considered if it's necessary in the library, or is an advanced technique that could be separately explained in an example
- Check existing issues, open and closed, to make sure it hasn't already been suggested
If you're having trouble with coPylot
, reach us please.
Be as detailed as possible, and be ready to answer questions when we get back to you. Make sure you:
- Tell us which OS you're using
- List the steps you've taken so far,
- and any solutions you've tried
- And a paste/picture of the complete output from the fail might help, too!
If you've decided to fix a bug, even something as small as a single-letter typo then great! Anything that improves the code/documentation for all future users is warmly welcomed.
If you decide to work on a requested feature it's best to let us (and everyone else) know what you're working on to avoid any duplciation of effort. You can do this by replying to the original Issue for the request.
When contributing a new example or making a change to a library please keep your code style consistent with ours. We try to stick to the pep8 guidelines for Python (https://www.python.org/dev/peps/pep-0008/).
Once you're ready to share your contribution with us you should submit it as a Pull Request.
- Be ready to receive and embrace constructive feedback.
- Be prepared for rejection; we can't always accept contributions. If you're unsure, ask first!
- First, start with a new branch on your fork from the target branch
- Submit changes to new branch of your fork
- Wait for the review and merge.
- Upon merge make sure you fetch upstream and update your master branch.
- Do use pep8 style guidelines + our preferences with
black
formatter - Use NumPy style docstrings
- Do comment your code where necessary
- Do submit only a single example/feature per pull-request
- Do include a description of what your example is expected to do
- Do add details of your example to README.md and CONTRIBUTING.md if it is needed
- Don't include any license information in your examples- our repositories are BSD-3-Clause License d
- Don't try to do too much at once- submit one or two examples at a time, and be receptive to feedback
- Don't submit multiple variations of the same example, demonstrate one thing concisely
# Create a new environment
conda create -n copylot python=3.9
# Activate the environment
conda activate copylot
# Install coPylot and dev dependencies
make setup-develop
# Optionally install the pre-commit hooks (which currently just run `black`)
pre-commit install
# Before making a PR, make sure tests are passing
make test
# Before making a PR, check that your branch passes linting
# and adheres to black's style guidelines
make check-format
make lint
# if pre-commit hooks are not installed and your branch does not meet black's style,
# run `black` manually to format your branch
make format
Go to Settings | Tools | Python Integrated Tools | Docstring format
and change it to NumPy
style. So autogenerated docstrings will be
in correct styling.
When you submit code to our libraries, you implicitly and irrevocably agree to adopt the associated licenses.
You should be able to find this in the file named LICENSE.txt
.
We use the BSD 3-Clause License.
If you have any questions, concerns or comments about these guidelines, please get in touch.
-- coPylot
team