This repository contains an extension template that can serve as a starting point for implementing a DataLad extension. An extension can provide any number of additional DataLad commands that are automatically included in DataLad's command line and Python API.
For a demo, clone this repository and install the demo extension via
pip install -e .
DataLad will now expose a new command suite with a hello... command.
% datalad --help |grep -B2 -A2 hello
*Demo DataLad command suite*
hello-cmd
Short description of the command
To start implementing your own extension, use this template, and adjust as necessary. A good approach is to
- Pick a name for the new extension.
- Look through the sources and replace
helloworldwith<newname>(hint:git grep helloworldshould find all spots). - Delete the example command implementation in
datalad_helloworld/hello_cmd.py. - Implement a new command, and adjust the
command_suiteindatalad_helloworld/__init__.pyto point to it. - Replace
hello_cmdwith the name of the new command indatalad_helloworld/tests/test_register.pyto automatically test whether the new extension installs correctly. - Adjust the documentation in
docs/source/index.rst. Refer todocs/README.mdfor more information on documentation building, testing and publishing. - Replace this README, and/or update the links in the badges at the top.
- Update
setup.cfgwith appropriate metadata on the new extension. - Generate GitHub labels for use by the "Add changelog.d snippet" and
"Auto-release on PR merge" workflows by using the code in the
datalad/release-actionrepository as described in its README.
You can consider filling in the provided .zenodo.json file with contributor information and meta data to acknowledge contributors and describe the publication record that is created when you make your code citeable by archiving it using zenodo.org. You may also want to consider acknowledging contributors with the allcontributors bot.
See CONTRIBUTING.md if you are interested in internals or contributing to the project.