Skip to main content

A package and CLI tool to generate RPM release fields and changelogs.

Project description

This project hosts the rpmautospec python package and command line tool, which automatically calculates release numbers and generates the changelog for RPM packages from their dist-git repository.

Dependencies:

  • Python >= 3.9

  • rpmautospec-core >= 0.1.4

Installation dependencies:

  • hatch

Optional dependencies:

  • uv (if using uv to install)

  • pygit2 >= 1.4

General

The command line tool rpmautospec can calculate the release and generate the changelog from the spec file of an RPM package and its git history, as well as process that spec file into a form which can be consumed by rpmbuild, and convert traditional spec files to using these automatic features.

Running the Examples

To run the examples with the rpmautospec command line tool from this repository (as opposed to a version that may be installed system-wide), you can install it into a Python virtualenv, managed either manually or by the uv tool. For the latter, substitute running rpmautospec by running uv run rpmautospec below.

To install the package, run this (optionally, within an activated virtualenv):

uv sync

The examples work with the guake package. Clone its dist-git repository this way, in a location of your choice, and then change into the repository worktree:

fedpkg clone guake
cd guake

Generate the Changelog

This will generate the changelog from the contents of the repository and the history:

rpmautospec generate-changelog

Calculate the Release Field Value

This will generate the numerical value for the release field from the number of commits since the Version field was last updated:

rpmautospec calculate-release

The rpmautospec Python module is not thread/multiprocess-safe

rpmautospec redefines some RPM macros when parsing spec files or expanding macros. These definitions are only relevant to the current instance of the rpm module imported in Python, they are not persistent. rpmautospec cleans those definitions when it is done by reloading the RPM configuration.

However, if another thread or process running from the same Python interpreter instance attempts to change or expand RPM macros in the meantime, the definitions might clash and the cleanup might override other changes.

In case this breaks your use case, please open an issue to discuss it. We can cooperate on some locking mechanism.

Contributing

You need to be legally allowed to submit any contribution to this project. What this means in detail is laid out in the file DCO.txt next to this file. The mechanism by which you certify this is adding a Signed-off-by trailer to git commit log messages, you can do this by using the --signoff/-s option to git commit.

License

The majority of rpmautospec is licensed under the MIT license, with one notable exception: Small parts of the rpmautospec._wrappers.minigit2 package are derived from pygit2, licensed under version 2 of the GNU General Public License, with a linking exception. Code in the rpmautospec._wrappers.minigit2 package which isn’t derived from pygit2 is dual-licensed under the MIT license or the GNU GPL version 2 or later (with the linking exception).

Find the texts of both licenses in the licenses/ subdirectory.

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

rpmautospec-0.8.2.tar.gz (148.8 kB view details)

Uploaded Source

Built Distribution

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

rpmautospec-0.8.2-py3-none-any.whl (66.5 kB view details)

Uploaded Python 3

File details

Details for the file rpmautospec-0.8.2.tar.gz.

File metadata

  • Download URL: rpmautospec-0.8.2.tar.gz
  • Upload date:
  • Size: 148.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.13

File hashes

Hashes for rpmautospec-0.8.2.tar.gz
Algorithm Hash digest
SHA256 51d355505827da93de89acf7d6b8f3c5970b8015b60f5b613513d779b0f4cdcd
MD5 e3e3d0a7c3aff051eb4be52e2162e9d0
BLAKE2b-256 28f4014ed6ad0f716c322213743428db0d51d3e11d1382fd5b3341898cea39ee

See more details on using hashes here.

File details

Details for the file rpmautospec-0.8.2-py3-none-any.whl.

File metadata

File hashes

Hashes for rpmautospec-0.8.2-py3-none-any.whl
Algorithm Hash digest
SHA256 e7eee0ccfe2bec3043d777a151b1c1420df512f67b57daceb1b565c5b90345bd
MD5 1daec338cdb8b262b388d42c9bb3dca4
BLAKE2b-256 0b6906931a8f32f50980e7c381347f9d581a53657d20fa2f3f8609e1e5415765

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