이슈를 5개 state role(needs-triage / needs-info / ready-for-agent / ready-for-human / wontfix)과 2개 category role(bug / enhancement)의 state machine으로 이동시키는 스킬. AI 댓글에는 disclaimer 필수.
작성자
mattpocock
라이선스
mattpocock/skills 참조
트리거
triage / 이슈 분류 / review incoming bugs / prepare for AFK agent / 이슈 워크플로우 관리
Apply outcome — agent brief / triage notes / out-of-scope 기록 + close 등.
Needs-info 템플릿
## Triage Notes**What we've established so far:**- point 1**What we still need from you (@reporter):**- specific actionable question 1
원문 SKILL.md (전문)
---name: triagedescription: Triage issues through a state machine driven by triage roles. Use when user wants to create an issue, triage issues, review incoming bugs or feature requests, prepare issues for an AFK agent, or manage issue workflow.---# TriageMove issues on the project issue tracker through a small state machine of triage roles.Every comment or issue posted to the issue tracker during triage **must** start with this disclaimer:```> *This was generated by AI during triage.*```## Reference docs- [AGENT-BRIEF.md](AGENT-BRIEF.md) — how to write durable agent briefs- [OUT-OF-SCOPE.md](OUT-OF-SCOPE.md) — how the `.out-of-scope/` knowledge base works## RolesTwo **category** roles:- `bug` — something is broken- `enhancement` — new feature or improvementFive **state** roles:- `needs-triage` — maintainer needs to evaluate- `needs-info` — waiting on reporter for more information- `ready-for-agent` — fully specified, ready for an AFK agent- `ready-for-human` — needs human implementation- `wontfix` — will not be actionedEvery triaged issue should carry exactly one category role and one state role. If state roles conflict, flag it and ask the maintainer before doing anything else.These are canonical role names — the actual label strings used in the issue tracker may differ. The mapping should have been provided to you - run `/setup-matt-pocock-skills` if not.State transitions: an unlabeled issue normally goes to `needs-triage` first; from there it moves to `needs-info`, `ready-for-agent`, `ready-for-human`, or `wontfix`. `needs-info` returns to `needs-triage` once the reporter replies. The maintainer can override at any time — flag transitions that look unusual and ask before proceeding.## InvocationThe maintainer invokes `/triage` and describes what they want in natural language. Interpret the request and act. Examples:- "Show me anything that needs my attention"- "Let's look at #42"- "Move #42 to ready-for-agent"- "What's ready for agents to pick up?"## Show what needs attentionQuery the issue tracker and present three buckets, oldest first:1. **Unlabeled** — never triaged.2. **`needs-triage`** — evaluation in progress.3. **`needs-info` with reporter activity since the last triage notes** — needs re-evaluation.Show counts and a one-line summary per issue. Let the maintainer pick.## Triage a specific issue1. **Gather context.** Read the full issue (body, comments, labels, reporter, dates). Parse any prior triage notes so you don't re-ask resolved questions. Explore the codebase using the project's domain glossary, respecting ADRs in the area. Read `.out-of-scope/*.md` and surface any prior rejection that resembles this issue.2. **Recommend.** Tell the maintainer your category and state recommendation with reasoning, plus a brief codebase summary relevant to the issue. Wait for direction.3. **Reproduce (bugs only).** Before any grilling, attempt reproduction: read the reporter's steps, trace the relevant code, run tests or commands. Report what happened — successful repro with code path, failed repro, or insufficient detail (a strong `needs-info` signal). A confirmed repro makes a much stronger agent brief.4. **Grill (if needed).** If the issue needs fleshing out, run a `/grill-with-docs` session.5. **Apply the outcome:** - `ready-for-agent` — post an agent brief comment ([AGENT-BRIEF.md](AGENT-BRIEF.md)). - `ready-for-human` — same structure as an agent brief, but note why it can't be delegated (judgment calls, external access, design decisions, manual testing). - `needs-info` — post triage notes (template below). - `wontfix` (bug) — polite explanation, then close. - `wontfix` (enhancement) — write to `.out-of-scope/`, link to it from a comment, then close ([OUT-OF-SCOPE.md](OUT-OF-SCOPE.md)). - `needs-triage` — apply the role. Optional comment if there's partial progress.## Quick state overrideIf the maintainer says "move #42 to ready-for-agent", trust them and apply the role directly. Confirm what you're about to do (role changes, comment, close), then act. Skip grilling. If moving to `ready-for-agent` without a grilling session, ask whether they want to write an agent brief.## Needs-info template```markdown## Triage Notes**What we've established so far:**- point 1- point 2**What we still need from you (@reporter):**- question 1- question 2```Capture everything resolved during grilling under "established so far" so the work isn't lost. Questions must be specific and actionable, not "please provide more info".## Resuming a previous sessionIf prior triage notes exist on the issue, read them, check whether the reporter has answered any outstanding questions, and present an updated picture before continuing. Don't re-ask resolved questions.
## 한 줄
이슈 트래커에 올린 모든 댓글·이슈는 **첫 줄에 disclaimer** 필수:
```
> *This was generated by AI during triage.*
```
`setup-matt-pocock-skills` 가 라벨 매핑을 제공해야 함.
## Role 매트릭스
| 종류 | Role |
|---|---|
| Category (1개 필수) | `bug`, `enhancement` |
| State (1개 필수) | `needs-triage`, `needs-info`, `ready-for-agent`, `ready-for-human`, `wontfix` |
State 전이: unlabeled → `needs-triage` → (`needs-info` / `ready-for-agent` / `ready-for-human` / `wontfix`). `needs-info` 는 reporter 응답 시 `needs-triage`로 복귀. unusual 전이는 maintainer에게 flag.
## 호출 방법
자연어 — "지금 봐야 하는 것 보여줘", "#42 보자", "#42를 ready-for-agent로", "AFK가 집을 수 있는 게 뭐 있어".
## 특정 이슈 triage 절차
1. **Context** — body, 댓글, label, reporter, 날짜 전부. 기존 triage notes 파싱(resolved 질문 재질문 금지). 도메인 glossary로 코드 explore, `.out-of-scope/*.md`에서 유사 prior rejection 찾기.
2. **Recommend** — category + state 추천 + reasoning + 짧은 코드 요약. maintainer direction 대기.
3. **Reproduce (bug only)** — grilling 전에 재현 시도. 결과 보고: success + code path / failed / insufficient detail (강한 `needs-info` 신호).
4. **Grill (필요시)** — `/grill-with-docs` 세션.
5. **Apply outcome** — agent brief / triage notes / out-of-scope 기록 + close 등.
## Needs-info 템플릿
```markdown
## Triage Notes
**What we've established so far:**
- point 1
**What we still need from you (@reporter):**
- specific actionable question 1
```
## 원문 SKILL.md (전문)
````markdown
---
name: triage
description: Triage issues through a state machine driven by triage roles. Use when user wants to create an issue, triage issues, review incoming bugs or feature requests, prepare issues for an AFK agent, or manage issue workflow.
---
# Triage
Move issues on the project issue tracker through a small state machine of triage roles.
Every comment or issue posted to the issue tracker during triage **must** start with this disclaimer:
```
> *This was generated by AI during triage.*
```
## Reference docs
- [AGENT-BRIEF.md](AGENT-BRIEF.md) — how to write durable agent briefs
- [OUT-OF-SCOPE.md](OUT-OF-SCOPE.md) — how the `.out-of-scope/` knowledge base works
## Roles
Two **category** roles:
- `bug` — something is broken
- `enhancement` — new feature or improvement
Five **state** roles:
- `needs-triage` — maintainer needs to evaluate
- `needs-info` — waiting on reporter for more information
- `ready-for-agent` — fully specified, ready for an AFK agent
- `ready-for-human` — needs human implementation
- `wontfix` — will not be actioned
Every triaged issue should carry exactly one category role and one state role. If state roles conflict, flag it and ask the maintainer before doing anything else.
These are canonical role names — the actual label strings used in the issue tracker may differ. The mapping should have been provided to you - run `/setup-matt-pocock-skills` if not.
State transitions: an unlabeled issue normally goes to `needs-triage` first; from there it moves to `needs-info`, `ready-for-agent`, `ready-for-human`, or `wontfix`. `needs-info` returns to `needs-triage` once the reporter replies. The maintainer can override at any time — flag transitions that look unusual and ask before proceeding.
## Invocation
The maintainer invokes `/triage` and describes what they want in natural language. Interpret the request and act. Examples:
- "Show me anything that needs my attention"
- "Let's look at #42"
- "Move #42 to ready-for-agent"
- "What's ready for agents to pick up?"
## Show what needs attention
Query the issue tracker and present three buckets, oldest first:
1. **Unlabeled** — never triaged.
2. **`needs-triage`** — evaluation in progress.
3. **`needs-info` with reporter activity since the last triage notes** — needs re-evaluation.
Show counts and a one-line summary per issue. Let the maintainer pick.
## Triage a specific issue
1. **Gather context.** Read the full issue (body, comments, labels, reporter, dates). Parse any prior triage notes so you don't re-ask resolved questions. Explore the codebase using the project's domain glossary, respecting ADRs in the area. Read `.out-of-scope/*.md` and surface any prior rejection that resembles this issue.
2. **Recommend.** Tell the maintainer your category and state recommendation with reasoning, plus a brief codebase summary relevant to the issue. Wait for direction.
3. **Reproduce (bugs only).** Before any grilling, attempt reproduction: read the reporter's steps, trace the relevant code, run tests or commands. Report what happened — successful repro with code path, failed repro, or insufficient detail (a strong `needs-info` signal). A confirmed repro makes a much stronger agent brief.
4. **Grill (if needed).** If the issue needs fleshing out, run a `/grill-with-docs` session.
5. **Apply the outcome:**
- `ready-for-agent` — post an agent brief comment ([AGENT-BRIEF.md](AGENT-BRIEF.md)).
- `ready-for-human` — same structure as an agent brief, but note why it can't be delegated (judgment calls, external access, design decisions, manual testing).
- `needs-info` — post triage notes (template below).
- `wontfix` (bug) — polite explanation, then close.
- `wontfix` (enhancement) — write to `.out-of-scope/`, link to it from a comment, then close ([OUT-OF-SCOPE.md](OUT-OF-SCOPE.md)).
- `needs-triage` — apply the role. Optional comment if there's partial progress.
## Quick state override
If the maintainer says "move #42 to ready-for-agent", trust them and apply the role directly. Confirm what you're about to do (role changes, comment, close), then act. Skip grilling. If moving to `ready-for-agent` without a grilling session, ask whether they want to write an agent brief.
## Needs-info template
```markdown
## Triage Notes
**What we've established so far:**
- point 1
- point 2
**What we still need from you (@reporter):**
- question 1
- question 2
```
Capture everything resolved during grilling under "established so far" so the work isn't lost. Questions must be specific and actionable, not "please provide more info".
## Resuming a previous session
If prior triage notes exist on the issue, read them, check whether the reporter has answered any outstanding questions, and present an updated picture before continuing. Don't re-ask resolved questions.
````