Skip to main content

Automatic Changelog generator using Jinja2 templates.

Project description

git-changelog

ci documentation pypi version gitpod gitter

Automatic Changelog generator using Jinja2 templates. From git logs to change logs.

Features

Installation

With pip:

pip install git-changelog

With pipx:

python3.7 -m pip install --user pipx
pipx install git-changelog

Usage (command-line)

usage: git-changelog [-b] [-h] [-i] [-g VERSION_REGEX] [-m MARKER_LINE]
                     [-o OUTPUT] [-R] [-c {angular,atom,conventional,basic}]
                     [-S SECTIONS [SECTIONS ...]]
                     [-t {angular,keepachangelog}] [-T] [-v]
                     [REPOSITORY]

Automatic Changelog generator using Jinja2 templates.

This tool parses your commit messages to extract useful data
that is then rendered using Jinja2 templates, for example to
a changelog file formatted in Markdown.

Each Git tag will be treated as a version of your project.
Each version contains a set of commits, and will be an entry
in your changelog. Commits in each version will be grouped
by sections, depending on the commit convention you follow.

BASIC CONVENTION

Default sections:
- add: Added
- fix: Fixed
- change: Changed
- remove: Removed

Additional sections:
- merge: Merged
- doc: Documented

ANGULAR CONVENTION

Default sections:
- feat: Features
- fix: Bug Fixes
- revert: Reverts
- ref, refactor: Code Refactoring
- perf: Performance Improvements

Additional sections:
- build: Build
- chore: Chore
- ci: Continuous Integration
- deps: Dependencies
- doc, docs: Docs
- style: Style
- test, tests: Tests

CONVENTIONALCOMMIT CONVENTION

Default sections:
- feat: Features
- fix: Bug Fixes
- revert: Reverts
- ref, refactor: Code Refactoring
- perf: Performance Improvements

Additional sections:
- build: Build
- chore: Chore
- ci: Continuous Integration
- deps: Dependencies
- doc, docs: Docs
- style: Style
- test, tests: Tests

positional arguments:
  REPOSITORY            The repository path, relative or absolute.

options:
  -b, --bump            Guess the new latest version by bumping the previous
                        one based on the set of unreleased commits. For
                        example, if a commit contains breaking changes, bump
                        the major number (or the minor number for 0.x
                        versions). Else if there are new features, bump the
                        minor number. Else just bump the patch number.
  -h, --help            Show this help message and exit.
  -i, --in-place        Insert new entries (versions missing from changelog)
                        in-place. An output file must be specified. With
                        custom templates, you can pass two additional
                        arguments: --version-regex and --marker-line. When
                        writing in-place, an 'in_place' variable will be
                        injected in the Jinja context, allowing to adapt the
                        generated contents (for example to skip changelog
                        headers or footers).
  -g, --version-regex VERSION_REGEX
                        A regular expression to match versions in the existing
                        changelog (used to find the latest release) when
                        writing in-place. The regular expression must be a
                        Python regex with a 'version' named group.
  -m, --marker-line MARKER_LINE
                        A marker line at which to insert new entries (versions
                        missing from changelog). If two marker lines are
                        present in the changelog, the contents between those
                        two lines will be overwritten (useful to update an
                        'Unreleased' entry for example).
  -o OUTPUT, --output OUTPUT
                        Output to given file. Default: stdout.
  -r, --parse-refs      Parse provider-specific references in commit
                        messages (GitHub/GitLab issues, PRs, etc.).
  -c, -s, --style, --commit-style,  --convention {angular,atom,conventional,basic}
                        The commit convention to match against. Default: basic.
  -S, --sections SECTIONS [SECTIONS ...]
                        The sections to render. See the available sections for
                        each supported convention in the description.
  -t, --template {angular,keepachangelog}
                        The Jinja2 template to use. Prefix with "path:" to
                        specify the path to a directory containing a file
                        named "changelog.md".
  -T, --trailers, --git-trailers
                        Parse Git trailers in the commit message. See
                        https://git-scm.com/docs/git-interpret-trailers.
  -v, --version         Show the current version of the program and exit.

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

git_changelog-1.0.1.tar.gz (25.7 kB view details)

Uploaded Source

Built Distribution

git_changelog-1.0.1-py3-none-any.whl (22.2 kB view details)

Uploaded Python 3

File details

Details for the file git_changelog-1.0.1.tar.gz.

File metadata

  • Download URL: git_changelog-1.0.1.tar.gz
  • Upload date:
  • Size: 25.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.0

File hashes

Hashes for git_changelog-1.0.1.tar.gz
Algorithm Hash digest
SHA256 ee02f7dd230dfa2be39e474649bc885f74254aac8d0bcd5ed6c89fcba0c2ec95
MD5 cf8db96fafc90389cf4bbf93044edf8c
BLAKE2b-256 464ecb603983010f319a78beec2fc091e8c2ec65d681668f6757a4da473dc6b3

See more details on using hashes here.

File details

Details for the file git_changelog-1.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for git_changelog-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 45ab8e7d8423bb2be9e9c8f3f1b9d485c246f00f7158744557ff277c51306054
MD5 9ff585b4b09bcf63a3bc36da2de9548c
BLAKE2b-256 c08bc8910d33805adf8e4f3bc0b4153faff57b55a586e71517386e09731b8e6e

See more details on using hashes here.

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