Skip to main content

Simplest changelog manager, oriented to human editing, not to special message formatting in commits and tags..

Project description

Changy

Very simple changelog manager with the idea that humans write changelogs for humans, not for robots.

Special message formatting (DSLs) to describe changes in commits, tags, etc., is a good idea, but it is not always convenient for development and the CI/CD process.

  • The person who commits is not always responsible for writing the changelog or making a release.
  • The person who makes a release is also not always responsible for writing the changelog.
  • The time when you want to work on the changelog is not always the time when you are making commits or preparing a release.
  • Special message formatting is not always convenient for describing changes that humans will read.
  • It is difficult to update messages in the commit history.

I searched for a tool that helps to manage changelogs but does not require unnecessary effort from a developer, but I did not find any that suited me. That's how Changy was born.

Changy is inspired by:

However, Changy simplifies the process by focusing on manual text file editing without the need for CLI commands or strict message formats.

Installation

pip install changy

# create initial files
changy init

# help
changy help

Idea

All paths could be changed via environment variables. See ./changy/settings.py for deatils.

CHANGELOG.md is compiled from parts from ./changes directory: one file per version.

Besides version files, there are some particular files:

  • ./changes/header.md — Content placed at the top of the changelog.
  • ./changes/changes_template.md — Template for version files. Changy copies this file to create new version files.
  • ./changes/unreleased.md — Contains changes not yet released.
  • ./changes/next_release.md — Contains changes approved for the next release.

You may edit ./changes/unreleased.md any time you want before making an actual release. The file has no special syntax.

Usage

Manual operations before release

# edit ./changes/unreleased.md

# This command should be run by the responsible person before release to mark that the changelog has been reviewed by humans and is ready to be released.
changy unreleased approve

git add -a
git commit -m "Approve changes for next release"

Somewhere in your CI/CD pipeline

For detailed example, see ./bin/prepate-release.sh

# Creates version file with approved changes and creates new unreleased file
# Changy will fail if there are no approved changes => you will not forget to approve changes
changy version create 1.2.3

# generates changelog
changy changelog create

git add -a
git commit -m "Release 1.2.3"

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

changy-0.4.3.tar.gz (7.3 kB view details)

Uploaded Source

Built Distribution

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

changy-0.4.3-py3-none-any.whl (8.9 kB view details)

Uploaded Python 3

File details

Details for the file changy-0.4.3.tar.gz.

File metadata

  • Download URL: changy-0.4.3.tar.gz
  • Upload date:
  • Size: 7.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.0.1 CPython/3.12.8

File hashes

Hashes for changy-0.4.3.tar.gz
Algorithm Hash digest
SHA256 1a38ce222243f3bbf4f51a890bc14e393521954970244dc7d669e2bcbe523f85
MD5 5ae764f61e8bcdf4e727097fd01d4f7c
BLAKE2b-256 43ed92e13e901b46547e314befcce921ad4471fa6dbaf4bdbcadf2afd3285e26

See more details on using hashes here.

Provenance

The following attestation bundles were made for changy-0.4.3.tar.gz:

Publisher: release.yaml on Tiendil/changy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file changy-0.4.3-py3-none-any.whl.

File metadata

  • Download URL: changy-0.4.3-py3-none-any.whl
  • Upload date:
  • Size: 8.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.0.1 CPython/3.12.8

File hashes

Hashes for changy-0.4.3-py3-none-any.whl
Algorithm Hash digest
SHA256 53d34778a0b525c154fb0c39ef02fb41c2179ef2915f7f63cfeaa0a241d0facc
MD5 71f5f62b98d9f36d2e29b6f3553884dc
BLAKE2b-256 45672bfe58c28eb5f49af43982da78aa63296fbfff39291fe6d65fda88dd835f

See more details on using hashes here.

Provenance

The following attestation bundles were made for changy-0.4.3-py3-none-any.whl:

Publisher: release.yaml on Tiendil/changy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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