From mattpocock-skills
Oversees domain language, records architecture decisions (ADRs), and maintains CONTEXT.md glossary. Used when defining terminology, clarifying overloaded terms, or capturing tradeoff-driven decisions.
How this skill is triggered — by the user, by Claude, or both
Slash command
/mattpocock-skills:domain-modelingThe summary Claude sees in its skill listing — used to decide when to auto-load this skill
在设计过程中主动构建和完善项目的领域模型。这是一门**主动**的学科——质疑术语、创造边界场景、在术语和决策形成的瞬间将其记录在案。(仅仅*阅读* `CONTEXT.md` 来获取词汇不是此 skill 的用途——那是任何 skill 都能做的单行习惯。此 skill 用于你在*修改*模型,而非仅仅消费它。)
在设计过程中主动构建和完善项目的领域模型。这是一门主动的学科——质疑术语、创造边界场景、在术语和决策形成的瞬间将其记录在案。(仅仅阅读 CONTEXT.md 来获取词汇不是此 skill 的用途——那是任何 skill 都能做的单行习惯。此 skill 用于你在修改模型,而非仅仅消费它。)
大多数 repo 只有一个 context:
/
├── CONTEXT.md
├── docs/
│ └── adr/
│ ├── 0001-event-sourced-orders.md
│ └── 0002-postgres-for-write-model.md
└── src/
如果根目录存在 CONTEXT-MAP.md,则该 repo 有多个 context。该 map 指向每个 context 的位置:
/
├── CONTEXT-MAP.md
├── docs/
│ └── adr/ ← 系统级决策
├── src/
│ ├── ordering/
│ │ ├── CONTEXT.md
│ │ └── docs/adr/ ← context 特定决策
│ └── billing/
│ ├── CONTEXT.md
│ └── docs/adr/
懒加载创建文件——仅当有内容需要写入时才创建。如果 CONTEXT.md 不存在,在第一个术语确定时创建。如果 docs/adr/ 不存在,在第一个 ADR 需要时创建。
当用户使用与 CONTEXT.md 中已有语言冲突的术语时,立即指出。"你的 glossary 将 'cancellation' 定义为 X,但你似乎指的是 Y——到底是哪个?"
当用户使用模糊或过载的术语时,提出精确的标准术语。"你说 'account'——指的是 Customer 还是 User?它们是不同的东西。"
当领域关系被讨论时,用具体的场景进行压力测试。创造能够探测边界案例的场景,迫使用户精确描述概念之间的界限。
当用户陈述某事物的工作方式时,检查代码是否一致。如果发现矛盾,指出:"你的代码取消了整个 Orders,但你刚才说部分取消是可能的——哪个是对的?"
当术语确定时,立即更新 CONTEXT.md。不要批量处理——在发生时即时捕获。使用 CONTEXT-FORMAT.md 中的格式。
CONTEXT.md 应完全不含实现细节。不要将 CONTEXT.md 视为 spec、草稿本或实现决策的仓库。它是 glossary,仅此而已。
仅当以下三个条件同时满足时才提供创建 ADR:
如果缺少任何一条,跳过 ADR。使用 ADR-FORMAT.md 中的格式。
npx claudepluginhub devcxl/mattpocock-skills-zhBuilds and refines a project's domain model – clarifying terminology, recording architecture decisions, and maintaining a glossary (CONTEXT.md) and ADRs. Activated automatically when ambiguous language or undefined terms arise.
Builds and sharpens a project's domain model by challenging terminology, recording architectural decisions, and writing a glossary. Use when defining domain language or making architectural decisions.
Maintains domain model artifacts: glossary (CONTEXT.md), Architecture Decision Records (ADRs), and context topology (single/multi-context). Triggers on terminology decisions, ADR creation, and context splitting.