1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-18 03:10:58 +00:00

chore: generate-changelog.py adjustments

- add T3T1 to the list of core hardware
- add flag for regenerating model-specific changelogs in case the main
  one is manually edited
- generate headings in the same format as currently used in
  core/CHANGELOG.md
This commit is contained in:
Martin Milata 2024-06-11 16:59:24 +02:00
parent 38bdfbe4af
commit 8869b16c83
3 changed files with 69 additions and 13 deletions

View File

@ -1 +0,0 @@
../tools/towncrier.toml

43
core/towncrier.toml Normal file
View File

@ -0,0 +1,43 @@
[tool.towncrier]
directory = ".changelog.d"
filename = "CHANGELOG.md"
template = ".towncrier.template.md"
start_string = "The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/)."
title_format = "\n## [{version}] ({project_date})"
issue_format = "[#{issue}]"
underlines = ["", ""]
[[tool.towncrier.type]]
directory = "added"
name = "Added"
showcontent = true
[[tool.towncrier.type]]
directory = "changed"
name = "Changed"
showcontent = true
[[tool.towncrier.type]]
directory = "deprecated"
name = "Deprecated"
showcontent = true
[[tool.towncrier.type]]
directory = "removed"
name = "Removed"
showcontent = true
[[tool.towncrier.type]]
directory = "fixed"
name = "Fixed"
showcontent = true
[[tool.towncrier.type]]
directory = "security"
name = "Security"
showcontent = true
[[tool.towncrier.type]]
directory = "incompatible"
name = "Incompatible changes"
showcontent = true

View File

@ -18,7 +18,7 @@ INTERNAL_MODELS = ("T2T1", "T2B1", "T3T1", "D001")
INTERNAL_MODELS_SKIP = ("D001",) INTERNAL_MODELS_SKIP = ("D001",)
def linkify_changelog(changelog_file, only_check=False): def linkify_changelog(changelog_file: Path, only_check: bool = False) -> bool:
links = {} links = {}
orig_links = {} orig_links = {}
result_lines = [] result_lines = []
@ -54,7 +54,7 @@ def linkify_changelog(changelog_file, only_check=False):
return True return True
def linkify_gh_diff(changelog_file, tag_prefix): def linkify_gh_diff(changelog_file: Path, tag_prefix: str):
linkified = False linkified = False
versions = [] versions = []
result_lines = [] result_lines = []
@ -79,7 +79,7 @@ def linkify_gh_diff(changelog_file, tag_prefix):
linkified = True linkified = True
def current_date(project): def current_date(project: Path) -> str:
parts = project.parts parts = project.parts
today = datetime.datetime.now() today = datetime.datetime.now()
@ -98,8 +98,8 @@ def current_date(project):
return today.strftime(f"%-d{daysuffix} %B %Y") return today.strftime(f"%-d{daysuffix} %B %Y")
def filter_changelog(changelog_file, internal_name): def filter_changelog(changelog_file: Path, internal_name: str):
def filter_line(line): def filter_line(line: str) -> str | None:
m = MODELS_RE.search(line) m = MODELS_RE.search(line)
if not m: if not m:
return line return line
@ -116,6 +116,16 @@ def filter_changelog(changelog_file, internal_name):
destination.write(res) destination.write(res)
def generate_filtered(project: Path, changelog: Path):
if project.parts[-1] != "core":
return
for internal_name in INTERNAL_MODELS:
if internal_name in INTERNAL_MODELS_SKIP:
continue
filter_changelog(changelog, internal_name)
@click.command() @click.command()
@click.argument( @click.argument(
"project", "project",
@ -130,7 +140,8 @@ def filter_changelog(changelog_file, internal_name):
@click.option( @click.option(
"--check", is_flag=True, help="Dry run, do not actually create changelog." "--check", is_flag=True, help="Dry run, do not actually create changelog."
) )
def cli(project, version, date, check): @click.option("--only-models", is_flag=True, help="Only regenerate the model-changelogs from the main one.")
def cli(project, version, date, check, only_models):
"""Generate changelog for given project (core, python, legacy/firmware, """Generate changelog for given project (core, python, legacy/firmware,
legacy/bootloader). legacy/bootloader).
@ -148,13 +159,17 @@ def cli(project, version, date, check):
raise click.ClickException(f"{changelog} not found") raise click.ClickException(f"{changelog} not found")
if version is None: if version is None:
if not check: if not check and not only_models:
raise click.ClickException("Version argument is required.") raise click.ClickException("Version argument is required.")
version = "unreleased" version = "unreleased"
if date is None: if date is None:
date = current_date(project) date = current_date(project)
if only_models:
generate_filtered(project, changelog)
return 0
args = ["towncrier", "build", "--yes", "--version", version, "--date", date] args = ["towncrier", "build", "--yes", "--version", version, "--date", date]
if check: if check:
args.append("--draft") args.append("--draft")
@ -168,11 +183,7 @@ def cli(project, version, date, check):
linkify_gh_diff(changelog, tag_prefix="python/v") linkify_gh_diff(changelog, tag_prefix="python/v")
# core changelog for each model # core changelog for each model
if project.parts[-1] == "core": generate_filtered(project, changelog)
for internal_name in INTERNAL_MODELS:
if internal_name in INTERNAL_MODELS_SKIP:
continue
filter_changelog(changelog, internal_name)
# towncrier calls git add before we do linkification, stage the changes too # towncrier calls git add before we do linkification, stage the changes too
subprocess.run(["git", "add", changelog], check=True) subprocess.run(["git", "add", changelog], check=True)

View File

@ -1,3 +1,6 @@
# This is the default configuration that is used by subprojects via symlink.
# Some subprojects have their own configuration which is not a symlink.
[tool.towncrier] [tool.towncrier]
directory = ".changelog.d" directory = ".changelog.d"
filename = "CHANGELOG.md" filename = "CHANGELOG.md"