name: codebase-documenter description: 该技能用于编写代码库文档,包括README文件、架构文档、代码注释和API文档。当用户请求帮助记录代码、创建入门指南、解释项目结构或使代码库对新开发人员更易访问时使用此技能。该技能提供模板、最佳实践和结构化方法,用于创建清晰、对初学者友好的文档。
代码库文档编写器
概述
该技能能够为代码库创建全面、对初学者友好的文档。它提供结构化模板和最佳实践,用于编写README、架构指南、代码注释和API文档,帮助新用户快速理解项目并做出贡献。
对初学者友好文档的核心原则
为新用户记录代码时,请遵循以下基本原则:
- 从“为什么”开始 - 在深入实现细节之前解释目的
- 使用渐进式披露 - 从简单到复杂分层呈现信息
- 提供上下文 - 不仅解释代码做什么,还要解释它为什么存在
- 包含示例 - 为每个概念展示具体使用示例
- 假设没有先验知识 - 尽可能定义术语并避免行话
- 视觉辅助 - 使用图表、流程图和文件树结构
- 快速成功 - 帮助用户在5分钟内运行某些内容
文档类型及使用时机
1. README文档
何时创建: 用于项目根目录、主要功能模块或独立组件。
遵循的结构:
# 项目名称
## 功能说明
[1-2句通俗易懂的解释]
## 快速开始
[让用户在<5分钟内运行项目]
## 项目结构
[带解释的可视化文件树]
## 核心概念
[用户需要理解的核心概念]
## 常见任务
[频繁操作的逐步指南]
## 故障排除
[常见问题及解决方案]
最佳实践:
- 以项目的价值主张开头
- 包含实际有效的设置说明(测试它们!)
- 提供项目结构的可视化概览
- 为高级主题链接到更深层的文档
- 保持根README专注于入门
2. 架构文档
何时创建: 用于具有多个模块、复杂数据流或不明显设计决策的项目。
遵循的结构:
# 架构概览
## 系统设计
[高级图表和解释]
## 目录结构
[每个目录用途的详细分解]
## 数据流
[数据如何在系统中移动]
## 关键设计决策
[为什么做出某些架构选择]
## 模块依赖关系
[不同部分如何交互]
## 扩展点
[在何处以及如何添加新功能]
最佳实践:
- 使用图表显示系统组件和关系
- 解释架构决策背后的“为什么”
- 记录正常路径和错误处理
- 识别模块之间的边界
- 包含带注释的可视化文件树结构
3. 代码注释
何时创建: 用于复杂逻辑、不明显算法或需要上下文的代码。
注释模式:
函数/方法文档:
/**
* 计算部分计费周期的按比例订阅费用。
*
* 存在原因:用户可以在月中订阅,因此我们只需要
* 向他们收取当前计费周期剩余天数的费用。
*
* @param {number} fullPrice - 正常的月度订阅价格
* @param {Date} startDate - 用户订阅开始时间
* @param {Date} periodEnd - 当前计费周期结束时间
* @returns {number} 按比例计算的收费金额
*
* @example
* // 用户在1月15日订阅,周期在1月31日结束
* calculateProratedCost(30, new Date('2024-01-15'), new Date('2024-01-31'))
* // 返回:16.13(31天中的17天)
*/
复杂逻辑文档:
# 存在此检查的原因:API对已删除用户返回null,
# 但对从未设置姓名的用户返回空字符串。我们需要
# 为审计日志区分这些情况。
if user_name is None:
# 用户已被删除 - 将此记录为安全事件
log_deletion_event(user_id)
elif user_name == "":
# 用户从未完成入职 - 可以安全跳过
continue
最佳实践:
- 解释“为什么”而不是“什么” - 代码显示它做什么
- 记录边缘情况和业务逻辑
- 为复杂函数添加示例
- 解释不直观的参数
- 注意任何陷阱或反直觉行为
4. API文档
何时创建: 用于任何HTTP端点、SDK方法或公共接口。
遵循的结构:
## 端点名称
### 功能说明
[端点用途的通俗易懂解释]
### 端点
`POST /api/v1/resource`
### 认证
[需要什么认证以及如何提供]
### 请求格式
[JSON模式或示例请求]
### 响应格式
[JSON模式或示例响应]
### 使用示例
[使用curl/代码的具体示例]
### 常见错误
[错误代码及其含义]
### 相关端点
[相关操作的链接]
最佳实践:
- 提供有效的curl示例
- 显示成功和错误响应
- 清晰解释认证
- 记录速率限制和约束
- 包含常见问题的故障排除
文档工作流程
步骤1:分析代码库
编写文档前:
- 识别入口点 - 主文件、索引文件、应用初始化
- 映射依赖关系 - 模块如何相互关联
- 找到核心概念 - 用户需要理解的关键抽象
- 定位配置 - 环境设置、配置文件
- 审查现有文档 - 在现有基础上构建,不要重复
步骤2:选择文档类型
基于用户请求和代码库分析:
- 新项目或缺少README → 从README文档开始
- 复杂架构或多个模块 → 创建架构文档
- 令人困惑的代码部分 → 添加内联代码注释
- HTTP/API端点 → 编写API文档
- 需要多种类型 → 按顺序处理:README → 架构 → API → 注释
步骤3:生成文档
使用assets/templates/中的模板作为起点:
assets/templates/README.template.md- 用于项目READMEassets/templates/ARCHITECTURE.template.md- 用于架构文档assets/templates/API.template.md- 用于API文档
根据特定代码库自定义模板:
- 填写项目特定信息 - 用实际内容替换占位符
- 添加具体示例 - 使用项目中的真实代码
- 包含视觉辅助 - 创建文件树、图表、流程图
- 测试说明 - 验证设置步骤是否实际有效
- 链接相关文档 - 将文档片段连接在一起
步骤4:审查清晰度
最终确定文档前:
- 以初学者身份阅读 - 没有项目上下文是否合理?
- 检查完整性 - 解释中是否存在空白?
- 验证示例 - 代码示例是否实际有效?
- 测试说明 - 有人能遵循设置步骤吗?
- 改进结构 - 信息是否易于查找?
文档模板
此技能在assets/templates/中包含多个提供起始结构的模板:
可用模板
- README.template.md - 包含快速开始、项目结构和常见任务部分的全面README结构
- ARCHITECTURE.template.md - 包含系统设计、数据流和设计决策的架构文档模板
- API.template.md - 包含请求/响应格式和示例的API端点文档
- CODE_COMMENTS.template.md - 有效内联文档的示例和模式
使用模板
- 从
assets/templates/阅读适当的模板 - 为特定项目自定义 - 用实际信息替换占位符
- 添加项目特定部分 - 根据需要扩展模板
- 包含真实示例 - 使用代码库中的实际代码
- 删除不相关部分 - 删除不适用的部分
最佳实践参考
有关详细的文档最佳实践、风格指南和高级模式,请参考:
references/documentation_guidelines.md- 全面的风格指南和最佳实践references/visual_aids_guide.md- 如何创建有效的图表和文件树
在以下情况下加载这些参考:
- 为复杂企业代码库创建文档
- 处理多个利益相关者需求
- 需要高级文档模式
- 标准化大型项目的文档
常见模式
创建文件树结构
文件树帮助新用户理解项目组织:
项目根目录/
├── src/ # 源代码
│ ├── components/ # 可重用UI组件
│ ├── pages/ # 页面级组件(路由)
│ ├── services/ # 业务逻辑和API调用
│ ├── utils/ # 辅助函数
│ └── types/ # TypeScript类型定义
├── public/ # 静态资源(图片、字体)
├── tests/ # 测试文件镜像src结构
└── package.json # 依赖项和脚本
解释复杂数据流
使用带图表的编号步骤:
用户请求流程:
1. 用户提交表单 → 2. 验证 → 3. API调用 → 4. 数据库 → 5. 响应
[1] components/UserForm.tsx
↓ 验证输入
[2] services/validation.ts
↓ 发送到API
[3] services/api.ts
↓ 查询数据库
[4] 数据库(PostgreSQL)
↓ 返回数据
[5] components/UserForm.tsx(更新UI)
记录设计决策
捕捉架构选择背后的“为什么”:
## 为什么我们使用Redux
**决策:** 使用Redux进行状态管理而不是Context API
**上下文:** 我们的应用有50多个组件需要访问用户
认证状态、购物车和UI偏好设置。
**推理:**
- 有这么多组件时,Context API会导致不必要的重新渲染
- Redux DevTools有助于调试复杂的状态变化
- 团队已有Redux专业知识
**权衡:**
- 更多样板代码
- 新开发人员学习曲线更陡
- 值得:性能、调试、团队熟悉度
输出指南
生成文档时:
- 为目标受众写作 - 根据文档是为初学者、中级还是高级用户调整复杂性
- 使用一致的格式 - 遵循markdown约定,一致的标题层次结构
- 提供有效的示例 - 测试所有代码片段和命令
- 在文档之间链接 - 创建文档导航结构
- 保持可维护性 - 文档应易于随着代码变化而更新
- 添加日期和版本 - 注明文档最后更新时间
快速参考
生成README的命令: “为此项目创建一个README文件,帮助新开发人员入门”
记录架构的命令: “记录此代码库的架构,解释不同模块如何交互”
添加代码注释的命令: “向此文件添加解释性注释,帮助新开发人员理解逻辑”
记录API的命令: “为此文件中的所有端点创建API文档”