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.
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).
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:
- GitLab: Convert a local directory into a repository
- GitHub: Adding a local repository to GitHub using Git
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.
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.