Skip to content

Latest commit

 

History

History
70 lines (55 loc) · 2.88 KB

README.md

File metadata and controls

70 lines (55 loc) · 2.88 KB

Fractal tasks-package template

This is a template for a Python package of tasks that can be used within the Fractal framework. This template is largely inspired by https://github.com/pydev-guide/pyrepo-copier.

How to use it

1. Copy and customize the template (first-time only)

This template uses copier to create a new repository from the template. You can install it e.g. via pipx, as in

pipx install copier

Then run copier, passing in the template url and the desired output directory (usually the name of your new package):

copier copy gh:fractal-analytics-platform/fractal-tasks-template your-package-name

As part of this procedure, copier will ask you a set of questions; answers are used to customize the template to fit your needs (e.g. by setting appropriate file/folder names).

2. Initialize git/GitLab/GitHub repository (first-time only)

After creating the repository, you need to initialize a git repository. This step is required because in this template, we use git tags to manage the versioning of the package.

You can create a git repository based on the current folder via

cd <your-package-name>
git init
git add .
git commit -m 'Initial commit'

Then you can create a first tag, e.g. for version 0.1.0, via

git tag -a 0.1.0 -m 'Initial version'

This is enough for local tracking of your package, but you may want to also keep a remote copy of your repository. To do so in GitLab or GitHub, for instance, follow the instructions in:

3. Start developing

Your customized instance of the template is now ready, and you can start developing. Specific instructions on how to install your package, managing your environment, versioning and more can be found in the DEVELOPERS_GUIDE.

4. Fetch template updates

This template may change over time, bringing in new improvements, fixes, and updates. To update an existing project that was created from this template using copier, follow these steps:

# From the root folder of your repository
cd <your-package-name>

# Run `git status` and make sure its output looks like
# >> "nothing to commit, working tree clean"
git status

# Run the update
copier update

See copier docs for more details.