cs-note
cs-note
启动必读
开始任何判断或动作前,先检查 .codestable/attention.md:存在就读取;缺 .codestable/ 就提示先运行 cs-onboard;只有 attention.md 缺失时,本技能可以先创建固定分节骨架再写入。不要回退到外部 AI 入口文件。
cs-learn / cs-trick / cs-decide 产出独立 markdown 文件,通过检索被读到;.codestable/attention.md 是 CodeStable 技能启动时的强制必读上下文。这两类信息归宿不同——本技能专管后者:把"短、稳、每次都要知道"的碎片追加到 attention 文件里。
不替代沉淀类技能,是补一个之前缺的入口。
什么进 cs-note,什么不进
判据:长度 + 频次 + 稳定度——三条都过才走 cs-note。
| 项 | 进 cs-note | 走别处 |
|---|---|---|
| 长度 | 一两行能讲清 | 超过半屏 / 需要展开背景 → cs-learn |
| 频次 | 几乎每次会话都用得上 | 只在某类具体任务相关 → cs-trick |
| 稳定度 | 项目长期生效的硬约束 | 临时绕过 / 短期 workaround → 写到 issue spec 或 feature spec |
| 拍板状态 | 已既成事实(不需要决策记录) | 需要记选型理由 / 拒方案 → cs-decide |
✅ 典型该进:
- "编译要先
pnpm run gen生成 schema" - "本地起服务前必须
docker compose up redis" - "项目用 yarn berry,别用
npm install" - "测试命令是
bun test,不是npm test" - "src/legacy/ 是历史代码,改之前先问"
- "
OPENAI_KEY走 1Password,别从 .env.example 复制"
❌ 典型不该进(会让 attention.md 膨胀):
- 某个 bug 的修法(→ cs-learn pitfall)
- 某个库怎么用(→ cs-trick library)
- 一段架构说明(→ .codestable/architecture/)
- "本周在做 X"这种短期状态(→ 别记,会过期)
- 需要 3 行以上才讲清的(→ cs-learn knowledge)
判不准就反问用户一句:"这条以后是不是每次会话都要让 AI 知道?"答"不一定" → 不是 cs-note。
目标文件
目标文件固定为 .codestable/attention.md。不再兼容 AGENTS.md / CLAUDE.md / .cursorrules 等外部 AI 工具入口。
.codestable/不存在 → 本仓库还没接入 CodeStable,先提示用户运行cs-onboard.codestable/attention.md不存在 → 视为骨架缺失,先创建最小骨架再写入AGENTS.md/CLAUDE.md即使存在也不读取、不写入、不询问用户偏好
attention.md 是 CodeStable 自己的启动注意事项入口,价值来自所有 CodeStable 技能都明确要求读取它,而不是依赖外部工具的自动注入。
固定分节结构
为了防止文件膨胀成另一个胖文件,分节写死一组(不在列表里的不开新节):
## 项目碎片知识
<!-- cs-note managed: 用 cs-note 维护,新条目按下面分节追加 -->
### 编译与构建
### 运行与本地起服务
### 测试
### 命令与脚本陷阱
### 路径与目录约定
### 环境变量与凭证
### 其他
规则:
- 新条目去对应分节末尾追加,每条一行(最多两行)
- 没有合适的分节 → 进"其他"。"其他"超过 5 条就停下来和用户讨论是否新增固定分节(不要默默加节)
- 分节为空时整段保留,不删(让 AI 看到这一节是有意义的)
- 注释行
<!-- cs-note managed -->是本技能的识别锚——找不到就在文件末尾插入整块结构 - 整段长度软上限 ~150 行——超过提示用户:"碎片知识太多了,挑几条沉到 cs-learn / cs-decide 里?"
流程
1. 判定该不该进
按上面"判据"表对一遍。任一项不过 → 引导到对应别的技能,本轮结束。
2. 确认 attention 文件
检查 .codestable/attention.md。缺 .codestable/ 就停止并提示先 cs-onboard;只缺 attention.md 就创建本技能的固定分节骨架。
3. 找位置:分节归类 + 查重
- 读
.codestable/attention.md,找<!-- cs-note managed -->锚定位 - 找不到锚 → 在文件末尾追加整块"项目碎片知识"骨架
- 在"项目碎片知识"段内 grep 关键词查重——已有相似条目时不另起一条,问用户"是更新已有那条还是确实是另一条"
- 选好分节,没有合适分节进"其他"
4. 写一条进去
每条格式:
- {一句话事实 + 必要时一句话原因}
例:
- 编译前要先 `pnpm run gen`,否则 schema 类型对不上
- 别用 `npm install`,项目锁文件是 yarn berry 的
- src/legacy/ 是 2023 前的老代码,改之前先和 @ldz 确认
写完用户 review 一句确认就退出。不主动连写多条——一次一条,避免顺手把没拍板的也塞进去。
5. 触发软上限检查
写完看一眼"项目碎片知识"段总行数:
- ≥150 行 → 提示用户挑几条沉到 cs-learn / cs-decide
- "其他"分节 ≥5 条 → 提示用户讨论是否新增固定分节
只是提示,不替用户决定。
主动推荐时机
不要每次都问。只在两个明确信号触发时推一句:
- 用户在对话中说出明显属于碎片知识的事实——"哦对这个项目要先 X 才能 Y"、"我们这个用 Z 不用 W"——推:"这条要不要
cs-note一下?以后 AI 每次都能看到。" - AI 自己刚踩了一个一句话能讲清的项目特殊设置(编译失败 / 命令不对 / 路径找错)——修复后推:"这个坑是项目通用的吗?是的话
cs-note记一笔,下次会话直接知道。"
用户说"不用了"立刻跳过,不重复推。
容易踩的坑
- 把详细背景 / 多步骤指南塞进 attention.md——超过两行就该走 cs-learn
- 写到
AGENTS.md/CLAUDE.md——CodeStable 不再兼容这些外部入口 - 默默新增分节——分节是写死的,新增要先和用户讨论
- 看到一条就连带把其他几条也写进去——一次一条
- 写"短期状态"(本周在做 X / 这个 sprint 的目标)——会过期但没人删,慢慢变误导
- 不查重就追加——同一条事实被记 3 次后 AI 反而搞不清哪条是准的
More from liuzhengdongfortest/codestable
cs-feat-design
feature 流程阶段 1——为新功能起草 {slug}-design.md 作为后续实现和验收的唯一输入,拍板后抽出 checklist。触发:用户说"开始设计方案"、"写 design doc"、"准备实现 XX",前提是已知道做什么、为谁、怎么算成功。
470cs-feat-accept
feature 流程阶段 3——验收闭环:对照 design 核实现 + 回写 architecture / requirement / roadmap,最后产出 {slug}-acceptance.md。触发:用户说"功能写完了验收一下"、"做最后检查"、"准备 merge"、"出验收报告"。前置依赖 cs-feat-impl 完成。
470cs-feat-impl
feature 流程阶段 2——按 {slug}-checklist.yaml 里 design 切好的 paradigm 维度 steps 推进,每步具体改哪个文件由 implement 自决,写完用统一格式汇报。触发:用户说"方案确认了开始实现"、"按方案写代码"、"开工"。前提是 design 已 approved 且有 checklist。遇到方案外情况要回方案谈不要硬冲。
469cs-brainstorm
想法还模糊时的讨论入口,做分诊后路由到 feature-design / feature-brainstorm / roadmap。AI 是思考伙伴不是记录员。触发:用户说"有个想法还没想清楚"、"先 brainstorm 一下"、"聊一聊这块"、"方向还在摇摆"。不处理 bug 和重构。
469cs-onboard
把新仓库或有零散文档的仓库接入 CodeStable 体系,两条路径自动判断:空仓库从零搭骨架,已有文档走审计 + 迁移映射。触发:用户说"在这个项目里用 CodeStable"、"搭 CodeStable 结构"、"初始化 CodeStable"、"迁移到 CodeStable"。
467cs-feat
新功能开发的子流程入口,把"加个 X 能力"从想法走到验收闭环。触发:用户说"做新功能"、"加个 X"、"实现 XX"。只做路由,根据已有产物决定走 brainstorm / design / fastforward / implement / acceptance。不处理 bug。
467