This package is still in its very early stages of development. The following covers some general guidelines for maintainers and contributors.
-
Fork this respository. It's fine to use "xbootstrap" as your fork repository name because it will live under your username.
-
Clone your fork locally, connect your repository to the upstream (main project), and create a branch to work on:
$ git clone git@github.com:YOUR_GITHUB_USERNAME/xbootstrap.git
$ cd xbootstrap
$ git remote add upstream git@github.com:dougiesquire/xbootstrap.git
$ git checkout -b YOUR-BUGFIX-FEATURE-BRANCH-NAME main
- Install
xbootstrap
's dependencies into a new conda environment:
$ conda env create -f ci/environment-3.11.yml
$ conda activate xbootstrap-test
- Install
xbootstrap
using the editable flag (meaning any changes you make to the package will be reflected directly in your environment):
$ pip install --no-deps -e .
Aside: to have the changes you make to the package register immediately when running IPython (e.g. a Jupyter notebook), run the following magic commands:
%load_ext autoreload
%autoreload 2
- This project uses
black
to format code andflake8
for linting. We usepre-commit
to ensure these have been run. Please set up commit hooks by running the following. This will mean thatblack
andflake8
are run whenever you make a commit:
pre-commit install
You can also run pre-commit
manually at any point to format your code:
pre-commit run --all-files
- Start making and committing your edits, including adding docstrings to functions and tests to
xbootstrap/tests
to check that your contributions are doing what they're suppose to. Please try to follow numpydoc style for docstrings. To run the test suite:
pytest xbootstrap
New releases to PyPI are published automatically when a tag is pushed to Github. To publish a new release:
export RELEASE=vX.X.X
# Create git tags
git commit --allow-empty -m "Release $RELEASE"
git tag -a $RELEASE -m "Version $RELEASE"
git push --tags