From agent-almanac
Stages files selectively, commits and amends with conventional messages using HEREDOC, reviews diffs and status. Use for precise git commits in version control workflows.
npx claudepluginhub pjt222/agent-almanacThis skill uses the workspace's default tool permissions.
---
Manages Git commit workflow using Conventional Commits format with safety protocols. Creates, validates, executes commits; handles hooks, PRs, and safety checks before operations.
Stages and commits git changes atomically with conventional messages. Analyzes status and diffs, groups into logical units (structural, behavioral, docs, config) without modifying code.
Stages intended Git changes, avoiding secrets, and commits with clear Conventional Commit messages. Use when work is ready and diff is understood.
Share bugs, ideas, or general feedback.
Stage files selectively, write clear commit messages, and verify commit history.
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
Expected: Clear picture of all modified, staged, and untracked files.
On failure: If git status fails, verify you are inside a git repository (git rev-parse --is-inside-work-tree).
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
Expected: Only the intended files and changes are staged. No .env, credentials, or large binaries.
On failure: Unstage accidentally added files with git reset HEAD <file>. If sensitive data was staged, unstage immediately before committing.
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 <noreply@anthropic.com>
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) |
Expected: Commit created with a descriptive message that explains why, not just what.
On failure: 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).
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
Expected: The previous commit is updated in-place. git log -1 shows the amended content.
On failure: If the commit was already pushed, do not amend. Create a new commit instead. Force-pushing amended commits to shared branches causes history divergence.
# View the last commit
git log -1 --stat
# View recent commit history
git log --oneline -5
# Verify the commit content
git show HEAD
Expected: The commit appears in history with the correct message, author, and file changes.
On failure: If the commit contains wrong files, use git reset --soft HEAD~1 to undo the commit while keeping changes staged, then re-commit correctly.
.env files) committedgit log shows the commit with correct metadatagit add . blindly: Always review git status first. Prefer staging specific files by name.--no-edit on content amends: When adding forgotten files to the last commit, use --no-edit to keep the existing message.--amend: When a pre-commit hook fails, the commit was never created. Using --amend would modify the previous commit. Always create a new commit after fixing hook issues.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