/commit¶
infraMITCommit, PR, and Merge¶
Stage changes, verify quality gates, commit with a descriptive message, create a PR, and merge to main.
Steps¶
Step 0: Quality Gate (Pre-Commit)¶
Run before branching. For every changed .qmd, .tex, or .R file that has quality rubrics, run:
- If any file scores below 80, halt and report the findings. The user must either fix the issues or explicitly override with phrases like "commit anyway" or "skip quality gate".
- If all files score 80+, continue.
Spawn the verifier agent (via Task with subagent_type=verifier) to run compilation/render checks on the changed files. Report pass/fail before committing.
Step 0b: Surface-Sync Gate (Pre-Commit)¶
Runs unconditionally. Enforces that count claims ("14 agents, 28 skills, 24 rules, 6 hooks" and siblings) across README.md, CLAUDE.md, the guide source + rendered HTML, the landing page, and the skill template all agree with the on-disk counts of .claude/{skills,agents,rules,hooks}:
- Exit 0: all counts consistent — continue.
- Exit 1: drift detected — print the diff and halt. Fix the stale counts, then re-run. Do NOT proceed past this gate on drift, even with "commit anyway" — the purpose is to catch the exact class of issue that produced PRs #70, #76, and #78.
- Exit 2: script error (missing surface file, unreadable directory) — investigate before proceeding.
Step 1: Check current state¶
Step 2: Create a branch¶
Step 3: Stage files¶
Add specific files (never use git add -A):
Do NOT stage .claude/settings.local.json or any files containing secrets.
Step 4: Commit with a descriptive message¶
If $ARGUMENTS is provided, use it as the commit message. Otherwise, analyze the staged changes and write a message that explains why, not just what.
Step 5: Push and create PR¶
git push -u origin <branch-name>
gh pr create --title "<short title>" --body "$(cat <<'EOF'
### Summary
<1-3 bullet points>
### Test plan
<checklist>
🤖 Generated with [Claude Code](https://claude.com/claude-code)
EOF
)"
Step 6: Merge and clean up¶
Step 7: Report¶
Report the PR URL and what was merged.
Important¶
- Never skip Step 0. Quality gates catch broken compilation, bad citations, and hardcoded paths before they reach
main. If the user insists on skipping, record their override reason in the commit message. - Always create a NEW branch — never commit directly to main.
- Exclude
settings.local.jsonand sensitive files from staging. - Use
--merge(not--squashor--rebase) unless asked otherwise. - If the commit message from
$ARGUMENTSis provided, use it exactly.