Beagle gen-release-notes

generate release notes for changes since a given tag

install
source · Clone the upstream repo
git clone https://github.com/existential-birds/beagle
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/existential-birds/beagle "$T" && mkdir -p ~/.claude/skills && cp -r "$T/plugins/beagle-core/skills/gen-release-notes" ~/.claude/skills/existential-birds-beagle-gen-release-notes && rm -rf "$T"
manifest: plugins/beagle-core/skills/gen-release-notes/SKILL.md
source content

Release Notes Generator

Generate professional release notes following the Keep a Changelog standard.

Input: Previous tag (e.g.,

v0.0.1
)

$ARGUMENTS

Use extended thinking to analyze the changes thoroughly before generating release notes.

Step 1: Gather Changes

Run these commands to collect information about changes since the provided tag:

# Store the previous tag
PREV_TAG="$ARGUMENTS"

# Verify the tag exists
git tag -l "$PREV_TAG"

# Get the repo URL for PR links
git remote get-url origin

# List commits since last tag
git log ${PREV_TAG}..HEAD --pretty=format:"%h %s" --no-merges

# Get detailed diff stats
git diff ${PREV_TAG}..HEAD --stat

# List changed files by directory
git diff ${PREV_TAG}..HEAD --name-only | sort | uniq

Also gather PR information:

# Get merged PRs since the tag (requires gh CLI)
gh pr list --state merged --search "merged:>=$(git log -1 --format=%ci $PREV_TAG | cut -d' ' -f1)" --json number,title,author,labels

Step 2: Analyze and Categorize

Categorize each change into exactly one of these groups (in this order):

CategoryIncludeExclude
AddedNew features, new public APIs, new CLI commandsInternal utilities not exposed to users
ChangedModified behavior, performance improvements, updated dependencies with user impactRefactors with no behavior change
DeprecatedFeatures marked for future removal-
RemovedDeleted features, removed public APIsRemoved internal code
FixedBug fixes, error handling improvementsTest-only fixes
SecurityVulnerability patches, security hardening-

Exclude entirely:

  • CI/CD configuration changes (unless they affect users)
  • Documentation-only changes (unless they reveal new features)
  • Code style/formatting changes
  • Test-only changes
  • Internal refactors with no user-visible impact
  • Merge commits

Step 3: Determine Version Number

Based on the changes, suggest the next version following Semantic Versioning:

  • MAJOR (X.0.0): Breaking changes to public API
  • MINOR (x.Y.0): New features, backward-compatible
  • PATCH (x.y.Z): Bug fixes only

Detect the tag format from existing tags (with or without

v
prefix).

Step 4: Write Release Notes

Generate a

CHANGELOG.md
entry using this exact format:

## [VERSION] - YYYY-MM-DD

### Added

- **scope:** Add new feature description ([#54](REPO_URL/pull/54))

### Changed

- **Breaking:** Rename `oldName()` to `newName()` for consistency ([#145](REPO_URL/pull/145))

  **Migration:** Replace all calls to `oldName()` with `newName()`.

### Deprecated

- **scope:** Deprecate `legacy_function()` in favor of `new_function()` ([#143](REPO_URL/pull/143))

### Removed

- **Breaking:** Remove deprecated `old_function()` ([#141](REPO_URL/pull/141))

### Fixed

- **scope:** Fix race condition when multiple workers access shared state ([#139](REPO_URL/pull/139))

### Security

- **deps:** Update vulnerable package to patched version ([#49](REPO_URL/pull/49))

Writing Rules

Format requirements:

  • Start every entry with an imperative verb: Add, Fix, Remove, Update, Improve, Rename, Deprecate, Patch
  • Include scope prefix in bold when present:
    **server:**
    ,
    **cli:**
    ,
    **api:**
  • One line per change (except breaking changes which get migration notes)
  • Include PR/issue link at end of line
  • Sort entries within each category by importance (most impactful first)
  • Omit empty categories entirely

Breaking changes:

  • Prefix with bold
    **Breaking:**
  • List first within their category
  • Add a
    **Migration:**
    block on the next line explaining exactly what users must change
  • Include before/after code examples for API signature changes

Tone:

  • Write for library consumers, not maintainers
  • Focus on what changed for users, not how it was implemented
  • Be specific—never write "various improvements" or "bug fixes"
  • Each entry should be understandable without reading the PR

Bad examples to avoid:

# BAD - Too vague
- Fixed bugs
- Performance improvements
- Updated dependencies

# BAD - Implementation-focused
- Refactored the internal state machine to use async/await

# BAD - Missing context
- Fixed #234

Good examples to follow:

# GOOD - Specific and user-focused
- **server:** Fix timeout errors when processing files larger than 100MB ([#234](URL))
- **cli:** Add `--dry-run` flag to preview changes before execution ([#235](URL))
- **api:** Improve cold-start latency from 2.3s to 0.8s by lazy-loading plugins ([#236](URL))

Step 5: Update CHANGELOG.md

  1. If

    CHANGELOG.md
    exists:

    • Insert new version after the
      ## [Unreleased]
      section (or at top if no Unreleased)
  2. If

    CHANGELOG.md
    doesn't exist, create it with this header:

# Changelog

All notable changes to this project will be documented in this file.

The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.1.0/),
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).

## [Unreleased]

  1. Update the footer reference links at the bottom of the file. This step is mandatory — CodeRabbit and other reviewers will flag the changelog as incomplete if these are missing. Two edits are required:

    a. Advance

    [Unreleased]
    so it compares against the new version instead of the previous one. b. Insert a new
    [NEW_VERSION]
    line
    right below
    [Unreleased]
    , comparing the previous tag to the new one.

    Example diff (releasing

    3.2.0
    after
    3.1.0
    ):

    -[Unreleased]: https://github.com/OWNER/REPO/compare/v3.1.0...HEAD
    +[Unreleased]: https://github.com/OWNER/REPO/compare/v3.2.0...HEAD
    +[3.2.0]: https://github.com/OWNER/REPO/compare/v3.1.0...v3.2.0
     [3.1.0]: https://github.com/OWNER/REPO/compare/v3.0.0...v3.1.0
    

    After editing, verify with:

    grep -E '^\[(Unreleased|NEW_VERSION)\]:' CHANGELOG.md
    — both lines must be present and
    [Unreleased]
    must point at the new tag, not the old one.

Step 6: Output Summary

After updating the changelog, provide:

  1. The suggested version number with rationale
  2. Summary of categorized changes
  3. Any breaking changes that need special attention
  4. Confirmation that CHANGELOG.md was updated

Conventional Commits Mapping

Map commit prefixes to changelog categories:

Commit PrefixChangelog Category
feat(scope):
Added
feat!(scope):
Added (with Breaking prefix)
fix(scope):
Fixed
perf(scope):
Changed
security(scope):
Security
docs:
,
chore:
,
ci:
,
test:
,
style:
Exclude