Contents:
Here's the long and short of it:
-
If you are a first-time contributor:
-
Go to https://github.com/LaurentRDC/scikit-ued and click the "fork" button to create your own copy of the project.
-
Clone the project to your local computer:
git clone https://github.com/your-username/scikit-ued.git
-
Change the directory:
cd scikit-ued
-
Add the upstream repository:
git remote add upstream https://github.com/LaurentRDC/scikit-ued.git
-
Now, you have remote repositories named:
upstream
, which refers to thescikit-ued
repositoryorigin
, which refers to your personal fork
-
-
Develop your contribution:
-
Pull the latest changes from upstream:
git checkout master git pull upstream master
-
Create a branch for the feature you want to work on. Since the branch name will appear in the merge message, use a sensible name such as 'my-new-feature':
git checkout -b my-new-feature
-
Commit locally as you progress (
git add
andgit commit
)
-
-
To submit your contribution:
-
Push your changes back to your fork on GitHub:
git push origin my-new-feature
-
Enter your GitHub username and password (repeat contributors or advanced users can remove this step by connecting to GitHub with SSH).
-
Go to GitHub. The new branch will show up with a green Pull Request button - click it.
-
If you want, post on the mailing list to explain your changes or to ask for review.
-
-
Review process:
- Reviewers (the other developers and interested community members) will write inline and/or general comments on your Pull Request (PR) to help you improve its implementation, documentation, and style.
- To update your pull request, make your changes on your local repository and commit. As soon as those changes are pushed up (to the same branch as before) the pull request will update automatically.
- Continuous integration is triggered after each Pull Request update to build the code, run unit tests, and other checks of your branch. The tests must pass before your PR can be merged.
- A pull request must be approved by a an admininistrator before merging.
-
Document changes
- If your change introduces any API modifications or fixes a known issue, please update
CHANGELOG.rst
.
- If your change introduces any API modifications or fixes a known issue, please update
If GitHub indicates that the branch of your Pull Request can no longer be merged automatically, merge the master branch into yours:
git fetch upstream master
git merge upstream/master
If any conflicts occur, they need to be fixed before continuing. See which files are in conflict using:
git status
Which displays a message like:
Unmerged paths:
(use "git add <file>..." to mark resolution)
both modified: file_with_conflict.txt
Inside the conflicted file, you'll find sections like these:
<<<<<<< HEAD
The way the text looks in your branch
=======
The way the text looks in the master branch
>>>>>>> master
Choose one version of the text that should be kept, and delete the rest:
The way the text looks in your branch
Now, add the fixed file:
git add file_with_conflict.txt
Once you've fixed all merge conflicts, do:
git commit
To create an appropriate development environment, you need to install the base requirements as well as extra, development requirements:
pip install .[development]
- All code should have tests.
- All code should be documented, to the same standard as NumPy and SciPy.
- For new functionality, always add an example to the tutorials
- No changes are ever committed without review and approval.
-
Run the
black
code formatter. -
Use the following import conventions:
import numpy as np import matplotlib.pyplot as plt from scipy import ndimage as ndi # only in Cython code cimport numpy as cnp cnp.import_array()
-
Refer to array dimensions as (plane), row, column, not as x, y, z. See
Coordinate conventions <numpy-images-coordinate-conventions>
in the user guide for more information. -
Use relative module imports, i.e.
from ..simulation import xyz
rather thanfrom skued.simulation import xyz
.
scikit-ued
has an extensive test suite that ensures that the code works as expected on many possible systems. scikit-ued
uses the pytest
framework.
Run all tests using:
pytest skued
To run the tests of a particular submodule (e.g. skued/image
):
pytest skued/image
Documentation is very important for any scientific software project. Documentation is located in the docs
directory.
To build docs:
python -m sphinx docs build
Then, all the HTML files will be generated in build/sphinx/html/
.
Code snippets in the documentation are checked via doctest
. To test the documentation snippets:
python -m sphinx -b doctest docs build
Please report bugs on GitHub.