93 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
			
		
		
	
	
			93 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
| #!/usr/bin/env python3
 | |
| from __future__ import annotations
 | |
| 
 | |
| import re
 | |
| 
 | |
| import ghapi.all
 | |
| from rich import print
 | |
| from rich.syntax import Syntax
 | |
| 
 | |
| ENTRY = re.compile(
 | |
|     r"""
 | |
|     Suggested \s changelog \s entry:
 | |
|     .*
 | |
|     ```rst
 | |
|     \s*
 | |
|     (.*?)
 | |
|     \s*
 | |
|     ```
 | |
| """,
 | |
|     re.DOTALL | re.VERBOSE,
 | |
| )
 | |
| 
 | |
| print()
 | |
| 
 | |
| 
 | |
| api = ghapi.all.GhApi(owner="pybind", repo="pybind11")
 | |
| 
 | |
| issues_pages = ghapi.page.paged(
 | |
|     api.issues.list_for_repo, labels="needs changelog", state="closed"
 | |
| )
 | |
| issues = (issue for page in issues_pages for issue in page)
 | |
| missing = []
 | |
| cats_descr = {
 | |
|     "feat": "New Features",
 | |
|     "feat(types)": "",
 | |
|     "feat(cmake)": "",
 | |
|     "fix": "Bug fixes",
 | |
|     "fix(types)": "",
 | |
|     "fix(cmake)": "",
 | |
|     "docs": "Documentation",
 | |
|     "tests": "Tests",
 | |
|     "ci": "CI",
 | |
|     "chore": "Other",
 | |
|     "unknown": "Uncategorised",
 | |
| }
 | |
| cats: dict[str, list[str]] = {c: [] for c in cats_descr}
 | |
| 
 | |
| for issue in issues:
 | |
|     changelog = ENTRY.findall(issue.body or "")
 | |
|     if not changelog or not changelog[0]:
 | |
|         missing.append(issue)
 | |
|     else:
 | |
|         (msg,) = changelog
 | |
|         if msg.startswith("- "):
 | |
|             msg = msg[2:]
 | |
|         if not msg.startswith("* "):
 | |
|             msg = "* " + msg
 | |
|         if not msg.endswith("."):
 | |
|             msg += "."
 | |
| 
 | |
|         msg += f"\n  `#{issue.number} <{issue.html_url}>`_"
 | |
|         for cat in cats:
 | |
|             if issue.title.lower().startswith(f"{cat}:"):
 | |
|                 cats[cat].append(msg)
 | |
|                 break
 | |
|         else:
 | |
|             cats["unknown"].append(msg)
 | |
| 
 | |
| for cat, msgs in cats.items():
 | |
|     if msgs:
 | |
|         desc = cats_descr[cat]
 | |
|         print(f"[bold]{desc}:" if desc else f".. {cat}")
 | |
|         print()
 | |
|         for msg in msgs:
 | |
|             print(Syntax(msg, "rst", theme="ansi_light", word_wrap=True))
 | |
|             print()
 | |
|         print()
 | |
| 
 | |
| if missing:
 | |
|     print()
 | |
|     print("[blue]" + "-" * 30)
 | |
|     print()
 | |
| 
 | |
|     for issue in missing:
 | |
|         print(f"[red bold]Missing:[/red bold][red] {issue.title}")
 | |
|         print(f"[red]  {issue.html_url}\n")
 | |
| 
 | |
|     print("[bold]Template:\n")
 | |
|     msg = "## Suggested changelog entry:\n\n```rst\n\n```"
 | |
|     print(Syntax(msg, "md", theme="ansi_light"))
 | |
| 
 | |
| print()
 |