Skip to main content

A custom builder to build zipped directories

Project description

hatch-zipped-directory

PyPI - Version PyPI - Python Version Tests Trackgit Views


This is a Hatch plugin that provides a custom builder to support building zip archives for quasi-manual installation into various foreign package installation systems. (Specifically, I use this for packaging Inkscape extensions and symbols libraries, but it may be useful in other contexts, such as deploying to cloud compute platforms.)

The builder creates a zip archive. All the contents of the zip archive will be included under a single specific top-level directory. The default name of the top-level directory is a file-name-safe version of the project name, however the name of the directory may be configured by setting the install-name key in the target-specific configuration section. This behavior may be disabled by setting install-name = ''.

In addition to whatever files are selected for inclusion in the archive via Hatch’s regular build configuration settings, any configured project README and license files will be included in the top level of the install directory within the zip archive.

As well, a METADATA.json file containing the project metadata in JSON format (as described in PEP 566) will be included in the top level of the install directory within the zip archive.

Example

Assume a project source directory looking something like:

.
├── pyproject.toml
├── LICENSE.txt
├── README.md
├── src
│   ├── subdir
│   │   ├── data.txt
│   │   └── more-code.py
│   └── my-code.py
└── tests
    └── test_foo.py

Where pyproject.toml looks like:

[build-system]
requires = [
    "hatchling",
    "hatch-zipped-directory",
]
build-backend = "hatchling.build"

[project]
name = "test-project"
version = "0.42"

[tool.hatch.build.targets.zipped-directory]
install-name = "org.example.test"
sources = [
    "/src",
]

Then, running

hatch build --target zipped-directory

will build a zip archive named dist/test_project-0.42.zip with the following structure:

.
└── org.example.test
    ├── LICENSE.txt
    ├── METADATA.json
    ├── README.md
    ├── my-code.py
    └── subdir
        ├── data.txt
        └── more-code.py

Reproducible Builds

By default, this plugin attempts to build reproducible archives by setting the timestamps of the zip entries to a fixed value. When building in reproducible mode, the UNIX file modes of the archive entries is also normalized (to either 0644 or 0755 depending on whether the file is executable.)

The timestamp used for reproducible builds may be configured by setting the SOURCE_DATE_EPOCH environment variable.

Reproducible builds may be disabled by setting reproducible = false in an appropriate section of pyproject.toml or hatch.toml. See Hatch’s documentation on Build Configuration for details.

Author

Jeff Dairiki dairiki@dairiki.org

License

hatch-zipped-directory is distributed under the terms of the MIT license.

Changes

0.1.0 (2023-12-12)

Bitrot

  • Fix for hatchling 1.19 (hatch 1.8). BuilderInterface.build arguments are now all kw-only. ([hatch/6c252f8])

[hatch/6c252f8]: https://github.com/pypa/hatch/commit/6c252f8b8a65711846a6060c3d54f02936da2aa0)

0.1.0b4 (2023-09-10)

Features

  • Add support for reproducible builds which are now enabled by default. When enabled, timestamps in the zip archive are set to a fixed value (configurable via the SOURCE_DATE_EPOCH environment variable) and the UNIX access modes of archive members are normalized to either 0644 or 0755 depending on whether the file is executable or not.

0.1.0b3 (2023-05-10)

Features

  • Refactor JSON metadata code. Now we use hatchling to generate conventionall RFC 822-formatted distribution metadata, then convert that to JSON, explicitly following the steps outline in PEP 566. Among other things, this allows configuration of the Metadata-Version by setting tool.hatch.build.targets.zipped-directory.core-metadata-version.

Tests

  • We now have 100% test coverage.

0.1.0b2 (2023-01-10)

Features

  • The prefixing of file names under a top-level directory in the zip archive can now be disabled by setting install-name = "". Thank you @gwerbin(#1)

Bugs

  • Use explicit encoding in hatch metadata hook (for Windows).

0.1.0b1 (2022-10-07)

Initial release.

Project details


Download files

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

Source Distribution

hatch_zipped_directory-0.1.0.tar.gz (12.3 kB view details)

Uploaded Source

Built Distribution

hatch_zipped_directory-0.1.0-py3-none-any.whl (8.8 kB view details)

Uploaded Python 3

File details

Details for the file hatch_zipped_directory-0.1.0.tar.gz.

File metadata

File hashes

Hashes for hatch_zipped_directory-0.1.0.tar.gz
Algorithm Hash digest
SHA256 091f4c17a0966d4c6fdcc0002676e770c80ec18093740aa4582c8eb075e32cd3
MD5 abee175c2751faa196de04df393997b7
BLAKE2b-256 5100fac2e8444fe692f255253b60bb17b954b57890e849d796d76f77b7e10a52

See more details on using hashes here.

File details

Details for the file hatch_zipped_directory-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for hatch_zipped_directory-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 0ba160dcd2b10d121605a5e6ca12777b61b3ae749a775c753f9d92abbdd44296
MD5 48b8921f70d1e7f44e9f1138b41fa747
BLAKE2b-256 a8fe5dc75b2799993ab79d57ae4f74cf8d1c934b3821706f948a57973b005f84

See more details on using hashes here.

Supported by

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