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:
parent
38bdfbe4af
commit
8869b16c83
@ -1 +0,0 @@
|
||||
../tools/towncrier.toml
|
43
core/towncrier.toml
Normal file
43
core/towncrier.toml
Normal 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
|
@ -18,7 +18,7 @@ INTERNAL_MODELS = ("T2T1", "T2B1", "T3T1", "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 = {}
|
||||
orig_links = {}
|
||||
result_lines = []
|
||||
@ -54,7 +54,7 @@ def linkify_changelog(changelog_file, only_check=False):
|
||||
return True
|
||||
|
||||
|
||||
def linkify_gh_diff(changelog_file, tag_prefix):
|
||||
def linkify_gh_diff(changelog_file: Path, tag_prefix: str):
|
||||
linkified = False
|
||||
versions = []
|
||||
result_lines = []
|
||||
@ -79,7 +79,7 @@ def linkify_gh_diff(changelog_file, tag_prefix):
|
||||
linkified = True
|
||||
|
||||
|
||||
def current_date(project):
|
||||
def current_date(project: Path) -> str:
|
||||
parts = project.parts
|
||||
today = datetime.datetime.now()
|
||||
|
||||
@ -98,8 +98,8 @@ def current_date(project):
|
||||
return today.strftime(f"%-d{daysuffix} %B %Y")
|
||||
|
||||
|
||||
def filter_changelog(changelog_file, internal_name):
|
||||
def filter_line(line):
|
||||
def filter_changelog(changelog_file: Path, internal_name: str):
|
||||
def filter_line(line: str) -> str | None:
|
||||
m = MODELS_RE.search(line)
|
||||
if not m:
|
||||
return line
|
||||
@ -116,6 +116,16 @@ def filter_changelog(changelog_file, internal_name):
|
||||
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.argument(
|
||||
"project",
|
||||
@ -130,7 +140,8 @@ def filter_changelog(changelog_file, internal_name):
|
||||
@click.option(
|
||||
"--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,
|
||||
legacy/bootloader).
|
||||
|
||||
@ -148,13 +159,17 @@ def cli(project, version, date, check):
|
||||
raise click.ClickException(f"{changelog} not found")
|
||||
|
||||
if version is None:
|
||||
if not check:
|
||||
if not check and not only_models:
|
||||
raise click.ClickException("Version argument is required.")
|
||||
version = "unreleased"
|
||||
|
||||
if date is None:
|
||||
date = current_date(project)
|
||||
|
||||
if only_models:
|
||||
generate_filtered(project, changelog)
|
||||
return 0
|
||||
|
||||
args = ["towncrier", "build", "--yes", "--version", version, "--date", date]
|
||||
if check:
|
||||
args.append("--draft")
|
||||
@ -168,11 +183,7 @@ def cli(project, version, date, check):
|
||||
linkify_gh_diff(changelog, tag_prefix="python/v")
|
||||
|
||||
# core changelog for each model
|
||||
if project.parts[-1] == "core":
|
||||
for internal_name in INTERNAL_MODELS:
|
||||
if internal_name in INTERNAL_MODELS_SKIP:
|
||||
continue
|
||||
filter_changelog(changelog, internal_name)
|
||||
generate_filtered(project, changelog)
|
||||
|
||||
# towncrier calls git add before we do linkification, stage the changes too
|
||||
subprocess.run(["git", "add", changelog], check=True)
|
||||
|
@ -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]
|
||||
directory = ".changelog.d"
|
||||
filename = "CHANGELOG.md"
|
||||
|
Loading…
Reference in New Issue
Block a user