We welcome your contributions! Please see the provided steps below and never hesitate to contact us.
If you are a new user, we recommend checking out the detailed Github Guides.
In order to make changes to napari
, you will need to fork the
repository.
If you are not familiar with git
, we recommend reading up on this guide.
Clone the forked repository to your local machine and change directories:
$ git clone https://github.com/your-username/napari.git
$ cd napari
Set the upstream
remote to the base napari
repository:
$ git remote add upstream https://github.com/napari/napari.git
Install the required dependencies:
$ pip install -r requirements.txt
Make the development version available globally:
$ pip install -e .
We use
pre-commit
to run black
formatting and flake8
linting automatically prior to each commit. Please install it in your environment as follows:
$ pre-commit install
Upon committing, your code will be formatted according to our black
configuration,
which includes the settings skip-string-normalization = true
and max-line-length = 79
.
To learn more, see black
's documentation.
Code will also be linted to enforce the stylistic and logistical rules specified in our flake8
configuration, which currently ignores E203, E501, W503 and C901. For information on any specific flake8 error code, see the Flake8 Rules. You may also wish to refer to the PEP 8 style guide.
If you wish to tell the linter to ignore a specific line use the # noqa
comment along with the specific error code (e.g. import sys # noqa: E402
) but please do not ignore errors lightly.
Our icon build process starts with a base set of svg
formatted icons stored in napari/resources/icons/svg
. If you want to add a new icon to the app, make the icon in whatever program you like and add it to that folder.
Then run the following command
python -m napari.resources.build_icons
This creates separate folders in napari/resources/icons
with full colored icon sets for each of our themes.
If you want to change one of the existing icons, modify the version in napari/resources/icons/svg
and run the commands above.
Icons are typically used inside of one of our stylesheet.qss
files, with the {{ folder }}
variable used to expand the current theme name.
QtDeleteButton {
image: url(":/icons/{{ folder }}/delete.svg");
}
A theme is a set of colors used throughout napari. See, for example, the
builtin themes in napari/utils/theme.py
. To make a new theme, create a new
dict
in palettes
with the same keys as one of the existing themes, and
replace the values with your new colors. To test out the theme, use the
theme_sample.py
file from the command line as follows:
python -m napari._qt.theme_sample
note: you may specify a theme with one additional argument on the command line:
python -m napari._qt.theme_sample dark
(providing no arguments will show all themes in theme.py
)
Create a new feature branch:
$ git checkout master -b your-branch-name
git
will automatically detect changes to a repository.
You can view them with:
$ git status
Add and commit your changed files:
$ git add my-file-or-directory
$ git commit -m "my message"
Each commit you make must have a GitHub-registered email
as the author
. You can read more here.
To set it, use git config --global user.email [email protected]
.
Switch to the master
branch:
$ git checkout master
Fetch changes and update master
:
$ git pull upstream master --tags
This is shorthand for:
$ git fetch upstream master --tags
$ git merge upstream/master
Update your other branches:
$ git checkout your-branch-name
$ git merge master
Update your remote branch:
$ git push -u origin your-branch-name
You can then make a pull-request to napari
's master
branch.
From the project root:
$ make docs
The docs will be built at docs/build/html
.
Most web browsers will allow you to preview HTML pages.
Try entering file:///absolute/path/to/napari/docs/build/html/index.html
in your address bar.
napari
has a Code of Conduct that should be honored by everyone who participates in the napari
community.
If you have questions, comments, suggestions for improvement, or any other inquiries regarding the project, feel free to open an issue.
Issues and pull-requests are written in Markdown. You can find a comprehensive guide here.