commit-changes
About
This skill helps developers stage, commit, and amend changes using conventional commit messages. It enables selective staging, descriptive message writing via HEREDOC format, and commit history verification. Use it to save logical work units or amend recent commits in a Git workflow.
Quick Install
Claude Code
Recommendednpx skills add pjt222/agent-almanac -a claude-code/plugin add https://github.com/pjt222/agent-almanacgit clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/commit-changesCopy and paste this command in Claude Code to install this skill
Documentation
Commit Changes
Stage files selectively, write clear commit messages, and verify commit history.
When to Use
- Saving a logical unit of work to version control
- Creating a commit with a descriptive, conventional message
- Amending the most recent commit (message or content)
- Reviewing what will be committed before committing
Inputs
- Required: One or more changed files to commit
- Optional: Commit message (will be drafted if not provided)
- Optional: Whether to amend the previous commit
- Optional: Co-author attribution
Procedure
Step 1: Review Current Changes
Check working tree status and inspect diffs:
# See which files are modified, staged, or untracked
git status
# See unstaged changes
git diff
# See staged changes
git diff --staged
Got: A clear picture of all modified, staged, and untracked files.
If fail: If git status fails, verify you are inside a git repository (git rev-parse --is-inside-work-tree).
Step 2: Stage Files Selectively
Stage specific files rather than using git add . or git add -A to avoid accidentally including sensitive files or unrelated changes:
# Stage specific files by name
git add src/feature.R tests/test-feature.R
# Stage all changes in a specific directory
git add src/
# Stage parts of a file interactively (not supported in non-interactive contexts)
# git add -p filename
Review what is staged before committing:
git diff --staged
Got: Only the intended files and changes are staged. No .env, credentials, or large binaries.
If fail: Unstage accidentally added files with git reset HEAD <file>. If sensitive data was staged, unstage before committing.
Step 3: Write a Commit Message
Use conventional commits format. Always pass the message via HEREDOC for proper formatting:
git commit -m "$(cat <<'EOF'
feat: add weighted mean calculation
Implements weighted_mean() with support for NA handling and
zero-weight filtering. Includes input validation for mismatched
vector lengths.
Co-Authored-By: Claude Opus 4.6 <[email protected]>
EOF
)"
Conventional commit types:
| Type | When to use |
|---|---|
feat | New feature |
fix | Bug fix |
docs | Documentation only |
test | Adding or updating tests |
refactor | Code change that neither fixes nor adds |
chore | Build, CI, dependency updates |
style | Formatting, whitespace (no logic change) |
Got: Commit created with a descriptive message that explains why, not what.
If fail: If a pre-commit hook fails, fix the issue, re-stage with git add, and create a new commit (do not use --amend since the failed commit was never created).
Step 4: Amend the Last Commit (Optional)
Only amend if the commit has not been pushed to a shared remote:
# Amend message only
git commit --amend -m "$(cat <<'EOF'
fix: correct weighted mean edge case for empty vectors
EOF
)"
# Amend with additional staged changes
git add forgotten-file.R
git commit --amend --no-edit
Got: The previous commit is updated in-place. git log -1 shows the amended content.
If fail: If the commit was already pushed, do not amend. Create a new commit instead. Force-pushing amended commits to shared branches causes history divergence.
Step 5: Verify the Commit
# View the last commit
git log -1 --stat
# View recent commit history
git log --oneline -5
# Verify the commit content
git show HEAD
Got: The commit appears in history with the correct message, author, and file changes.
If fail: If the commit contains wrong files, use git reset --soft HEAD~1 to undo the commit while keeping changes staged, then re-commit correctly.
Validation
- Only intended files are included in the commit
- No sensitive data (tokens, passwords,
.envfiles) committed - Commit message follows conventional commits format
- Message body explains why the change was made
-
git logshows the commit with correct metadata - Pre-commit hooks (if any) passed
Pitfalls
- Committing too much at once: Each commit should represent one logical change. Split unrelated changes into separate commits.
- Using
git add .blindly: Always reviewgit statusfirst. Prefer staging specific files by name. - Amending pushed commits: Never amend commits that have been pushed to a shared branch. This rewrites history and causes problems for collaborators.
- Vague commit messages: "fix bug" or "update" tells nothing. Describe what changed and why.
- Forgetting
--no-editon content amends: When adding forgotten files to the last commit, use--no-editto keep the existing message. - Hook failure leading to
--amend: When a pre-commit hook fails, the commit was never created. Using--amendwould modify the previous commit. Always create a new commit after fixing hook issues.
Related Skills
manage-git-branches- branch workflow before committingcreate-pull-request- next step after committingresolve-git-conflicts- handling conflicts during merge/rebaseconfigure-git-repository- repository setup and conventions
GitHub Repository
Related Skills
content-collections
MetaThis skill provides a production-tested setup for Content Collections, a TypeScript-first tool that transforms Markdown/MDX files into type-safe data collections with Zod validation. Use it when building blogs, documentation sites, or content-heavy Vite + React applications to ensure type safety and automatic content validation. It covers everything from Vite plugin configuration and MDX compilation to deployment optimization and schema validation.
polymarket
MetaThis skill enables developers to build applications with the Polymarket prediction markets platform, including API integration for trading and market data. It also provides real-time data streaming via WebSocket to monitor live trades and market activity. Use it for implementing trading strategies or creating tools that process live market updates.
creating-opencode-plugins
MetaThis skill helps developers create OpenCode plugins that hook into 25+ event types like commands, files, and LSP operations. It provides the plugin structure, event API specifications, and implementation patterns for JavaScript/TypeScript modules. Use it when you need to intercept, monitor, or extend the OpenCode AI assistant's lifecycle with custom event-driven logic.
sglang
MetaSGLang is a high-performance LLM serving framework that specializes in fast, structured generation for JSON, regex, and agentic workflows using its RadixAttention prefix caching. It delivers significantly faster inference, especially for tasks with repeated prefixes, making it ideal for complex, structured outputs and multi-turn conversations. Choose SGLang over alternatives like vLLM when you need constrained decoding or are building applications with extensive prefix sharing.
