---
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.
---
围绕这个计划的每个方面持续追问我,直到我们达成共同理解。沿着 design tree 的每个分支往下走,逐一解决决策之间的依赖。对每个问题,都提供你推荐的答案。
一次只问一个问题,并等待我对每个问题的反馈后再继续。
如果某个问题可以通过探索 codebase 来回答,就去探索 codebase,而不是问我。
## Domain awareness
探索 codebase 时,也查找现有文档:
### File structure
大多数 repos 只有一个 context:
```
/
├── CONTEXT.md
├── docs/
│ └── adr/
│ ├── 0001-event-sourced-orders.md
│ └── 0002-postgres-for-write-model.md
└── src/
```
如果根目录存在 `CONTEXT-MAP.md`,说明 repo 有多个 contexts。这个 map 指向每个 context 的位置:
```
/
├── CONTEXT-MAP.md
├── docs/
│ └── adr/ ← system-wide decisions
├── src/
│ ├── ordering/
│ │ ├── CONTEXT.md
│ │ └── docs/adr/ ← context-specific decisions
│ └── billing/
│ ├── CONTEXT.md
│ └── docs/adr/
```
懒创建文件:只有在有内容可写时才创建。如果没有 `CONTEXT.md`,在第一个 term 被解决时创建。如果没有 `docs/adr/`,在第一个 ADR 需要时创建。
## During the session
### Challenge against the glossary
当用户使用的 term 与 `CONTEXT.md` 中的现有语言冲突时,立即指出。“Your glossary defines 'cancellation' as X, but you seem to mean Y — which is it?”
### Sharpen fuzzy language
当用户使用含糊或 overloaded terms 时,提出一个精确的 canonical term。“You're saying 'account' — do you mean the Customer or the User? Those are different things.”
### Discuss concrete scenarios
讨论 domain relationships 时,用具体场景做 stress-test。发明能探测 edge cases 的场景,迫使用户精确说明概念之间的边界。
### Cross-reference with code
当用户说明某件事如何工作时,检查代码是否一致。如果发现矛盾,指出来:“Your code cancels entire Orders, but you just said partial cancellation is possible — which is right?”
### Update CONTEXT.md inline
当一个 term 被解决时,立即更新 `CONTEXT.md`。不要攒到最后;随着发生就捕获。使用 [CONTEXT-FORMAT.md](./CONTEXT-FORMAT.md) 中的格式。
`CONTEXT.md` 应完全不包含实现细节。不要把 `CONTEXT.md` 当作 spec、scratch pad 或实现决策仓库。它只是 glossary,除此之外不承担别的职责。
### Offer ADRs sparingly
只有以下三点全部为真时,才提议创建 ADR:
1. **Hard to reverse** — 之后改主意的成本有意义
2. **Surprising without context** — 未来读者会疑惑“为什么这样做?”
3. **The result of a real trade-off** — 确实有真实替代方案,并且你基于具体原因选择了一个
如果三者缺一,就跳过 ADR。使用 [ADR-FORMAT.md](./ADR-FORMAT.md) 中的格式。