Skip to main content

manage files with git, without checking their contents into git

Project description

Python wheel package for git-annex

Test git-annex wheel from PyPi

Why?

Git-annex is written in Haskell and plenty of installation methods are available. However, for deploying git-annex as a dependency of a Python library/application, like DataLad or AnnexRemote, system packages are a lot less flexible than Python's virtual environments, and other methods are more complex and fragile.

With git-annex being available from PyPi, versioned dependencies and deployment in application-specific environments are possible via standard means of Python packaging.

Caveats

A standard git-annex deployment is (primarily) a single binary (git-annex), and a bunch of symlinks that make this one binary fulfilled multiple roles (git-annex-shell, git-remote-annex, etc.). A Python wheel, however, is a ZIP file container with no support for symlinks, and also no support for "post-install" scripts.

In order to square this circle, the git-annex binary is wrapped via regular Python entrypoint scripts that handle calling git-annex as necessary. This delivers a cross-platform compatible wheel, but at a start-up cost (~30ms vs ~11ms on my laptop).

Installation

Get the package from PyPi, and install like any other package from PyPi.

uv users can deploy git-annex in a dedicated virtual environment via the one-liner:

uv tool install git-annex

git-annex build configuration

Git-annex is built with libmagic support.

Platform notes

Linux

The manylinux wheel is self-contained and includes copies of all libraries. It only depends on the declared GLIBC versions. The magic.mgc database is not included, and is assumed to be available on the target system. Install it separately, if needed (e.g., libmagic-mgc package).

Windows

The wheel is self-contained and includes a copy of libmagic and the magic.mgc database.

Mac

The wheel is self-contained and includes a copy of libmagic and the magic.mgc database.

Developer information

Sources

The sources for this package are available at https://github.com/psychoinformatics-de/git-annex-wheel

The repository tracks the git-annex sources as a Git submodule.

Issues

For issues related to the Python wheel packaging of git-annex, please use the tracker at https://github.com/psychoinformatics-de/git-annex-wheel/issues

How to update for a new git-annex release?

Advance the submodule ./git-annex to the new release tag.

Now adjust the package version in pyproject.toml accordingly. This version must follow the rules for Python packages.

The included (GitHub) action workflows will build a corresponding wheel and upload it to PyPi.

Acknowledgements

This work was funded, in part, by

  • Deutsche Forschungsgemeinschaft (DFG, German Research Foundation) under grant TRR 379 (546006540, Q02 project)
  • Deutsche Forschungsgemeinschaft (DFG, German Research Foundation) under grant SFB 1451 (431549029, INF project)
  • MKW-NRW: Ministerium für Kultur und Wissenschaft des Landes Nordrhein-Westfalen under the Kooperationsplattformen 2022 program, grant number: KP22-106A

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

git_annex-10.20251029-py3-none-win_amd64.whl (27.1 MB view details)

Uploaded Python 3Windows x86-64

git_annex-10.20251029-py3-none-manylinux_2_34_x86_64.whl (22.0 MB view details)

Uploaded Python 3manylinux: glibc 2.34+ x86-64

git_annex-10.20251029-py3-none-macosx_15_0_x86_64.whl (14.3 MB view details)

Uploaded Python 3macOS 15.0+ x86-64

git_annex-10.20251029-py3-none-macosx_14_0_arm64.whl (36.4 MB view details)

Uploaded Python 3macOS 14.0+ ARM64

File details

Details for the file git_annex-10.20251029-py3-none-win_amd64.whl.

File metadata

File hashes

Hashes for git_annex-10.20251029-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 ac00ea11037945d4d3f1f8f359e1cf3e2a982b2012f01539c14ad4514d4f5397
MD5 3ae362ec6cd3dd439191c2669f61b309
BLAKE2b-256 9051e0d7009c5c04e40d233b20ff7244f8f3d3cdb92d37583db5d680c24645c4

See more details on using hashes here.

File details

Details for the file git_annex-10.20251029-py3-none-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for git_annex-10.20251029-py3-none-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 ffa919bef2bab9bc250fbcd4beabab85ed4d83df3cacb451f7721a0aa33889ad
MD5 3a10e0baf78fd1111c0afe9ba2cbc268
BLAKE2b-256 2d5e04b1e0da7587292da01281b7b26f03dcbe16435ae854685ae4a09d9bcb8e

See more details on using hashes here.

File details

Details for the file git_annex-10.20251029-py3-none-macosx_15_0_x86_64.whl.

File metadata

File hashes

Hashes for git_annex-10.20251029-py3-none-macosx_15_0_x86_64.whl
Algorithm Hash digest
SHA256 3f65da050d3de0048198144ddee42ce7c250d4bd2ae4247bf0a6c34635483bbb
MD5 7f189c8998e05ca6b7c2f490c83488ab
BLAKE2b-256 aa234c8368265afd80e1b8b9bb7279ea052ca2ea665cd37d9ab4847b711c32d9

See more details on using hashes here.

File details

Details for the file git_annex-10.20251029-py3-none-macosx_14_0_arm64.whl.

File metadata

File hashes

Hashes for git_annex-10.20251029-py3-none-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 9cd2e961a026798c039bbec67712defbab34e8dfc46764762c6df0d0d7886d5c
MD5 4c3becbea9b92e208b35c3c4a5bd9568
BLAKE2b-256 51bd4c1046cbeebbec56e01746961b99c5b17a6e3b8e1b7b3e6e00911b5b0bbe

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page