pc prompt-collection

grill-with-docs

원본 보기

grill-me의 강화판 — 계획을 인터뷰하면서 동시에 CONTEXT.md(도메인 용어집)와 docs/adr/(아키텍처 결정)를 인라인으로 업데이트. fuzzy 용어를 sharpen하고, 코드와 대조하고, hard-to-reverse 결정만 ADR로 남긴다.

작성자
mattpocock
라이선스
mattpocock/skills 참조
트리거
계획 검토 + 도메인 용어 / grill against docs / stress-test plan against project language / 도메인 인터뷰
#skill#interview#design-review#ddd#context#adr#mattpocock

한 줄

grill-me + 도메인 인지 — 인터뷰 중 사용자가 쓴 단어가 CONTEXT.md 정의와 충돌하면 즉시 challenge하고, 합의된 용어는 그 자리에서 CONTEXT.md에 적는다.

언제 쓰는가

  • 새 기능을 implementation 전에 도메인 언어와 정렬
  • 모호한/overloaded 용어 sharpen (“account”는 Customer인가 User인가?)
  • 사용자가 말한 동작과 코드 동작의 contradiction 발견

파일 구조 가정

  • 단일 컨텍스트: 루트의 CONTEXT.md + docs/adr/
  • 멀티 컨텍스트: 루트의 CONTEXT-MAP.md가 각 컨텍스트의 CONTEXT.md 위치를 가리킴

파일은 lazy 생성 — 첫 용어가 resolve될 때 CONTEXT.md를 만든다.

함정

  • CONTEXT.md에 구현 디테일을 넣지 말 것. spec도, scratch pad도 아니다. glossary일 뿐.
  • ADR은 3가지 조건이 모두 충족될 때만: hard to reverse + surprising without context + 진짜 trade-off. 하나라도 빠지면 skip.
  • 용어 업데이트는 batch하지 말고 그때그때 — 발견 즉시 캡처.

원문 SKILL.md (전문)

---
name: grill-with-docs
description: Grilling session that challenges your plan against the existing domain model, sharpens terminology, and updates documentation (CONTEXT.md, ADRs) inline as decisions crystallise. Use when user wants to stress-test a plan against their project's language and documented decisions.
---

<what-to-do>

Interview me relentlessly about every aspect of this plan until we reach a shared understanding. Walk down each branch of the design tree, resolving dependencies between decisions one-by-one. For each question, provide your recommended answer.

Ask the questions one at a time, waiting for feedback on each question before continuing.

If a question can be answered by exploring the codebase, explore the codebase instead.

</what-to-do>

<supporting-info>

## Domain awareness

During codebase exploration, also look for existing documentation:

### File structure

Most repos have a single context:

```
/
├── CONTEXT.md
├── docs/
│   └── adr/
│       ├── 0001-event-sourced-orders.md
│       └── 0002-postgres-for-write-model.md
└── src/
```

If a `CONTEXT-MAP.md` exists at the root, the repo has multiple contexts. The map points to where each one lives:

```
/
├── CONTEXT-MAP.md
├── docs/
│   └── adr/                          ← system-wide decisions
├── src/
│   ├── ordering/
│   │   ├── CONTEXT.md
│   │   └── docs/adr/                 ← context-specific decisions
│   └── billing/
│       ├── CONTEXT.md
│       └── docs/adr/
```

Create files lazily — only when you have something to write. If no `CONTEXT.md` exists, create one when the first term is resolved. If no `docs/adr/` exists, create it when the first ADR is needed.

## During the session

### Challenge against the glossary

When the user uses a term that conflicts with the existing language in `CONTEXT.md`, call it out immediately. "Your glossary defines 'cancellation' as X, but you seem to mean Y — which is it?"

### Sharpen fuzzy language

When the user uses vague or overloaded terms, propose a precise canonical term. "You're saying 'account' — do you mean the Customer or the User? Those are different things."

### Discuss concrete scenarios

When domain relationships are being discussed, stress-test them with specific scenarios. Invent scenarios that probe edge cases and force the user to be precise about the boundaries between concepts.

### Cross-reference with code

When the user states how something works, check whether the code agrees. If you find a contradiction, surface it: "Your code cancels entire Orders, but you just said partial cancellation is possible — which is right?"

### Update CONTEXT.md inline

When a term is resolved, update `CONTEXT.md` right there. Don't batch these up — capture them as they happen. Use the format in [CONTEXT-FORMAT.md](./CONTEXT-FORMAT.md).

`CONTEXT.md` should be totally devoid of implementation details. Do not treat `CONTEXT.md` as a spec, a scratch pad, or a repository for implementation decisions. It is a glossary and nothing else.

### Offer ADRs sparingly

Only offer to create an ADR when all three are true:

1. **Hard to reverse** — the cost of changing your mind later is meaningful
2. **Surprising without context** — a future reader will wonder "why did they do it this way?"
3. **The result of a real trade-off** — there were genuine alternatives and you picked one for specific reasons

If any of the three is missing, skip the ADR. Use the format in [ADR-FORMAT.md](./ADR-FORMAT.md).

</supporting-info>
## 한 줄

grill-me + 도메인 인지 — 인터뷰 중 사용자가 쓴 단어가 `CONTEXT.md` 정의와 충돌하면 즉시 challenge하고, 합의된 용어는 그 자리에서 `CONTEXT.md`에 적는다.

## 언제 쓰는가

- 새 기능을 implementation 전에 도메인 언어와 정렬
- 모호한/overloaded 용어 sharpen ("account"는 Customer인가 User인가?)
- 사용자가 말한 동작과 코드 동작의 contradiction 발견

## 파일 구조 가정

- 단일 컨텍스트: 루트의 `CONTEXT.md` + `docs/adr/`
- 멀티 컨텍스트: 루트의 `CONTEXT-MAP.md`가 각 컨텍스트의 `CONTEXT.md` 위치를 가리킴

파일은 lazy 생성 — 첫 용어가 resolve될 때 `CONTEXT.md`를 만든다.

## 함정

- `CONTEXT.md`에 구현 디테일을 넣지 말 것. spec도, scratch pad도 아니다. **glossary일 뿐.**
- ADR은 **3가지 조건이 모두** 충족될 때만: hard to reverse + surprising without context + 진짜 trade-off. 하나라도 빠지면 skip.
- 용어 업데이트는 batch하지 말고 그때그때 — 발견 즉시 캡처.

## 원문 SKILL.md (전문)

````markdown
---
name: grill-with-docs
description: Grilling session that challenges your plan against the existing domain model, sharpens terminology, and updates documentation (CONTEXT.md, ADRs) inline as decisions crystallise. Use when user wants to stress-test a plan against their project's language and documented decisions.
---

<what-to-do>

Interview me relentlessly about every aspect of this plan until we reach a shared understanding. Walk down each branch of the design tree, resolving dependencies between decisions one-by-one. For each question, provide your recommended answer.

Ask the questions one at a time, waiting for feedback on each question before continuing.

If a question can be answered by exploring the codebase, explore the codebase instead.

</what-to-do>

<supporting-info>

## Domain awareness

During codebase exploration, also look for existing documentation:

### File structure

Most repos have a single context:

```
/
├── CONTEXT.md
├── docs/
│   └── adr/
│       ├── 0001-event-sourced-orders.md
│       └── 0002-postgres-for-write-model.md
└── src/
```

If a `CONTEXT-MAP.md` exists at the root, the repo has multiple contexts. The map points to where each one lives:

```
/
├── CONTEXT-MAP.md
├── docs/
│   └── adr/                          ← system-wide decisions
├── src/
│   ├── ordering/
│   │   ├── CONTEXT.md
│   │   └── docs/adr/                 ← context-specific decisions
│   └── billing/
│       ├── CONTEXT.md
│       └── docs/adr/
```

Create files lazily — only when you have something to write. If no `CONTEXT.md` exists, create one when the first term is resolved. If no `docs/adr/` exists, create it when the first ADR is needed.

## During the session

### Challenge against the glossary

When the user uses a term that conflicts with the existing language in `CONTEXT.md`, call it out immediately. "Your glossary defines 'cancellation' as X, but you seem to mean Y — which is it?"

### Sharpen fuzzy language

When the user uses vague or overloaded terms, propose a precise canonical term. "You're saying 'account' — do you mean the Customer or the User? Those are different things."

### Discuss concrete scenarios

When domain relationships are being discussed, stress-test them with specific scenarios. Invent scenarios that probe edge cases and force the user to be precise about the boundaries between concepts.

### Cross-reference with code

When the user states how something works, check whether the code agrees. If you find a contradiction, surface it: "Your code cancels entire Orders, but you just said partial cancellation is possible — which is right?"

### Update CONTEXT.md inline

When a term is resolved, update `CONTEXT.md` right there. Don't batch these up — capture them as they happen. Use the format in [CONTEXT-FORMAT.md](./CONTEXT-FORMAT.md).

`CONTEXT.md` should be totally devoid of implementation details. Do not treat `CONTEXT.md` as a spec, a scratch pad, or a repository for implementation decisions. It is a glossary and nothing else.

### Offer ADRs sparingly

Only offer to create an ADR when all three are true:

1. **Hard to reverse** — the cost of changing your mind later is meaningful
2. **Surprising without context** — a future reader will wonder "why did they do it this way?"
3. **The result of a real trade-off** — there were genuine alternatives and you picked one for specific reasons

If any of the three is missing, skip the ADR. Use the format in [ADR-FORMAT.md](./ADR-FORMAT.md).

</supporting-info>
````