Skip to main content

A generator for Rust/Cargo ebuilds written in Python

Project description

Author:

Michał Górny

License:

MIT

Homepage:

https://github.com/projg2/pycargoebuild/

pycargoebuild is a generator for ebuilds using the Cargo infrastructure of Rust language. It is primarily meant to aid in keeping the list of CRATES and their LICENSE up-to-date. It is a rewrite of the cargo-ebuild tool in Python, with no actual dependency on Rust.

pycargoebuild reads Cargo.toml and Cargo.lock files in order to obtain the package’s metadata and dependency list, respectively. Then it fetches all dependent crates into DISTDIR and reads their Cargo.toml files to construct the complete list of licenses. The resulting data can either be used to construct a new ebuild from a template or to update the values of CRATES and LICENSE in an existing ebuild.

Why not cargo-ebuild?

pycargoebuild has the following features that cargo-ebuild 0.5.2 is missing:

  • small size (cargo-ebuild compiles to 5.5M on my system)

  • full support for SPDX-2.0 license expressions with boolean simplification (whereas cargo-ebuild just dumps all licenses it finds)

  • pretty-printing with line wrapping for license expressions

  • support for updating CRATES and crate LICENSE in existing ebuilds (whereas cargo-ebuild can only generate new ebuilds)

  • support for combining the data from multiple subpackages (useful e.g. in setuptools-rust)

  • support for fast crate fetching if aria2c is installed

  • support for skipping crate licenses (e.g. for when Crates are used at build/test time only)

Usage

To create a new ebuild, run:

pycargoebuild <package-directory>

where package-directory is the directory containing Cargo.toml. This creates an ebuild file named after the package name and version in the current directory, and outputs its name.

To update an existing ebuild, use instead:

pycargoebuild -i <current-file>.ebuild <package-directory>

Note that the existing file must contain both CRATES variable and LICENSE+= assignment like the following:

# Dependent crate licenses
LICENSE+="..."

It is also possible to explicitly specify the output filename using the -o option.

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

pycargoebuild-0.5.0.tar.gz (11.4 kB view details)

Uploaded Source

Built Distribution

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

pycargoebuild-0.5.0-py3-none-any.whl (12.8 kB view details)

Uploaded Python 3

File details

Details for the file pycargoebuild-0.5.0.tar.gz.

File metadata

  • Download URL: pycargoebuild-0.5.0.tar.gz
  • Upload date:
  • Size: 11.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.0

File hashes

Hashes for pycargoebuild-0.5.0.tar.gz
Algorithm Hash digest
SHA256 deed9d62b79f098132f6b1e42b8839bb952d24c2b91ba1f9783ac0a7b70dec84
MD5 d4aeefd4abfe625fd422593ab535de15
BLAKE2b-256 4ae91dfc8cdc52bee9c2e8ad7b9db85bb5efe73a9485658e6b79affe4a0e13b7

See more details on using hashes here.

File details

Details for the file pycargoebuild-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: pycargoebuild-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 12.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.0

File hashes

Hashes for pycargoebuild-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9c635133ceb4fde85d20c7efc5a129ed2e22f3724a62c3c2633fdc3134b2b3f5
MD5 41c924887f9f50ec54c83369d84904bc
BLAKE2b-256 ee9f0018b19ecd2d11cc9fc16e7ace008d1abe726f159df3eb0b2ed455dd3559

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