Claudest commit
This skill should be used when the user says "commit my changes", "commit this", "create a commit", "git commit", "save my work", or mentions committing code.
git clone https://github.com/gupsammy/Claudest
T=$(mktemp -d) && git clone --depth=1 https://github.com/gupsammy/Claudest "$T" && mkdir -p ~/.claude/skills && cp -r "$T/plugins/claude-coding/skills/commit" ~/.claude/skills/gupsammy-claudest-commit && rm -rf "$T"
plugins/claude-coding/skills/commit/SKILL.mdCommit
Analyze uncommitted changes and create well-organized commits using conventional commit format.
Workflow
1. Discover Changes
Current repo state (injected at invocation — no tool calls needed):
- Status: !
git status --porcelain - Diff stats: !
git diff --stat
If no changes, report "Nothing to commit" and stop. If not in a git repository, report and stop.
2. Stage Files
Run
git add -A to stage all changes.
Exclude generated or ephemeral files that should never be version-controlled:
scratch.*, temp.*, debug.*, playground.*, *.log, dist/, build/, target/, node_modules/, __pycache__/.
If such files detected:
- Unstage with
git reset HEAD <file> - Ask user if they want to add to .gitignore
Proceed when all intended files are staged and ephemeral files are excluded.
3. Analyze Commit Boundaries
For each changed file, write a one-line PURPOSE description (not file location).
Group by PURPOSE, not directory:
- Same goal = one commit
- Different goals = separate commits
Each commit should represent one logical change because atomic commits enable
git bisect and git revert without side-effects.
Signs of separate concerns:
- "Added X" AND "Fixed Y" (feature + bugfix)
- Changes that could be reverted independently
If multiple concerns: use
git reset HEAD then git add <specific-files> for each group. Commit foundational changes first.
Handle renames (R status): When splitting, add BOTH old and new paths. Git detects renames by similarity scoring across the old/new pair — staging only the new path causes git to log a delete + add, losing rename history.
Proceed when every changed file is assigned to exactly one commit group.
4. Validate (if available)
Run the validation script after staging:
python3 ${CLAUDE_PLUGIN_ROOT}/skills/commit/scripts/validate.py . --output json
Interpret the result:
- Exit 0 → validation passed; proceed to Step 5
- Exit 1 → validation failed; parse the
field, report the error to the user, and stopoutput - Exit 2 → no validator found for this project; skip gracefully and proceed to Step 5
5. Create Commit
Check recent commit style:
git log --oneline -10
Use conventional commit format:
<type>(<scope>): <description>
Types: feat, fix, docs, refactor, test, chore, perf
Rules:
- Lowercase, no period, imperative mood
- Max 72 chars for subject
- NO Co-authored-by trailers, NO AI attribution — these pollute
and break downstream tooling that greps commit metadatagit log - NO emojis
Proceed when the commit message is drafted and matches the repo's existing style.
6. Push (only if requested)
If user mentions "push" or arguments contain "push", run
git push. If push fails, report the error and stop — do not retry or force-push.
Output
One line per commit (hash + message). If temporary files were excluded, list them as bullets below.