name: commit description: Use when creating Git commits to ensure they follow the Conventional Commits specification. Provides guidance on commit message structure, types, scopes, and best practices for clear, consistent commit messages.
Commit
This skill provides guidance for writing Git commits that follow the Conventional Commits specification (v1.0.0).
Purpose
Conventional Commits is a specification for adding human and machine-readable meaning to commit messages. It provides an easy set of rules for creating an explicit commit history.
When to Use This Skill
Use this skill when:
- Creating Git commits
- Reviewing commit messages in PRs
- Writing clear, structured commit messages
Commit Message Structure
Basic Format
<type>[optional scope]: <description>
[optional body]
[optional footer(s)]
Examples
feat: add user authentication
feat(api): add JWT token generation
fix: resolve memory leak in image processor
docs: update README with setup instructions
refactor(database): optimize user query performance
Commit Types
Primary Types
feat - A new feature for the user
feat: add export to PDF functionality
feat(api): add webhook signature verification
fix - A bug fix for the user
fix: resolve login redirect loop
fix(api): handle null response from webhook
docs - Documentation only changes
docs: update API endpoint documentation
docs(readme): add troubleshooting section
style - Changes that don't affect code meaning (formatting, whitespace)
style: format code with gofmt
style: update indentation
refactor - Code change that neither fixes a bug nor adds a feature
refactor: extract user validation to service
refactor(models): simplify tenant scoping logic
perf - Performance improvements
perf: add database index for user lookups
perf(queries): reduce N+1 queries
test - Adding or updating tests
test: add tests for user authentication
test(integration): add webhook processing tests
chore - Changes to build process, dependencies, or maintenance
chore: update Go to 1.23.5
chore(deps): bump dependency version
Additional Types
build - Changes to build system or dependencies
build: configure Docker for production
build(task): update build configuration
ci - Changes to CI configuration
ci: add security scanning to workflow
ci(tests): run tests in parallel
revert - Reverts a previous commit
revert: revert "feat: add export feature"
This reverts commit abc123.
Scope (Optional)
While not necessary this is strongly preferred. Scope provides additional context about what part of the codebase changed:
feat(auth): add two-factor authentication
fix(api): handle rate limit errors
docs(contributing): update PR guidelines
refactor(services): extract common validation logic
Common scope examples:
-
auth- Authentication/authorization -
api- API endpoints -
cli- CLI commands -
config- Configuration changes -
deps- Dependencies -
docs- Documentation -
tests- Test suite
Choose scopes that match your project's architecture and domain areas.
Description
The description is a short summary of the code change:
Rules:
- Use imperative, present tense: "add" not "added" or "adds"
- Don't capitalize first letter
- No period (.) at the end
- Keep under 72 characters (ideally under 50)
Good descriptions:
add user profile page
fix memory leak in file upload
update email templates for notifications
remove deprecated API endpoint
Bad descriptions:
Added user profile page # Past tense
Fix Memory Leak In File Upload # Capitalized
Updated email templates. # Period at end
Lots of changes to the codebase # Vague
Body (Optional)
The body provides additional context about the change:
When to include a body:
- Complex changes needing explanation
- Non-obvious design decisions
- Breaking changes
- Migration instructions
Format:
- Separate from description with blank line
- Use imperative mood like description
- Wrap at 72 characters
- Can include multiple paragraphs
Example:
feat(api): add webhook signature verification
Add HMAC-SHA256 signature verification for all incoming webhooks
to prevent unauthorized access and replay attacks.
The signature is validated using a secret key stored per
installation. Requests with invalid signatures are rejected
with a 401 response.
Footer (Optional)
Footers provide metadata about the commit:
Breaking Changes
Use BREAKING CHANGE: footer for incompatible API changes:
feat(api): change authentication endpoint
BREAKING CHANGE: The /auth endpoint now requires a client_id parameter.
Update all API clients to include client_id in authentication requests.
Or use ! after type/scope:
feat!: change authentication endpoint
feat(api)!: remove deprecated /login endpoint
Issue References
Reference issues and pull requests:
fix(auth): resolve session timeout bug
Fixes #123
Closes #456
Related to #789
Common reference types:
-
Fixes #123- Closes the issue -
Closes #123- Closes the issue -
Resolves #123- Closes the issue -
Related to #123- References without closing
Complete Examples
Simple Feature
feat: add password reset functionality
Feature with Scope
feat(api): add rate limiting for endpoints
Bug Fix with Body
fix(api): handle rate limit errors
When external API returns 429 status, retry the request
with exponential backoff up to 3 attempts before failing.
Fixes #234
Breaking Change
feat(api)!: redesign webhook payload structure
BREAKING CHANGE: Webhook payloads now use a nested structure.
Before:
{
"event": "issue.created",
"data": {...}
}
After:
{
"type": "issue",
"action": "created",
"payload": {...}
}
Clients must update their webhook handlers to use the new structure.
Refactoring
refactor(services): extract validation to helper
Move common validation logic from multiple services into
a shared helper. No behavior changes.
Best Practices
Do:
- Make commit messages short and concise
- Use present tense imperative mood ("add" not "added")
- Keep first line under 50 characters when possible
- Reference issues/PRs in footer
- Explain "why" in body, not "what" (code shows what)
- Break up large changes into multiple commits
- Make commits atomic (one logical change per commit)
Don't:
- Use vague descriptions ("fix stuff", "updates")
- Combine multiple unrelated changes in one commit
- Capitalize first letter of description
- End description with period
- Use past tense ("added", "fixed")
- Commit broken code (each commit should work)
Summary
Conventional Commits provide:
- Clear, consistent commit history
- Better collaboration through explicit intent
- Easier code review and git history navigation
- Improved project documentation through structured messages
Key formula:
<type>(<scope>): <description>
[body]
[footer]
chat Comments (0)
Sign in to join the discussion and leave a comment.
Skill Details
Related Skills
Build your own?
Join 12,000+ developers contributing to the Claude ecosystem.
No comments yet. Be the first to share your thoughts!