Agent-alchemy git-commit
Commit staged changes with conventional commit message. Use when user says "commit changes", "commit this", "save my changes", or wants to create a git commit.
install
source · Clone the upstream repo
git clone https://github.com/sequenzia/agent-alchemy
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/sequenzia/agent-alchemy "$T" && mkdir -p ~/.claude/skills && cp -r "$T/ported/20260310/all/skills/git-commit" ~/.claude/skills/sequenzia-agent-alchemy-git-commit-fd5521 && rm -rf "$T"
manifest:
ported/20260310/all/skills/git-commit/SKILL.mdsource content
Git Commit
Create a commit with a conventional commit message based on staged changes. Automatically stages all changes and analyzes the diff to generate an appropriate commit message.
Workflow
Execute these steps in order.
Step 1: Check Repository State
Check for changes to commit:
git status --porcelain
- If output is empty, report: "Nothing to commit. Working directory is clean." and stop.
- If changes exist, continue to Step 2.
Step 2: Stage All Changes
Run:
git add .
Report: "Staged all changes."
Step 3: Analyze Changes
View the staged diff to understand what changed:
git diff --cached --stat
git diff --cached
Analyze the diff to determine:
- The type of change (feat, fix, docs, refactor, etc.)
- The scope (optional, based on affected files/modules)
- A concise description of what changed
Step 4: Construct Commit Message
Build a conventional commit message following this format:
<type>(<optional-scope>): <description> [optional body]
Types:
- New featurefeat
- Bug fixfix
- Documentation onlydocs
- Formatting, no code changestyle
- Code restructuring without behavior changerefactor
- Adding or updating teststest
- Maintenance taskschore
- Build system or dependenciesbuild
- CI configurationci
- Performance improvementperf
Rules:
- Use imperative mood ("add" not "added")
- Use lowercase
- No trailing period
- Keep description under 72 characters
- Add a body only for complex changes or breaking changes
- Do NOT add co-author, attribution, or "Generated with" lines
Step 5: Create Commit
Run:
git commit -m "$(cat <<'EOF' <commit message here> EOF )"
Step 6: Handle Result
On success:
- Report the commit hash: "Committed: {short_hash} - {message}"
On pre-commit hook failure:
- Report: "Pre-commit hook failed. The commit was NOT created."
- Explain what the hook reported
- Instruct: "Fix the issues above and run the commit command again. Do NOT use --amend as that would modify the previous commit."
Error Recovery
If the commit fails:
- Hook failure: Fix the reported issues, then stage and commit again (do NOT amend)
- Unstage changes:
to unstage without losing changesgit reset HEAD
Notes
- This command stages ALL changes including untracked files
- Pre-commit hooks run automatically; their failures mean no commit was created
- Always create a NEW commit after hook failure, never amend the previous commit
Integration Notes
Required Capabilities
| Capability | Purpose |
|---|---|
| Shell execution | Run git commands (, , , , ) |
| User interaction | Display commit results, report errors, provide recovery instructions |
External Dependencies
- git CLI must be available on the system PATH
- Repository must be initialized (
or cloned)git init
Platform Considerations
- The heredoc syntax for commit messages (
) assumes a POSIX-compatible shell (bash, zsh, sh)cat <<'EOF' - Pre-commit hooks are repository-specific; behavior varies by project configuration