Skip to main content

Generate Beautiful Changelogs using Conventional Commits

Project description

Table of Contents
  1. About
  2. Quick Start
  3. Usage
  4. Development
  5. Contributing
  6. License

About

usechange is a Python CLI for generating changelogs and release notes from Conventional Commits. It reads git history between refs, groups commits by type, renders Markdown release notes, and can update version numbers based on semantic versioning rules.

It gives you:

  • Changelog generation - Render release notes and optionally write to CHANGELOG.md.
  • Semver bumping - Determine version bumps from commit types and breaking changes.
  • Release workflows - Tag and publish using uv and gh.
  • GitHub sync - Sync release notes to GitHub releases.
  • Repo metadata - Create commit and compare links automatically.

(back to top)

Quick Start

usechange provides a short alias and command shortcuts:

  • usechange and change are equivalent.
  • changelog also supports the log alias.

Install usechange with uv (recommended)

uv add usechange

Install with pip (alternative)

pip install usechange

Generate a changelog

change log --write

Interactive release workflow

change release

Sync the latest release to GitHub

change github release

Interactive changelog preview

Example prompt for selecting optional changelog flags:

Select optional flags (space to select, enter to confirm):
> [ ] --from - Start commit reference
  [ ] --to - End commit reference
  [ ] --dir - Path to a git repository
  [ ] --clean [bool] - Ensure working directory is clean
  [ ] --output - Changelog file to write
  [ ] --write [bool] - Write changelog to CHANGELOG.md
  [ ] --no-output [bool] - Do not write a changelog file
  [ ] --noAuthors [bool] - Skip contributors section
  [ ] --noDate [bool] - Omit date from header
  [ ] --noEmojis [bool] - Omit emojis from headers
  [ ] --hideAuthorEmail [bool] - Hide author email if no username is found
  [ ] --bump [bool] - Determine and update version
  [ ] -r - Release as a specific version
  [ ] --release [bool] - Bump, tag, and release
  [ ] --no-commit [bool] - Skip release commit
  [ ] --no-tag [bool] - Skip release tag
  [ ] --push [bool] - Push commits and tags
  [ ] --no-github [bool] - Skip GitHub release sync
  [ ] --publish [bool] - Publish after generating
  [ ] --publishTag - Publish with a custom tag
  [ ] --nameSuffix - Append suffix to package name
  [ ] --versionSuffix - Append suffix to version
  [ ] --canary - Shortcut for --bump and --versionSuffix
  [ ] --major [bool] - Force major bump
  [ ] --minor [bool] - Force minor bump
  [ ] --patch [bool] - Force patch bump
  [ ] --premajor - Force premajor bump
  [ ] --preminor - Force preminor bump
  [ ] --prepatch - Force prepatch bump
  [ ] --prerelease - Force prerelease bump
Press <space>, <tab> for multi-selection and <enter> to accept

(back to top)

Usage

Generate changelog

change log --from v0.1.0 --to HEAD --output CHANGELOG.md

Version bumping

change log --bump --write
change log --major --write

Release workflow

change release --yes

GitHub release sync

change github release 0.2.0
change gh release all

Configuration

usechange reads configuration from one of the following:

  • changelog.config.json
  • .changelogrc
  • changelog.config.toml
  • pyproject.toml under [tool.changelog]

(back to top)

Development

Common tasks:

uv run poe test
uv run poe lint
uv run poe format
uv run poe typecheck
uv run poe clean-full

(back to top)

Contributing

Quick workflow:

  1. Fork and branch: git checkout -b feature/name
  2. Make changes
  3. Run checks: uv run poe clean-full
  4. Commit and push
  5. Open a Pull Request

(back to top)

License

License not yet specified in this repository.

(back to top)


Built by thememium

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

usechange-0.1.21.tar.gz (18.0 kB view details)

Uploaded Source

Built Distribution

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

usechange-0.1.21-py3-none-any.whl (26.0 kB view details)

Uploaded Python 3

File details

Details for the file usechange-0.1.21.tar.gz.

File metadata

  • Download URL: usechange-0.1.21.tar.gz
  • Upload date:
  • Size: 18.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.6 {"installer":{"name":"uv","version":"0.10.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for usechange-0.1.21.tar.gz
Algorithm Hash digest
SHA256 a2149cd6ee27c4ee14acbc237d4c6b9101f6ab25fe5b6e11f58584c3266980e6
MD5 f04948b7c2e687fe142950d358c3eab4
BLAKE2b-256 67a04e6e1ac7f8000fb8777b26e59c8ecf215393f3d32193616a7505cdcffed1

See more details on using hashes here.

File details

Details for the file usechange-0.1.21-py3-none-any.whl.

File metadata

  • Download URL: usechange-0.1.21-py3-none-any.whl
  • Upload date:
  • Size: 26.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.6 {"installer":{"name":"uv","version":"0.10.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for usechange-0.1.21-py3-none-any.whl
Algorithm Hash digest
SHA256 9f5359c0b4a80f19241cda0b02e207d99604b9ca04900ab589bae56fac2071cc
MD5 cd862dd16849f009007aefc527dd312d
BLAKE2b-256 c5d5b4865da5c97e12993f02c883d29816ddde5d704a4f5fc1fcccc0dd737e95

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