aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorKevin Guthrie <[email protected]>2024-04-02 16:49:24 -0400
committerKevin Guthrie <[email protected]>2024-04-02 16:49:24 -0400
commitc878956619b313b663a618bb5071cde0f5d03621 (patch)
treefde67a927f191afa48107af9345cc34e966a0ce3
parent5fdf287c4d6a9ddc8a9caf3447cd27575c13a24c (diff)
downloadpingora-kbg/change-log.tar.gz
pingora-kbg/change-log.zip
Adding the stub for the changelog and the configuration file for generating it in the futurekbg/change-log
-rw-r--r--CHANGELOG.md7
-rw-r--r--cliff.toml87
2 files changed, 94 insertions, 0 deletions
diff --git a/CHANGELOG.md b/CHANGELOG.md
new file mode 100644
index 0000000..65b1e9b
--- /dev/null
+++ b/CHANGELOG.md
@@ -0,0 +1,7 @@
+# Changelog
+
+All notable changes to this project will be documented in this file.
+
+## [0.1.0] - 2024-02-28
+### Highlights
+- First Public Release of Pingora ๐ŸŽ‰
diff --git a/cliff.toml b/cliff.toml
new file mode 100644
index 0000000..43c402a
--- /dev/null
+++ b/cliff.toml
@@ -0,0 +1,87 @@
+# git-cliff ~ default configuration file
+# https://git-cliff.org/docs/configuration
+#
+# Lines starting with "#" are comments.
+# Configuration options are organized into tables and keys.
+# See documentation for more information on available options.
+
+[changelog]
+# changelog header
+header = """
+# Changelog\n
+All notable changes to this project will be documented in this file.\n
+"""
+# template for the changelog body
+# https://keats.github.io/tera/docs/#introduction
+body = """
+{% if version %}\
+ {% if previous.version %}\
+ ## [{{ version | trim_start_matches(pat="v") }}](https://github.com/cloudflare/pingora/compare/{{ previous.version }}...{{ version }}) - {{ timestamp | date(format="%Y-%m-%d") }}
+ {% else %}\
+ ## [{{ version | trim_start_matches(pat="v") }}] - {{ timestamp | date(format="%Y-%m-%d") }}
+ {% endif %}\
+{% else %}\
+ ## [unreleased]
+{% endif %}\
+
+### Highlights
+ - Human-written change summaries go here
+
+{% for group, commits in commits | group_by(attribute="group") %}
+ ### {{ group | striptags | trim | upper_first }}
+ {% for commit in commits %}
+ - {% if commit.scope %}*({{ commit.scope }})* {% endif %}\
+ {% if commit.breaking %}[**breaking**] {% endif %}\
+ {{ commit.message | upper_first }}\
+ {% endfor %}
+{% endfor %}\n
+"""
+# template for the changelog footer
+footer = """
+"""
+# remove the leading and trailing whitespace
+trim = true
+
+[git]
+# parse the commits based on https://www.conventionalcommits.org
+conventional_commits = true
+
+# filter out the commits that are not conventional
+filter_unconventional = false
+
+# process each line of a commit as an individual commit
+split_commits = false
+
+# regex for preprocessing the commit messages
+commit_preprocessors = [
+ { pattern = '\n\w+(?:\-\w+)*:\s+[^\n]+', replace = "\n" },
+ { pattern = '\n+', replace = "\n " },
+ { pattern = '\s+$', replace = "" }
+]
+
+# regex for parsing and grouping commits
+commit_parsers = [
+ { message = "^feat", group = "<!-- 0 -->๐Ÿš€ Features" },
+ { message = "^fix", group = "<!-- 1 -->๐Ÿ› Bug Fixes" },
+ { message = "^doc", group = "<!-- 3 -->๐Ÿ“š Documentation", skip = true },
+ { message = "^perf", group = "<!-- 4 -->โšก Performance" },
+ { message = "^refactor", group = "<!-- 2 -->๐Ÿšœ Refactor", skip = true },
+ { message = "^style", group = "<!-- 5 -->๐ŸŽจ Styling", skip = true },
+ { message = "^test", group = "<!-- 6 -->๐Ÿงช Testing", skip = true },
+ { message = "^chore\\(release\\): prepare for", skip = true },
+ { message = "^chore\\(deps.*\\)", skip = true },
+ { message = "^chore\\(pr\\)", skip = true },
+ { message = "^chore\\(pull\\)", skip = true },
+ { message = "^chore|^ci", group = "<!-- 7 -->โš™๏ธ Miscellaneous Tasks" },
+ { body = ".*security", group = "<!-- 8 -->๐Ÿ›ก๏ธ Security" },
+ { message = "^revert", group = "<!-- 9 -->โ—€๏ธ Revert" },
+ { message = '\S+(?:\s+\S+){6,}', group = "<!--10--> Everything Else" }
+]
+
+# protect breaking changes from being skipped due to matching a skipping commit_parser
+protect_breaking_commits = false
+
+# filter out the commits that are not matched by commit parsers
+filter_commits = false
+tag_pattern = "[0-9].[0-9].[0-9]"
+topo_order = false \ No newline at end of file