Files
agcore/AGENTS.md
T
徐涛 0267da93f1 docs(agents): 完善 AGENTS.md 中的工作准则和规范细节
补充精准变更原则的约束条件,更新测试要求为更严格的核心逻辑验证策略,
细化依赖升级的分级策略,新增 Git Scope 推导规则和示例,
重构模块组织章节并提供完整目录结构示例,新增文档方案规范章节
2026-06-01 23:06:19 +08:00

8.2 KiB
Raw Blame History

AGENTS.md


交互要求

  • 思考过程全程必须使用中文,包括需求分析、逻辑拆解、方案选择等所有推理环节
  • 最终输出内容必须全部使用中文,除代码语法本身和英文关键词以外

核心原则 (Karpathy)

1. 先思考再编码 (Think Before Coding)

不要预设。不要隐藏困惑。呈现权衡。

  • 明确陈述你的假设。如果不确定,就问。
  • 如果存在多种解释,全部列出——不要默默选择其一。
  • 如果有更简单的方法,就说出来。在必要时提出反对。
  • 如果某件事不清楚,停下来。说出困惑所在。然后提问。

2. 简洁优先 (Simplicity First)

解决问题的最小代码量。不写任何推测性代码。

  • 不实现超出需求的特性。
  • 不为只用一次的代码创建抽象。
  • 不添加未经要求的"灵活性"或"可配置性"。
  • 不为不可能发生的场景做错误处理。
  • 如果你写了 200 行而它本可以用 50 行完成,重写它。

3. 精准变更 (Surgical Changes)

只改动必须改的。只清理你自己造成的混乱。

  • 未明确要求时不修改已有文件
  • 先确认意图再动手
  • 不要"优化"相邻的代码、注释或格式。
  • 不要重构没有问题的代码。
  • 遵循已有风格,即使你自己的写法不同。
  • 如果你注意到不相关的死代码,提出来——但不要删除它。
  • 删除你的改动导致的未使用的导入/变量/函数。

4. 目标驱动执行 (Goal-Driven Execution)

定义成功标准。迭代直至验证通过。

  • "添加验证" → "通过测试验证已有实现的正确性"
  • "修复缺陷" → "编写测试复现问题,验证修复"
  • "重构 X" → "确保重构后测试仍然通过"

对于多步骤任务,简要列出计划:

1. [步骤] → 验证:[检查项]
2. [步骤] → 验证:[检查项]

技术栈规范

通用规范

包管理器: cargo

代码风格

  • 文件/文件夹命名:kebab-case
  • 类/组件命名:PascalCase
  • 变量/函数命名:snake_case

测试要求

  • 核心业务逻辑需测试(关键算法、边界条件、错误处理)
  • 简单逻辑不需要测试(枚举字面值、Getter、无分支的简单转换)
  • 不主动补测试(除非用户明确要求)

错误处理

  • 优先使用 Result 处理错误,避免 unwrap()
  • 异步 API 使用 ? 传播错误,不在 catch 中静默吞掉错误
  • 错误按层级组织:公开 API 用全局 Error,内部实现可定义细粒度子错误

安全规范

  • 不硬编码密钥,使用环境变量
  • 用户输入必须验证
  • 依赖升级策略:
    • 安全补丁:立即升级(修复已知漏洞)
    • 次要版本:评估后升级(新功能、向后兼容)
    • 主要版本:谨慎升级(可能破坏兼容性,需全面测试)
    • 验证:升级后运行完整测试套件确保无回归

Git Commit 规范

  • 使用 Conventional Commits 格式:<type>(<scope>): <description>
  • 描述使用中文
  • 类型:
    • feat - 新功能
    • fix - Bug 修复
    • enhance - 增强现有功能(非新功能)
    • docs - 文档更新
    • style - 代码格式(不影响功能)
    • refactor - 重构
    • test - 测试相关
    • chore - 构建/工具/配置
  • 描述使用祈使句、现在时态、句尾无句号
  • Scope 推导规则
    • 从被提交的文件路径中推导出一个最相关的 scope
    • 一个 commit 只写一个主要 scope,不要罗列多个
    • 如果改动涉及多个模块,选择影响范围最大的那个或使用更上层抽象名称
    • 如果改动是全局的,可以省略 scope 或使用 core/global
  • 示例
    • feat(llm): 添加流式响应支持(修改 src/llm/stream.rs
    • fix(memory): 修复向量检索边界条件(修改 src/memory/vector_store.rs
    • refactor(core): 统一错误类型定义(修改多个模块的错误处理)
    • docs: 更新 API 文档(全局文档更新)
    • chore(deps): 升级 tokio 到 1.40(依赖更新)

Rust

包管理器: cargo

代码风格

  • cargo fmt 格式化,cargo clippy 检查
  • 变量/函数命名:snake_case
  • 优先使用 Result 处理错误,避免 unwrap()
  • 所有权规则:不使用 &mut 时不用,引用必须合法

模块组织

  • 按功能领域组织模块(一个模块一个职责)
  • 2018+ 版风格:使用 foo.rs 作为模块根,子模块放在 foo/ 目录下
  • 扁平优先:如果模块没有子模块,直接用单个 foo.rs 文件
  • 需要子模块时才用目录:只有当模块需要组织多个子模块时才创建 foo/ 目录
  • 避免 mod.rs:不使用 foo/mod.rs 风格,统一使用 foo.rs 作为模块根
  • 公共 API 重导出:在模块根中使用 pub use 重新导出子模块的公共类型,提供清晰的 API 边界

示例结构图

src/
├── lib.rs                  # crate 根,声明顶层模块
├── llm.rs                  # LLM 模块(无子模块,扁平文件)
├── memory.rs               # 记忆模块根(有子模块)
├── memory/
│   ├── conversation.rs     # ✓ 子模块
│   └── vector_store.rs     # ✓ 子模块
├── prompt.rs               # 提示词模块根(有子模块)
├── prompt/
│   ├── template.rs         # ✓ 子模块
│   └── optimizer.rs        # ✓ 子模块
├── tool.rs                 # 工具模块根(有子模块)
├── tool/
│   ├── mcp.rs              # ✓ 子模块
│   └── registry.rs         # ✓ 子模块
└── agent.rs                # Agent 模块根(有子模块)
└── agent/
    ├── runtime.rs          # ✓ 子模块
    └── planner.rs          # ✓ 子模块

# ❌ 避免的风格
src/
└── memory/
    └── mod.rs              # ❌ 不使用 mod.rs 风格

# ✅ memory.rs 示例:声明子模块并重导出公共 API
pub mod conversation;
pub mod vector_store;

// 重导出常用类型,提供简洁的公共 API
pub use conversation::ConversationMemory;
pub use vector_store::VectorStore;

测试文件: 内联测试(#[cfg(test)] mod tests {})或 tests/ 目录

依赖管理: Cargo.toml,语义化版本


文档规范

方案规范 (docs/)

编号规则:创建新方案前必须先通过 shell 命令确认当前实际最大编号(Unix: ls docs/ / Windows: dir docs\),禁止使用上下文中缓存的编号,如遇冲突自动递增

方案文档结构6 项):

  1. 背景与目标 - 问题描述、预期目标
  2. 需求分析 - 功能需求、非功能需求
  3. 方案设计 - 架构设计、模块划分、接口定义
  4. 实现计划 - 任务拆解、优先级、时间估算
  5. 风险评估 - 潜在风险、缓解措施
  6. 验收标准 - 可验证的完成条件

项目特定规则

项目结构

  • 源代码:src/lib crate
  • 测试:内联 #[cfg(test)] mod tests {}

项目目标

agcore 是一个智能体(Agent)核心工具箱,提供:

  • LLM 调用:完整的请求/响应周期管理
  • 提示词工程:组合、模板化、优化
  • 记忆系统:存储、检索、管理对话/向量记忆
  • 工具调用MCP 协议集成与自定义工具注册
  • Agent 运行时:多轮对话、任务编排

设计原则

  • 模块化:每个功能领域独立 module,通过 trait 定义接口
  • 可插拔:LLM 后端、记忆存储、工具注册均通过 trait 抽象
  • 无运行时依赖:core 层尽量少依赖,具体实现在 separate crates
  • 异步优先:涉及 IO 的 API 均使用 async

特殊约定

  • 所有公开 API 必须有文档注释(///
  • 使用 thiserrorderive_more 定义错误类型
  • 错误按层级组织:公开 API 用全局 Error,内部实现可定义细粒度子错误
  • 跨 module 依赖通过 trait 而非具体类型
  • 配置优先从环境变量读取,支持 builder 模式注入

这些指南生效的标志:

  • diff 中不必要的改动更少
  • 因过度复杂而导致的重写更少
  • 澄清问题在实现之前提出
  • 干净、精简的 PR