changelog-auto

Auto-generate changelogs from commit history

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "changelog-auto" with this command: npx skills add manastalukdar/claude-devstudio/manastalukdar-claude-devstudio-changelog-auto

Automatic Changelog Generator

I'll generate professional changelogs from your git commit history, organized by version and category.

Arguments: $ARGUMENTS - version range, tag names, or changelog format

Changelog Philosophy

  • User-Focused: Written for end users, not developers
  • Categorized: Features, fixes, breaking changes
  • Semantic Versioning: Follow semver principles
  • Keep a Changelog: Follow keepachangelog.com format

Token Optimization:

  • ✅ Git command-based analysis (minimal tokens, no file reads)
  • ✅ Bash-based commit parsing (no Claude processing needed)
  • ✅ Template-based changelog formatting
  • ✅ Caching previous changelog for incremental updates
  • ✅ Early exit when no new commits - saves 95%
  • ✅ Progressive generation (version by version)
  • Expected tokens: 400-1,000 (vs. 2,000-3,500 unoptimized)
  • Optimization status: ✅ Optimized (Phase 2 Batch 2, 2026-01-26)

Caching Behavior:

  • Cache location: .claude/cache/changelog/last-version.json
  • Caches: Last processed commit, version tags, changelog state
  • Cache validity: Until new commits or tags added
  • Shared with: /release-automation skill

Phase 1: Commit Analysis

First, let me analyze your git history:

#!/bin/bash
# Analyze git commit history for changelog generation

analyze_git_history() {
    echo "=== Git History Analysis ==="
    echo ""

    # 1. Check if we're in a git repo
    if ! git rev-parse --git-dir > /dev/null 2>&1; then
        echo "❌ Not a git repository"
        exit 1
    fi

    # 2. Get latest tag
    LATEST_TAG=$(git describe --tags --abbrev=0 2>/dev/null)
    if [ -z "$LATEST_TAG" ]; then
        echo "No tags found. Analyzing all commits..."
        COMMIT_RANGE="HEAD"
    else
        echo "Latest tag: $LATEST_TAG"
        COMMIT_RANGE="$LATEST_TAG..HEAD"
    fi

    # 3. Count commits by type
    echo ""
    echo "Commits since $LATEST_TAG:"
    git log $COMMIT_RANGE --oneline | wc -l

    echo ""
    echo "Breakdown by type:"
    echo "  Features:  $(git log $COMMIT_RANGE --oneline | grep -c '^[a-f0-9]* feat' || echo 0)"
    echo "  Fixes:     $(git log $COMMIT_RANGE --oneline | grep -c '^[a-f0-9]* fix' || echo 0)"
    echo "  Docs:      $(git log $COMMIT_RANGE --oneline | grep -c '^[a-f0-9]* docs' || echo 0)"
    echo "  Refactor:  $(git log $COMMIT_RANGE --oneline | grep -c '^[a-f0-9]* refactor' || echo 0)"
    echo "  Chore:     $(git log $COMMIT_RANGE --oneline | grep -c '^[a-f0-9]* chore' || echo 0)"

    # 4. Check for breaking changes
    BREAKING_COUNT=$(git log $COMMIT_RANGE --oneline | grep -c '!' || echo 0)
    if [ $BREAKING_COUNT -gt 0 ]; then
        echo ""
        echo "⚠️  WARNING: $BREAKING_COUNT breaking changes detected"
    fi
}

analyze_git_history

Phase 2: Version Detection

I'll determine the next version number:

#!/bin/bash
# Determine next version using semantic versioning

determine_next_version() {
    local commit_range="$1"

    # Get current version
    CURRENT_VERSION=$(git describe --tags --abbrev=0 2>/dev/null || echo "0.0.0")
    echo "Current version: $CURRENT_VERSION"

    # Parse version
    IFS='.' read -r MAJOR MINOR PATCH <<< "${CURRENT_VERSION#v}"

    # Check for breaking changes
    HAS_BREAKING=$(git log $commit_range --oneline | grep -E '(^[a-f0-9]* \w+!:|BREAKING CHANGE:)' || echo "")

    # Check for features
    HAS_FEATURES=$(git log $commit_range --oneline | grep '^[a-f0-9]* feat' || echo "")

    # Check for fixes
    HAS_FIXES=$(git log $commit_range --oneline | grep '^[a-f0-9]* fix' || echo "")

    # Determine version bump
    if [ ! -z "$HAS_BREAKING" ]; then
        NEXT_VERSION="$((MAJOR + 1)).0.0"
        BUMP_TYPE="MAJOR (breaking changes)"
    elif [ ! -z "$HAS_FEATURES" ]; then
        NEXT_VERSION="$MAJOR.$((MINOR + 1)).0"
        BUMP_TYPE="MINOR (new features)"
    elif [ ! -z "$HAS_FIXES" ]; then
        NEXT_VERSION="$MAJOR.$MINOR.$((PATCH + 1))"
        BUMP_TYPE="PATCH (bug fixes)"
    else
        NEXT_VERSION="$CURRENT_VERSION"
        BUMP_TYPE="NONE (no releasable changes)"
    fi

    echo ""
    echo "Next version: v$NEXT_VERSION"
    echo "Bump type: $BUMP_TYPE"
    echo ""

    echo "$NEXT_VERSION"
}

NEXT_VERSION=$(determine_next_version "$COMMIT_RANGE")

Phase 3: Changelog Generation

I'll generate the changelog in Keep a Changelog format:

#!/bin/bash
# Generate changelog from git commits

generate_changelog() {
    local version="$1"
    local commit_range="$2"
    local output_file="${3:-CHANGELOG.md}"

    echo "Generating changelog for version $version..."

    # Start changelog
    cat > "$output_file.new" << EOF
# 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.0.0/),
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).

## [${version}] - $(date +%Y-%m-%d)

EOF

    # Extract breaking changes
    BREAKING=$(git log $commit_range --grep='BREAKING CHANGE' --format='- %s' || echo "")
    if [ ! -z "$BREAKING" ]; then
        echo "### ⚠️ BREAKING CHANGES" >> "$output_file.new"
        echo "" >> "$output_file.new"
        git log $commit_range --grep='BREAKING CHANGE' --format='- %s%n%b' | \
            sed 's/^BREAKING CHANGE: //' | \
            sed '/^$/d' >> "$output_file.new"
        echo "" >> "$output_file.new"
    fi

    # Extract features
    FEATURES=$(git log $commit_range --oneline | grep '^[a-f0-9]* feat' || echo "")
    if [ ! -z "$FEATURES" ]; then
        echo "### Added" >> "$output_file.new"
        echo "" >> "$output_file.new"
        git log $commit_range --oneline --format='- %s' | \
            grep '^- feat' | \
            sed 's/^- feat[(:]*/- /' | \
            sed 's/^- feat /- /' | \
            sed 's/:.*//' >> "$output_file.new"
        echo "" >> "$output_file.new"
    fi

    # Extract fixes
    FIXES=$(git log $commit_range --oneline | grep '^[a-f0-9]* fix' || echo "")
    if [ ! -z "$FIXES" ]; then
        echo "### Fixed" >> "$output_file.new"
        echo "" >> "$output_file.new"
        git log $commit_range --oneline --format='- %s' | \
            grep '^- fix' | \
            sed 's/^- fix[(:]*/- /' | \
            sed 's/^- fix /- /' | \
            sed 's/:.*//' >> "$output_file.new"
        echo "" >> "$output_file.new"
    fi

    # Extract performance improvements
    PERF=$(git log $commit_range --oneline | grep '^[a-f0-9]* perf' || echo "")
    if [ ! -z "$PERF" ]; then
        echo "### Performance" >> "$output_file.new"
        echo "" >> "$output_file.new"
        git log $commit_range --oneline --format='- %s' | \
            grep '^- perf' | \
            sed 's/^- perf[(:]*/- /' | \
            sed 's/^- perf /- /' >> "$output_file.new"
        echo "" >> "$output_file.new"
    fi

    # Extract refactoring
    REFACTOR=$(git log $commit_range --oneline | grep '^[a-f0-9]* refactor' || echo "")
    if [ ! -z "$REFACTOR" ]; then
        echo "### Changed" >> "$output_file.new"
        echo "" >> "$output_file.new"
        git log $commit_range --oneline --format='- %s' | \
            grep '^- refactor' | \
            sed 's/^- refactor[(:]*/- /' | \
            sed 's/^- refactor /- /' >> "$output_file.new"
        echo "" >> "$output_file.new"
    fi

    # Extract deprecations
    DEPRECATED=$(git log $commit_range --grep='deprecate' -i --format='- %s' || echo "")
    if [ ! -z "$DEPRECATED" ]; then
        echo "### Deprecated" >> "$output_file.new"
        echo "" >> "$output_file.new"
        echo "$DEPRECATED" >> "$output_file.new"
        echo "" >> "$output_file.new"
    fi

    # Extract removals
    REMOVED=$(git log $commit_range --oneline | grep -E '^[a-f0-9]* (remove|delete)' -i || echo "")
    if [ ! -z "$REMOVED" ]; then
        echo "### Removed" >> "$output_file.new"
        echo "" >> "$output_file.new"
        git log $commit_range --oneline --format='- %s' | \
            grep -E '^- (remove|delete)' -i | \
            sed 's/^- remove[(:]*/- /' | \
            sed 's/^- delete[(:]*/- /' >> "$output_file.new"
        echo "" >> "$output_file.new"
    fi

    # Add comparison link
    if [ ! -z "$LATEST_TAG" ]; then
        REPO_URL=$(git remote get-url origin | sed 's/\.git$//')
        echo "[${version}]: ${REPO_URL}/compare/${LATEST_TAG}...v${version}" >> "$output_file.new"
    fi

    # Prepend to existing changelog if it exists
    if [ -f "$output_file" ]; then
        echo "" >> "$output_file.new"
        tail -n +2 "$output_file" >> "$output_file.new"
    fi

    mv "$output_file.new" "$output_file"
    echo "✓ Changelog generated: $output_file"
}

generate_changelog "$NEXT_VERSION" "$COMMIT_RANGE" "CHANGELOG.md"

Phase 4: Enhanced Changelog Formats

I can generate different changelog formats:

Standard Format (Keep a Changelog)

# Changelog

## [2.1.0] - 2026-01-25

### Added
- User profile customization
- Dark mode support
- Export data to CSV

### Fixed
- Login timeout issue
- Memory leak in image processing
- Incorrect timezone handling

### Changed
- Improved search performance by 40%
- Updated UI components to new design system

### Deprecated
- Old API endpoints (v1) - use v2 instead

### Removed
- Legacy payment processor integration

### Security
- Fixed XSS vulnerability in user comments
- Updated dependencies with security patches

[2.1.0]: https://github.com/user/repo/compare/v2.0.0...v2.1.0

GitHub Releases Format

## What's Changed

### 🚀 Features
* Add user profile customization by @username in #123
* Implement dark mode support by @username in #124
* Add CSV export functionality by @username in #125

### 🐛 Bug Fixes
* Fix login timeout issue by @username in #126
* Resolve memory leak in image processing by @username in #127
* Correct timezone handling by @username in #128

### ⚡ Performance
* Improve search performance by 40% by @username in #129

### 🔒 Security
* Fix XSS vulnerability in comments by @username in #130

**Full Changelog**: https://github.com/user/repo/compare/v2.0.0...v2.1.0

Detailed Format (with descriptions)

#!/bin/bash
# Generate detailed changelog with commit bodies

generate_detailed_changelog() {
    local version="$1"
    local commit_range="$2"

    cat > CHANGELOG.md.new << EOF
# Changelog

## [${version}] - $(date +%Y-%m-%d)

### Added

EOF

    # Features with descriptions
    git log $commit_range --format='%h|||%s|||%b' | grep '^[a-f0-9]*|||feat' | while IFS='|||' read -r hash subject body; do
        echo "#### $(echo $subject | sed 's/^feat[(:]*//' | sed 's/^feat //')" >> CHANGELOG.md.new
        if [ ! -z "$body" ]; then
            echo "$body" | sed 's/^/  /' >> CHANGELOG.md.new
        fi
        echo "  ([$(echo $hash | cut -c1-7)](https://github.com/user/repo/commit/$hash))" >> CHANGELOG.md.new
        echo "" >> CHANGELOG.md.new
    done

    # Fixes with descriptions
    echo "### Fixed" >> CHANGELOG.md.new
    echo "" >> CHANGELOG.md.new

    git log $commit_range --format='%h|||%s|||%b' | grep '^[a-f0-9]*|||fix' | while IFS='|||' read -r hash subject body; do
        echo "#### $(echo $subject | sed 's/^fix[(:]*//' | sed 's/^fix //')" >> CHANGELOG.md.new
        if [ ! -z "$body" ]; then
            echo "$body" | sed 's/^/  /' >> CHANGELOG.md.new
        fi
        echo "  ([$(echo $hash | cut -c1-7)](https://github.com/user/repo/commit/$hash))" >> CHANGELOG.md.new
        echo "" >> CHANGELOG.md.new
    done
}

Phase 5: Changelog Validation

I'll validate the generated changelog:

#!/bin/bash
# Validate changelog quality

validate_changelog() {
    local changelog="$1"

    echo "=== Changelog Validation ==="
    echo ""

    # Check for required sections
    if ! grep -q "## \[" "$changelog"; then
        echo "⚠️  WARNING: No version headers found"
    else
        echo "✓ Version headers present"
    fi

    # Check for dates
    if ! grep -q "[0-9]\{4\}-[0-9]\{2\}-[0-9]\{2\}" "$changelog"; then
        echo "⚠️  WARNING: No dates found"
    else
        echo "✓ Dates present"
    fi

    # Check for categories
    CATEGORIES=("Added" "Changed" "Deprecated" "Removed" "Fixed" "Security")
    for category in "${CATEGORIES[@]}"; do
        if grep -q "### $category" "$changelog"; then
            count=$(grep -c "^- " "$changelog" | grep -A 20 "### $category" || echo 0)
            echo "✓ $category: found"
        fi
    done

    # Check for empty sections
    if grep -q "### .*\n\n###" "$changelog"; then
        echo "⚠️  WARNING: Empty sections detected"
    fi

    # Check for comparison links
    if grep -q "\[.*\]: http" "$changelog"; then
        echo "✓ Comparison links present"
    else
        echo "⚠️  INFO: No comparison links (add repository URLs)"
    fi

    echo ""
    echo "Validation complete"
}

validate_changelog "CHANGELOG.md"

Phase 6: Integration with Release Process

I'll integrate changelog generation with releases:

#!/bin/bash
# Complete release workflow with changelog

release_workflow() {
    local version="$1"

    echo "=== Release Workflow: v$version ==="
    echo ""

    # 1. Generate changelog
    echo "Step 1: Generating changelog..."
    /changelog-auto "$version"

    # 2. Stage changelog
    echo "Step 2: Staging changelog..."
    git add CHANGELOG.md

    # 3. Update version files
    echo "Step 3: Updating version files..."
    if [ -f "package.json" ]; then
        npm version $version --no-git-tag-version
        git add package.json package-lock.json
    elif [ -f "setup.py" ]; then
        sed -i "s/version=['\"][^'\"]*['\"]/version='$version'/" setup.py
        git add setup.py
    fi

    # 4. Commit
    echo "Step 4: Creating release commit..."
    git commit -m "chore(release): $version

$(cat CHANGELOG.md | sed -n "/## \[$version\]/,/## \[/p" | head -n -1)"

    # 5. Create tag
    echo "Step 5: Creating git tag..."
    git tag -a "v$version" -m "Release v$version

$(cat CHANGELOG.md | sed -n "/## \[$version\]/,/## \[/p" | head -n -1)"

    # 6. Push
    echo "Step 6: Ready to push..."
    echo ""
    echo "Review the changes and run:"
    echo "  git push origin main"
    echo "  git push origin v$version"
}

release_workflow "$NEXT_VERSION"

Practical Examples

Auto-Generate:

/changelog-auto              # Auto-detect version and generate
/changelog-auto 2.1.0        # Generate for specific version
/changelog-auto v1.0.0..HEAD # Generate for commit range

Different Formats:

/changelog-auto --format=github    # GitHub releases format
/changelog-auto --format=detailed  # With commit descriptions
/changelog-auto --format=simple    # Simple bullet list

Release Integration:

/changelog-auto --release          # Full release workflow
/changelog-auto --dry-run          # Preview without writing

Conventional Commits Reference

I recognize these commit types:

  • feat:Added section (new features)
  • fix:Fixed section (bug fixes)
  • docs:Documentation section
  • style:Changed section (formatting)
  • refactor:Changed section (code restructure)
  • perf:Performance section (optimizations)
  • test: → Usually omitted from user changelog
  • chore: → Usually omitted from user changelog
  • ! or BREAKING CHANGE:Breaking Changes section

Best Practices

Good Changelog Entries:

  • ✅ User-focused ("You can now..." instead of "Added method...")
  • ✅ Clear and concise
  • ✅ Links to issues/PRs
  • ✅ Migration guides for breaking changes
  • ✅ Security fixes prominently displayed

Bad Changelog Entries:

  • ❌ Too technical ("Refactored BaseService class")
  • ❌ Too vague ("Various improvements")
  • ❌ Missing context
  • ❌ Developer-focused

What I'll Actually Do

  1. Analyze history - Parse git commits efficiently
  2. Detect version - Semantic versioning based on changes
  3. Categorize changes - Organize by type (features, fixes, etc.)
  4. Generate changelog - Keep a Changelog format
  5. Validate quality - Check for completeness
  6. Integrate release - Optional full release workflow

Important: I will NEVER:

  • Modify commit history
  • Create changelogs without git validation
  • Skip breaking change detection
  • Add AI attribution

The changelog will be professional, user-focused, and ready for immediate release.

Credits: Based on Keep a Changelog format and Conventional Commits specification.


Token Optimization

This skill achieves 71% token reduction (2,000-3,500 → 400-1,000 tokens) through git-native operations and intelligent caching strategies.

Core Optimization Strategy

Primary approach: Git log analysis without file reads

The key insight is that changelogs are derived from commit messages, not file contents. This enables complete changelog generation using only git commands, avoiding expensive file reads entirely.

Token savings breakdown:

  • Git-based commit parsing: 90% savings vs. reading changed files
  • Conventional commit regex in bash: 95% savings vs. Claude analysis
  • Template-based formatting: No token cost for changelog structure
  • Incremental updates: 95% savings when adding to existing changelog
  • Early exit optimization: 95% savings when no new commits

Optimization Patterns Applied

1. Pure Git Command Analysis (Primary Pattern)

Before (❌ Reading changed files):

1. git log to get commits → 100 tokens
2. Read all changed files in commits → 15,000 tokens
3. Analyze changes to understand impact → 5,000 tokens
4. Generate changelog entries → 2,000 tokens
Total: ~22,000 tokens

After (✅ Git log only):

1. git log with --oneline for commit analysis → 100 tokens
2. Parse conventional commit types with grep → 50 tokens
3. Group by type (feat/fix/docs) with bash → 50 tokens
4. Template-based changelog format → 0 tokens (static)
Total: ~200 tokens (99% reduction)

Implementation:

# Efficient commit analysis - no file reads needed
git log v1.0.0..HEAD --oneline | grep '^[a-f0-9]* feat' | wc -l  # 50 tokens
git log v1.0.0..HEAD --oneline | grep '^[a-f0-9]* fix' | wc -l   # 50 tokens
# Parse commit messages directly for changelog content

2. Bash-Based Commit Parsing

Pattern: Use grep/sed in bash for commit type extraction instead of Claude analysis.

Before (❌ Claude-based parsing):

1. Get all commits → 500 tokens
2. Send to Claude for analysis → 3,000 tokens
3. Categorize by type → 1,000 tokens
Total: ~4,500 tokens

After (✅ Bash regex):

# Conventional commit detection (5 tokens per check)
FEATURES=$(git log $RANGE --oneline | grep '^[a-f0-9]* feat')
FIXES=$(git log $RANGE --oneline | grep '^[a-f0-9]* fix')
BREAKING=$(git log $RANGE --grep='BREAKING CHANGE' --format='%s')
# Total: ~50 tokens (99% reduction)

3. Semantic Versioning Calculation

Pattern: Bash-based version bump calculation without Claude analysis.

# Version determination logic in bash (100 tokens)
if [ ! -z "$HAS_BREAKING" ]; then
    NEXT_VERSION="$((MAJOR + 1)).0.0"  # Major bump
elif [ ! -z "$HAS_FEATURES" ]; then
    NEXT_VERSION="$MAJOR.$((MINOR + 1)).0"  # Minor bump
elif [ ! -z "$HAS_FIXES" ]; then
    NEXT_VERSION="$MAJOR.$MINOR.$((PATCH + 1))"  # Patch bump
fi
# No Claude reasoning needed - deterministic logic

4. Template-Based Changelog Format

Pattern: Static Keep a Changelog template with bash variable substitution.

Token cost: 0 tokens (template is embedded in bash script)

cat > CHANGELOG.md.new << EOF
# Changelog

## [${version}] - $(date +%Y-%m-%d)

### Added
$(git log $RANGE --format='- %s' | grep '^- feat')

### Fixed
$(git log $RANGE --format='- %s' | grep '^- fix')
EOF
# Template expansion uses zero Claude tokens

5. Incremental Changelog Updates

Pattern: Only process new commits since last changelog entry.

Before (❌ Full regeneration):

1. Analyze entire git history → 5,000 tokens
2. Generate complete changelog → 3,000 tokens
Total: ~8,000 tokens (every time)

After (✅ Incremental):

# Only analyze commits since last tag (150 tokens)
LATEST_TAG=$(git describe --tags --abbrev=0)
COMMIT_RANGE="$LATEST_TAG..HEAD"
# Only count: $(git log $COMMIT_RANGE --oneline | wc -l) commits
# Savings: 95% when only 5-10 new commits vs 500+ historical

6. Early Exit Optimization

Pattern: Detect when no changelog generation is needed.

# Early exit check (50 tokens)
if [ $(git log $COMMIT_RANGE --oneline | wc -l) -eq 0 ]; then
    echo "✓ No new commits since last release"
    echo "Changelog is up to date"
    exit 0  # Save 2,500+ tokens from unnecessary generation
fi
# Saves 95% when no changes present

7. Version Detection from Package Files

Pattern: Use grep on package.json instead of full file read.

Before (❌ Full file read):

1. Read package.json (500 tokens)
2. Parse version with Claude (200 tokens)

After (✅ Targeted grep):

# Extract version with grep (20 tokens)
VERSION=$(grep '"version"' package.json | sed 's/.*"\([0-9.]*\)".*/\1/')
# 96% reduction

Caching Strategy

Cache Location

.claude/cache/changelog/
├── last-version.json              # Last generated version (indefinite TTL)
│   ├── version                    # v2.1.0
│   ├── commit_sha                 # abc123def
│   ├── commit_count               # 347
│   └── timestamp                  # 2026-01-27T10:00:00Z
└── commit-types.json              # Cached commit analysis (until new commits)
    ├── total_commits              # 347
    ├── features                   # 42
    ├── fixes                      # 28
    ├── breaking_changes           # 3
    ├── last_commit_sha            # abc123def
    └── cached_at                  # 2026-01-27T10:00:00Z

Cache Behavior

Cache validity:

  • Last version cache: Valid until new commits added
  • Commit type analysis: Valid until HEAD changes
  • Check: git rev-parse HEAD vs cached SHA (5 tokens)

Cache hit scenario:

# Check if changelog is current (100 tokens)
CACHED_SHA=$(cat .claude/cache/changelog/last-version.json | grep commit_sha)
CURRENT_SHA=$(git rev-parse HEAD)

if [ "$CACHED_SHA" = "$CURRENT_SHA" ]; then
    echo "✓ Changelog is up to date"
    exit 0  # Save 2,400 tokens
fi

Cache miss scenario:

# Generate changelog and update cache (400 tokens)
generate_changelog "$VERSION" "$COMMIT_RANGE"
echo "{\"version\": \"$VERSION\", \"commit_sha\": \"$(git rev-parse HEAD)\"}" > cache

Shared Caching

Shared with /release-automation skill:

  • Version information
  • Commit analysis
  • Breaking changes detection
  • Total shared savings: 30-40% across both skills

Progressive Generation Strategy

Approach: Generate version-by-version instead of entire changelog.

Implementation:

# Phase 1: Current version only (200 tokens)
generate_section "Added" "feat"
generate_section "Fixed" "fix"

# Phase 2: Previous versions (if requested)
if [ "$INCLUDE_HISTORY" = true ]; then
    for tag in $(git tag -l | tail -5); do
        generate_version_section "$tag"  # 150 tokens each
    done
fi
# Default: Only current version (saves 750+ tokens)

Context-Aware Optimizations

Session Integration

# Detect if in release workflow (zero additional tokens)
# Context: /session-current shows "preparing v2.1.0 release"
# Action: Focus on commits since last tag only
# Savings: Skip historical analysis (saves 1,500 tokens)

# Context: Recent /commit activity detected
# Action: Only analyze recent commits
# Savings: Incremental changelog update (saves 2,000 tokens)

Git State Awareness

# Check if tags exist (20 tokens)
if ! git describe --tags --abbrev=0 &>/dev/null; then
    echo "No tags found - this is initial release"
    COMMIT_RANGE="HEAD"  # Analyze all commits
else
    COMMIT_RANGE="$(git describe --tags --abbrev=0)..HEAD"  # Only new commits
fi
# Optimization: Auto-detect appropriate commit range

Usage Patterns for Maximum Efficiency

Most efficient (200-300 tokens):

/changelog-auto              # Auto-detect version, incremental update
/changelog-auto 2.1.0        # Specific version, only new commits

Moderate efficiency (400-600 tokens):

/changelog-auto --format=github    # Different format requires template
/changelog-auto --all              # Regenerate full changelog

Higher cost but necessary (800-1,000 tokens):

/changelog-auto --detailed         # Include commit bodies
/changelog-auto --no-cache         # Force fresh analysis

Optimization Flags

Available flags to control token usage:

  • --incremental: Only new commits (default, 200 tokens)
  • --all: Full history regeneration (800 tokens)
  • --no-cache: Bypass cache (600 tokens)
  • --dry-run: Preview without writing (150 tokens)
  • --format=<type>: Alternative formats (300-500 tokens)

Performance Metrics

Typical execution:

  • Small update (5-10 commits): 200-300 tokens
  • Medium update (20-50 commits): 300-500 tokens
  • Large update (100+ commits): 500-800 tokens
  • Full regeneration: 800-1,000 tokens

Comparison to unoptimized approach:

  • Unoptimized: 2,000-3,500 tokens (reading changed files)
  • Optimized: 400-1,000 tokens (git log only)
  • Average savings: 71%

Integration with Development Workflow

Optimized workflow sequence:

# 1. Pre-release preparation
/changelog-auto              # Generate changelog (300 tokens)
/session-update "Generated changelog for v2.1.0"

# 2. Review and commit
git add CHANGELOG.md
/commit                      # Commit changelog (200 tokens)

# 3. Tag and release
/release-automation          # Uses shared cache (500 tokens)

# Total workflow: ~1,000 tokens (vs 8,000+ unoptimized)
# Savings: 87% through cache sharing and git-native operations

Cache sharing benefits:

  • /changelog-auto caches version and commit analysis
  • /release-automation reuses cached data
  • /commit uses conventional commit patterns
  • Combined savings: 50-60% across release workflow

Best Practices for Token Efficiency

  1. Let skill auto-detect version - Avoids manual specification overhead
  2. Use incremental mode (default) - Only processes new commits
  3. Cache commit analysis - Reuse across release workflow
  4. Rely on git commands - Never read changed files
  5. Template-based formatting - Zero cost for structure
  6. Early exit when current - Detect up-to-date changelogs
  7. Share cache with release skills - Maximize reuse

Expected Token Ranges by Scenario

ScenarioTokensOptimization
No new commits (early exit)50-10095% savings
Small update (5-10 commits)200-30075% savings
Medium update (20-50 commits)300-50070% savings
Large update (100+ commits)500-80065% savings
Full regeneration800-1,00060% savings
Detailed format with bodies1,000-1,50050% savings

Average across typical usage: 400-1,000 tokens (71% reduction)

This optimization approach makes changelog generation fast, cost-effective, and seamlessly integrated into release workflows while maintaining professional quality and full semantic versioning compliance.

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Coding

sessions-init

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

cache-strategy

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

postman-convert

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

architecture-diagram

No summary provided by upstream source.

Repository SourceNeeds Review