name: groom
description: Groom a single GitHub issue — produce an implementation spec and optionally post the grooming summary as a GitHub comment. Standalone entry point for the grooming-agent.
argument-hint:
Groom
Standalone grooming for a single issue. Runs the full grooming analysis and writes the spec to disk. Posting to GitHub is your choice — you are prompted at the end.
Step 1 — Load config
Read project config from the orchestrator's ## Project Config block:
ORCHESTRATOR=".claude/skills/orchestrator/SKILL.md"
REPO=$(grep '^REPO=' "$ORCHESTRATOR" | cut -d= -f2)
TEMP_ROOT=$(grep '^TEMP_ROOT=' "$ORCHESTRATOR" | cut -d= -f2)
Step 2 — Sync the issue
Ensure the issue file exists at {TEMP_ROOT}/issues/<N>/issue.md. Run:
bash .claude/skills/issue-workflow/scripts/issue-sync.sh <N>
If the file already exists and is recent (less than 5 minutes old), skip the sync.
Step 3 — Invoke the grooming agent
Invoke the grooming-agent sub-agent with the following invocation context:
Issue number:
<N>Runtime values (do not read any config file — use these directly):
TEMP_ROOT={TEMP_ROOT}REPO={REPO}complexity_signal: derive from the issue content yourselfSTANDALONE MODE — two differences from the normal pipeline run:
- Skip Step 5 (posting to GitHub). Instead, include the full comment body you would have posted in a section titled
## Grooming Comment Draftat the end of your response. Use exactly the same format the pipeline would post (including the<!-- ai-pipeline:grooming-plan -->marker), so it is ready to post as-is.- Skip Step 6 (StructuredOutput JSON). Return a short human-readable summary instead: effort, risk, complexity, and any open questions.
The spec file is still written to {TEMP_ROOT}/issues/<N>/spec.md as normal.
Step 4 — Offer to post
After the agent responds, display its ## Grooming Comment Draft to the user, then ask:
Post this as a comment on issue #<N>? Reply
yesto post as-is,noto finish without posting, or paste edited text to post a modified version.
If yes — check for an existing grooming comment first (dedup):
EXISTING_ID=$(gh api repos/{REPO}/issues/<N>/comments \
--jq '[.[] | select(.body | contains("<!-- ai-pipeline:grooming-plan -->"))] | last | .id // empty')
Update with PATCH if found, otherwise post a new comment.
If no — confirm the spec was written to {TEMP_ROOT}/issues/<N>/spec.md and finish.
If edited — use the user-provided text as the comment body and post.