grill-with-docs

工程开发 社区 @mattpocock
信任分
88/100
兼容 Agent
1
速查档案 只列事实:领域、Agent、信任分、作者、原文章节。装与不装请看下方作者解读。
领域
工程开发
兼容 Agent
Claude Code
信任分
88 / 100 · 社区维护
作者 / 版本 / 许可
@mattpocock · 未声明 license
安装命令数
1 条

需要注意: 未限定 allowed-tools,默认拥有全部工具权限。

想读作者英文原文? ↓ 滚到正文区切换 · 在 GitHub 查看 ↗

解读由编辑根据原文凝练而成,命令、链接、术语均与作者原文一致;想看完整论述请切到右侧

设计思路

grill-with-docsgrill-me 的「领域知识增强版」——拷问的同时维护两份语料文件CONTEXT.md(领域术语表)和 docs/adr/(架构决策记录)。每当用户用一个术语和已有定义冲突、或用一个模糊词、或对一段代码的描述与代码本身矛盾,skill 会立刻挑出来;术语一旦敲定,当场写进 CONTEXT.md,不批处理。

仓库布局

单一 context 项目:

/
├── docs/adr/  ← system-wide decisions
├── CONTEXT.md
├── src/

多 context 项目根有 CONTEXT-MAP.md 指引各 context 在哪:

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

lazy 创建——没有 CONTEXT.md / docs/adr/ 就先不建,第一个术语 / ADR 出现时再建。

Session 中的核心动作

  • Challenge against the glossary:术语和已有定义冲突就立刻提:「你的 glossary 把『cancellation』定义为 X,但你这里似乎指 Y——到底是哪个?」
  • Sharpen fuzzy language:模糊或重载的词出现时提议精确替换:「你说的『account』指 Customer 还是 User?这两件事不一样。」
  • Discuss concrete scenarios:讨论领域关系时用具体场景压力测——构造边界 case 强迫对方精确化。
  • Cross-reference with code:用户讲的工作机制和代码不一致时立刻挑:「你的代码取消整个 Order,但你刚才说支持部分取消——哪个是对的?」
  • Update CONTEXT.md inline:术语敲定就当场写入,不批处理。

CONTEXT.md 的纪律

  • 是 glossary,不是 spec / 草稿 / 实现决策的归宿——纯粹术语表,绝不混实现细节。
  • CONTEXT-FORMAT.md 的格式。

ADR 的纪律

只有同时满足以下三条才提议建 ADR:

  1. 难以回退:以后改主意代价不小
  2. 没有上下文会让未来读者疑惑:"为什么这样做?"
  3. 真权衡的结果:有真备选项,因具体理由选了这个

三条缺一就跳过 ADR,用 ADR-FORMAT.md 的格式。

适合谁

  • 在做 DDD(领域驱动设计)的项目
  • 团队术语长期混乱、需要建 ubiquitous language 的产品
  • 写 ADR 但不知道何时该写、何时该跳过的工程负责人

何时不该用

  • 简单 CRUD / 工具脚本——没有领域复杂度
  • 临时实验——ADR 写出来很快就过时

配套

grill-me(无语料的拷问母法)、ubiquitous-language(专门维护通用语言)、brainstorming(前期发散设计)。