Profile 模型
Profile 是 Huoban 的墨方。
它负责把项目知识、团队习惯、架构约束、编码风格、风险偏好和历史决策注入到 AI 工作中。它不改变 skill 本身,但会改变同一个 skill 在不同项目中的判断重点。
Profile 不是普通规则文件
现有生态里已经有很多上下文文件:AGENTS.mdCLAUDE.md- Cursor Rules
- 项目 prompt 文档
- 团队 coding guidelines
AGENTS.md is a profile file. Huoban Profile is a profile object.也就是说,Huoban 不替代这些文件,而是把它们升级成标准对象:可分层、可合并、可校验、可导入导出、可进入 Run snapshot。
data 与 content
Profile 应同时支持结构化字段和自然语言内容。| 字段 | 面向谁 | 作用 |
|---|---|---|
data | runtime / validator / policy | 合并、校验、冲突检测、explain、hash。 |
content | agent / LLM | 作为自然语言上下文影响判断。 |
Layer
Profile 使用 layer 表达上下文分层。 常见 layer:style:代码风格、改动粒度、测试习惯。architecture:模块边界、依赖规则、设计约束。domain:业务术语、不变量、合规要求。commands:项目常用命令和验证方式。testing:测试策略、覆盖要求、fixture 习惯。history:ADR、历史迁移、拒绝过的方案。risk:高风险操作、审批要求、禁止动作。
多 Profile 合并
一个 Run 可以使用多个 Profile:- 按数组顺序应用。
- 后者覆盖前者的同名 scalar 字段。
- list 字段默认 append,除非明确声明 replace。
- 同名 layer 合并。
- 冲突写入
status.conditions。 - 最终 effective profile 必须可解释、可 hash、可快照。
Flow 与 Run 中的 Profile
Flow 可以声明默认 Profile:
Run 可以覆盖或追加 Profile: