6aspec 2.0.0-dev.22 → 2.0.0-dev.24

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,39 +1,133 @@
1
1
  ---
2
- description:
3
- globs:
4
- alwaysApply: false
2
+ description: 代码编写规范与质量标准
3
+ globs: "**/*.{java,js,ts,py,go,cpp,c,cs}"
4
+ alwaysApply: true
5
5
  ---
6
6
 
7
- ## 代码质量
8
- - **单一职责**:每个类和方法只负责一个功能
9
- - **开闭原则**:对扩展开放,对修改关闭
10
- - **依赖倒置**:依赖抽象而不是具体实现
11
- - **接口隔离**:使用小而专一的接口
12
- - **代码复用**:提取公共逻辑,避免重复代码
7
+ # 代码编写规范
8
+
9
+ ## 🚨 红线规则(绝对禁止)
10
+
11
+ ### 性能红线
12
+ - **禁止在循环中进行数据库查询**:避免N+1问题,使用批量查询或预加载
13
+ - **禁止在循环中进行网络请求**:使用批量API或异步处理
14
+ - **禁止在循环中进行文件I/O操作**:批量读写或使用缓存
15
+ - **禁止在热点代码路径中使用反射**:影响性能,考虑编译时生成或缓存
16
+ - **禁止在生产环境使用System.out.println调试**:使用日志框架
17
+
18
+ ### 安全红线
19
+ - **禁止直接拼接SQL语句**:必须使用参数化查询防止SQL注入
20
+ - **禁止在日志中输出敏感信息**:密码、token、身份证号等
21
+ - **禁止硬编码密钥和敏感配置**:使用配置文件或环境变量
22
+ - **禁止信任用户输入**:所有外部输入必须验证和过滤
23
+ - **禁止使用弱加密算法**:MD5、SHA1等已不安全
24
+
25
+ ### 架构红线
26
+ - **禁止循环依赖**:包、模块、类之间不能相互依赖
27
+ - **禁止跨层直接调用**:Controller不能直接调用DAO
28
+ - **禁止在实体类中包含业务逻辑**:保持实体类的纯净性
29
+ - **禁止在静态代码块中进行复杂操作**:可能导致类加载问题
30
+ - **禁止捕获异常后不处理**:空catch块是代码异味
31
+
32
+ ## 🔒 安全规范
33
+
34
+ ### 输入验证
35
+ - **参数校验**:所有API入参必须校验
36
+ - **数据过滤**:防止XSS、SQL注入等攻击
37
+ - **权限检查**:每个操作都要验证用户权限
38
+ - **敏感数据处理**:加密存储,脱敏展示
39
+
40
+ ### 日志安全
41
+ - **敏感信息脱敏**:密码、token等不能明文记录
42
+ - **操作审计**:关键操作必须记录审计日志
43
+ - **错误信息**:不暴露系统内部信息给用户
44
+
45
+ ## ⚡ 性能优化
46
+
47
+ ### 数据库优化
48
+ - **索引使用**:查询字段必须有合适的索引
49
+ - **批量操作**:使用批量插入/更新减少数据库交互
50
+ - **连接池管理**:合理配置数据库连接池
51
+ - **查询优化**:避免全表扫描,使用分页查询
13
52
 
14
- ## 性能优化
15
- - **算法复杂度**:选择合适的算法和数据结构
16
- - **缓存策略**:合理使用缓存减少重复计算
17
- - **懒加载**:对于昂贵的操作使用懒加载
18
- - **批量处理**:批量处理数据库操作和网络请求
53
+ ### 缓存策略
54
+ - **多级缓存**:本地缓存 + 分布式缓存
55
+ - **缓存更新**:及时更新或失效过期数据
56
+ - **缓存穿透**:防止恶意查询不存在的数据
57
+ - **缓存雪崩**:设置随机过期时间
19
58
 
59
+ ### 算法复杂度
60
+ - **时间复杂度**:优先选择O(1)、O(log n)算法
61
+ - **空间复杂度**:避免不必要的内存占用
62
+ - **数据结构选择**:根据使用场景选择合适的数据结构
20
63
 
21
- ## 编码规范
22
- - **命名规范**:类名、方法名、变量名清晰表达意图
23
- - **代码结构**:合理的包结构和类层次
24
- - **注释规范**:必要的类和方法注释
25
- - **代码复用**:避免重复代码,提取公共方法
64
+ ## 📝 编码规范
26
65
 
66
+ ### 命名规范
67
+ - **类名**:大驼峰命名,名词,表达清晰意图
68
+ - **方法名**:小驼峰命名,动词开头,表达具体行为
69
+ - **变量名**:小驼峰命名,避免缩写,见名知意
70
+ - **常量名**:全大写,下划线分隔
71
+ - **包名**:全小写,层次清晰
27
72
 
28
- ## 设计原则
29
- - **SOLID 原则**:单一职责、开闭原则等
30
- - **DRY 原则**:不重复自己
31
- - **KISS 原则**:保持简单
32
- - **YAGNI 原则**:你不会需要它
73
+ ### 代码结构
74
+ - **包结构**:按功能模块划分,层次清晰
75
+ - **类大小**:单个类不超过500行
76
+ - **方法长度**:单个方法不超过50行
77
+ - **参数个数**:方法参数不超过5个
78
+ - **嵌套层次**:代码嵌套不超过4层
33
79
 
80
+ ### 注释规范
81
+ - **类注释**:说明类的职责和使用场景
82
+ - **方法注释**:说明参数、返回值、异常
83
+ - **复杂逻辑注释**:解释为什么这样做
84
+ - **TODO注释**:标记待完成的工作
34
85
 
35
- ## 重构策略
36
- - **持续重构**:小步快跑,持续改进
86
+ ## 🏗️ 设计原则
87
+
88
+ ### SOLID原则
89
+ - **单一职责原则**:一个类只负责一个功能领域
90
+ - **开闭原则**:对扩展开放,对修改关闭
91
+ - **里氏替换原则**:子类可以替换父类
92
+ - **接口隔离原则**:使用多个专门的接口
93
+ - **依赖倒置原则**:依赖抽象而不是具体实现
94
+
95
+ ### 其他原则
96
+ - **DRY原则**:不重复自己,提取公共代码
97
+ - **KISS原则**:保持简单,避免过度设计
98
+ - **YAGNI原则**:你不会需要它,不做过度设计
99
+ - **最少知识原则**:对象应该对其他对象有最少的了解
100
+
101
+ ## 🔄 重构策略
102
+
103
+ ### 重构时机
104
+ - **新功能开发时**:同步重构相关代码
105
+ - **Bug修复时**:改善代码结构
106
+ - **代码审查时**:发现问题及时重构
107
+ - **性能优化时**:重构性能瓶颈代码
108
+
109
+ ### 重构原则
110
+ - **小步快跑**:每次重构范围要小
37
111
  - **测试保护**:重构前确保测试覆盖
38
- - **重构时机**:新功能开发时同步重构
39
- - **技术债务**:定期评估和偿还技术债务
112
+ - **持续集成**:频繁提交,及时发现问题
113
+ - **技术债务管理**:定期评估和偿还
114
+
115
+ ## ✅ 检查清单
116
+
117
+ ### 代码提交前检查
118
+ - [ ] 是否违反红线规则
119
+ - [ ] 是否有安全漏洞
120
+ - [ ] 是否有性能问题
121
+ - [ ] 命名是否规范
122
+ - [ ] 是否有充分的测试
123
+ - [ ] 是否有必要的注释
124
+ - [ ] 是否符合团队编码风格
125
+
126
+ ### 代码审查检查
127
+ - [ ] 业务逻辑是否正确
128
+ - [ ] 异常处理是否完善
129
+ - [ ] 边界条件是否考虑
130
+ - [ ] 是否有代码重复
131
+ - [ ] 是否符合设计原则
132
+ - [ ] 是否有技术债务
133
+ - [ ] 文档是否需要更新
@@ -9,8 +9,11 @@
9
9
  1. **选择需求并检查状态**
10
10
 
11
11
  - 读取 `6aspecdoc/brown/<name>/status.json`
12
- - 确认 `phases.review` 为 "done"
13
- - 如果未完成 Phase 7,询问是否强制归档
12
+ - 获取 `flowDepth`(流程深度)
13
+ - 根据流程深度检查前置条件:
14
+ - **轻量级/标准级流程**:确认 `phases.implement` 为 "done" 或 `status` 为 "completed"
15
+ - **完整级流程**:确认 `phases.review` 为 "done"
16
+ - 如果未满足前置条件,询问是否强制归档
14
17
 
15
18
  2. **确认归档**
16
19
 
@@ -126,7 +129,10 @@
126
129
  ```
127
130
 
128
131
  **防护措施**
129
- - 如果未完成所有阶段,警告用户并询问是否强制归档
132
+ - 根据流程深度检查不同的前置条件:
133
+ - 轻量级/标准级:implement 必须完成
134
+ - 完整级:review 必须完成
135
+ - 如果未满足前置条件,警告用户并询问是否强制归档
130
136
  - 归档前必须确认
131
137
  - 归档操作不可逆(除非手动恢复)
132
138
  - 保留完整的归档信息和摘要
@@ -30,7 +30,9 @@
30
30
  **如果所有阶段都完成 (`phases` 全部为 "done")**:
31
31
  - 祝贺用户
32
32
  - 显示最终状态
33
- - 建议:"所有阶段已完成!可以运行 `/6aspec:brown:implement` 开始实施,或运行 `/6aspec:brown:archive` 归档。"
33
+ - 根据流程深度给出建议:
34
+ - 轻量级/标准级:"所有阶段已完成!可以运行 `/6aspec:brown:verify` 进行质量检查(可选),或运行 `/6aspec:brown:archive` 归档。"
35
+ - 完整级:"所有阶段已完成!可以运行 `/6aspec:brown:archive` 归档。"
34
36
  - 停止
35
37
 
36
38
  **如果有待执行的阶段**:
@@ -43,6 +45,7 @@
43
45
  - `design` → 调用 `/6aspec:brown:design`
44
46
  - `tasks` → 调用 `/6aspec:brown:tasks`
45
47
  - `implement` → 调用 `/6aspec:brown:implement`
48
+ - 如果 implement 已完成且无待执行阶段 → 提示:"所有阶段已完成!可以运行 `/6aspec:brown:verify` 进行质量检查(可选),或运行 `/6aspec:brown:archive` 归档。"
46
49
 
47
50
  **标准级流程(standard)**:
48
51
  - `understand` → 调用 `/6aspec:brown:understand`
@@ -52,6 +55,7 @@
52
55
  - `design` → 调用 `/6aspec:brown:design`
53
56
  - `tasks` → 调用 `/6aspec:brown:tasks`
54
57
  - `implement` → 调用 `/6aspec:brown:implement`
58
+ - 如果 implement 已完成且无待执行阶段 → 提示:"所有阶段已完成!可以运行 `/6aspec:brown:verify` 进行质量检查(可选),或运行 `/6aspec:brown:archive` 归档。"
55
59
 
56
60
  **完整级流程(complete)**:
57
61
  - `understand` → 调用 `/6aspec:brown:understand`
@@ -50,7 +50,26 @@
50
50
  - 保持变更最小化和聚焦
51
51
  - 遵循技术方案设计
52
52
 
53
- d. **标记任务完成**
53
+ d. **质量控制检查**
54
+ **必须严格遵循代码规范**:`.6aspec/rules/biz/code.md`,并使用其中的"检查清单"章节进行自我验证。
55
+
56
+ **重点关注以下红线规则(零容忍):**
57
+ - [ ] 循环中的数据库查询、网络请求、文件I/O操作
58
+ - [ ] SQL字符串拼接、敏感信息硬编码、弱加密算法使用
59
+ - [ ] 循环依赖、跨层直接调用、空catch块
60
+
61
+ **棕地需求特别检查:**
62
+ - [ ] 修改是否符合现有代码风格和架构模式
63
+ - [ ] 是否引入了新的技术债务
64
+ - [ ] 是否影响了现有功能的稳定性
65
+ - [ ] 是否遵循了设计文档中的技术决策
66
+
67
+ **技术检查:**
68
+ - [ ] 运行相关测试确保无回归
69
+ - [ ] 检查代码编译和语法错误
70
+ - [ ] 验证修改范围最小化
71
+
72
+ e. **标记任务完成**
54
73
  - 在任务文件中更新状态:`📋 待开始` → `✅ 已完成`
55
74
  - 在 `04-tasks-overview.md` 中更新任务状态:`- [ ]` → `- [x]`
56
75
  - 更新 `status.json` 中的任务计数
@@ -79,7 +98,14 @@
79
98
  ...
80
99
 
81
100
  ### 下一步
82
- 所有任务已完成!运行 `/6aspec:brown:verify` 进行验证。
101
+ 所有任务已完成!
102
+
103
+ - 轻量级/标准级流程:
104
+ - 运行 `/6aspec:brown:verify` 进行质量检查(可选)
105
+ - 运行 `/6aspec:brown:archive` 归档此需求
106
+
107
+ - 完整级流程:
108
+ - 运行 `/6aspec:brown:continue` 继续下一阶段(verify)
83
109
  ```
84
110
 
85
111
  **如果暂停**:
@@ -102,7 +128,25 @@
102
128
 
103
129
  6. **更新状态**
104
130
 
105
- 如果全部完成,更新 `status.json`:
131
+ 如果全部完成,根据流程深度更新 `status.json`:
132
+
133
+ **轻量级/标准级流程**:
134
+ ```json
135
+ {
136
+ "status": "completed",
137
+ "phases": {
138
+ ...
139
+ "implement": "done"
140
+ },
141
+ "tasks": {
142
+ "total": 8,
143
+ "completed": 8,
144
+ "pending": 0
145
+ }
146
+ }
147
+ ```
148
+
149
+ **完整级流程**:
106
150
  ```json
107
151
  {
108
152
  "status": "verify_pending",
@@ -0,0 +1,287 @@
1
+ # 棕地需求 - Update SOP
2
+
3
+ 非破坏性地更新指定阶段的文档,支持简单模式和智能模式。
4
+
5
+ **输入**:
6
+ - `/6aspec:brown:update <requirement-name> <phase>` - 简单更新(默认)
7
+ - `/6aspec:brown:update <requirement-name> <phase> --smart` - 智能更新
8
+ - `/6aspec:brown:update <requirement-name> --history` - 查看更新历史
9
+
10
+ **适用场景**:
11
+ - ✅ 补充遗漏的信息
12
+ - ✅ 修正错别字、格式问题
13
+ - ✅ 澄清模糊的描述
14
+ - ✅ 添加新的考虑因素(不推翻原有决策)
15
+ - ✅ 调整优先级、时间估算等非核心内容
16
+ - ✅ 修正小的技术细节
17
+
18
+ **不适用场景(建议使用 rollback)**:
19
+ - ❌ 推翻核心决策(如技术方案选型)
20
+ - ❌ 发现前面阶段的分析有重大错误
21
+ - ❌ 需求发生根本性变化
22
+ - ❌ 影响范围太大,难以准确识别
23
+ - ❌ 需要重新思考整个方案
24
+
25
+ **支持的阶段**:
26
+ - `understand` - 现状分析(相对稳定,不常需要update)
27
+ - `impact` - 影响面分析(相对稳定,不常需要update)
28
+ - `proposal` - 需求提案(常见update场景)
29
+ - `specs` - 需求规格(常见update场景)
30
+ - `design` - 技术设计(常见update场景)
31
+ - `tasks` - 任务拆解(常见update场景)
32
+
33
+ **限制**:
34
+ - 只能更新已完成的阶段(状态为 "done")
35
+ - 不能更新已归档的需求
36
+ - 不能更新不存在的阶段文档
37
+ - 在实施阶段(implement、verify、review)使用时需要特别小心
38
+
39
+ **步骤**
40
+
41
+ 1. **选择需求**
42
+
43
+ 如果提供了名称,使用它。否则:
44
+ - 从对话上下文推断
45
+ - 如果模糊,读取 `6aspecdoc/brown/` 目录,让用户选择
46
+
47
+ 2. **处理特殊选项**
48
+
49
+ **如果是 `--history` 选项**:
50
+ - 读取 `6aspecdoc/brown/<name>/artifacts/` 目录下的所有文档
51
+ - 提取每个文档末尾的"修改记录"部分
52
+ - 按时间顺序汇总显示所有更新历史
53
+ - 显示统计信息(总更新次数、最近更新时间等)
54
+ - 停止执行
55
+
56
+ 3. **检查当前状态**
57
+
58
+ 读取 `6aspecdoc/brown/<name>/status.json`:
59
+ - 确认需求未归档
60
+ - 确认目标阶段存在且状态为 "done"
61
+ - 确认对应的文档文件存在
62
+
63
+ 4. **读取目标文档**
64
+
65
+ 根据阶段名称读取对应文档:
66
+ - `understand` → `artifacts/understanding.md`
67
+ - `impact` → `artifacts/impact-analysis.md`
68
+ - `proposal` → `artifacts/proposal.md`
69
+ - `specs` → `artifacts/specs.md`
70
+ - `design` → `artifacts/design.md`
71
+ - `tasks` → `artifacts/tasks.md`
72
+
73
+ 5. **获取用户修改需求**
74
+
75
+ 询问用户要修改的内容:
76
+ ```
77
+ 问题:"请描述您要对 <phase> 阶段文档进行的修改:"
78
+
79
+ 提示:
80
+ - 请具体描述要修改、补充或调整的内容
81
+ - 如果是补充信息,请说明要补充什么
82
+ - 如果是修正错误,请说明错误的地方和正确的内容
83
+ - 如果是调整描述,请说明要如何调整
84
+ ```
85
+
86
+ 6. **执行更新(根据模式)**
87
+
88
+ **简单模式(默认)**:
89
+
90
+ a. 根据用户描述修改目标文档
91
+
92
+ b. 在文档末尾添加或更新修改记录:
93
+ ```markdown
94
+ ## 修改记录
95
+ - 2026-02-27 10:30: <修改描述>(update)
96
+ ```
97
+
98
+ c. 分析可能受影响的后续文档,生成检查清单
99
+
100
+ d. 更新 status.json 中的 lastUpdate
101
+
102
+ e. 显示检查清单,提示用户手动检查后续文档
103
+
104
+ **智能模式(--smart)**:
105
+
106
+ a. 分析修改内容对后续文档的影响范围
107
+
108
+ b. 读取所有可能受影响的后续文档
109
+
110
+ c. 生成详细的更新计划:
111
+ ```markdown
112
+ ## 更新计划
113
+
114
+ ### 修改内容
115
+ - <phase>.md: <修改描述>
116
+
117
+ ### 影响分析
118
+ - <后续文档1>: 需要更新"<具体部分>"
119
+ - 位置:第 X.Y 节
120
+ - 修改:<具体修改内容>
121
+ - <后续文档2>: 不需要修改
122
+
123
+ ### 风险评估
124
+ - <风险级别>:<风险描述>
125
+ - 建议:<执行建议>
126
+ ```
127
+
128
+ d. **等待用户确认**:
129
+ ```
130
+ 问题:"是否执行上述更新计划?"
131
+ 选项:
132
+ - 确认执行更新
133
+ - 取消
134
+ ```
135
+
136
+ e. 如果用户确认,批量执行所有更新:
137
+ - 修改目标文档
138
+ - 更新所有受影响的后续文档
139
+ - 在每个修改的文档末尾添加修改记录
140
+
141
+ f. 生成更新报告
142
+
143
+ 7. **更新状态记录**
144
+
145
+ 更新 `6aspecdoc/brown/<name>/status.json`:
146
+
147
+ a. 更新 `lastModified` 时间戳
148
+
149
+ b. 更新 `lastUpdate` 记录:
150
+ ```json
151
+ "lastUpdate": {
152
+ "phase": "<phase>",
153
+ "timestamp": "<时间戳>",
154
+ "description": "<修改描述>",
155
+ "affectedPhases": ["<阶段1>", "<阶段2>"],
156
+ "mode": "simple|smart"
157
+ }
158
+ ```
159
+
160
+ 8. **显示更新结果**
161
+
162
+ **输出**
163
+
164
+ **简单模式输出**:
165
+ ```
166
+ ## 更新完成:<name>
167
+
168
+ **更新阶段**: <phase>
169
+ **更新时间**: <时间戳>
170
+ **更新模式**: 简单模式
171
+
172
+ ### 修改内容
173
+ <修改描述>
174
+
175
+ ### 影响分析和检查清单
176
+
177
+ #### 可能受影响的文档
178
+ - [ ] <文档1>: <检查要点>
179
+ - [ ] <文档2>: <检查要点>
180
+
181
+ #### 建议
182
+ <具体检查建议>
183
+
184
+ ### 下一步
185
+ 请根据检查清单逐一检查可能受影响的文档,必要时手动调整。
186
+ ```
187
+
188
+ **智能模式输出**:
189
+ ```
190
+ ## 更新完成:<name>
191
+
192
+ **更新阶段**: <phase>
193
+ **更新时间**: <时间戳>
194
+ **更新模式**: 智能模式
195
+
196
+ ### 修改内容
197
+ <修改描述>
198
+
199
+ ### 联动更新
200
+ - <文档1>: <更新内容>
201
+ - <文档2>: <更新内容>
202
+
203
+ ### 修改摘要
204
+ - 共修改 N 个文件
205
+ - 新增 X 字
206
+ - 修改 Y 处
207
+
208
+ ### 建议
209
+ 请人工复查关键文档,确认修改内容符合预期。
210
+ ```
211
+
212
+ **历史查看输出**:
213
+ ```
214
+ ## 更新历史:<name>
215
+
216
+ ### 更新记录
217
+ 1. **2026-02-27 10:30** - proposal
218
+ - 描述:补充业务背景说明
219
+
220
+ 2. **2026-02-26 15:20** - specs
221
+ - 描述:调整性能指标要求
222
+
223
+ ### 统计
224
+ - 总更新次数:2
225
+ - 最近更新:2026-02-27 10:30
226
+ - 涉及阶段:proposal, specs
227
+ ```
228
+
229
+ **依赖关系和影响分析规则**
230
+
231
+ 根据文档依赖关系确定影响范围:
232
+
233
+ ```
234
+ understand (现状分析)
235
+
236
+ impact (影响面分析)
237
+
238
+ proposal (Why, What, Impact)
239
+
240
+ specs (功能需求、验收标准)
241
+
242
+ design (技术方案)
243
+
244
+ tasks (任务拆解)
245
+
246
+ implement (代码实现)
247
+ ```
248
+
249
+ **影响分析矩阵**:
250
+
251
+ | 修改位置 | 可能影响的文档 | 影响程度 | 检查重点 |
252
+ |---------|--------------|---------|---------|
253
+ | understand.现状 | impact, proposal | 中 | 影响面、需求背景 |
254
+ | impact.影响面 | proposal, design | 中 | 需求范围、非功能需求 |
255
+ | proposal.Why | specs, design | 中 | 优先级、技术选型 |
256
+ | proposal.What | specs, design, tasks | 高 | 功能需求、技术方案、任务拆解 |
257
+ | proposal.Impact | design | 低 | 非功能需求 |
258
+ | specs.功能需求 | design, tasks | 高 | 技术方案、任务拆解 |
259
+ | specs.验收标准 | tasks | 中 | 任务定义、测试用例 |
260
+ | design.技术方案 | tasks | 高 | 任务拆解、工作量估算 |
261
+ | design.技术选型 | tasks | 中 | 技术栈、工作量估算 |
262
+
263
+ **防护措施**
264
+ - 必须确认需求未归档
265
+ - 必须确认目标阶段已完成(状态为 "done")
266
+ - 必须确认对应文档文件存在
267
+ - 智能模式必须等待用户确认后才执行更新
268
+ - 在实施阶段使用时特别提示代码一致性问题
269
+ - 记录所有更新历史,支持追溯
270
+ - 生成的检查清单必须具体明确
271
+ - 智能模式的影响分析必须准确,避免误判
272
+
273
+ **错误处理**
274
+
275
+ - 如果需求不存在,提示创建新需求
276
+ - 如果需求已归档,提示先取消归档
277
+ - 如果目标阶段不存在或未完成,提示阶段状态
278
+ - 如果对应文档文件不存在,提示文件缺失
279
+ - 如果在实施阶段使用,特别提示:
280
+ ```
281
+ ⚠️ 警告:当前需求处于实施阶段,更新文档后请检查代码是否需要相应调整。
282
+ 如果修改影响代码实现,建议使用 rollback 或创建新需求。
283
+ ```
284
+ - 如果智能模式影响分析失败,降级为简单模式
285
+ - 如果用户取消智能模式的更新计划,停止执行
286
+ - 如果文档修改失败,回滚已修改的文件并报告错误
287
+ - 如果--history选项找不到修改记录,显示"暂无更新历史"
@@ -11,28 +11,29 @@
11
11
  1. **选择需求并检查状态**
12
12
 
13
13
  - 读取 `6aspecdoc/brown/<name>/status.json`
14
- - 确认 `phases.implement` 为 "done"
15
14
  - 获取 `flowDepth`(流程深度)
16
- - 如果未完成 Phase 5,提示先运行 `/6aspec:brown:implement`
15
+ - 检查 `phases.implement` 状态:
16
+ - 如果为 "done" → 完整验证
17
+ - 如果为 "in_progress" → 增量验证
18
+ - 如果为 "pending" → 警告:"尚未开始实现,建议先运行 `/6aspec:brown:implement`",但仍可继续验证
17
19
 
18
20
  2. **读取验证基准文档**
19
21
 
20
- 根据流程深度读取不同的文档:
22
+ 统一的文档读取逻辑,根据文档是否存在自动适配:
21
23
 
22
- **轻量级流程**:
23
- - `artifacts/proposal.md` - 需求提案
24
+ **必读文档**(所有流程都有):
24
25
  - `artifacts/design.md` - 技术方案
25
- - `artifacts/tasks.md` - 任务列表
26
+ - `artifacts/tasks.md` 或 `artifacts/04-tasks-overview.md` - 任务列表
26
27
 
27
- **标准级流程**:
28
- - `artifacts/understanding.md` - 需求理解
29
- - `artifacts/impact-analysis.md` - 影响面分析
30
- - `artifacts/design.md` - 技术方案
31
- - `artifacts/tasks.md` - 任务列表
28
+ **可选文档**(根据存在性读取):
29
+ - `artifacts/understanding.md` - 需求理解(标准级/完整级)
30
+ - `artifacts/proposal.md` - 需求提案(轻量级)
31
+ - `artifacts/impact-analysis.md` - 影响面分析(标准级/完整级)
32
+ - `requirement.md` - 需求描述(快速通道)
32
33
 
33
- **完整级流程**:
34
- - 所有标准级文档
35
- - 加上非功能需求评估(在 impact-analysis.md 中)
34
+ **文档读取策略**:
35
+ - 尝试读取文档,如果不存在则跳过
36
+ - 验证报告中明确标注跳过的检查项
36
37
 
37
38
  3. **初始化验证报告结构**
38
39
 
@@ -60,15 +61,17 @@
60
61
  - 解析 checkbox:`- [ ]`(未完成)vs `- [x]`(已完成)
61
62
  - 统计完成率:X/Y 任务完成
62
63
  - 如果有未完成任务:
63
- - 添加 **CRITICAL** 问题:`Task incomplete: <task-id> - <description>`
64
+ - **增量验证**:添加 **INFO** 说明:`Incremental verification: X/Y tasks completed`
65
+ - **完整验证**:添加 **CRITICAL** 问题:`Task incomplete: <task-id> - <description>`
64
66
  - 建议:`Complete task or mark as done if already implemented`
65
67
 
66
68
  **4.2 影响面覆盖验证**(棕地特色)
67
69
 
68
- 仅适用于标准级/完整级流程:
70
+ 根据文档存在性自动适配:
69
71
 
70
- - 读取 `artifacts/impact-analysis.md`
71
- - 提取影响点列表:
72
+ - 尝试读取 `artifacts/impact-analysis.md`
73
+ - 如果文档不存在,跳过此检查,标注:`Skipped: no impact-analysis.md found`
74
+ - 如果文档存在,提取影响点列表:
72
75
  - 数据库表
73
76
  - 实体类
74
77
  - 服务类
@@ -85,9 +88,10 @@
85
88
 
86
89
  **5.1 需求实现映射**(借鉴 OpenSpec)
87
90
 
88
- - 提取需求关键点:
89
- - 轻量级:从 proposal.md 提取 What 部分
90
- - 标准级/完整级:从 understanding.md 提取需求描述
91
+ - 提取需求关键点(按优先级尝试):
92
+ - 优先:从 understanding.md 提取需求描述
93
+ - 其次:从 proposal.md 提取 What 部分
94
+ - 最后:从 requirement.md 提取需求描述
91
95
  - 对每个需求点:
92
96
  - 搜索代码库查找实现证据
93
97
  - 如果找到,记录文件路径和行号
@@ -98,10 +102,11 @@
98
102
 
99
103
  **5.2 业务规则验证**(棕地特色)
100
104
 
101
- 仅适用于标准级/完整级流程:
105
+ 根据文档存在性自动适配:
102
106
 
103
- - 读取 `artifacts/impact-analysis.md` 中的"业务规则确认"部分
104
- - 提取关键业务规则:
107
+ - 尝试读取 `artifacts/impact-analysis.md` 中的"业务规则确认"部分
108
+ - 如果文档不存在或无业务规则部分,跳过此检查,标注:`Skipped: no business rules found`
109
+ - 如果存在,提取关键业务规则:
105
110
  - 必填校验
106
111
  - 不可修改约束
107
112
  - 继承逻辑
@@ -155,10 +160,11 @@
155
160
 
156
161
  **6.3 非功能需求符合验证**(棕地特色)
157
162
 
158
- 仅适用于完整级流程:
163
+ 根据文档存在性自动适配:
159
164
 
160
- - 读取 `artifacts/impact-analysis.md` 中的"非功能需求评估"部分
161
- - 验证四个维度:
165
+ - 尝试读取 `artifacts/impact-analysis.md` 中的"非功能需求评估"部分
166
+ - 如果文档不存在或无非功能需求部分,跳过此检查,标注:`Skipped: no non-functional requirements found`
167
+ - 如果存在,验证四个维度:
162
168
 
163
169
  **性能**:
164
170
  - 检查是否添加了必要的索引
@@ -192,7 +198,7 @@
192
198
 
193
199
  7. **生成验证报告**
194
200
 
195
- 创建 `6aspecdoc/brown/<name>/artifacts/verification-report.md`(标准级/完整级)或 `6aspecdoc/brown/<name>/artifacts/05-verification-report.md`(完整级):
201
+ 创建 `6aspecdoc/brown/<name>/artifacts/verification-report.md`:
196
202
 
197
203
  ```markdown
198
204
  # 验证报告:<name>
@@ -200,6 +206,8 @@
200
206
  > **需求**: <name>
201
207
  > **流程深度**: 轻量级/标准级/完整级
202
208
  > **验证时间**: <timestamp>
209
+ > **验证类型**: 🔄 增量验证 / ✅ 完整验证
210
+ > **任务进度**: X/Y 已完成 (Z%)
203
211
  > **验证状态**: ✅ 通过 / ⚠️ 有警告 / ❌ 有严重问题
204
212
 
205
213
  ## 验证概览
@@ -244,21 +252,46 @@
244
252
  - **位置**: ProjectApplicationService:123
245
253
  - **建议**: Consider using BusinessLogicException pattern like other services
246
254
 
255
+ ## 验证说明
256
+
257
+ 根据验证类型添加说明:
258
+
259
+ - 如果是增量验证:
260
+ ```
261
+ ⚠️ 这是增量验证(部分任务未完成)。建议在所有任务完成后重新验证。
262
+ ```
263
+
264
+ - 如果是完整验证:
265
+ ```
266
+ ✅ 这是完整验证(所有任务已完成)。
267
+ ```
268
+
247
269
  ## 最终评估
248
270
 
249
- 根据问题严重程度给出评估:
271
+ 根据问题严重程度和验证类型给出评估:
272
+
273
+ - 如果是增量验证:
274
+ ```
275
+ ⚠️ 这是增量验证,当前进度 X/Y 任务完成。
276
+
277
+ 已完成任务的验证结果:
278
+ - [结果摘要]
250
279
 
251
- - 如果有 CRITICAL 问题:
280
+ 未完成任务:
281
+ - [ ] TASK-XXX: <描述>
282
+ ```
283
+
284
+ - 如果是完整验证且有 CRITICAL 问题:
252
285
  ```
253
286
  ❌ 发现 X 个严重问题,必须修复后才能归档。
254
287
  ```
255
288
 
256
- - 如果只有 WARNING:
289
+ - 如果是完整验证且只有 WARNING:
257
290
  ```
258
291
  ⚠️ 没有严重问题,但有 Y 个警告需要考虑。可以归档,但建议修复警告。
259
292
  ```
260
293
 
261
- - 如果全部通过:
294
+ - 如果是完整验证且全部通过:
262
295
  ```
263
296
  ✅ 所有检查通过,可以归档。
264
297
  ```
@@ -276,19 +309,59 @@
276
309
 
277
310
  ## 下一步
278
311
 
279
- 根据验证结果给出建议:
280
- - 如果有 CRITICAL:修复严重问题后重新验证
281
- - 如果只有 WARNING:可以归档,但建议修复警告
282
- - 如果全部通过:运行 `/6aspec:brown:review` 进行实施后评估(完整级)或 `/6aspec:brown:archive` 归档
312
+ 根据验证类型和结果给出建议:
313
+
314
+ - 如果是增量验证:
315
+ ```
316
+ 1. 继续完成剩余任务
317
+ 2. 完成后重新运行 `/6aspec:brown:verify` 进行完整验证
318
+ ```
319
+
320
+ - 如果是完整验证且有 CRITICAL:
321
+ ```
322
+ 修复严重问题后重新验证
323
+ ```
324
+
325
+ - 如果是完整验证且只有 WARNING:
326
+ ```
327
+ - 轻量级/标准级:可以运行 `/6aspec:brown:archive` 归档,但建议修复警告
328
+ - 完整级:可以运行 `/6aspec:brown:continue` 进入 review 阶段,但建议修复警告
329
+ ```
330
+
331
+ - 如果是完整验证且全部通过:
332
+ ```
333
+ - 轻量级/标准级:运行 `/6aspec:brown:archive` 归档
334
+ - 完整级:运行 `/6aspec:brown:continue` 进入 review 阶段
335
+ ```
283
336
  ```
284
337
 
285
338
  8. **更新状态**
286
339
 
287
- 如果验证通过(无 CRITICAL 问题),更新 `status.json`:
340
+ 根据流程深度、验证类型和验证结果决定是否更新状态:
341
+
342
+ **轻量级/标准级流程**:
343
+ - 不更新 status 和 phases(verify 是可选的)
344
+ - 在 `verificationRuns` 数组中添加本次验证记录:
345
+ ```json
346
+ {
347
+ "verificationRuns": [
348
+ {
349
+ "timestamp": "<timestamp>",
350
+ "type": "incremental" / "complete",
351
+ "status": "passed" / "warning" / "failed",
352
+ "criticalIssues": 0,
353
+ "warnings": 2,
354
+ "tasksCompleted": "5/8"
355
+ }
356
+ ]
357
+ }
358
+ ```
359
+
360
+ **完整级流程**:
361
+ - 只有在完整验证(implement 已完成)且验证通过(无 CRITICAL 问题)时才更新状态:
288
362
  ```json
289
363
  {
290
364
  "status": "review_pending",
291
- "status": "completed",
292
365
  "phases": {
293
366
  ...
294
367
  "verify": "done",
@@ -296,6 +369,7 @@
296
369
  }
297
370
  }
298
371
  ```
372
+ - 如果是增量验证或验证未通过,不更新状态
299
373
 
300
374
  **输出**
301
375
 
@@ -303,11 +377,13 @@
303
377
  ## 验证完成:<name>
304
378
 
305
379
  **流程深度**: 轻量级/标准级/完整级
380
+ **验证类型**: 🔄 增量验证 / ✅ 完整验证
381
+ **任务进度**: X/Y 已完成 (Z%)
306
382
  **验证状态**: ✅ 通过 / ⚠️ 有警告 / ❌ 有严重问题
307
383
 
308
384
  ### 验证概览
309
- - Completeness: X/Y 任务完成, M/N 影响点覆盖
310
- - Correctness: P/Q 需求实现, R/S 业务规则验证
385
+ - Completeness: X/Y 任务完成, M/N 影响点覆盖(或跳过)
386
+ - Correctness: P/Q 需求实现, R/S 业务规则验证(或跳过)
311
387
  - Coherence: 设计遵循/代码一致
312
388
 
313
389
  ### 问题统计
@@ -316,13 +392,13 @@
316
392
  - SUGGESTION: Z 个(建议修复)
317
393
 
318
394
  ### 最终评估
319
- <根据问题严重程度给出评估>
395
+ <根据验证类型和问题严重程度给出评估>
320
396
 
321
397
  ### 文档位置
322
398
  6aspecdoc/brown/<name>/artifacts/verification-report.md
323
399
 
324
400
  ### 下一步
325
- <根据验证结果给出建议>
401
+ <根据验证类型和结果给出建议>
326
402
  ```
327
403
 
328
404
  **验证启发式规则**(借鉴 OpenSpec)
@@ -335,26 +411,30 @@
335
411
 
336
412
  **优雅降级**(借鉴 OpenSpec)
337
413
 
338
- 根据流程深度调整验证范围:
414
+ 统一的验证流程,根据文档存在性自动适配:
339
415
 
340
- - **轻量级流程**:
341
- - 验证:任务完成度 + 设计遵循
342
- - 跳过:影响面覆盖、业务规则、非功能需求
343
- - 说明:`Lightweight flow: skipped impact/business rule checks`
416
+ - **文档存在性检查**:
417
+ - 尝试读取每个验证所需的文档
418
+ - 如果文档不存在,跳过相应的验证检查
419
+ - 在验证报告中明确标注跳过的检查项
344
420
 
345
- - **标准级流程**:
346
- - 验证:任务完成度 + 影响面覆盖 + 业务规则 + 设计遵循
347
- - 跳过:非功能需求详细验证
348
- - 说明:`Standard flow: skipped detailed non-functional requirement checks`
421
+ - **自动适配示例**:
422
+ - 如果没有 `impact-analysis.md` 跳过影响面覆盖验证、业务规则验证、非功能需求验证
423
+ - 如果没有 `understanding.md` → 从 `proposal.md` 或 `requirement.md` 提取需求
424
+ - 如果没有非功能需求评估部分 跳过非功能需求验证
349
425
 
350
- - **完整级流程**:
351
- - 验证:所有三个维度的全部检查
352
- - 说明:`Complete flow: all checks performed`
426
+ - **验证报告标注**:
427
+ - 跳过的检查项标注为:`Skipped: <reason>`
428
+ - 例如:`Skipped: no impact-analysis.md found`
429
+ - 例如:`Skipped: no business rules section in impact-analysis.md`
353
430
 
354
431
  **防护措施**
355
- - 必须先完成 Phase 5(implement)
432
+ - 支持在任何时候运行 verify(增量验证或完整验证)
356
433
  - 验证必须基于文档基准,不能主观判断
357
434
  - 发现问题必须明确标注严重程度(CRITICAL/WARNING/SUGGESTION)
358
435
  - 每个问题必须提供具体的、可操作的建议
359
- - 如果验证未通过(有 CRITICAL 问题),不能进入下一阶段
360
- - 根据流程深度优雅降级,不要对轻量级流程执行完整级的验证
436
+ - 增量验证时,未完成任务标注为 INFO,不作为 CRITICAL 问题
437
+ - 完整验证时,未完成任务标注为 CRITICAL 问题
438
+ - 轻量级/标准级流程的 verify 不更新状态
439
+ - 完整级流程只有在完整验证且通过时才更新状态
440
+ - 根据文档存在性自动适配验证范围,跳过的检查项必须明确标注
@@ -66,6 +66,21 @@ alwaysApply: false
66
66
  ## 2. 质量控制 (Quality Control)
67
67
 
68
68
  在输出代码后,必须进行自我审查:
69
+
70
+ ### 2.1 代码规范遵循与检查
71
+ **必须严格遵循代码规范**:`.6aspec/rules/biz/code.md`,并使用其中的"检查清单"章节进行自我验证。
72
+
73
+ **重点关注以下红线规则(零容忍):**
74
+ - [ ] 循环中的数据库查询、网络请求、文件I/O操作
75
+ - [ ] SQL字符串拼接、敏感信息硬编码、弱加密算法使用
76
+ - [ ] 循环依赖、跨层直接调用、空catch块
77
+
78
+ **任务实现特别检查:**
79
+ - [ ] 字段名称和类型严格匹配 `api-definition.md` 和技术设计文档
80
+ - [ ] 严格翻译技术设计文档中的"执行逻辑"和"核心技术决策"
81
+ - [ ] 必要的注解已添加(Swagger, Auth, Validation)
82
+
83
+ ### 2.2 技术检查
69
84
  1. **Lint 检查**:运行 `read_lints` 检查新文件,修复所有 Import 错误和语法错误。
70
85
  2. **不写测试**:严禁编写 `src/test` 下的单元测试代码(除非用户明确要求)。
71
86
  3. **不修改无关文件**:严禁修改与本任务无关的现有代码(除非是必要的 Entity 关联更新)。
@@ -110,7 +110,18 @@
110
110
 
111
111
  **这是本 SOP 的核心价值环节。**
112
112
 
113
- 基于 Step 2 的初步分析,AI 必须主动列出 **3-5 个关键不确定点或风险点**,向用户提问确认。
113
+ 基于 Step 2 的初步分析,AI 必须:
114
+ 1. **识别所有关键不确定点或风险点**
115
+ 2. **按优先级排序**,选择最重要的 **3-5 个**向用户提问确认
116
+ 3. **其他问题写入待确认项**,标注优先级,后续通过 `clarify` 命令继续澄清
117
+
118
+ #### 优先级判断标准
119
+
120
+ | 优先级 | 定义 | 示例 |
121
+ | :--- | :--- | :--- |
122
+ | **P0** | 影响核心流程,不明确则无法进行领域建模 | 核心业务规则、主流程分支逻辑、关键状态定义 |
123
+ | **P1** | 影响设计决策或存在实施风险 | 性能要求、集成方式、并发处理策略 |
124
+ | **P2** | 影响细节实现但不阻塞主流程 | UI细节、提示文案、次要分支场景 |
114
125
 
115
126
  #### 反向提问的分类
116
127
 
@@ -124,6 +135,8 @@
124
135
 
125
136
  #### 提问格式
126
137
 
138
+ **如果识别出的关键问题 ≤ 5 个**,全部向用户提问:
139
+
127
140
  ```markdown
128
141
  ---
129
142
 
@@ -132,6 +145,7 @@
132
145
  基于对 PRD 的分析,以下 N 个问题需要确认后才能继续:
133
146
 
134
147
  ### Q1: [问题标题]
148
+ **优先级**:P0 / P1 / P2
135
149
  **类别**:语义模糊 / 边界缺失 / 流程遗漏 / 规则冲突 / 非功能隐患
136
150
  **来源**:PRD 第X章 / 第X节
137
151
  **问题描述**:<具体问题>
@@ -148,6 +162,35 @@
148
162
  - 告知哪些问题需要与产品/业务方再确认(将记录为"待确认项")
149
163
  ```
150
164
 
165
+ **如果识别出的关键问题 > 5 个**,只提问最重要的 3-5 个,其他写入待确认项:
166
+
167
+ ```markdown
168
+ ---
169
+
170
+ ## 🔍 需求澄清确认
171
+
172
+ 基于对 PRD 的分析,识别出 N 个关键不确定点。以下是最重要的 3-5 个问题,需要优先确认:
173
+
174
+ ### Q1: [问题标题]
175
+ **优先级**:P0 / P1
176
+ **类别**:语义模糊 / 边界缺失 / 流程遗漏 / 规则冲突 / 非功能隐患
177
+ **来源**:PRD 第X章 / 第X节
178
+ **问题描述**:<具体问题>
179
+ **AI 建议**:<如果有合理的默认假设,可以给出建议供用户参考>
180
+
181
+ ### Q2: [问题标题]
182
+ ...
183
+
184
+ ---
185
+
186
+ ⚠️ **还有 X 个其他关键问题已记录到待确认项**(详见生成的 requirement.md),建议后续通过 `/6aspec:green:clarify` 继续澄清。
187
+
188
+ 请逐一确认以上问题,您可以:
189
+ - 直接回答每个问题
190
+ - 提供补充文档
191
+ - 告知哪些问题需要与产品/业务方再确认(将记录为"待确认项")
192
+ ```
193
+
151
194
  **重要**:
152
195
  - 必须等待用户回复后再继续,不要跳过此步骤
153
196
  - 如果用户表示某些问题需要后续确认,记录为"待确认项"写入 requirement.md
@@ -226,11 +269,11 @@
226
269
  | 兼容性 | <如有> | |
227
270
 
228
271
  ## 8. 待确认项
229
- > 以下问题尚需与产品/业务方进一步确认,不阻塞领域建模但可能影响详细设计。
272
+ > 以下问题尚需与产品/业务方进一步确认。P0/P1 问题会阻塞流程,需优先澄清;P2 问题不阻塞领域建模但可能影响详细设计。
230
273
 
231
- | 序号 | 问题 | 状态 | 负责人 | 备注 |
232
- | :--- | :--- | :--- | :--- | :--- |
233
- | TBD-01 | <待确认问题> | 待确认/已确认 | <负责人> | <备注> |
274
+ | 序号 | 优先级 | 问题 | 类别 | AI建议 | 状态 | 备注 |
275
+ | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
276
+ | TBD-01 | P0/P1/P2 | <待确认问题> | 语义模糊/边界缺失/流程遗漏/规则冲突/非功能隐患 | <AI建议> | 待确认/已确认 | <备注> |
234
277
 
235
278
  ## 9. 附录
236
279
 
@@ -246,7 +289,11 @@
246
289
 
247
290
  ### Step 5: 更新状态文件
248
291
 
249
- 完成需求澄清文档后,更新 `.green-status.json`:
292
+ 完成需求澄清文档后,根据待确认项的优先级更新 `.green-status.json`:
293
+
294
+ #### 情况 1:无待确认项,或只有 P2 待确认项
295
+
296
+ 状态设置为 `requirement_clarified`,可以进入领域建模:
250
297
 
251
298
  ```json
252
299
  {
@@ -268,19 +315,51 @@
268
315
  }
269
316
  ```
270
317
 
271
- **注意**:如果存在较多"待确认项"(TBD ≥ 3 个且涉及核心流程),建议状态保持为 `created`,并提示用户:
318
+ **如果有 P2 待确认项**,向用户提示:
272
319
  ```
273
- ⚠️ 当前有 N 个待确认项涉及核心流程,建议先与产品/业务方确认后,再运行 /6aspec:green:clarify 继续澄清。
320
+ 核心问题已澄清,需求澄清文档已生成。
321
+
322
+ 📋 还有 N 个次要待确认项(P2)记录在 requirement.md 中,不阻塞领域建模,可后续通过 /6aspec:green:clarify 补充澄清。
323
+
324
+ 下一步:运行 /6aspec:green:model 开始领域建模
274
325
  ```
275
326
 
276
- 此时 `nextAction` 应设置为:
327
+ #### 情况 2:存在 P0 或 P1 待确认项
328
+
329
+ 状态保持为 `created`,需要先澄清后才能进入建模:
330
+
277
331
  ```json
278
332
  {
279
- "command": "clarify",
280
- "description": "继续需求澄清(有 N 个核心待确认项)"
333
+ "status": "created",
334
+ "lastModified": "<ISO8601-now>",
335
+ "artifacts": {
336
+ "requirement": {
337
+ "status": "partial",
338
+ "completedAt": "<ISO8601-now>"
339
+ },
340
+ "models": {
341
+ "status": "blocked"
342
+ }
343
+ },
344
+ "nextAction": {
345
+ "command": "clarify",
346
+ "description": "继续需求澄清(有 N 个 P0/P1 待确认项)"
347
+ }
281
348
  }
282
349
  ```
283
350
 
351
+ 向用户提示:
352
+ ```
353
+ ⚠️ 需求初步澄清已完成,但还有 N 个重要待确认项(P0: X个, P1: Y个)记录在 requirement.md 中。
354
+
355
+ 这些问题涉及核心流程或设计决策,建议先与产品/业务方确认后,再运行 /6aspec:green:clarify 继续澄清。
356
+
357
+ 待确认项列表:
358
+ - TBD-01 (P0): <问题简述>
359
+ - TBD-02 (P1): <问题简述>
360
+ ...
361
+ ```
362
+
284
363
  ## 输出要求
285
364
  1. 格式:Markdown 源码格式
286
365
  2. 文档位置:`6aspecdoc/green/<feature-name>/requirement.md`
@@ -0,0 +1,11 @@
1
+ ---
2
+ name: "6aspec:brown: Update"
3
+ description: 非破坏性地更新指定阶段的文档
4
+ category: Workflow
5
+ tags: [workflow, requirement, update, document]
6
+ ---
7
+
8
+ 1. Immediate response upon activation: brown field requirement workflow - **Update** has been activated
9
+ 2. **Read and strictly follow the brown field constitution**: `.6aspec/rules/brown/brown_constitution.md`
10
+ 3. Read file: `.6aspec/rules/brown/brown_update_sop.md`
11
+ 4. Strictly follow the SOP defined in that file
@@ -0,0 +1,9 @@
1
+ ---
2
+ description: 非破坏性地更新指定阶段的文档
3
+ alwaysApply: false
4
+ ---
5
+
6
+ 1. Immediate response upon activation: brown field requirement workflow - **Update** has been activated
7
+ 2. **Read and strictly follow the brown field constitution**: `.6aspec/rules/brown/brown_constitution.md`
8
+ 3. Read file: `.6aspec/rules/brown/brown_update_sop.md`
9
+ 4. Strictly follow the SOP defined in that file
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "6aspec",
3
- "version": "2.0.0-dev.22",
3
+ "version": "2.0.0-dev.24",
4
4
  "description": "6Aspec - 轻量级 spec 驱动开发框架,支持 Cursor 和 Claude Code",
5
5
  "main": "lib/installer.js",
6
6
  "bin": {