Skip to main content

Wheel maker

Project description

fromager

Fromager is a tool for completely re-building a dependency tree of Python wheels from source.

The goals are to support guaranteeing

  1. The binary package someone is installing was built from source in a known build environment compatible with their own environment
  2. All of the package’s dependencies were also built from source -- any binary package installed will have been built from source
  3. All of the build tools used to build these binary packages will also have been built from source
  4. The build can be customized for the packager's needs, including patching out bugs, passing different compilation options to support build "variants", etc.

The basic design tenet is to automate everything with a default behavior that works for most PEP-517 compatible packages, but support overriding all of the actions for special cases, without encoding those special cases directly into fromager.

Using private registries

Fromager uses the requests library and pip at different points for talking to package registries. Both support authenticating to remote servers in various ways. The simplest way to integrate the authentication with fromager is to have a netrc file with a valid entry for the host. The file will be read from ~/.netrc by default. Another location can be specified by setting the NETRC environment variable.

For example, to use a gitlab package registry, use a personal access token as documented in this issue:

machine gitlab.com login oauth2 password $token

Determining versions via GitHub tags

In some cases, the builder might have to use tags on GitHub to determine the version of a project instead of looking at pypi.org. To avoid rate limit or to access private GitHub repository, a personal access token can be passed to fromager by setting the following environment variable:

GITHUB_TOKEN=<access_token>

Additional docs

What's with the name?

Python's name comes from Monty Python, the group of comedians. One of their skits is about a cheese shop that has no cheese in stock. The original Python Package Index (pypi.org) was called The Cheeseshop, in part because it hosted metadata about packages but no actual packages. The wheel file format was selected because cheese is packaged in wheels. And "fromager" is the French word for someone who makes or sells cheese.

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

fromager-0.31.1.tar.gz (129.9 kB view details)

Uploaded Source

Built Distribution

fromager-0.31.1-py3-none-any.whl (80.4 kB view details)

Uploaded Python 3

File details

Details for the file fromager-0.31.1.tar.gz.

File metadata

  • Download URL: fromager-0.31.1.tar.gz
  • Upload date:
  • Size: 129.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for fromager-0.31.1.tar.gz
Algorithm Hash digest
SHA256 08bca0d45a19dde38e2dcdeff43f71437b3ee2bdee65ac55bb56bdc07e6597f9
MD5 81b45054a89b8179d5ddc429d3aaab14
BLAKE2b-256 a748e610debfb311c3a6a76391615b165422f8d931154355c3d302f761f34de9

See more details on using hashes here.

Provenance

File details

Details for the file fromager-0.31.1-py3-none-any.whl.

File metadata

  • Download URL: fromager-0.31.1-py3-none-any.whl
  • Upload date:
  • Size: 80.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for fromager-0.31.1-py3-none-any.whl
Algorithm Hash digest
SHA256 de925b83fd93db12d96652c87ec06ea9c81ee21b3aa628ac2ec3e323aa51e1e3
MD5 a1d4a4ece22371a82e0c077d762ed7b9
BLAKE2b-256 0ddee822569ea73bb37dd772f0dea15b16d65a95e248f169b765e652338d6c93

See more details on using hashes here.

Provenance

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