The following sections explain how things actually work inside fledge.
NEWS.mdNew entries are added to NEWS.md from commit messages to
commits in master.
Only top-level commits are considered (roughly equivalent to
git log --first-parent.) The messages from these commits
are parsed. Only lines that start with a star * or a dash
- are included.
If a line starts with three dashes, then everything past that line is excluded. Example: the following commit message
Merge f-fancy-feature to master, closes #5678
- Added fancy feature (#5678).
- Fixed bug as a side effect (#9012).
---
The fancy feature consists of the components:
- foo
- bar
- baz
will be added as below to NEWS.md:
- Added fancy feature (#5678).
- Fixed bug as a side effect (#9012).When retrieving the current NEWS for defining the tag message, the
entries between the first two first-level headers (starting with
#) are returned. You can use second and third level headers
and add as many empty lines as you want.
The first function to call at any stage is always
bump_version(). This does the following
Calls update_news() to collect NEWS entries from
top-level commits.
Calls update_version() to increment the version in
DESCRIPTION and add a header to
NEWS.md.
bump_version() continues depending on the release
type:
"dev" releases: Calls finalize_version()
to commit DESCRIPTION and NEWS.md. Also
creates a tag with a message. You can always edit NEWS.md
and call finalize_version() again. Both the commit and the
tag will be updated.commit_version() to commit
DESCRIPTION and NEWS.md without tagging. In
this stage, you can edit NEWS.md and commit as much as you
like. The tag is created only after you use tag_version()
manually.