mit einem Klick
releasing
// Full release lifecycle — version bump, CHANGELOG, rich release notes, tag, publish. Use when user says "release", "tag and release", "publish version", "cut a release", "new version".
// Full release lifecycle — version bump, CHANGELOG, rich release notes, tag, publish. Use when user says "release", "tag and release", "publish version", "cut a release", "new version".
| name | releasing |
| description | Full release lifecycle — version bump, CHANGELOG, rich release notes, tag, publish. Use when user says "release", "tag and release", "publish version", "cut a release", "new version". |
| user-invocable | true |
| allowed-tools | ["Bash(git *)","Bash(gh *)","Bash(git cliff *)","Bash(make check)","Read"] |
| argument-hint | [patch|minor|major|<version>] (e.g., patch, minor, 2.4.0) |
Tag and publish a new version with rich, narrative release notes.
Run in parallel:
git branch --show-current # Must be main
git status --porcelain # Must be clean
git log origin/main..HEAD --oneline # Must be empty (all pushed)
If any fail: report and stop.
Run make check — all must pass.
Get the last tag:
git describe --tags --abbrev=0
Parse $ARGUMENTS:
2.4.0 → use it directlypatch / minor / major → bump the last tag accordinglyfeat commits → minorfix/docs/refactor → patchThe version is X.Y.Z (no v prefix in display). The git tag is vX.Y.Z.
git cliff --tag vX.Y.Z --output CHANGELOG.md
Read the FULL diff since the last tag to understand every change:
git diff <last-tag>..HEAD -- '*.py' '*.yml' '*.toml'
git log <last-tag>..HEAD --format="%H %s"
Also read any PR descriptions referenced in commits:
gh pr list --state merged --search "is:merged" --limit 20 --json number,title,body
Now write release notes following this structure and style (study existing releases for tone):
Lead with a theme headline — one sentence summarizing what this release is about
## Shell Provider — Chat-First Shell Interface via Telegram## Bug Fixes & Reliability## Wrap Prompt Mode — Preserve Your Shell PromptExplain WHY, not just WHAT — don't just list commit messages. Explain user-facing impact:
- Fix idempotent prompt markers- **Idempotent prompt markers** — guards prevent duplicate marker injection on repeated setup (e.g., after exec bash or profile reload)Group by theme, not commit type — if 3 fixes all relate to "shell prompt reliability", group them under that heading instead of a flat "### Fixed" list
Include context — before/after examples, tables, config snippets where they help
End with Install / Upgrade block — always include uv tool upgrade ccgram and brew upgrade ccgram
Keep it concise — a patch release with 2 fixes needs 15-20 lines, not 100. Scale depth with change magnitude.
No "Documentation" section — skip changelog/readme commits, they're noise in release notes
Link PRs where available: ([#36](https://github.com/alexei-led/ccgram/pull/36))
Present the draft release notes to the user for review before proceeding.
git add CHANGELOG.md
git commit -m "docs: update CHANGELOG.md for vX.Y.Z"
git push origin main
git tag vX.Y.Z
git push origin vX.Y.Z
CRITICAL: The CHANGELOG commit message must NOT contain [skip ci] — it kills tag-triggered workflows.
Poll until the release exists (CI creates it), then edit with the crafted notes:
# Poll every 15s, up to 5 minutes
gh release view vX.Y.Z --json tagName 2>/dev/null
Once it exists:
gh release edit vX.Y.Z --notes "<crafted release notes>"
Report final status with link to the release.
v2.4.0 → PyPI 2.4.0.github/workflows/release.yml (3 jobs: PyPI, Homebrew, GitHub Release)--latest for baseline notes; this skill replaces them with rich notesgit tag -d vX.Y.Z && git push origin :refs/tags/vX.Y.Z