Customizing changelogs
You don’t have to settle for the built-in changelog sections, there are a number of ways to customize generated changelogs. Each top-level heading on this page is a different way to customize. You can skip right to the most interesting one for you.
Before starting, here is how a version in a changelog looks by default:
Knope will always include these sections in the same order, but it only includes sections which contain changes.
Changing the header level
By default, the heading of a version is ##
, each section is ###
, and each change is ####
.
The relative level of those sections is always the same,
but you can change each version to be a top-level heading (#
)
by modifying the last version in the changelog to be that level.
Knope looks for the previous version to decide the level of the next version.
Adding more sections
You can use the extra_changelog_sections
config option to add extra sections to a changelog.
This is per-package, so if you have more than one package, you’ll need to customize each changelog.
You can add as many sections as you want, they will appear in order after the built-in sections.
Each section can be added to from any number of [conventional commit footers] and [changeset types].
The semantic version impact of any custom changes is patch
.
Overriding built-in sections
The built-in sections, as described at the top of this page, can be overridden.
Here’s some config that would override all the built-in sections, only changing their name (not their order or sources):
Adding to Notes
from more sources
The built-in Notes
section comes from any conventional commit footers named Changelog-Note
.
You can override this section in the config file to add more sources:
Now, when running a [CreateChangeFile
] step (for example, with knope document-change
), the note
type will be available: