commit-message-crafter

Commit Message Crafter

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 "commit-message-crafter" with this command: npx skills add latestaiagents/agent-skills/latestaiagents-agent-skills-commit-message-crafter

Commit Message Crafter

Write clear, consistent, and meaningful commit messages.

When to Use

  • Writing a commit message for staged changes

  • Following conventional commits format

  • Standardizing commit messages across a team

  • Writing messages for squash commits or PRs

The Conventional Commits Format

<type>(<scope>): <subject>

<body>

<footer>

Types

Type When to Use

feat

New feature for the user

fix

Bug fix for the user

docs

Documentation only changes

style

Formatting, missing semicolons, etc. (no code change)

refactor

Code change that neither fixes a bug nor adds a feature

perf

Performance improvement

test

Adding or fixing tests

chore

Maintenance tasks, dependencies, build changes

ci

CI/CD configuration changes

revert

Reverting a previous commit

Scope (Optional)

The part of the codebase affected:

  • auth , api , ui , db , config , deps , etc.

Subject Rules

  • Use imperative mood: "Add feature" not "Added feature"

  • Don't capitalize first letter

  • No period at the end

  • Max 50 characters (72 absolute max)

  • Complete the sentence: "This commit will..."

Examples

Simple Feature

feat(auth): add password reset functionality

Bug Fix with Body

fix(api): handle null response from payment gateway

The payment gateway occasionally returns null instead of an error object when the service is degraded. This caused uncaught exceptions in the checkout flow.

Fixes #1234

Breaking Change

feat(api)!: change user endpoint response format

BREAKING CHANGE: The /api/users endpoint now returns paginated results. Clients must update to handle the new response structure: { data: [], meta: { page, total } }

Refactoring

refactor(utils): extract date formatting into separate module

Moved date formatting logic from multiple components into a centralized dateUtils module for better maintainability.

Multiple Changes (Squash Commit)

feat(dashboard): redesign analytics widgets

  • Add new chart component for user growth
  • Implement date range picker
  • Add export to CSV functionality
  • Update color scheme to match brand guidelines

Co-authored-by: Jane Doe <jane@example.com>

Workflow

Step 1: Analyze Changes

See what's staged

git diff --staged

See files changed

git diff --staged --name-only

Step 2: Determine Type

Ask: What is the PRIMARY purpose of these changes?

  • Adding something new? → feat

  • Fixing broken behavior? → fix

  • Improving without changing behavior? → refactor

Step 3: Identify Scope

Look at the files changed. What's the common area?

  • All in /src/auth/ ? → scope is auth

  • Mixed areas? → omit scope or use broader term

Step 4: Write Subject

Complete this sentence with your changes: "If applied, this commit will _______________"

Good: "add user avatar upload" Bad: "added user avatar upload functionality to the system"

Step 5: Add Body (If Needed)

Include body when:

  • The "why" isn't obvious from the subject

  • There are multiple related changes

  • Breaking changes need explanation

  • Linking to issues/tickets

Step 6: Add Footer (If Needed)

Fixes #123 Closes #456 BREAKING CHANGE: description Co-authored-by: Name <email>

Quick Templates

Feature

feat(<scope>): <what you added>

<why you added it, if not obvious>

Relates to #<issue>

Bug Fix

fix(<scope>): <what you fixed>

<what was broken and why>

Fixes #<issue>

Dependency Update

chore(deps): update <package> to <version>

<any breaking changes or notes>

Common Mistakes to Avoid

  • Vague messages: "fix bug", "update code", "changes"

  • Too long: Keep subject under 50 chars

  • Wrong tense: "Added" instead of "Add"

  • Multiple unrelated changes: Split into separate commits

  • No context: Just "fix" without explaining what or why

Team Conventions

Consider documenting your team's conventions:

Commit Message Convention

  • Use conventional commits format
  • Scope is required for features and fixes
  • Reference issue numbers in footer
  • Breaking changes must include BREAKING CHANGE footer

Tools

Set up commit template

git config --global commit.template ~/.gitmessage

Use commitizen for interactive commits

npx cz

Validate commits with commitlint

npm install -D @commitlint/{cli,config-conventional}

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.

Automation

graphrag-patterns

No summary provided by upstream source.

Repository SourceNeeds Review
Automation

agentic-rag

No summary provided by upstream source.

Repository SourceNeeds Review
Automation

production-rag-checklist

No summary provided by upstream source.

Repository SourceNeeds Review
Automation

rag-evaluation

No summary provided by upstream source.

Repository SourceNeeds Review