AgentSkillsCN

commit

按照 Conventional Commits 格式撰写结构清晰的提交信息。当您提交代码更改、编写提交信息,或整理 Git 历史时,可使用此技能。

SKILL.md
--- frontmatter
name: commit
description: Create well-structured commit messages following Conventional Commits format. Use when committing code changes, writing commit messages, or formatting git history.

Commit Messages

Follow these conventions when creating commits.

Prerequisites

Before committing, ensure you're working on a feature branch, not the master branch.

bash
# Check current branch
git branch --show-current

If you're on master, create a new branch first:

bash
# Create and switch to a new branch
git checkout -b <type>/<brief-description>

Branch Naming

Branch names follow the pattern:

code
{type}/{brief-description}

For work tied to a feature epic, include the feature ID:

code
{type}/{feature-id}-{brief-description}

Examples:

  • feat/add-user-auth - Adding authentication
  • feat/FT050-workflow-automation - Feature epic work
  • fix/resolve-link-validation - Bug fix
  • docs/workflow-guide - Documentation
  • chore/update-ruby-version - Dependencies

Commit Format

code
<type>: <summary>

<body>

<footer>

The summary is required. Body and footer are optional but helpful when context is needed.

Commit Types

TypePurpose
featNew feature
fixBug fix
docsDocumentation only
styleCode formatting (no logic change)
refactorCode restructuring (no behavior change)
testAdding or modifying tests
choreBuild tools, dependencies, configs

Summary Rules

  • Under 50 characters - Get to the point
  • Imperative mood - "Add feature" not "Added feature"
  • Capitalize first word - "Add feature" not "add feature"
  • No period at end - Save the character

Body Guidelines

Use the body to explain why, not how. The code shows how; the commit explains why.

  • Use imperative mood and present tense
  • Wrap lines at 72 characters
  • Include motivation for the change
  • Contrast with previous behavior when relevant

Examples

Simple change (no body needed)

code
docs: fix typo in workflow guide

Feature with context

code
feat: add link archival endpoint

Implement POST /api/v1/links/:id/archive endpoint to allow
marking links as archived without deletion. Includes validation
and database migration.

Bug fix

code
fix: resolve popup not opening on Firefox

The popup.html failed to load on Firefox due to CSP issues.
Updated manifest.json with proper permissions.

Dependency update

code
chore: update Docker base image to Ruby 3.4.2

Bump base image for security patches and performance improvements.

Refactor

code
refactor: extract link validation to service

Move duplicate validation code from three endpoints into a shared
validator class. No behavior change.

Test addition

code
test: add archival endpoint tests

Commit Frequency

Commit after completing logical chunks of work. Each commit should be a checkpoint—a coherent piece of work that makes sense on its own.

bash
git commit -m "feat: add archival endpoint skeleton"
git commit -m "feat: add archival validation logic"
git commit -m "test: add archival endpoint tests"
git commit -m "docs: document archival API endpoint"

Small, focused commits are easier to review and easier to revert if needed.

Squash Merge Note

We use squash merges for all PRs. Your individual commits get combined into a single, clean commit when merged to master. This means:

  • Don't stress over "fix typo" commits during development
  • The final squash commit message gets polished at merge time
  • Master history shows one commit per PR

Issue References

If your project uses issue tracking (GitHub Issues, Jira, Linear, etc.), reference issue IDs in PR titles or branch names, not commit messages. This enables automatic linking and status updates.

Branch: feat/GH-128-add-user-auth PR title: feat: add user authentication #128

Principles

  • Each commit should be a single, coherent change
  • Commits should be independently understandable
  • Focus on why the change was made, not what changed

References