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,602 @@
1
+ #!/usr/bin/env bash
2
+
3
+ # manage-constitution.sh - Constitution 管理后端脚本
4
+ #
5
+ # 功能:
6
+ # - 查看 Constitution 和特定 Article
7
+ # - 提议和应用 Amendment
8
+ # - 自动传播版本变更到所有文件
9
+ # - 验证版本一致性
10
+ # - 显示版本历史
11
+ #
12
+ # 用法:
13
+ # bash manage-constitution.sh show [ARTICLE]
14
+ # bash manage-constitution.sh amend PROPOSAL_FILE
15
+ # bash manage-constitution.sh apply VERSION_TYPE
16
+ # bash manage-constitution.sh verify
17
+ # bash manage-constitution.sh impact
18
+ # bash manage-constitution.sh history
19
+
20
+ set -euo pipefail
21
+
22
+ # ============================================================================
23
+ # 配置和常量
24
+ # ============================================================================
25
+
26
+ SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
27
+ REPO_ROOT="$(cd "$SCRIPT_DIR/../.." && pwd)"
28
+ source "$SCRIPT_DIR/common.sh"
29
+ CONSTITUTION_FILE="$REPO_ROOT/.claude/constitution/project-constitution.md"
30
+ AMENDMENT_DIR="$REPO_ROOT/.claude/constitution/amendments"
31
+
32
+ # 需要更新版本号的文件模式
33
+ declare -a FILES_TO_UPDATE=(
34
+ "$REPO_ROOT/.claude/docs/templates/*.md"
35
+ "$REPO_ROOT/.claude/agents/*.md"
36
+ "$REPO_ROOT/.claude/scripts/validate-constitution.sh"
37
+ "$REPO_ROOT/.claude/scripts/validate-scope-boundary.sh"
38
+ "$REPO_ROOT/.claude/hooks/pre-push-guard.sh"
39
+ "$REPO_ROOT/CLAUDE.md"
40
+ )
41
+
42
+ # 颜色代码
43
+ RED='\033[0;31m'
44
+ GREEN='\033[0;32m'
45
+ YELLOW='\033[1;33m'
46
+ BLUE='\033[0;34m'
47
+ CYAN='\033[0;36m'
48
+ NC='\033[0m' # No Color
49
+
50
+ # ============================================================================
51
+ # 辅助函数
52
+ # ============================================================================
53
+
54
+ log_info() {
55
+ echo -e "${BLUE}ℹ${NC} $*"
56
+ }
57
+
58
+ log_success() {
59
+ echo -e "${GREEN}✅${NC} $*"
60
+ }
61
+
62
+ log_warning() {
63
+ echo -e "${YELLOW}⚠️${NC} $*"
64
+ }
65
+
66
+ log_error() {
67
+ echo -e "${RED}❌${NC} $*" >&2
68
+ }
69
+
70
+ # 获取当前 Constitution 版本
71
+ get_current_version() {
72
+ if [[ ! -f "$CONSTITUTION_FILE" ]]; then
73
+ log_error "Constitution file not found: $CONSTITUTION_FILE"
74
+ exit 1
75
+ fi
76
+
77
+ # 从 Constitution 文件提取版本号 (格式: **Version**: v2.0.0)
78
+ local version=$(grep -E '^\*\*Version\*\*:|^> \*\*Version\*\*:' "$CONSTITUTION_FILE" | head -1 | sed 's/.*v\([0-9.]*\).*/\1/')
79
+
80
+ if [[ -z "$version" ]]; then
81
+ log_error "Could not extract version from Constitution file"
82
+ exit 1
83
+ fi
84
+
85
+ echo "$version"
86
+ }
87
+
88
+ # 版本号增量 (MAJOR.MINOR.PATCH)
89
+ bump_version() {
90
+ local current="$1"
91
+ local type="$2"
92
+
93
+ # 分解版本号
94
+ local major minor patch
95
+ IFS='.' read -r major minor patch <<< "$current"
96
+
97
+ case "$type" in
98
+ MAJOR)
99
+ major=$((major + 1))
100
+ minor=0
101
+ patch=0
102
+ ;;
103
+ MINOR)
104
+ minor=$((minor + 1))
105
+ patch=0
106
+ ;;
107
+ PATCH)
108
+ patch=$((patch + 1))
109
+ ;;
110
+ *)
111
+ log_error "Invalid version type: $type (must be MAJOR, MINOR, or PATCH)"
112
+ exit 1
113
+ ;;
114
+ esac
115
+
116
+ echo "$major.$minor.$patch"
117
+ }
118
+
119
+ # 提取特定 Article
120
+ extract_article() {
121
+ local article_num="$1"
122
+
123
+ if [[ ! -f "$CONSTITUTION_FILE" ]]; then
124
+ log_error "Constitution file not found"
125
+ exit 1
126
+ fi
127
+
128
+ # 使用 sed 提取指定 Article (从 "## Article X:" 到下一个 "## " 或 "## Article")
129
+ sed -n "/^## Article $article_num:/,/^## \(Article\|[^A]\)/p" "$CONSTITUTION_FILE" | sed '$d'
130
+ }
131
+
132
+ # ============================================================================
133
+ # 核心功能
134
+ # ============================================================================
135
+
136
+ # 显示 Constitution 或特定 Article
137
+ show_constitution() {
138
+ local article="${1:-}"
139
+
140
+ if [[ -z "$article" ]]; then
141
+ # 显示完整 Constitution
142
+ echo -e "${CYAN}═══════════════════════════════════════════════════════════${NC}"
143
+ echo -e "${CYAN} CC-DevFlow Project Constitution v$(get_current_version)${NC}"
144
+ echo -e "${CYAN}═══════════════════════════════════════════════════════════${NC}"
145
+ echo ""
146
+ cat "$CONSTITUTION_FILE"
147
+ else
148
+ # 显示特定 Article
149
+ echo -e "${CYAN}═══════════════════════════════════════════════════════════${NC}"
150
+ echo -e "${CYAN} Article $article - Constitution v$(get_current_version)${NC}"
151
+ echo -e "${CYAN}═══════════════════════════════════════════════════════════${NC}"
152
+ echo ""
153
+
154
+ local content=$(extract_article "$article")
155
+ if [[ -z "$content" ]]; then
156
+ log_error "Article $article not found"
157
+ exit 1
158
+ fi
159
+
160
+ echo "$content"
161
+ fi
162
+ }
163
+
164
+ # 提议 Amendment
165
+ propose_amendment() {
166
+ local proposal_file="$1"
167
+
168
+ log_info "Analyzing amendment proposal..."
169
+
170
+ # 检查提案文件是否存在
171
+ if [[ ! -f "$proposal_file" ]]; then
172
+ log_error "Proposal file not found: $proposal_file"
173
+ exit 1
174
+ fi
175
+
176
+ # 读取提案内容
177
+ log_info "Reading proposal: $proposal_file"
178
+ echo ""
179
+ cat "$proposal_file"
180
+ echo ""
181
+
182
+ # 提取版本类型
183
+ local version_type=$(grep -i "Proposed Version" "$proposal_file" | sed 's/.* (\(.*\)).*/\1/' | tr '[:lower:]' '[:upper:]')
184
+
185
+ if [[ -z "$version_type" ]] || [[ ! "$version_type" =~ ^(MAJOR|MINOR|PATCH)$ ]]; then
186
+ log_error "Invalid or missing version type in proposal (must be MAJOR, MINOR, or PATCH)"
187
+ exit 1
188
+ fi
189
+
190
+ local current_version=$(get_current_version)
191
+ local new_version=$(bump_version "$current_version" "$version_type")
192
+
193
+ log_info "Version change: v$current_version → v$new_version ($version_type)"
194
+
195
+ # 影响分析
196
+ log_info "Running impact analysis..."
197
+ echo ""
198
+ echo "Files to be updated:"
199
+ for pattern in "${FILES_TO_UPDATE[@]}"; do
200
+ for file in $pattern; do
201
+ if [[ -f "$file" ]]; then
202
+ echo " - ${file#$REPO_ROOT/}"
203
+ fi
204
+ done
205
+ done
206
+ echo ""
207
+
208
+ # 用户确认
209
+ read -p "$(echo -e ${YELLOW}Apply this amendment? [y/N]:${NC} )" -r confirm
210
+
211
+ if [[ ! "$confirm" =~ ^[Yy]$ ]]; then
212
+ log_warning "Amendment cancelled"
213
+ exit 0
214
+ fi
215
+
216
+ log_success "Amendment proposal accepted. Use 'apply $version_type' to execute."
217
+ }
218
+
219
+ # 应用 Amendment
220
+ apply_amendment() {
221
+ local version_type="$1"
222
+
223
+ # 验证版本类型
224
+ if [[ ! "$version_type" =~ ^(MAJOR|MINOR|PATCH)$ ]]; then
225
+ log_error "Invalid version type: $version_type (must be MAJOR, MINOR, or PATCH)"
226
+ exit 1
227
+ fi
228
+
229
+ local current_version=$(get_current_version)
230
+ local new_version=$(bump_version "$current_version" "$version_type")
231
+
232
+ log_info "Starting amendment application..."
233
+ log_info "Version: v$current_version → v$new_version ($version_type)"
234
+
235
+ # 1. 更新 Constitution 文件的版本号
236
+ log_info "Updating Constitution version..."
237
+ update_constitution_version "$current_version" "$new_version"
238
+
239
+ # 2. 传播变更到所有文件
240
+ log_info "Propagating changes to all files..."
241
+ propagate_constitution_changes "$current_version" "$new_version"
242
+
243
+ # 3. 生成同步报告
244
+ log_info "Generating sync report..."
245
+ generate_sync_report "$current_version" "$new_version"
246
+
247
+ # 4. 提示创建 Git commit
248
+ log_success "Amendment v$new_version applied successfully!"
249
+ echo ""
250
+ log_info "Next steps:"
251
+ echo " 1. Review changes: git diff"
252
+ echo " 2. Create commit: git add . && git commit -m 'feat(constitution): Amendment v$new_version'"
253
+ echo " 3. Verify consistency: bash $0 verify"
254
+ }
255
+
256
+ # 更新 Constitution 文件的版本号
257
+ update_constitution_version() {
258
+ local old_version="$1"
259
+ local new_version="$2"
260
+ local current_date=$(TZ='Asia/Shanghai' date '+%Y-%m-%d')
261
+
262
+ # 更新版本号行
263
+ sed -i.bak "s/\*\*Version\*\*: v$old_version/\*\*Version\*\*: v$new_version/g" "$CONSTITUTION_FILE"
264
+
265
+ # 更新最后修订日期
266
+ sed -i.bak "s/\*\*Last Amended\*\*: .*/\*\*Last Amended\*\*: $current_date/g" "$CONSTITUTION_FILE"
267
+
268
+ # 清理备份文件
269
+ rm -f "$CONSTITUTION_FILE.bak"
270
+
271
+ log_success "Constitution version updated: v$old_version → v$new_version"
272
+ }
273
+
274
+ # 传播 Constitution 变更到所有文件
275
+ propagate_constitution_changes() {
276
+ local old_version="$1"
277
+ local new_version="$2"
278
+ local updated_count=0
279
+
280
+ for pattern in "${FILES_TO_UPDATE[@]}"; do
281
+ for file in $pattern; do
282
+ if [[ -f "$file" ]]; then
283
+ # 替换所有 "Constitution v2.0.0" 或 "Constitution.*v2.0.0" 为新版本
284
+ # 支持多种格式:
285
+ # - "Constitution v2.0.0"
286
+ # - "Constitution: v2.0.0"
287
+ # - "Constitution (v2.0.0)"
288
+ # - "project-constitution.md v2.0.0"
289
+ # - "project-constitution.md (v2.0.0)"
290
+
291
+ if grep -q "Constitution.*v$old_version\|project-constitution.md.*v$old_version" "$file"; then
292
+ sed -i.bak "s/Constitution\(.*\)v$old_version/Constitution\1v$new_version/g" "$file"
293
+ sed -i.bak "s/project-constitution.md\(.*\)v$old_version/project-constitution.md\1v$new_version/g" "$file"
294
+ rm -f "$file.bak"
295
+
296
+ echo " ✅ ${file#$REPO_ROOT/}"
297
+ ((updated_count++))
298
+ fi
299
+ fi
300
+ done
301
+ done
302
+
303
+ log_success "Updated $updated_count files"
304
+ }
305
+
306
+ # 生成同步报告
307
+ generate_sync_report() {
308
+ local old_version="$1"
309
+ local new_version="$2"
310
+ local report_file="$AMENDMENT_DIR/sync-report-v$new_version.md"
311
+ local current_date=$(get_beijing_time_full)
312
+
313
+ # 创建 amendments 目录(如果不存在)
314
+ mkdir -p "$AMENDMENT_DIR"
315
+
316
+ cat > "$report_file" << EOF
317
+ # Constitution Amendment Sync Report
318
+
319
+ **Amendment Version**: v$old_version → v$new_version
320
+ **Date**: $current_date
321
+ **Status**: Applied
322
+
323
+ ---
324
+
325
+ ## Files Updated (Auto-sync)
326
+
327
+ EOF
328
+
329
+ # 列出所有更新的文件
330
+ for pattern in "${FILES_TO_UPDATE[@]}"; do
331
+ for file in $pattern; do
332
+ if [[ -f "$file" ]] && grep -q "Constitution.*v$new_version\|project-constitution.md.*v$new_version" "$file"; then
333
+ echo "- ✅ \`${file#$REPO_ROOT/}\`" >> "$report_file"
334
+ fi
335
+ done
336
+ done
337
+
338
+ cat >> "$report_file" << EOF
339
+
340
+ ---
341
+
342
+ ## Verification
343
+
344
+ Run the following command to verify consistency:
345
+
346
+ \`\`\`bash
347
+ bash .claude/scripts/manage-constitution.sh verify
348
+ \`\`\`
349
+
350
+ ## Next Steps
351
+
352
+ 1. **Review Changes**: \`git diff\`
353
+ 2. **Run Tests**: \`bash .claude/tests/constitution/run_all_constitution_tests.sh\`
354
+ 3. **Create Commit**:
355
+ \`\`\`bash
356
+ git add .
357
+ git commit -m "feat(constitution): Amendment v$new_version
358
+
359
+ - Updated Constitution to v$new_version
360
+ - Propagated changes to all templates, agents, and scripts
361
+ - Generated sync report
362
+
363
+ 🤖 Generated with Claude Code
364
+
365
+ Co-Authored-By: Claude <noreply@anthropic.com>"
366
+ \`\`\`
367
+
368
+ ---
369
+
370
+ *Report generated by manage-constitution.sh*
371
+ EOF
372
+
373
+ log_success "Sync report generated: ${report_file#$REPO_ROOT/}"
374
+
375
+ # 显示报告内容
376
+ echo ""
377
+ cat "$report_file"
378
+ }
379
+
380
+ # 验证版本一致性
381
+ verify_consistency() {
382
+ log_info "Verifying Constitution consistency..."
383
+ echo ""
384
+
385
+ local constitution_version=$(get_current_version)
386
+ local inconsistent_files=()
387
+ local total_files=0
388
+ local consistent_files=0
389
+
390
+ echo "Constitution Version: v$constitution_version"
391
+ echo ""
392
+ echo "Checking files..."
393
+ echo ""
394
+
395
+ for pattern in "${FILES_TO_UPDATE[@]}"; do
396
+ for file in $pattern; do
397
+ if [[ -f "$file" ]]; then
398
+ ((total_files++))
399
+
400
+ # 检查文件是否包含 Constitution 版本引用
401
+ if grep -q "Constitution\|project-constitution.md" "$file"; then
402
+ # 提取文件中的版本号 (精确匹配 "v数字.数字.数字" 格式)
403
+ local file_version=$(grep -o "Constitution.*v[0-9]\+\.[0-9]\+\.[0-9]\+\|project-constitution.md.*v[0-9]\+\.[0-9]\+\.[0-9]\+" "$file" | head -1 | grep -o "v[0-9]\+\.[0-9]\+\.[0-9]\+" | sed 's/v//')
404
+
405
+ if [[ -n "$file_version" ]]; then
406
+ if [[ "$file_version" == "$constitution_version" ]]; then
407
+ echo " ✅ ${file#$REPO_ROOT/} (v$file_version)"
408
+ ((consistent_files++))
409
+ else
410
+ echo " ❌ ${file#$REPO_ROOT/} (v$file_version, expected v$constitution_version)"
411
+ inconsistent_files+=("${file#$REPO_ROOT/}: v$file_version (expected v$constitution_version)")
412
+ fi
413
+ fi
414
+ fi
415
+ fi
416
+ done
417
+ done
418
+
419
+ echo ""
420
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
421
+ echo "Summary:"
422
+ echo " Total files checked: $total_files"
423
+ echo " Consistent files: $consistent_files"
424
+ echo " Inconsistent files: ${#inconsistent_files[@]}"
425
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
426
+ echo ""
427
+
428
+ if [[ ${#inconsistent_files[@]} -eq 0 ]]; then
429
+ log_success "All files consistent with Constitution v$constitution_version"
430
+ return 0
431
+ else
432
+ log_error "Inconsistent version references found:"
433
+ printf '%s\n' "${inconsistent_files[@]}" | sed 's/^/ /'
434
+ echo ""
435
+ log_info "Fix: Run 'bash $0 apply PATCH' to sync all files"
436
+ exit 1
437
+ fi
438
+ }
439
+
440
+ # 生成影响报告
441
+ generate_impact_report() {
442
+ log_info "Generating Constitution impact report..."
443
+ echo ""
444
+
445
+ local current_version=$(get_current_version)
446
+ local current_date=$(get_beijing_time_full)
447
+
448
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
449
+ echo "Constitution Impact Report"
450
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
451
+ echo ""
452
+ echo "Current Version: v$current_version"
453
+ echo "Generated: $current_date"
454
+ echo ""
455
+
456
+ # Article 引用统计
457
+ echo "Article References:"
458
+ echo ""
459
+
460
+ for article in I II III IV V VI VII VIII IX X; do
461
+ local count=0
462
+ local files=()
463
+
464
+ for pattern in "${FILES_TO_UPDATE[@]}"; do
465
+ for file in $pattern; do
466
+ if [[ -f "$file" ]] && grep -q "Article $article" "$file"; then
467
+ ((count++))
468
+ files+=("${file#$REPO_ROOT/}")
469
+ fi
470
+ done
471
+ done
472
+
473
+ echo " Article $article: $count enforcement points"
474
+ if [[ $count -gt 0 ]]; then
475
+ for f in "${files[@]}"; do
476
+ echo " - $f"
477
+ done
478
+ fi
479
+ echo ""
480
+ done
481
+
482
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
483
+ }
484
+
485
+ # 显示版本历史
486
+ show_version_history() {
487
+ log_info "Constitution Version History"
488
+ echo ""
489
+
490
+ if [[ ! -f "$CONSTITUTION_FILE" ]]; then
491
+ log_error "Constitution file not found"
492
+ exit 1
493
+ fi
494
+
495
+ # 提取 Version History 部分
496
+ sed -n '/^## Version History/,/^##[^#]/p' "$CONSTITUTION_FILE" | sed '$d'
497
+
498
+ # 如果没有 Version History 部分,显示当前版本
499
+ if ! grep -q "^## Version History" "$CONSTITUTION_FILE"; then
500
+ echo "Current Version: v$(get_current_version)"
501
+ echo ""
502
+ echo "No version history available yet."
503
+ echo "Version history will be maintained in the Constitution file."
504
+ fi
505
+ }
506
+
507
+ # ============================================================================
508
+ # 主函数
509
+ # ============================================================================
510
+
511
+ main() {
512
+ local action="${1:-}"
513
+
514
+ case "$action" in
515
+ show)
516
+ show_constitution "${2:-}"
517
+ ;;
518
+ amend)
519
+ if [[ -z "${2:-}" ]]; then
520
+ log_error "Missing proposal file argument"
521
+ echo "Usage: $0 amend PROPOSAL_FILE"
522
+ exit 1
523
+ fi
524
+ propose_amendment "$2"
525
+ ;;
526
+ apply)
527
+ if [[ -z "${2:-}" ]]; then
528
+ log_error "Missing version type argument"
529
+ echo "Usage: $0 apply [MAJOR|MINOR|PATCH]"
530
+ exit 1
531
+ fi
532
+ apply_amendment "${2^^}" # 转为大写
533
+ ;;
534
+ verify)
535
+ verify_consistency
536
+ ;;
537
+ impact)
538
+ generate_impact_report
539
+ ;;
540
+ history)
541
+ show_version_history
542
+ ;;
543
+ ""|--help|-h)
544
+ cat << 'EOF'
545
+ Constitution Management Script
546
+
547
+ USAGE:
548
+ manage-constitution.sh COMMAND [OPTIONS]
549
+
550
+ COMMANDS:
551
+ show [ARTICLE] 显示完整 Constitution 或特定 Article
552
+ 例: show I (显示 Article I)
553
+
554
+ amend PROPOSAL_FILE 提议 Amendment
555
+ 例: amend amendments/add-article-xi.md
556
+
557
+ apply VERSION_TYPE 应用 Amendment 并传播变更
558
+ VERSION_TYPE: MAJOR, MINOR, PATCH
559
+ 例: apply MINOR
560
+
561
+ verify 验证所有文件的版本一致性
562
+
563
+ impact 生成影响报告 (Article 引用统计)
564
+
565
+ history 显示版本历史
566
+
567
+ --help, -h 显示此帮助信息
568
+
569
+ EXAMPLES:
570
+ # 查看 Constitution
571
+ bash manage-constitution.sh show
572
+
573
+ # 查看 Article I
574
+ bash manage-constitution.sh show I
575
+
576
+ # 提议修正案
577
+ bash manage-constitution.sh amend amendments/add-observability.md
578
+
579
+ # 应用 MINOR 版本修正案 (v2.0.0 → v2.1.0)
580
+ bash manage-constitution.sh apply MINOR
581
+
582
+ # 验证一致性
583
+ bash manage-constitution.sh verify
584
+
585
+ # 生成影响报告
586
+ bash manage-constitution.sh impact
587
+
588
+ # 查看版本历史
589
+ bash manage-constitution.sh history
590
+
591
+ EOF
592
+ ;;
593
+ *)
594
+ log_error "Unknown command: $action"
595
+ echo "Use '$0 --help' for usage information"
596
+ exit 1
597
+ ;;
598
+ esac
599
+ }
600
+
601
+ # 执行主函数
602
+ main "$@"