cc-devflow 1.0.1

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.
Files changed (277) hide show
  1. package/.claude/CLAUDE.md +83 -0
  2. package/.claude/agents/architecture-designer.md +443 -0
  3. package/.claude/agents/bug-analyzer.md +382 -0
  4. package/.claude/agents/checklist-agent.md +175 -0
  5. package/.claude/agents/clarify-analyst.md +50 -0
  6. package/.claude/agents/code-reviewer.md +71 -0
  7. package/.claude/agents/codex-analyzer.md +39 -0
  8. package/.claude/agents/compatibility-checker.md +580 -0
  9. package/.claude/agents/consistency-checker.md +532 -0
  10. package/.claude/agents/impact-analyzer.md +441 -0
  11. package/.claude/agents/planner.md +230 -0
  12. package/.claude/agents/prd-writer.md +320 -0
  13. package/.claude/agents/project-guidelines-generator.md +1329 -0
  14. package/.claude/agents/qa-tester.md +313 -0
  15. package/.claude/agents/release-manager.md +295 -0
  16. package/.claude/agents/security-reviewer.md +314 -0
  17. package/.claude/agents/style-guide-generator.md +458 -0
  18. package/.claude/agents/tech-architect.md +516 -0
  19. package/.claude/agents/ui-designer.md +485 -0
  20. package/.claude/commands/code-review-high.md +58 -0
  21. package/.claude/commands/core-architecture.md +429 -0
  22. package/.claude/commands/core-guidelines.md +486 -0
  23. package/.claude/commands/core-roadmap.md +439 -0
  24. package/.claude/commands/core-style.md +293 -0
  25. package/.claude/commands/flow-archive.md +245 -0
  26. package/.claude/commands/flow-checklist.md +260 -0
  27. package/.claude/commands/flow-clarify.md +136 -0
  28. package/.claude/commands/flow-constitution.md +82 -0
  29. package/.claude/commands/flow-dev.md +134 -0
  30. package/.claude/commands/flow-epic.md +150 -0
  31. package/.claude/commands/flow-fix.md +104 -0
  32. package/.claude/commands/flow-ideate.md +214 -0
  33. package/.claude/commands/flow-init.md +313 -0
  34. package/.claude/commands/flow-new.md +394 -0
  35. package/.claude/commands/flow-prd.md +131 -0
  36. package/.claude/commands/flow-qa.md +93 -0
  37. package/.claude/commands/flow-release.md +92 -0
  38. package/.claude/commands/flow-restart.md +98 -0
  39. package/.claude/commands/flow-status.md +64 -0
  40. package/.claude/commands/flow-tech.md +142 -0
  41. package/.claude/commands/flow-ui.md +189 -0
  42. package/.claude/commands/flow-update.md +111 -0
  43. package/.claude/commands/flow-upgrade.md +115 -0
  44. package/.claude/commands/flow-verify.md +96 -0
  45. package/.claude/commands/problem-analyzer.md +60 -0
  46. package/.claude/config/quality-rules.yml +161 -0
  47. package/.claude/docs/SPEC_KIT_CONSTITUTION_ANALYSIS.md +426 -0
  48. package/.claude/docs/design/consistency-conflict-detection-algorithms.md +658 -0
  49. package/.claude/docs/design/intent-driven-input-design.md +380 -0
  50. package/.claude/docs/design/prd-version-management-design.md +437 -0
  51. package/.claude/docs/guides/INIT_TROUBLESHOOTING.md +117 -0
  52. package/.claude/docs/guides/NEW_TROUBLESHOOTING.md +151 -0
  53. package/.claude/docs/guides/ROADMAP_TROUBLESHOOTING.md +188 -0
  54. package/.claude/docs/guides/TASK_COMPLETION_MARKING.md +338 -0
  55. package/.claude/docs/templates/ARCHITECTURE_TEMPLATE.md +633 -0
  56. package/.claude/docs/templates/BACKLOG_TEMPLATE.md +261 -0
  57. package/.claude/docs/templates/CHECKLIST_TEMPLATE.md +52 -0
  58. package/.claude/docs/templates/CLARIFICATION_REPORT_TEMPLATE.md +206 -0
  59. package/.claude/docs/templates/CODE_REVIEW_TEMPLATE.md +71 -0
  60. package/.claude/docs/templates/EPIC_TEMPLATE.md +805 -0
  61. package/.claude/docs/templates/INIT_FLOW_TEMPLATE.md +213 -0
  62. package/.claude/docs/templates/INTENT_CLARIFICATION_TEMPLATE.md +57 -0
  63. package/.claude/docs/templates/NEW_ORCHESTRATION_TEMPLATE.md +148 -0
  64. package/.claude/docs/templates/PRD_TEMPLATE.md +562 -0
  65. package/.claude/docs/templates/RESEARCH_TEMPLATE.md +276 -0
  66. package/.claude/docs/templates/REVIEW-HIGH.md +57 -0
  67. package/.claude/docs/templates/ROADMAP_DIALOGUE_TEMPLATE.md +198 -0
  68. package/.claude/docs/templates/ROADMAP_TEMPLATE.md +310 -0
  69. package/.claude/docs/templates/STYLE_TEMPLATE.md +1266 -0
  70. package/.claude/docs/templates/TASKS_TEMPLATE.md +523 -0
  71. package/.claude/docs/templates/TECH_DESIGN_TEMPLATE.md +1019 -0
  72. package/.claude/docs/templates/UI_PROTOTYPE_TEMPLATE.md +1436 -0
  73. package/.claude/guides/agent-guides/agent-coordination-guide.md +459 -0
  74. package/.claude/guides/project-guidelines-system.md +463 -0
  75. package/.claude/guides/technical-guides/datetime-handling-guide.md +563 -0
  76. package/.claude/guides/technical-guides/git-github-guide.md +642 -0
  77. package/.claude/guides/technical-guides/test-execution-guide.md +618 -0
  78. package/.claude/guides/workflow-guides/bug-fix-orchestrator.md +217 -0
  79. package/.claude/guides/workflow-guides/flow-orchestrator.md +282 -0
  80. package/.claude/hooks/checklist-gate.js +397 -0
  81. package/.claude/hooks/error-handling-reminder.sh +12 -0
  82. package/.claude/hooks/error-handling-reminder.ts +459 -0
  83. package/.claude/hooks/post-tool-use-tracker.sh +280 -0
  84. package/.claude/hooks/pre-tool-use-guardrail.sh +36 -0
  85. package/.claude/hooks/pre-tool-use-guardrail.ts +342 -0
  86. package/.claude/hooks/skill-activation-prompt.sh +36 -0
  87. package/.claude/hooks/skill-activation-prompt.ts +214 -0
  88. package/.claude/hooks/state/skills-used-test-guard.json +3 -0
  89. package/.claude/rules/devflow-conventions.md +305 -0
  90. package/.claude/rules/project-constitution.md +748 -0
  91. package/.claude/schemas/constitution.schema.json +43 -0
  92. package/.claude/scripts/analyze-upgrade-impact.sh +200 -0
  93. package/.claude/scripts/archive-requirement.sh +351 -0
  94. package/.claude/scripts/calculate-checklist-completion.sh +243 -0
  95. package/.claude/scripts/calculate-quarter.sh +206 -0
  96. package/.claude/scripts/check-dependencies.sh +409 -0
  97. package/.claude/scripts/check-prerequisites.sh +232 -0
  98. package/.claude/scripts/check-task-status.sh +264 -0
  99. package/.claude/scripts/checklist-errors.sh +131 -0
  100. package/.claude/scripts/common.sh +570 -0
  101. package/.claude/scripts/consolidate-research.sh +182 -0
  102. package/.claude/scripts/create-requirement.sh +426 -0
  103. package/.claude/scripts/export-contracts.sh +117 -0
  104. package/.claude/scripts/extract-data-model.sh +78 -0
  105. package/.claude/scripts/generate-clarification-questions.sh +377 -0
  106. package/.claude/scripts/generate-clarification-report.sh +463 -0
  107. package/.claude/scripts/generate-quickstart.sh +146 -0
  108. package/.claude/scripts/generate-research-tasks.sh +157 -0
  109. package/.claude/scripts/generate-status-report.sh +523 -0
  110. package/.claude/scripts/generate-tech-analysis.sh +46 -0
  111. package/.claude/scripts/locate-requirement-in-roadmap.sh +233 -0
  112. package/.claude/scripts/manage-constitution.sh +602 -0
  113. package/.claude/scripts/mark-task-complete.sh +198 -0
  114. package/.claude/scripts/populate-research-tasks.sh +259 -0
  115. package/.claude/scripts/recover-workflow.sh +460 -0
  116. package/.claude/scripts/run-clarify-scan.sh +601 -0
  117. package/.claude/scripts/run-high-review.sh +62 -0
  118. package/.claude/scripts/run-problem-analysis.sh +68 -0
  119. package/.claude/scripts/setup-epic.sh +173 -0
  120. package/.claude/scripts/sync-roadmap-progress.sh +300 -0
  121. package/.claude/scripts/sync-task-marks.sh +199 -0
  122. package/.claude/scripts/test-clarify-scan.sh +515 -0
  123. package/.claude/scripts/update-agent-context.sh +806 -0
  124. package/.claude/scripts/validate-constitution.sh +567 -0
  125. package/.claude/scripts/validate-hooks.sh +487 -0
  126. package/.claude/scripts/validate-research.sh +332 -0
  127. package/.claude/scripts/validate-scope-boundary.sh +493 -0
  128. package/.claude/scripts/verify-setup.sh +37 -0
  129. package/.claude/settings.json +76 -0
  130. package/.claude/skills/_reference-implementations/README.md +96 -0
  131. package/.claude/skills/_reference-implementations/backend-express-prisma/SKILL.md +302 -0
  132. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/architecture-overview.md +451 -0
  133. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/async-and-errors.md +307 -0
  134. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/complete-examples.md +638 -0
  135. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/configuration.md +275 -0
  136. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/database-patterns.md +224 -0
  137. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/middleware-guide.md +213 -0
  138. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/routing-and-controllers.md +756 -0
  139. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/sentry-and-monitoring.md +336 -0
  140. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/services-and-repositories.md +789 -0
  141. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/testing-guide.md +235 -0
  142. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/validation-patterns.md +754 -0
  143. package/.claude/skills/_reference-implementations/frontend-react-mui/SKILL.md +399 -0
  144. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/common-patterns.md +331 -0
  145. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/complete-examples.md +872 -0
  146. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/component-patterns.md +502 -0
  147. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/data-fetching.md +767 -0
  148. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/file-organization.md +502 -0
  149. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/loading-and-error-states.md +501 -0
  150. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/performance.md +406 -0
  151. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/routing-guide.md +364 -0
  152. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/styling-guide.md +428 -0
  153. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/typescript-standards.md +418 -0
  154. package/.claude/skills/cc-devflow-orchestrator/SKILL.md +229 -0
  155. package/.claude/skills/constitution-guardian/SKILL.md +306 -0
  156. package/.claude/skills/devflow-constitution-quick-ref/SKILL.md +374 -0
  157. package/.claude/skills/devflow-file-standards/SKILL.md +353 -0
  158. package/.claude/skills/devflow-tdd-enforcer/SKILL.md +192 -0
  159. package/.claude/skills/skill-developer/ADVANCED.md +197 -0
  160. package/.claude/skills/skill-developer/HOOK_MECHANISMS.md +306 -0
  161. package/.claude/skills/skill-developer/PATTERNS_LIBRARY.md +152 -0
  162. package/.claude/skills/skill-developer/SKILL.md +426 -0
  163. package/.claude/skills/skill-developer/SKILL_RULES_REFERENCE.md +315 -0
  164. package/.claude/skills/skill-developer/TRIGGER_TYPES.md +305 -0
  165. package/.claude/skills/skill-developer/TROUBLESHOOTING.md +514 -0
  166. package/.claude/skills/skill-rules.json +213 -0
  167. package/.claude/tests/README.md +300 -0
  168. package/.claude/tests/TODO.md +69 -0
  169. package/.claude/tests/__pycache__/test_analyze_upgrade_impact.cpython-311-pytest-7.2.2.pyc +0 -0
  170. package/.claude/tests/__pycache__/test_consolidate_research.cpython-311-pytest-7.2.2.pyc +0 -0
  171. package/.claude/tests/__pycache__/test_export_contracts.cpython-311-pytest-7.2.2.pyc +0 -0
  172. package/.claude/tests/__pycache__/test_extract_data_model.cpython-311-pytest-7.2.2.pyc +0 -0
  173. package/.claude/tests/__pycache__/test_generate_quickstart.cpython-311-pytest-7.2.2.pyc +0 -0
  174. package/.claude/tests/__pycache__/test_generate_research_tasks.cpython-311-pytest-7.2.2.pyc +0 -0
  175. package/.claude/tests/constitution/run_all_constitution_tests.sh +111 -0
  176. package/.claude/tests/constitution/test_agent_assignment.sh +207 -0
  177. package/.claude/tests/constitution/test_article_coverage.sh +201 -0
  178. package/.claude/tests/constitution/test_template_completeness.sh +150 -0
  179. package/.claude/tests/constitution/test_version_consistency.sh +120 -0
  180. package/.claude/tests/fixtures/spec_delta_full.md +16 -0
  181. package/.claude/tests/fixtures/tasks_progress_sample.md +5 -0
  182. package/.claude/tests/run-all-tests.sh +229 -0
  183. package/.claude/tests/scripts/run.sh +30 -0
  184. package/.claude/tests/scripts/test-framework.sh +128 -0
  185. package/.claude/tests/scripts/test_check_prerequisites.sh +511 -0
  186. package/.claude/tests/scripts/test_check_prerequisites.sh.bak +504 -0
  187. package/.claude/tests/scripts/test_check_prerequisites.sh.bak2 +505 -0
  188. package/.claude/tests/scripts/test_check_prerequisites.sh.bak3 +506 -0
  189. package/.claude/tests/scripts/test_check_prerequisites.sh.bak4 +507 -0
  190. package/.claude/tests/scripts/test_check_prerequisites.sh.bak5 +508 -0
  191. package/.claude/tests/scripts/test_check_task_status.sh +499 -0
  192. package/.claude/tests/scripts/test_common.sh +244 -0
  193. package/.claude/tests/scripts/test_generate_status_report.sh +71 -0
  194. package/.claude/tests/scripts/test_mark_task_complete.sh +441 -0
  195. package/.claude/tests/scripts/test_mark_task_complete.sh.backup +410 -0
  196. package/.claude/tests/scripts/test_recover_workflow.sh +304 -0
  197. package/.claude/tests/scripts/test_setup_epic.sh +437 -0
  198. package/.claude/tests/scripts/test_sync_task_marks.sh +196 -0
  199. package/.claude/tests/scripts/test_validate_constitution.sh +74 -0
  200. package/.claude/tests/scripts/test_validate_research.sh +462 -0
  201. package/.claude/tests/slugify.bats +82 -0
  202. package/.claude/tests/test-framework.sh +732 -0
  203. package/.claude/tests/test_analyze_upgrade_impact.py +34 -0
  204. package/.claude/tests/test_consolidate_research.py +48 -0
  205. package/.claude/tests/test_export_contracts.py +43 -0
  206. package/.claude/tests/test_extract_data_model.py +33 -0
  207. package/.claude/tests/test_generate_quickstart.py +50 -0
  208. package/.claude/tests/test_generate_research_tasks.py +52 -0
  209. package/.claude/tsc-cache/6e64f818-6398-49ca-8623-581a9af85c44/edited-files.log +1 -0
  210. package/.claude/tsc-cache/795ba6e3-b98a-423b-bab2-51aa62812569/affected-repos.txt +1 -0
  211. package/.claude/tsc-cache/795ba6e3-b98a-423b-bab2-51aa62812569/edited-files.log +1 -0
  212. package/.claude/tsc-cache/ae335694-be5a-4ba4-a1a0-b676c09a7906/affected-repos.txt +1 -0
  213. package/.claude/tsc-cache/ae335694-be5a-4ba4-a1a0-b676c09a7906/edited-files.log +1 -0
  214. package/CHANGELOG.md +507 -0
  215. package/LICENSE +21 -0
  216. package/README.md +534 -0
  217. package/README.zh-CN.md +530 -0
  218. package/bin/adapt.js +240 -0
  219. package/bin/cc-devflow-cli.js +185 -0
  220. package/bin/cc-devflow.js +78 -0
  221. package/config/adapters.yml +5 -0
  222. package/config/schema/adapters.schema.json +44 -0
  223. package/docs/CLAUDE.md +26 -0
  224. package/docs/commands/README.md +61 -0
  225. package/docs/commands/README.zh-CN.md +55 -0
  226. package/docs/commands/core-roadmap.md +106 -0
  227. package/docs/commands/core-roadmap.zh-CN.md +102 -0
  228. package/docs/commands/core-style.md +405 -0
  229. package/docs/commands/core-style.zh-CN.md +405 -0
  230. package/docs/commands/flow-init.md +134 -0
  231. package/docs/commands/flow-init.zh-CN.md +163 -0
  232. package/docs/commands/flow-new.md +274 -0
  233. package/docs/commands/flow-new.zh-CN.md +270 -0
  234. package/docs/guides/getting-started.md +204 -0
  235. package/docs/guides/getting-started.zh-CN.md +152 -0
  236. package/lib/adapters/adapter-interface.js +57 -0
  237. package/lib/adapters/claude-adapter.js +74 -0
  238. package/lib/adapters/codex-adapter.js +40 -0
  239. package/lib/adapters/config-validator.js +68 -0
  240. package/lib/adapters/logger.js +42 -0
  241. package/lib/adapters/registry.js +153 -0
  242. package/lib/compiler/CLAUDE.md +92 -0
  243. package/lib/compiler/__tests__/drift.test.js +215 -0
  244. package/lib/compiler/__tests__/errors.test.js +184 -0
  245. package/lib/compiler/__tests__/incremental.test.js +174 -0
  246. package/lib/compiler/__tests__/integration.test.js +174 -0
  247. package/lib/compiler/__tests__/manifest.test.js +233 -0
  248. package/lib/compiler/__tests__/parser.test.js +456 -0
  249. package/lib/compiler/__tests__/schemas.test.js +301 -0
  250. package/lib/compiler/__tests__/skills-registry.test.js +125 -0
  251. package/lib/compiler/__tests__/transformer.test.js +286 -0
  252. package/lib/compiler/emitters/antigravity-emitter.js +171 -0
  253. package/lib/compiler/emitters/base-emitter.js +73 -0
  254. package/lib/compiler/emitters/codex-emitter.js +52 -0
  255. package/lib/compiler/emitters/cursor-emitter.js +31 -0
  256. package/lib/compiler/emitters/index.js +50 -0
  257. package/lib/compiler/emitters/qwen-emitter.js +39 -0
  258. package/lib/compiler/errors.js +119 -0
  259. package/lib/compiler/index.js +256 -0
  260. package/lib/compiler/manifest.js +242 -0
  261. package/lib/compiler/parser.js +258 -0
  262. package/lib/compiler/platforms.js +113 -0
  263. package/lib/compiler/resource-copier.js +320 -0
  264. package/lib/compiler/rules-emitters/__tests__/antigravity-rules-emitter.test.js +191 -0
  265. package/lib/compiler/rules-emitters/__tests__/codex-rules-emitter.test.js +109 -0
  266. package/lib/compiler/rules-emitters/__tests__/cursor-rules-emitter.test.js +123 -0
  267. package/lib/compiler/rules-emitters/__tests__/qwen-rules-emitter.test.js +123 -0
  268. package/lib/compiler/rules-emitters/antigravity-rules-emitter.js +253 -0
  269. package/lib/compiler/rules-emitters/base-rules-emitter.js +83 -0
  270. package/lib/compiler/rules-emitters/codex-rules-emitter.js +116 -0
  271. package/lib/compiler/rules-emitters/cursor-rules-emitter.js +98 -0
  272. package/lib/compiler/rules-emitters/index.js +71 -0
  273. package/lib/compiler/rules-emitters/qwen-rules-emitter.js +70 -0
  274. package/lib/compiler/schemas.js +144 -0
  275. package/lib/compiler/skills-registry.js +225 -0
  276. package/lib/compiler/transformer.js +236 -0
  277. package/package.json +50 -0
@@ -0,0 +1,493 @@
1
+ #!/usr/bin/env bash
2
+ # ============================================================================
3
+ # validate-scope-boundary.sh - 验证需求文档的边界合规性 (需求不扩散检查)
4
+ # ============================================================================
5
+ #
6
+ # 用途: 检查 PRD, EPIC, TASKS 文档是否遵循需求不扩散原则
7
+ #
8
+ # 使用:
9
+ # ./validate-scope-boundary.sh REQ-123
10
+ # ./validate-scope-boundary.sh REQ-123 --strict # 严格模式 (失败则退出)
11
+ # ./validate-scope-boundary.sh --all # 验证所有需求
12
+ #
13
+ # 检查项:
14
+ # 1. PRD 需求不扩散验证
15
+ # - [NEEDS CLARIFICATION] 标记是否已解决
16
+ # - 用户故事是否有优先级 (P1, P2, P3)
17
+ # - 用户故事是否有 Independent Test 标准
18
+ # - 是否包含技术实现细节 (API, database, framework)
19
+ #
20
+ # 2. EPIC Phase -1 闸门验证
21
+ # - Simplicity Gate 是否执行
22
+ # - Anti-Abstraction Gate 是否执行
23
+ # - Integration-First Gate 是否执行
24
+ # - Complexity Tracking 表格是否填写 (如有违规)
25
+ #
26
+ # 3. TASKS 用户故事组织验证
27
+ # - 任务是否按用户故事组织 (Phase 3+)
28
+ # - 任务是否有 [US#] 标签
29
+ # - 是否有 Foundational Phase
30
+ # - 是否有 Checkpoint 验证点
31
+ #
32
+ # 输出:
33
+ # - 通过: 退出码 0
34
+ # - 失败: 退出码 1
35
+ # - 警告: 退出码 2
36
+ # ============================================================================
37
+
38
+ set -euo pipefail
39
+
40
+ # ================================================================
41
+ # 颜色定义
42
+ # ================================================================
43
+ readonly RED='\033[0;31m'
44
+ readonly GREEN='\033[0;32m'
45
+ readonly YELLOW='\033[1;33m'
46
+ readonly BLUE='\033[0;34m'
47
+ readonly NC='\033[0m' # No Color
48
+
49
+ # ================================================================
50
+ # 全局变量
51
+ # ================================================================
52
+ STRICT_MODE=false
53
+ VALIDATE_ALL=false
54
+ ERRORS=0
55
+ WARNINGS=0
56
+ REPO_ROOT=""
57
+ REQ_ID=""
58
+
59
+ # ================================================================
60
+ # 辅助函数
61
+ # ================================================================
62
+
63
+ print_error() {
64
+ echo -e "${RED}✗ ERROR${NC}: $*" >&2
65
+ ((ERRORS++))
66
+ }
67
+
68
+ print_warning() {
69
+ echo -e "${YELLOW}⚠ WARNING${NC}: $*"
70
+ ((WARNINGS++))
71
+ }
72
+
73
+ print_success() {
74
+ echo -e "${GREEN}✓ PASS${NC}: $*"
75
+ }
76
+
77
+ print_info() {
78
+ echo -e "${BLUE}ℹ INFO${NC}: $*"
79
+ }
80
+
81
+ get_repo_root() {
82
+ if git rev-parse --is-inside-work-tree >/dev/null 2>&1; then
83
+ git rev-parse --show-toplevel
84
+ else
85
+ pwd
86
+ fi
87
+ }
88
+
89
+ # ================================================================
90
+ # PRD 验证函数
91
+ # ================================================================
92
+
93
+ validate_prd_anti_expansion() {
94
+ local prd_file="$1"
95
+ local req_id="$2"
96
+
97
+ print_info "验证 PRD 需求不扩散: $req_id"
98
+
99
+ if [[ ! -f "$prd_file" ]]; then
100
+ print_error "PRD 文件不存在: $prd_file"
101
+ return 1
102
+ fi
103
+
104
+ local prd_content
105
+ prd_content=$(cat "$prd_file")
106
+
107
+ # 检查1: 未解决的 [NEEDS CLARIFICATION] 标记
108
+ local clarifications
109
+ clarifications=$(echo "$prd_content" | grep -c "\[NEEDS CLARIFICATION" || true)
110
+
111
+ if [[ $clarifications -gt 0 ]]; then
112
+ print_warning "PRD 包含 $clarifications 个未解决的 [NEEDS CLARIFICATION] 标记"
113
+ echo "$prd_content" | grep -n "\[NEEDS CLARIFICATION" | head -5
114
+ else
115
+ print_success "PRD 无未解决的澄清标记"
116
+ fi
117
+
118
+ # 检查2: 用户故事优先级
119
+ local stories_without_priority
120
+ stories_without_priority=$(echo "$prd_content" | \
121
+ grep "^### Story" | \
122
+ grep -v "Priority: P[0-9]" | \
123
+ wc -l | tr -d ' ')
124
+
125
+ if [[ $stories_without_priority -gt 0 ]]; then
126
+ print_error "PRD 有 $stories_without_priority 个用户故事缺少优先级标记"
127
+ else
128
+ print_success "PRD 所有用户故事都有优先级"
129
+ fi
130
+
131
+ # 检查3: Independent Test 标准
132
+ local stories_without_independent_test
133
+ stories_without_independent_test=$(echo "$prd_content" | \
134
+ grep "^### Story" -A 10 | \
135
+ grep -c "^### Story" || true)
136
+
137
+ local independent_test_count
138
+ independent_test_count=$(echo "$prd_content" | \
139
+ grep -c "\*\*Independent Test\*\*" || true)
140
+
141
+ if [[ $independent_test_count -lt $stories_without_independent_test ]]; then
142
+ print_error "PRD 有用户故事缺少 Independent Test 标准"
143
+ else
144
+ print_success "PRD 所有用户故事都有 Independent Test 标准"
145
+ fi
146
+
147
+ # 检查4: 技术实现细节 (不应出现在 PRD)
148
+ local tech_keywords=("API endpoint" "database schema" "REST API" "GraphQL" "PostgreSQL" "MongoDB" "React component" "Vue component")
149
+ local found_tech_details=false
150
+
151
+ for keyword in "${tech_keywords[@]}"; do
152
+ if echo "$prd_content" | grep -iq "$keyword"; then
153
+ print_warning "PRD 包含技术实现细节: '$keyword' (应该只描述 WHAT 和 WHY,不是 HOW)"
154
+ found_tech_details=true
155
+ fi
156
+ done
157
+
158
+ if [[ "$found_tech_details" == "false" ]]; then
159
+ print_success "PRD 未包含技术实现细节"
160
+ fi
161
+
162
+ # 检查5: 需求不扩散验证清单
163
+ if echo "$prd_content" | grep -q "### 需求不扩散验证"; then
164
+ print_success "PRD 包含需求不扩散验证清单"
165
+ else
166
+ print_warning "PRD 缺少需求不扩散验证清单"
167
+ fi
168
+ }
169
+
170
+ # ================================================================
171
+ # EPIC 验证函数
172
+ # ================================================================
173
+
174
+ validate_epic_phase_minus_one() {
175
+ local epic_file="$1"
176
+ local req_id="$2"
177
+
178
+ print_info "验证 EPIC Phase -1 闸门: $req_id"
179
+
180
+ if [[ ! -f "$epic_file" ]]; then
181
+ print_error "EPIC 文件不存在: $epic_file"
182
+ return 1
183
+ fi
184
+
185
+ local epic_content
186
+ epic_content=$(cat "$epic_file")
187
+
188
+ # 检查1: Phase -1 章节是否存在
189
+ if echo "$epic_content" | grep -q "## Phase -1.*Pre-Implementation Gates"; then
190
+ print_success "EPIC 包含 Phase -1 宪法闸门章节"
191
+ else
192
+ print_error "EPIC 缺少 Phase -1 宪法闸门章节"
193
+ return 1
194
+ fi
195
+
196
+ # 检查2: Simplicity Gate
197
+ if echo "$epic_content" | grep -q "### Simplicity Gate"; then
198
+ print_success "EPIC 包含 Simplicity Gate"
199
+
200
+ # 检查项目数量限制
201
+ if echo "$epic_content" | grep -q "≤3 个项目"; then
202
+ print_success "Simplicity Gate: 检查项目数量限制"
203
+ else
204
+ print_warning "Simplicity Gate: 缺少项目数量限制检查"
205
+ fi
206
+
207
+ # 检查 NO FUTURE-PROOFING
208
+ if echo "$epic_content" | grep -q "NO FUTURE-PROOFING"; then
209
+ print_success "Simplicity Gate: 检查未来优化预留"
210
+ else
211
+ print_warning "Simplicity Gate: 缺少未来优化检查"
212
+ fi
213
+ else
214
+ print_error "EPIC 缺少 Simplicity Gate"
215
+ fi
216
+
217
+ # 检查3: Anti-Abstraction Gate
218
+ if echo "$epic_content" | grep -q "### Anti-Abstraction Gate"; then
219
+ print_success "EPIC 包含 Anti-Abstraction Gate"
220
+
221
+ # 检查 Framework Trust
222
+ if echo "$epic_content" | grep -q "Framework Trust"; then
223
+ print_success "Anti-Abstraction Gate: 检查框架直接使用"
224
+ else
225
+ print_warning "Anti-Abstraction Gate: 缺少框架使用检查"
226
+ fi
227
+ else
228
+ print_error "EPIC 缺少 Anti-Abstraction Gate"
229
+ fi
230
+
231
+ # 检查4: Integration-First Gate
232
+ if echo "$epic_content" | grep -q "### Integration-First Gate"; then
233
+ print_success "EPIC 包含 Integration-First Gate"
234
+
235
+ # 检查 Contracts Defined First
236
+ if echo "$epic_content" | grep -q "Contracts Defined First"; then
237
+ print_success "Integration-First Gate: 检查契约优先定义"
238
+ else
239
+ print_warning "Integration-First Gate: 缺少契约定义检查"
240
+ fi
241
+ else
242
+ print_error "EPIC 缺少 Integration-First Gate"
243
+ fi
244
+
245
+ # 检查5: Complexity Tracking 表格
246
+ if echo "$epic_content" | grep -q "### Complexity Tracking"; then
247
+ print_success "EPIC 包含 Complexity Tracking 表格"
248
+
249
+ # 检查是否有违规记录
250
+ local violations
251
+ violations=$(echo "$epic_content" | \
252
+ sed -n '/### Complexity Tracking/,/^---/p' | \
253
+ grep "^|" | \
254
+ grep -v "违规项" | \
255
+ grep -v "^| --" | \
256
+ wc -l | tr -d ' ')
257
+
258
+ if [[ $violations -gt 1 ]]; then
259
+ print_warning "EPIC 记录了 $((violations - 1)) 个宪法违规项"
260
+ fi
261
+ else
262
+ print_warning "EPIC 缺少 Complexity Tracking 表格"
263
+ fi
264
+ }
265
+
266
+ # ================================================================
267
+ # TASKS 验证函数
268
+ # ================================================================
269
+
270
+ validate_tasks_story_organization() {
271
+ local tasks_file="$1"
272
+ local req_id="$2"
273
+
274
+ print_info "验证 TASKS 用户故事组织: $req_id"
275
+
276
+ if [[ ! -f "$tasks_file" ]]; then
277
+ print_error "TASKS 文件不存在: $tasks_file"
278
+ return 1
279
+ fi
280
+
281
+ local tasks_content
282
+ tasks_content=$(cat "$tasks_file")
283
+
284
+ # 检查1: Foundational Phase 是否存在
285
+ if echo "$tasks_content" | grep -q "## Phase 2.*Foundational"; then
286
+ print_success "TASKS 包含 Foundational Phase (阻塞性前置条件)"
287
+ else
288
+ print_error "TASKS 缺少 Foundational Phase"
289
+ fi
290
+
291
+ # 检查2: 用户故事阶段 (Phase 3+)
292
+ local user_story_phases
293
+ user_story_phases=$(echo "$tasks_content" | \
294
+ grep "^## Phase [3-9].*User Story" | \
295
+ wc -l | tr -d ' ')
296
+
297
+ if [[ $user_story_phases -gt 0 ]]; then
298
+ print_success "TASKS 包含 $user_story_phases 个用户故事阶段"
299
+ else
300
+ print_error "TASKS 缺少用户故事组织结构 (应该从 Phase 3 开始)"
301
+ fi
302
+
303
+ # 检查3: [US#] 标签
304
+ local tasks_with_us_label
305
+ tasks_with_us_label=$(echo "$tasks_content" | \
306
+ grep "^\- \[ \].*\[US[0-9]\]" | \
307
+ wc -l | tr -d ' ')
308
+
309
+ if [[ $tasks_with_us_label -gt 0 ]]; then
310
+ print_success "TASKS 包含 $tasks_with_us_label 个带 [US#] 标签的任务"
311
+ else
312
+ print_warning "TASKS 缺少 [US#] 标签 (建议所有任务都标记所属用户故事)"
313
+ fi
314
+
315
+ # 检查4: Independent Test 标准
316
+ local independent_test_count
317
+ independent_test_count=$(echo "$tasks_content" | \
318
+ grep -c "\*\*Independent Test\*\*" || true)
319
+
320
+ if [[ $independent_test_count -ge $user_story_phases ]]; then
321
+ print_success "TASKS 每个用户故事都有 Independent Test 标准"
322
+ else
323
+ print_warning "TASKS 有用户故事缺少 Independent Test 标准"
324
+ fi
325
+
326
+ # 检查5: Checkpoint 验证点
327
+ local checkpoint_count
328
+ checkpoint_count=$(echo "$tasks_content" | \
329
+ grep -c "\*\*Checkpoint\*\*" || true)
330
+
331
+ if [[ $checkpoint_count -ge $user_story_phases ]]; then
332
+ print_success "TASKS 每个用户故事都有 Checkpoint 验证点"
333
+ else
334
+ print_warning "TASKS 有用户故事缺少 Checkpoint 验证点"
335
+ fi
336
+
337
+ # 检查6: Implementation Strategy
338
+ if echo "$tasks_content" | grep -q "## Implementation Strategy"; then
339
+ print_success "TASKS 包含 Implementation Strategy (MVP First, Incremental Delivery)"
340
+ else
341
+ print_warning "TASKS 缺少 Implementation Strategy 章节"
342
+ fi
343
+ }
344
+
345
+ # ================================================================
346
+ # 主验证函数
347
+ # ================================================================
348
+
349
+ validate_requirement() {
350
+ local req_id="$1"
351
+ local req_dir="$REPO_ROOT/devflow/requirements/$req_id"
352
+
353
+ echo ""
354
+ echo "========================================================================"
355
+ echo "验证需求: $req_id"
356
+ echo "========================================================================"
357
+
358
+ if [[ ! -d "$req_dir" ]]; then
359
+ print_error "需求目录不存在: $req_dir"
360
+ return 1
361
+ fi
362
+
363
+ local local_errors=0
364
+ local local_warnings=0
365
+
366
+ # 验证 PRD
367
+ if [[ -f "$req_dir/PRD.md" ]]; then
368
+ validate_prd_anti_expansion "$req_dir/PRD.md" "$req_id" || ((local_errors++))
369
+ else
370
+ print_warning "PRD.md 不存在,跳过 PRD 验证"
371
+ fi
372
+
373
+ echo ""
374
+
375
+ # 验证 EPIC
376
+ if [[ -f "$req_dir/EPIC.md" ]]; then
377
+ validate_epic_phase_minus_one "$req_dir/EPIC.md" "$req_id" || ((local_errors++))
378
+ else
379
+ print_warning "EPIC.md 不存在,跳过 EPIC 验证"
380
+ fi
381
+
382
+ echo ""
383
+
384
+ # 验证 TASKS
385
+ if [[ -f "$req_dir/TASKS.md" ]]; then
386
+ validate_tasks_story_organization "$req_dir/TASKS.md" "$req_id" || ((local_errors++))
387
+ else
388
+ print_warning "TASKS.md 不存在,跳过 TASKS 验证"
389
+ fi
390
+
391
+ echo ""
392
+ echo "------------------------------------------------------------------------"
393
+ echo "验证结果: $req_id"
394
+ echo "------------------------------------------------------------------------"
395
+
396
+ if [[ $local_errors -eq 0 && $WARNINGS -eq 0 ]]; then
397
+ print_success "需求 $req_id 完全符合需求不扩散原则"
398
+ elif [[ $local_errors -eq 0 ]]; then
399
+ print_warning "需求 $req_id 有 $WARNINGS 个警告,但总体符合需求不扩散原则"
400
+ else
401
+ print_error "需求 $req_id 有 $local_errors 个错误,不符合需求不扩散原则"
402
+ fi
403
+
404
+ return $local_errors
405
+ }
406
+
407
+ # ================================================================
408
+ # 主函数
409
+ # ================================================================
410
+
411
+ main() {
412
+ REPO_ROOT=$(get_repo_root)
413
+
414
+ # 解析参数
415
+ if [[ $# -eq 0 ]]; then
416
+ echo "用法: $0 <REQ-ID> [--strict]"
417
+ echo " $0 --all [--strict]"
418
+ echo ""
419
+ echo "示例:"
420
+ echo " $0 REQ-123"
421
+ echo " $0 REQ-123 --strict"
422
+ echo " $0 --all"
423
+ exit 1
424
+ fi
425
+
426
+ # 检查参数
427
+ while [[ $# -gt 0 ]]; do
428
+ case "$1" in
429
+ --strict)
430
+ STRICT_MODE=true
431
+ shift
432
+ ;;
433
+ --all)
434
+ VALIDATE_ALL=true
435
+ shift
436
+ ;;
437
+ REQ-*)
438
+ REQ_ID="$1"
439
+ shift
440
+ ;;
441
+ *)
442
+ echo "未知参数: $1"
443
+ exit 1
444
+ ;;
445
+ esac
446
+ done
447
+
448
+ # 执行验证
449
+ if [[ "$VALIDATE_ALL" == "true" ]]; then
450
+ print_info "验证所有需求文档..."
451
+
452
+ local req_dirs
453
+ req_dirs=$(find "$REPO_ROOT/devflow/requirements" -maxdepth 1 -type d -name "REQ-*" 2>/dev/null || true)
454
+
455
+ if [[ -z "$req_dirs" ]]; then
456
+ print_warning "未找到任何需求目录"
457
+ exit 0
458
+ fi
459
+
460
+ for req_dir in $req_dirs; do
461
+ local req_id
462
+ req_id=$(basename "$req_dir")
463
+ validate_requirement "$req_id" || true
464
+ done
465
+ else
466
+ validate_requirement "$REQ_ID"
467
+ fi
468
+
469
+ # 输出总结
470
+ echo ""
471
+ echo "========================================================================"
472
+ echo "验证总结"
473
+ echo "========================================================================"
474
+ echo "错误: $ERRORS"
475
+ echo "警告: $WARNINGS"
476
+
477
+ if [[ $ERRORS -eq 0 && $WARNINGS -eq 0 ]]; then
478
+ print_success "所有检查通过 ✓"
479
+ exit 0
480
+ elif [[ $ERRORS -eq 0 ]]; then
481
+ print_warning "有 $WARNINGS 个警告,但整体符合要求"
482
+ exit 0
483
+ else
484
+ print_error "有 $ERRORS 个错误,不符合需求不扩散原则"
485
+ if [[ "$STRICT_MODE" == "true" ]]; then
486
+ exit 1
487
+ else
488
+ exit 2
489
+ fi
490
+ fi
491
+ }
492
+
493
+ main "$@"
@@ -0,0 +1,37 @@
1
+ #!/usr/bin/env bash
2
+ set -e
3
+
4
+ # ============================================================
5
+ # 安装验证 | Verify Setup
6
+ # ============================================================
7
+ # 目标:
8
+ # - 确认 .claude 结构完整
9
+ # - 给出最小可用性检查
10
+ # ============================================================
11
+
12
+ SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
13
+ CLAUDE_DIR="$(cd "$SCRIPT_DIR/.." && pwd)"
14
+
15
+ require_dir() {
16
+ local target="$1"
17
+ if [[ ! -d "$target" ]]; then
18
+ echo "ERROR: Missing directory: $target" >&2
19
+ exit 1
20
+ fi
21
+ }
22
+
23
+ require_file() {
24
+ local target="$1"
25
+ if [[ ! -f "$target" ]]; then
26
+ echo "ERROR: Missing file: $target" >&2
27
+ exit 1
28
+ fi
29
+ }
30
+
31
+ require_dir "$CLAUDE_DIR/commands"
32
+ require_dir "$CLAUDE_DIR/skills"
33
+ require_dir "$CLAUDE_DIR/scripts"
34
+ require_file "$CLAUDE_DIR/commands/flow-new.md"
35
+ require_file "$CLAUDE_DIR/skills/cc-devflow-orchestrator/SKILL.md"
36
+
37
+ echo "cc-devflow setup OK."
@@ -0,0 +1,76 @@
1
+ {
2
+ "enableAllProjectMcpServers": true,
3
+ "permissions": {
4
+ "allow": [
5
+ "Bash(git status)",
6
+ "Bash(git diff:*)",
7
+ "Bash(git add:*)",
8
+ "Bash(git switch:*)",
9
+ "Bash(git checkout:*)",
10
+ "Bash(git commit:*)",
11
+ "Bash(git push:*)",
12
+ "Bash(gh pr:*)",
13
+ "Bash(npm run dev)",
14
+ "Bash(npm run test:watch)",
15
+ "Bash(npm run test)",
16
+ "Bash(npm run typecheck)",
17
+ "Bash(mkdir:*)",
18
+ "Bash(echo:*)"
19
+ ],
20
+ "ask": [
21
+ "Bash(git merge:*)",
22
+ "Bash(gh pr merge:*)",
23
+ "Bash(gh pr create:*)"
24
+ ],
25
+ "deny": [
26
+ "Read(./.env)",
27
+ "Read(./.env.*)",
28
+ "Read(./secrets/**)",
29
+ "Bash(rm -rf:*)"
30
+ ]
31
+ },
32
+ "hooks": {
33
+ "UserPromptSubmit": [
34
+ {
35
+ "hooks": [
36
+ {
37
+ "type": "command",
38
+ "command": "$CLAUDE_PROJECT_DIR/.claude/hooks/skill-activation-prompt.sh"
39
+ }
40
+ ]
41
+ }
42
+ ],
43
+ "PostToolUse": [
44
+ {
45
+ "matcher": "Edit|MultiEdit|Write",
46
+ "hooks": [
47
+ {
48
+ "type": "command",
49
+ "command": "$CLAUDE_PROJECT_DIR/.claude/hooks/post-tool-use-tracker.sh"
50
+ }
51
+ ]
52
+ }
53
+ ],
54
+ "PreToolUse": [
55
+ {
56
+ "matcher": "Edit|Write",
57
+ "hooks": [
58
+ {
59
+ "type": "command",
60
+ "command": "$CLAUDE_PROJECT_DIR/.claude/hooks/pre-tool-use-guardrail.sh"
61
+ }
62
+ ]
63
+ }
64
+ ],
65
+ "Stop": [
66
+ {
67
+ "hooks": [
68
+ {
69
+ "type": "command",
70
+ "command": "$CLAUDE_PROJECT_DIR/.claude/hooks/error-handling-reminder.sh"
71
+ }
72
+ ]
73
+ }
74
+ ]
75
+ }
76
+ }
@@ -0,0 +1,96 @@
1
+ # Reference Implementations
2
+
3
+ **这些是参考实现,不会被 Claude Code 激活为 skills。**
4
+
5
+ ## 用途
6
+
7
+ 这些参考实现的作用是:
8
+
9
+ 1. **为 `project-guidelines-generator` agent 提供学习样本**
10
+ - Agent 会读取这些文件,学习结构和模式
11
+ - 理解如何组织 SKILL.md 和 resources/
12
+ - 提取最佳实践和代码示例
13
+
14
+ 2. **展示特定技术栈的最佳实践**
15
+ - `frontend-react-mui/`: React 18 + Material-UI v7 + TanStack Query/Router
16
+ - `backend-express-prisma/`: Express + Prisma + TypeScript
17
+
18
+ 3. **作为生成其他技术栈 guidelines 的模板**
19
+ - Vue + Vuetify → 适配自 frontend-react-mui
20
+ - Django + SQLAlchemy → 适配自 backend-express-prisma
21
+
22
+ ## 生成的技能位置
23
+
24
+ 实际激活的技能位于:
25
+ - `.claude/skills/frontend-guidelines/` - 根据项目技术栈生成的前端指南
26
+ - `.claude/skills/backend-guidelines/` - 根据项目技术栈生成的后端指南
27
+
28
+ ## 如何使用
29
+
30
+ 运行以下命令生成适配你项目的开发指南:
31
+
32
+ ```bash
33
+ # 生成前端指南
34
+ /core-guidelines --frontend
35
+
36
+ # 生成后端指南
37
+ /core-guidelines --backend
38
+
39
+ # 自动检测并生成(可能生成 1 或 2 个)
40
+ /core-guidelines
41
+ ```
42
+
43
+ ## 技术栈映射
44
+
45
+ ### Frontend Reference (React + MUI)
46
+ - **Framework**: React 18
47
+ - **UI Library**: Material-UI v7
48
+ - **Data Fetching**: TanStack Query (useSuspenseQuery)
49
+ - **Routing**: TanStack Router
50
+ - **State Management**: React Context + Query Cache
51
+ - **Styling**: MUI sx prop + styled-components
52
+ - **TypeScript**: Strict mode
53
+
54
+ ### Backend Reference (Express + Prisma)
55
+ - **Runtime**: Node.js
56
+ - **Framework**: Express
57
+ - **ORM**: Prisma
58
+ - **Database**: MySQL (but Prisma supports多种)
59
+ - **Architecture**: Layered (Routes → Controllers → Services → Repositories)
60
+ - **Validation**: Zod schemas
61
+ - **Error Tracking**: Sentry
62
+ - **TypeScript**: Strict mode
63
+
64
+ ## 维护
65
+
66
+ 这些参考实现来自 `claude-code-infrastructure-showcase` 项目。
67
+
68
+ 如需更新:
69
+ ```bash
70
+ # 从 showcase 复制最新版本
71
+ cp -r claude-code-infrastructure-showcase/.claude/skills/frontend-dev-guidelines \
72
+ .claude/skills/_reference-implementations/frontend-react-mui
73
+
74
+ cp -r claude-code-infrastructure-showcase/.claude/skills/backend-dev-guidelines \
75
+ .claude/skills/_reference-implementations/backend-express-prisma
76
+ ```
77
+
78
+ ## 架构哲学
79
+
80
+ **为什么不直接激活这些 skills?**
81
+
82
+ 因为:
83
+ 1. **技术栈特定性**:这些是 React+MUI 和 Express+Prisma 的最佳实践,不适用于所有项目
84
+ 2. **职责分明**:前端和后端应该是独立的 skills,各自有清晰的激活边界
85
+ 3. **动态适配**:每个项目应该有适合自己技术栈的 guidelines
86
+
87
+ **生成系统的优势**:
88
+ - ✅ 自动检测项目技术栈
89
+ - ✅ 获取官方最新文档(Context7 MCP)
90
+ - ✅ 适配不同框架(React/Vue/Angular, Express/Django/FastAPI)
91
+ - ✅ 职责分明(frontend-guidelines vs backend-guidelines)
92
+ - ✅ 保持最佳实践(从参考实现学习模式)
93
+
94
+ ---
95
+
96
+ **Remember**: Template is code, generation is compilation.