@paths.design/caws-cli 10.1.0 → 11.0.0

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 (419) hide show
  1. package/README.md +125 -374
  2. package/dist/index.js +43 -756
  3. package/dist/shell/binding/resolve-binding.d.ts +4 -0
  4. package/dist/shell/binding/resolve-binding.d.ts.map +1 -0
  5. package/dist/shell/binding/resolve-binding.js +228 -0
  6. package/dist/shell/binding/resolve-binding.js.map +1 -0
  7. package/dist/shell/binding/types.d.ts +42 -0
  8. package/dist/shell/binding/types.d.ts.map +1 -0
  9. package/dist/shell/binding/types.js +21 -0
  10. package/dist/shell/binding/types.js.map +1 -0
  11. package/dist/shell/commands/claim.d.ts +14 -0
  12. package/dist/shell/commands/claim.d.ts.map +1 -0
  13. package/dist/shell/commands/claim.js +197 -0
  14. package/dist/shell/commands/claim.js.map +1 -0
  15. package/dist/shell/commands/doctor.d.ts +13 -0
  16. package/dist/shell/commands/doctor.d.ts.map +1 -0
  17. package/dist/shell/commands/doctor.js +97 -0
  18. package/dist/shell/commands/doctor.js.map +1 -0
  19. package/dist/shell/commands/evidence.d.ts +28 -0
  20. package/dist/shell/commands/evidence.d.ts.map +1 -0
  21. package/dist/shell/commands/evidence.js +166 -0
  22. package/dist/shell/commands/evidence.js.map +1 -0
  23. package/dist/shell/commands/gates.d.ts +19 -0
  24. package/dist/shell/commands/gates.d.ts.map +1 -0
  25. package/dist/shell/commands/gates.js +181 -0
  26. package/dist/shell/commands/gates.js.map +1 -0
  27. package/dist/shell/commands/init.d.ts +8 -0
  28. package/dist/shell/commands/init.d.ts.map +1 -0
  29. package/dist/shell/commands/init.js +64 -0
  30. package/dist/shell/commands/init.js.map +1 -0
  31. package/dist/shell/commands/scope.d.ts +11 -0
  32. package/dist/shell/commands/scope.d.ts.map +1 -0
  33. package/dist/shell/commands/scope.js +92 -0
  34. package/dist/shell/commands/scope.js.map +1 -0
  35. package/dist/shell/commands/status.d.ts +15 -0
  36. package/dist/shell/commands/status.d.ts.map +1 -0
  37. package/dist/shell/commands/status.js +106 -0
  38. package/dist/shell/commands/status.js.map +1 -0
  39. package/dist/shell/commands/waiver.d.ts +38 -0
  40. package/dist/shell/commands/waiver.d.ts.map +1 -0
  41. package/dist/shell/commands/waiver.js +240 -0
  42. package/dist/shell/commands/waiver.js.map +1 -0
  43. package/dist/shell/gates/disposition.d.ts +23 -0
  44. package/dist/shell/gates/disposition.d.ts.map +1 -0
  45. package/dist/shell/gates/disposition.js +87 -0
  46. package/dist/shell/gates/disposition.js.map +1 -0
  47. package/dist/shell/gates/gate-result-contract.d.ts +39 -0
  48. package/dist/shell/gates/gate-result-contract.d.ts.map +1 -0
  49. package/dist/shell/gates/gate-result-contract.js +150 -0
  50. package/dist/shell/gates/gate-result-contract.js.map +1 -0
  51. package/dist/shell/gates/quality-gates-adapter.d.ts +55 -0
  52. package/dist/shell/gates/quality-gates-adapter.d.ts.map +1 -0
  53. package/dist/shell/gates/quality-gates-adapter.js +161 -0
  54. package/dist/shell/gates/quality-gates-adapter.js.map +1 -0
  55. package/dist/shell/gates/waiver-filter.d.ts +58 -0
  56. package/dist/shell/gates/waiver-filter.d.ts.map +1 -0
  57. package/dist/shell/gates/waiver-filter.js +119 -0
  58. package/dist/shell/gates/waiver-filter.js.map +1 -0
  59. package/dist/shell/index.d.ts +50 -0
  60. package/dist/shell/index.d.ts.map +1 -0
  61. package/dist/shell/index.js +73 -0
  62. package/dist/shell/index.js.map +1 -0
  63. package/dist/shell/register.d.ts +11 -0
  64. package/dist/shell/register.d.ts.map +1 -0
  65. package/dist/shell/register.js +274 -0
  66. package/dist/shell/register.js.map +1 -0
  67. package/dist/shell/render/claim.d.ts +22 -0
  68. package/dist/shell/render/claim.d.ts.map +1 -0
  69. package/dist/shell/render/claim.js +75 -0
  70. package/dist/shell/render/claim.js.map +1 -0
  71. package/dist/shell/render/decision.d.ts +15 -0
  72. package/dist/shell/render/decision.d.ts.map +1 -0
  73. package/dist/shell/render/decision.js +66 -0
  74. package/dist/shell/render/decision.js.map +1 -0
  75. package/dist/shell/render/diagnostic.d.ts +19 -0
  76. package/dist/shell/render/diagnostic.d.ts.map +1 -0
  77. package/dist/shell/render/diagnostic.js +76 -0
  78. package/dist/shell/render/diagnostic.js.map +1 -0
  79. package/dist/shell/render/finding.d.ts +15 -0
  80. package/dist/shell/render/finding.d.ts.map +1 -0
  81. package/dist/shell/render/finding.js +57 -0
  82. package/dist/shell/render/finding.js.map +1 -0
  83. package/dist/shell/render/gates.d.ts +3 -0
  84. package/dist/shell/render/gates.d.ts.map +1 -0
  85. package/dist/shell/render/gates.js +56 -0
  86. package/dist/shell/render/gates.js.map +1 -0
  87. package/dist/shell/render/init.d.ts +11 -0
  88. package/dist/shell/render/init.d.ts.map +1 -0
  89. package/dist/shell/render/init.js +32 -0
  90. package/dist/shell/render/init.js.map +1 -0
  91. package/dist/shell/render/status.d.ts +26 -0
  92. package/dist/shell/render/status.d.ts.map +1 -0
  93. package/dist/shell/render/status.js +143 -0
  94. package/dist/shell/render/status.js.map +1 -0
  95. package/dist/shell/render/waiver.d.ts +21 -0
  96. package/dist/shell/render/waiver.d.ts.map +1 -0
  97. package/dist/shell/render/waiver.js +94 -0
  98. package/dist/shell/render/waiver.js.map +1 -0
  99. package/dist/shell/rules.d.ts +37 -0
  100. package/dist/shell/rules.d.ts.map +1 -0
  101. package/dist/shell/rules.js +51 -0
  102. package/dist/shell/rules.js.map +1 -0
  103. package/dist/shell/session/actor.d.ts +14 -0
  104. package/dist/shell/session/actor.d.ts.map +1 -0
  105. package/dist/shell/session/actor.js +34 -0
  106. package/dist/shell/session/actor.js.map +1 -0
  107. package/dist/shell/session/resolve-session.d.ts +5 -0
  108. package/dist/shell/session/resolve-session.d.ts.map +1 -0
  109. package/dist/shell/session/resolve-session.js +239 -0
  110. package/dist/shell/session/resolve-session.js.map +1 -0
  111. package/dist/shell/session/types.d.ts +56 -0
  112. package/dist/shell/session/types.d.ts.map +1 -0
  113. package/dist/shell/session/types.js +15 -0
  114. package/dist/shell/session/types.js.map +1 -0
  115. package/dist/store/agents-store.d.ts +3 -0
  116. package/dist/store/agents-store.d.ts.map +1 -0
  117. package/dist/store/agents-store.js +63 -0
  118. package/dist/store/agents-store.js.map +1 -0
  119. package/dist/store/apply-patch.d.ts +16 -0
  120. package/dist/store/apply-patch.d.ts.map +1 -0
  121. package/dist/store/apply-patch.js +191 -0
  122. package/dist/store/apply-patch.js.map +1 -0
  123. package/dist/store/atomic-write.d.ts +16 -0
  124. package/dist/store/atomic-write.d.ts.map +1 -0
  125. package/dist/store/atomic-write.js +132 -0
  126. package/dist/store/atomic-write.js.map +1 -0
  127. package/dist/store/doctor-snapshot.d.ts +20 -0
  128. package/dist/store/doctor-snapshot.d.ts.map +1 -0
  129. package/dist/store/doctor-snapshot.js +176 -0
  130. package/dist/store/doctor-snapshot.js.map +1 -0
  131. package/dist/store/events-store.d.ts +33 -0
  132. package/dist/store/events-store.d.ts.map +1 -0
  133. package/dist/store/events-store.js +297 -0
  134. package/dist/store/events-store.js.map +1 -0
  135. package/dist/store/index.d.ts +21 -0
  136. package/dist/store/index.d.ts.map +1 -0
  137. package/dist/store/index.js +47 -0
  138. package/dist/store/index.js.map +1 -0
  139. package/dist/store/init-store.d.ts +21 -0
  140. package/dist/store/init-store.d.ts.map +1 -0
  141. package/dist/store/init-store.js +295 -0
  142. package/dist/store/init-store.js.map +1 -0
  143. package/dist/store/json-store.d.ts +3 -0
  144. package/dist/store/json-store.d.ts.map +1 -0
  145. package/dist/store/json-store.js +65 -0
  146. package/dist/store/json-store.js.map +1 -0
  147. package/dist/store/policy-store.d.ts +3 -0
  148. package/dist/store/policy-store.d.ts.map +1 -0
  149. package/dist/store/policy-store.js +65 -0
  150. package/dist/store/policy-store.js.map +1 -0
  151. package/dist/store/repo-root.d.ts +46 -0
  152. package/dist/store/repo-root.d.ts.map +1 -0
  153. package/dist/store/repo-root.js +145 -0
  154. package/dist/store/repo-root.js.map +1 -0
  155. package/dist/store/rules.d.ts +53 -0
  156. package/dist/store/rules.d.ts.map +1 -0
  157. package/dist/store/rules.js +78 -0
  158. package/dist/store/rules.js.map +1 -0
  159. package/dist/store/specs-store.d.ts +3 -0
  160. package/dist/store/specs-store.d.ts.map +1 -0
  161. package/dist/store/specs-store.js +131 -0
  162. package/dist/store/specs-store.js.map +1 -0
  163. package/dist/store/types.d.ts +84 -0
  164. package/dist/store/types.d.ts.map +1 -0
  165. package/dist/store/types.js +14 -0
  166. package/dist/store/types.js.map +1 -0
  167. package/dist/store/waivers-store.d.ts +25 -0
  168. package/dist/store/waivers-store.d.ts.map +1 -0
  169. package/dist/store/waivers-store.js +232 -0
  170. package/dist/store/waivers-store.js.map +1 -0
  171. package/dist/store/worktrees-store.d.ts +3 -0
  172. package/dist/store/worktrees-store.d.ts.map +1 -0
  173. package/dist/store/worktrees-store.js +62 -0
  174. package/dist/store/worktrees-store.js.map +1 -0
  175. package/dist/store/yaml-store.d.ts +9 -0
  176. package/dist/store/yaml-store.d.ts.map +1 -0
  177. package/dist/store/yaml-store.js +121 -0
  178. package/dist/store/yaml-store.js.map +1 -0
  179. package/package.json +15 -13
  180. package/dist/budget-derivation.js +0 -751
  181. package/dist/cicd-optimizer.js +0 -504
  182. package/dist/commands/archive.js +0 -500
  183. package/dist/commands/burnup.js +0 -198
  184. package/dist/commands/diagnose.js +0 -525
  185. package/dist/commands/evaluate.js +0 -314
  186. package/dist/commands/gates.js +0 -149
  187. package/dist/commands/init.js +0 -857
  188. package/dist/commands/iterate.js +0 -417
  189. package/dist/commands/mode.js +0 -269
  190. package/dist/commands/parallel.js +0 -242
  191. package/dist/commands/plan.js +0 -438
  192. package/dist/commands/provenance.js +0 -1143
  193. package/dist/commands/quality-monitor.js +0 -284
  194. package/dist/commands/scope.js +0 -264
  195. package/dist/commands/session.js +0 -312
  196. package/dist/commands/sidecar.js +0 -74
  197. package/dist/commands/specs.js +0 -1448
  198. package/dist/commands/status.js +0 -1151
  199. package/dist/commands/templates.js +0 -237
  200. package/dist/commands/tool.js +0 -136
  201. package/dist/commands/tutorial.js +0 -480
  202. package/dist/commands/validate.js +0 -357
  203. package/dist/commands/verify-acs.js +0 -443
  204. package/dist/commands/waivers.js +0 -599
  205. package/dist/commands/workflow.js +0 -243
  206. package/dist/commands/worktree.js +0 -386
  207. package/dist/config/lite-scope.js +0 -158
  208. package/dist/config/modes.js +0 -347
  209. package/dist/constants/spec-types.js +0 -65
  210. package/dist/gates/budget-limit.js +0 -121
  211. package/dist/gates/feedback.js +0 -260
  212. package/dist/gates/format.js +0 -179
  213. package/dist/gates/god-object.js +0 -117
  214. package/dist/gates/pipeline.js +0 -167
  215. package/dist/gates/scope-boundary.js +0 -93
  216. package/dist/gates/spec-completeness.js +0 -109
  217. package/dist/gates/todo-detection.js +0 -205
  218. package/dist/generators/jest-config-generator.js +0 -242
  219. package/dist/generators/working-spec.js +0 -237
  220. package/dist/minimal-cli.js +0 -88
  221. package/dist/parallel/parallel-manager.js +0 -433
  222. package/dist/policy/PolicyManager.js +0 -465
  223. package/dist/scaffold/claude-hooks.js +0 -443
  224. package/dist/scaffold/cursor-hooks.js +0 -177
  225. package/dist/scaffold/git-hooks.js +0 -928
  226. package/dist/scaffold/index.js +0 -794
  227. package/dist/session/session-manager.js +0 -653
  228. package/dist/sidecars/index.js +0 -33
  229. package/dist/sidecars/listeners.js +0 -40
  230. package/dist/sidecars/provenance-summary.js +0 -238
  231. package/dist/sidecars/quality-gaps.js +0 -258
  232. package/dist/sidecars/schema.js +0 -149
  233. package/dist/sidecars/spec-drift.js +0 -151
  234. package/dist/sidecars/waiver-draft.js +0 -176
  235. package/dist/spec/SpecFileManager.js +0 -419
  236. package/dist/templates/.caws/schemas/policy.schema.json +0 -112
  237. package/dist/templates/.caws/schemas/scope.schema.json +0 -52
  238. package/dist/templates/.caws/schemas/waivers.schema.json +0 -106
  239. package/dist/templates/.caws/schemas/working-spec.schema.json +0 -340
  240. package/dist/templates/.caws/schemas/worktrees.schema.json +0 -38
  241. package/dist/templates/.caws/templates/working-spec.template.yml +0 -80
  242. package/dist/templates/.caws/tools/README.md +0 -18
  243. package/dist/templates/.caws/tools/scope-guard.js +0 -203
  244. package/dist/templates/.caws/tools-allow.json +0 -331
  245. package/dist/templates/.caws/waivers.yml +0 -19
  246. package/dist/templates/.claude/README.md +0 -190
  247. package/dist/templates/.claude/hooks/audit.sh +0 -121
  248. package/dist/templates/.claude/hooks/block-dangerous.sh +0 -203
  249. package/dist/templates/.claude/hooks/classify_command.py +0 -592
  250. package/dist/templates/.claude/hooks/doc-frontmatter-check.sh +0 -173
  251. package/dist/templates/.claude/hooks/lite-sprawl-check.sh +0 -145
  252. package/dist/templates/.claude/hooks/naming-check.sh +0 -100
  253. package/dist/templates/.claude/hooks/protected-paths.sh +0 -39
  254. package/dist/templates/.claude/hooks/quality-check.sh +0 -81
  255. package/dist/templates/.claude/hooks/scan-secrets.sh +0 -85
  256. package/dist/templates/.claude/hooks/scope-guard.sh +0 -381
  257. package/dist/templates/.claude/hooks/session-caws-status.sh +0 -117
  258. package/dist/templates/.claude/hooks/session-log.sh +0 -634
  259. package/dist/templates/.claude/hooks/simplification-guard.sh +0 -92
  260. package/dist/templates/.claude/hooks/stop-worktree-check.sh +0 -46
  261. package/dist/templates/.claude/hooks/test_classify_command.py +0 -370
  262. package/dist/templates/.claude/hooks/test_wrapper_smoke.sh +0 -96
  263. package/dist/templates/.claude/hooks/validate-spec.sh +0 -76
  264. package/dist/templates/.claude/hooks/worktree-guard.sh +0 -220
  265. package/dist/templates/.claude/hooks/worktree-write-guard.sh +0 -190
  266. package/dist/templates/.claude/rules/git-safety.md +0 -26
  267. package/dist/templates/.claude/rules/worktree-isolation.md +0 -83
  268. package/dist/templates/.claude/settings.json +0 -141
  269. package/dist/templates/.cursor/README.md +0 -299
  270. package/dist/templates/.cursor/hooks/audit.sh +0 -55
  271. package/dist/templates/.cursor/hooks/block-dangerous.sh +0 -84
  272. package/dist/templates/.cursor/hooks/caws-quality-check.sh +0 -52
  273. package/dist/templates/.cursor/hooks/caws-scope-guard.sh +0 -130
  274. package/dist/templates/.cursor/hooks/format.sh +0 -38
  275. package/dist/templates/.cursor/hooks/naming-check.sh +0 -64
  276. package/dist/templates/.cursor/hooks/scan-secrets.sh +0 -51
  277. package/dist/templates/.cursor/hooks/scope-guard.sh +0 -52
  278. package/dist/templates/.cursor/hooks/session-log.sh +0 -924
  279. package/dist/templates/.cursor/hooks/validate-spec.sh +0 -83
  280. package/dist/templates/.cursor/hooks.json +0 -76
  281. package/dist/templates/.cursor/rules/00-claims-verification.mdc +0 -144
  282. package/dist/templates/.cursor/rules/01-working-style.mdc +0 -50
  283. package/dist/templates/.cursor/rules/02-quality-gates.mdc +0 -368
  284. package/dist/templates/.cursor/rules/03-naming-and-refactor.mdc +0 -33
  285. package/dist/templates/.cursor/rules/04-logging-language-style.mdc +0 -23
  286. package/dist/templates/.cursor/rules/05-safe-defaults-guards.mdc +0 -23
  287. package/dist/templates/.cursor/rules/06-typescript-conventions.mdc +0 -36
  288. package/dist/templates/.cursor/rules/07-process-ops.mdc +0 -20
  289. package/dist/templates/.cursor/rules/08-solid-and-architecture.mdc +0 -16
  290. package/dist/templates/.cursor/rules/09-docstrings.mdc +0 -89
  291. package/dist/templates/.cursor/rules/10-documentation-quality-standards.mdc +0 -385
  292. package/dist/templates/.cursor/rules/11-scope-management-waivers.mdc +0 -381
  293. package/dist/templates/.cursor/rules/12-implementation-completeness.mdc +0 -516
  294. package/dist/templates/.cursor/rules/13-language-agnostic-standards.mdc +0 -578
  295. package/dist/templates/.cursor/rules/README.md +0 -148
  296. package/dist/templates/.github/copilot-instructions.md +0 -82
  297. package/dist/templates/.idea/runConfigurations/CAWS_Evaluate.xml +0 -5
  298. package/dist/templates/.idea/runConfigurations/CAWS_Validate.xml +0 -5
  299. package/dist/templates/.junie/guidelines.md +0 -73
  300. package/dist/templates/.vscode/launch.json +0 -17
  301. package/dist/templates/.vscode/settings.json +0 -95
  302. package/dist/templates/.windsurf/rules/caws-quality-standards.md +0 -54
  303. package/dist/templates/.windsurf/workflows/caws-guided-development.md +0 -92
  304. package/dist/templates/CLAUDE.md +0 -174
  305. package/dist/templates/COMMIT_CONVENTIONS.md +0 -86
  306. package/dist/templates/OIDC_SETUP.md +0 -300
  307. package/dist/templates/agents.md +0 -145
  308. package/dist/templates/codemod/README.md +0 -1
  309. package/dist/templates/codemod/test.js +0 -93
  310. package/dist/templates/docs/README.md +0 -151
  311. package/dist/templates/scripts/new_feature.sh +0 -80
  312. package/dist/templates/scripts/quality-gates/check-god-objects.js +0 -146
  313. package/dist/templates/scripts/quality-gates/run-quality-gates.js +0 -50
  314. package/dist/templates/scripts/v3/analysis/todo_analyzer.py +0 -1997
  315. package/dist/test-analysis.js +0 -786
  316. package/dist/tool-interface.js +0 -314
  317. package/dist/tool-loader.js +0 -303
  318. package/dist/tool-validator.js +0 -393
  319. package/dist/utils/agent-session.js +0 -202
  320. package/dist/utils/async-utils.js +0 -188
  321. package/dist/utils/command-wrapper.js +0 -200
  322. package/dist/utils/event-log.js +0 -584
  323. package/dist/utils/event-renderer.js +0 -521
  324. package/dist/utils/finalization.js +0 -230
  325. package/dist/utils/git-lock.js +0 -119
  326. package/dist/utils/gitignore-updater.js +0 -158
  327. package/dist/utils/ide-detection.js +0 -133
  328. package/dist/utils/lifecycle-events.js +0 -94
  329. package/dist/utils/project-analysis.js +0 -367
  330. package/dist/utils/promise-utils.js +0 -72
  331. package/dist/utils/quality-gates-errors.js +0 -520
  332. package/dist/utils/quality-gates-utils.js +0 -387
  333. package/dist/utils/schema-validator.js +0 -50
  334. package/dist/utils/spec-resolver.js +0 -711
  335. package/dist/utils/typescript-detector.js +0 -369
  336. package/dist/utils/working-state.js +0 -530
  337. package/dist/utils/yaml-validation.js +0 -156
  338. package/dist/validation/spec-validation.js +0 -921
  339. package/dist/waivers-manager.js +0 -732
  340. package/dist/worktree/worktree-manager.js +0 -1374
  341. package/templates/.caws/schemas/policy.schema.json +0 -112
  342. package/templates/.caws/schemas/scope.schema.json +0 -52
  343. package/templates/.caws/schemas/waivers.schema.json +0 -106
  344. package/templates/.caws/schemas/working-spec.schema.json +0 -340
  345. package/templates/.caws/schemas/worktrees.schema.json +0 -38
  346. package/templates/.caws/templates/working-spec.template.yml +0 -80
  347. package/templates/.caws/tools/README.md +0 -18
  348. package/templates/.caws/tools/scope-guard.js +0 -203
  349. package/templates/.caws/tools-allow.json +0 -331
  350. package/templates/.caws/waivers.yml +0 -19
  351. package/templates/.claude/README.md +0 -190
  352. package/templates/.claude/hooks/audit.sh +0 -121
  353. package/templates/.claude/hooks/block-dangerous.sh +0 -203
  354. package/templates/.claude/hooks/classify_command.py +0 -592
  355. package/templates/.claude/hooks/doc-frontmatter-check.sh +0 -173
  356. package/templates/.claude/hooks/lite-sprawl-check.sh +0 -145
  357. package/templates/.claude/hooks/naming-check.sh +0 -100
  358. package/templates/.claude/hooks/protected-paths.sh +0 -39
  359. package/templates/.claude/hooks/quality-check.sh +0 -81
  360. package/templates/.claude/hooks/scan-secrets.sh +0 -85
  361. package/templates/.claude/hooks/scope-guard.sh +0 -381
  362. package/templates/.claude/hooks/session-caws-status.sh +0 -117
  363. package/templates/.claude/hooks/session-log.sh +0 -634
  364. package/templates/.claude/hooks/simplification-guard.sh +0 -92
  365. package/templates/.claude/hooks/stop-worktree-check.sh +0 -46
  366. package/templates/.claude/hooks/test_classify_command.py +0 -370
  367. package/templates/.claude/hooks/test_wrapper_smoke.sh +0 -96
  368. package/templates/.claude/hooks/validate-spec.sh +0 -76
  369. package/templates/.claude/hooks/worktree-guard.sh +0 -220
  370. package/templates/.claude/hooks/worktree-write-guard.sh +0 -190
  371. package/templates/.claude/rules/git-safety.md +0 -26
  372. package/templates/.claude/rules/worktree-isolation.md +0 -83
  373. package/templates/.claude/settings.json +0 -141
  374. package/templates/.cursor/README.md +0 -299
  375. package/templates/.cursor/hooks/audit.sh +0 -55
  376. package/templates/.cursor/hooks/block-dangerous.sh +0 -84
  377. package/templates/.cursor/hooks/caws-quality-check.sh +0 -52
  378. package/templates/.cursor/hooks/caws-scope-guard.sh +0 -130
  379. package/templates/.cursor/hooks/format.sh +0 -38
  380. package/templates/.cursor/hooks/naming-check.sh +0 -64
  381. package/templates/.cursor/hooks/scan-secrets.sh +0 -51
  382. package/templates/.cursor/hooks/scope-guard.sh +0 -52
  383. package/templates/.cursor/hooks/session-log.sh +0 -924
  384. package/templates/.cursor/hooks/validate-spec.sh +0 -83
  385. package/templates/.cursor/hooks.json +0 -76
  386. package/templates/.cursor/rules/00-claims-verification.mdc +0 -144
  387. package/templates/.cursor/rules/01-working-style.mdc +0 -50
  388. package/templates/.cursor/rules/02-quality-gates.mdc +0 -368
  389. package/templates/.cursor/rules/03-naming-and-refactor.mdc +0 -33
  390. package/templates/.cursor/rules/04-logging-language-style.mdc +0 -23
  391. package/templates/.cursor/rules/05-safe-defaults-guards.mdc +0 -23
  392. package/templates/.cursor/rules/06-typescript-conventions.mdc +0 -36
  393. package/templates/.cursor/rules/07-process-ops.mdc +0 -20
  394. package/templates/.cursor/rules/08-solid-and-architecture.mdc +0 -16
  395. package/templates/.cursor/rules/09-docstrings.mdc +0 -89
  396. package/templates/.cursor/rules/10-documentation-quality-standards.mdc +0 -385
  397. package/templates/.cursor/rules/11-scope-management-waivers.mdc +0 -381
  398. package/templates/.cursor/rules/12-implementation-completeness.mdc +0 -516
  399. package/templates/.cursor/rules/13-language-agnostic-standards.mdc +0 -578
  400. package/templates/.cursor/rules/README.md +0 -148
  401. package/templates/.github/copilot-instructions.md +0 -82
  402. package/templates/.idea/runConfigurations/CAWS_Evaluate.xml +0 -5
  403. package/templates/.idea/runConfigurations/CAWS_Validate.xml +0 -5
  404. package/templates/.junie/guidelines.md +0 -73
  405. package/templates/.vscode/launch.json +0 -17
  406. package/templates/.vscode/settings.json +0 -95
  407. package/templates/.windsurf/rules/caws-quality-standards.md +0 -54
  408. package/templates/.windsurf/workflows/caws-guided-development.md +0 -92
  409. package/templates/CLAUDE.md +0 -174
  410. package/templates/COMMIT_CONVENTIONS.md +0 -86
  411. package/templates/OIDC_SETUP.md +0 -300
  412. package/templates/agents.md +0 -145
  413. package/templates/codemod/README.md +0 -1
  414. package/templates/codemod/test.js +0 -93
  415. package/templates/docs/README.md +0 -151
  416. package/templates/scripts/new_feature.sh +0 -80
  417. package/templates/scripts/quality-gates/check-god-objects.js +0 -146
  418. package/templates/scripts/quality-gates/run-quality-gates.js +0 -50
  419. package/templates/scripts/v3/analysis/todo_analyzer.py +0 -1997
@@ -1,158 +0,0 @@
1
- /**
2
- * @fileoverview CAWS Lite-Mode Scope Configuration Loader
3
- * Reads and validates .caws/scope.json for guardrails-only mode
4
- * @author @darianrosebrook
5
- */
6
-
7
- const fs = require('fs-extra');
8
- const path = require('path');
9
- const micromatch = require('micromatch');
10
-
11
- const SCOPE_FILE = '.caws/scope.json';
12
-
13
- /**
14
- * Default scope configuration for lite mode
15
- * @returns {Object} Default scope.json contents
16
- */
17
- function getLiteScopeDefaults() {
18
- return {
19
- version: 1,
20
- allowedDirectories: ['src/', 'tests/', 'docs/'],
21
- bannedPatterns: {
22
- files: ['*-enhanced.*', '*-final.*', '*-v2.*', '*-copy.*'],
23
- directories: ['*venv*', '.venv', 'm-venv', 'env/'],
24
- docs: ['*-summary.md', '*-recap.md', '*-plan.md', 'sprint-*'],
25
- },
26
- maxNewFilesPerCommit: 10,
27
- designatedVenvPath: '.venv',
28
- };
29
- }
30
-
31
- /**
32
- * Load lite scope configuration from .caws/scope.json
33
- * @param {string} [projectRoot] - Project root directory (defaults to cwd)
34
- * @returns {Object} Scope configuration (defaults if file not found)
35
- */
36
- function loadLiteScope(projectRoot) {
37
- const root = projectRoot || process.cwd();
38
- const scopePath = path.join(root, SCOPE_FILE);
39
-
40
- try {
41
- if (!fs.existsSync(scopePath)) {
42
- return getLiteScopeDefaults();
43
- }
44
-
45
- const raw = fs.readFileSync(scopePath, 'utf8');
46
- const config = JSON.parse(raw);
47
-
48
- // Merge with defaults for any missing fields
49
- const defaults = getLiteScopeDefaults();
50
- return {
51
- version: config.version || defaults.version,
52
- allowedDirectories: config.allowedDirectories || defaults.allowedDirectories,
53
- bannedPatterns: {
54
- files: config.bannedPatterns?.files || defaults.bannedPatterns.files,
55
- directories: config.bannedPatterns?.directories || defaults.bannedPatterns.directories,
56
- docs: config.bannedPatterns?.docs || defaults.bannedPatterns.docs,
57
- },
58
- maxNewFilesPerCommit: config.maxNewFilesPerCommit ?? defaults.maxNewFilesPerCommit,
59
- designatedVenvPath: config.designatedVenvPath || defaults.designatedVenvPath,
60
- };
61
- } catch (error) {
62
- // If file is malformed, return defaults
63
- return getLiteScopeDefaults();
64
- }
65
- }
66
-
67
- /**
68
- * Check if a file path is allowed by the scope configuration
69
- * @param {string} filePath - Relative file path to check
70
- * @param {Object} [scope] - Scope configuration (loads from disk if not provided)
71
- * @param {string} [projectRoot] - Project root directory
72
- * @returns {boolean} Whether the path is allowed
73
- */
74
- function isPathAllowed(filePath, scope, projectRoot) {
75
- const config = scope || loadLiteScope(projectRoot);
76
- const dirs = config.allowedDirectories;
77
-
78
- // If no allowed directories specified, everything is allowed
79
- if (!dirs || dirs.length === 0) {
80
- return true;
81
- }
82
-
83
- // Normalize the file path
84
- const normalized = filePath.replace(/\\/g, '/');
85
-
86
- // Check if file is within any allowed directory
87
- for (const dir of dirs) {
88
- const normalizedDir = dir.replace(/\\/g, '/').replace(/\/$/, '');
89
- if (normalized.startsWith(normalizedDir + '/') || normalized === normalizedDir) {
90
- return true;
91
- }
92
- }
93
-
94
- // Also allow root-level config files (package.json, etc.)
95
- if (!normalized.includes('/')) {
96
- return true;
97
- }
98
-
99
- // Allow .caws/ directory itself
100
- if (normalized.startsWith('.caws/')) {
101
- return true;
102
- }
103
-
104
- return false;
105
- }
106
-
107
- /**
108
- * Check if a filename or path matches any banned pattern
109
- * @param {string} filePath - File path to check
110
- * @param {Object} [scope] - Scope configuration (loads from disk if not provided)
111
- * @param {string} [projectRoot] - Project root directory
112
- * @returns {{ matched: boolean, pattern: string|null, category: string|null }} Match result
113
- */
114
- function matchesBannedPattern(filePath, scope, projectRoot) {
115
- const config = scope || loadLiteScope(projectRoot);
116
- const banned = config.bannedPatterns;
117
- const basename = path.basename(filePath);
118
- const normalized = filePath.replace(/\\/g, '/');
119
-
120
- // Check file patterns
121
- if (banned.files && banned.files.length > 0) {
122
- if (micromatch.isMatch(basename, banned.files, { dot: true })) {
123
- const matched = banned.files.find((p) => micromatch.isMatch(basename, p, { dot: true }));
124
- return { matched: true, pattern: matched, category: 'files' };
125
- }
126
- }
127
-
128
- // Check directory patterns
129
- if (banned.directories && banned.directories.length > 0) {
130
- const parts = normalized.split('/');
131
- for (const part of parts) {
132
- if (micromatch.isMatch(part, banned.directories, { dot: true })) {
133
- const matched = banned.directories.find((p) =>
134
- micromatch.isMatch(part, p, { dot: true })
135
- );
136
- return { matched: true, pattern: matched, category: 'directories' };
137
- }
138
- }
139
- }
140
-
141
- // Check doc patterns
142
- if (banned.docs && banned.docs.length > 0) {
143
- if (micromatch.isMatch(basename, banned.docs, { dot: true })) {
144
- const matched = banned.docs.find((p) => micromatch.isMatch(basename, p, { dot: true }));
145
- return { matched: true, pattern: matched, category: 'docs' };
146
- }
147
- }
148
-
149
- return { matched: false, pattern: null, category: null };
150
- }
151
-
152
- module.exports = {
153
- loadLiteScope,
154
- isPathAllowed,
155
- matchesBannedPattern,
156
- getLiteScopeDefaults,
157
- SCOPE_FILE,
158
- };
@@ -1,347 +0,0 @@
1
- /**
2
- * @fileoverview CAWS Complexity Modes Configuration
3
- * Defines different tiers of CAWS complexity for different project needs
4
- * @author @darianrosebrook
5
- */
6
-
7
- const chalk = require('chalk');
8
-
9
- /**
10
- * CAWS Complexity Tiers
11
- */
12
- const COMPLEXITY_TIERS = {
13
- lite: {
14
- name: 'Lite',
15
- description: 'Guardrails-only mode — no YAML specs required',
16
- color: chalk.magenta,
17
- icon: '',
18
- features: {
19
- workingSpec: false,
20
- destructiveCommandBlocking: true,
21
- fileSprawlDetection: true,
22
- scopeFence: true,
23
- simplificationGuard: true,
24
- worktreeIsolation: true,
25
- },
26
- qualityRequirements: {
27
- testCoverage: 0,
28
- mutationScore: 0,
29
- contracts: 'none',
30
- },
31
- riskTiers: ['T3'],
32
- commands: {
33
- init: true,
34
- status: true,
35
- worktree: true,
36
- },
37
- },
38
-
39
- simple: {
40
- name: 'Simple',
41
- description: 'Minimal CAWS for small projects and quick prototyping',
42
- color: chalk.green,
43
- icon: '',
44
- features: {
45
- workingSpec: true,
46
- basicValidation: true,
47
- statusDisplay: true,
48
- noQualityGates: true,
49
- noProvenance: true,
50
- noWaivers: true,
51
- noChangeBudgets: true,
52
- noMultiSpec: false, // Can use multi-spec but simplified
53
- },
54
- qualityRequirements: {
55
- testCoverage: 70,
56
- mutationScore: 30,
57
- contracts: 'optional',
58
- },
59
- riskTiers: ['T3'], // Only T3 supported
60
- commands: {
61
- init: true,
62
- validate: true,
63
- status: true,
64
- specs: true, // Basic specs support
65
- // No: diagnose, evaluate, iterate, provenance, waivers, hooks, archive
66
- },
67
- },
68
-
69
- standard: {
70
- name: 'Standard',
71
- description: 'Balanced CAWS with change management and quality gates',
72
- color: chalk.yellow,
73
- icon: '',
74
- features: {
75
- workingSpec: true,
76
- fullValidation: true,
77
- statusDisplay: true,
78
- qualityGates: true,
79
- provenance: true,
80
- waivers: true,
81
- changeBudgets: true,
82
- multiSpec: true,
83
- changeFolders: true,
84
- },
85
- qualityRequirements: {
86
- testCoverage: 80,
87
- mutationScore: 50,
88
- contracts: 'required',
89
- },
90
- riskTiers: ['T1', 'T2', 'T3'],
91
- commands: {
92
- init: true,
93
- validate: true,
94
- status: true,
95
- specs: true,
96
- diagnose: true,
97
- evaluate: true,
98
- iterate: true,
99
- provenance: true,
100
- waivers: true,
101
- hooks: true,
102
- archive: true,
103
- },
104
- },
105
-
106
- enterprise: {
107
- name: 'Enterprise',
108
- description: 'Full CAWS with comprehensive audit trails and compliance',
109
- color: chalk.red,
110
- icon: '',
111
- features: {
112
- workingSpec: true,
113
- fullValidation: true,
114
- statusDisplay: true,
115
- qualityGates: true,
116
- provenance: true,
117
- waivers: true,
118
- changeBudgets: true,
119
- multiSpec: true,
120
- changeFolders: true,
121
- auditTrails: true,
122
- compliance: true,
123
- advancedMonitoring: true,
124
- },
125
- qualityRequirements: {
126
- testCoverage: 90,
127
- mutationScore: 70,
128
- contracts: 'required',
129
- },
130
- riskTiers: ['T1', 'T2', 'T3'],
131
- commands: {
132
- init: true,
133
- validate: true,
134
- status: true,
135
- specs: true,
136
- diagnose: true,
137
- evaluate: true,
138
- iterate: true,
139
- provenance: true,
140
- waivers: true,
141
- hooks: true,
142
- archive: true,
143
- troubleshoot: true,
144
- testAnalysis: true,
145
- qualityMonitor: true,
146
- },
147
- },
148
- };
149
-
150
- /**
151
- * Get tier information
152
- * @param {string} tier - Tier name
153
- * @returns {Object} Tier configuration
154
- */
155
- function getTier(tier) {
156
- return COMPLEXITY_TIERS[tier] || COMPLEXITY_TIERS.standard;
157
- }
158
-
159
- /**
160
- * Get available tiers
161
- * @returns {string[]} Array of tier names
162
- */
163
- function getAvailableTiers() {
164
- return Object.keys(COMPLEXITY_TIERS);
165
- }
166
-
167
- /**
168
- * Check if a command is available in the current tier
169
- * @param {string} command - Command name
170
- * @param {string} tier - Tier name
171
- * @returns {boolean} Whether command is available
172
- */
173
- function isCommandAvailable(command, tier = 'standard') {
174
- const tierConfig = getTier(tier);
175
- return tierConfig.commands[command] === true;
176
- }
177
-
178
- /**
179
- * Check if a feature is enabled in the current tier
180
- * @param {string} feature - Feature name
181
- * @param {string} tier - Tier name
182
- * @returns {boolean} Whether feature is enabled
183
- */
184
- function isFeatureEnabled(feature, tier = 'standard') {
185
- const tierConfig = getTier(tier);
186
- return tierConfig.features[feature] === true;
187
- }
188
-
189
- /**
190
- * Get quality requirements for a tier
191
- * @param {string} tier - Tier name
192
- * @returns {Object} Quality requirements
193
- */
194
- function getQualityRequirements(tier = 'standard') {
195
- const tierConfig = getTier(tier);
196
- return tierConfig.qualityRequirements;
197
- }
198
-
199
- /**
200
- * Get supported risk tiers for a complexity tier
201
- * @param {string} tier - Tier name
202
- * @returns {string[]} Supported risk tiers
203
- */
204
- function getSupportedRiskTiers(tier = 'standard') {
205
- const tierConfig = getTier(tier);
206
- return tierConfig.riskTiers;
207
- }
208
-
209
- /**
210
- * Validate if a risk tier is supported in the current complexity tier
211
- * @param {string} riskTier - Risk tier to validate
212
- * @param {string} complexityTier - Complexity tier
213
- * @returns {boolean} Whether risk tier is supported
214
- */
215
- function isRiskTierSupported(riskTier, complexityTier = 'standard') {
216
- const supportedTiers = getSupportedRiskTiers(complexityTier);
217
- return supportedTiers.includes(riskTier);
218
- }
219
-
220
- /**
221
- * Display tier comparison
222
- */
223
- function displayTierComparison() {
224
- console.log(chalk.bold.cyan('\nCAWS Complexity Tiers'));
225
- console.log(chalk.cyan('=========================================================\n'));
226
-
227
- // Header
228
- console.log(
229
- chalk.bold(
230
- 'Tier'.padEnd(12) +
231
- 'Features'.padEnd(15) +
232
- 'Coverage'.padEnd(10) +
233
- 'Commands'.padEnd(12) +
234
- 'Use Case'
235
- )
236
- );
237
- console.log(chalk.gray('-'.repeat(90)));
238
-
239
- Object.entries(COMPLEXITY_TIERS).forEach(([tierName, tier]) => {
240
- const tierColor = tier.color;
241
- const icon = tier.icon;
242
-
243
- const features = Object.entries(tier.features)
244
- .filter(([, enabled]) => enabled)
245
- .map(([feature]) => feature.replace(/([A-Z])/g, ' $1').toLowerCase())
246
- .slice(0, 3)
247
- .join(', ');
248
-
249
- const commands = Object.keys(tier.commands).filter((cmd) => tier.commands[cmd]).length;
250
-
251
- console.log(
252
- `${icon} ${tierColor(tierName.padEnd(10))} ${features.padEnd(13)} ${tier.qualityRequirements.testCoverage}%${' '.padEnd(8)}${commands}${' '.padEnd(10)}${tier.description}`
253
- );
254
- });
255
-
256
- console.log('');
257
- }
258
-
259
- /**
260
- * Get current mode from configuration
261
- * @returns {Promise<string>} Current mode
262
- */
263
- async function getCurrentMode() {
264
- const fs = require('fs-extra');
265
- const MODE_CONFIG = '.caws/mode.json';
266
-
267
- try {
268
- if (!(await fs.pathExists(MODE_CONFIG))) {
269
- return 'standard'; // Default to standard mode
270
- }
271
-
272
- const config = JSON.parse(await fs.readFile(MODE_CONFIG, 'utf8'));
273
- return config.current || 'standard';
274
- } catch (error) {
275
- return 'standard'; // Default to standard mode on error
276
- }
277
- }
278
-
279
- /**
280
- * Set current mode in configuration
281
- * @param {string} mode - Mode to set
282
- * @returns {Promise<boolean>} Success status
283
- */
284
- async function setCurrentMode(mode) {
285
- const fs = require('fs-extra');
286
- const path = require('path');
287
- const MODE_CONFIG = '.caws/mode.json';
288
-
289
- if (!getAvailableTiers().includes(mode)) {
290
- return false;
291
- }
292
-
293
- try {
294
- await fs.ensureDir(path.dirname(MODE_CONFIG));
295
- const config = {
296
- current: mode,
297
- initialized: true,
298
- lastChanged: new Date().toISOString(),
299
- };
300
- await fs.writeFile(MODE_CONFIG, JSON.stringify(config, null, 2));
301
- return true;
302
- } catch (error) {
303
- return false;
304
- }
305
- }
306
-
307
- /**
308
- * Get tier recommendation based on project characteristics
309
- * @param {Object} projectInfo - Project information
310
- * @returns {string} Recommended tier
311
- */
312
- function getTierRecommendation(projectInfo = {}) {
313
- const { size = 'medium', teamSize = 1, compliance = false, auditRequired = false } = projectInfo;
314
-
315
- // Enterprise tier for compliance/audit requirements
316
- if (compliance || auditRequired) {
317
- return 'enterprise';
318
- }
319
-
320
- // Enterprise for large teams or projects
321
- if (teamSize > 5 || size === 'large') {
322
- return 'enterprise';
323
- }
324
-
325
- // Standard for medium teams/projects
326
- if (teamSize > 1 || size === 'medium') {
327
- return 'standard';
328
- }
329
-
330
- // Simple for solo/small projects
331
- return 'simple';
332
- }
333
-
334
- module.exports = {
335
- COMPLEXITY_TIERS,
336
- getTier,
337
- getAvailableTiers,
338
- getCurrentMode,
339
- setCurrentMode,
340
- isCommandAvailable,
341
- isFeatureEnabled,
342
- getQualityRequirements,
343
- getSupportedRiskTiers,
344
- isRiskTierSupported,
345
- displayTierComparison,
346
- getTierRecommendation,
347
- };
@@ -1,65 +0,0 @@
1
- /**
2
- * @fileoverview Spec Types and Status Constants
3
- * Defines spec types, statuses, and their metadata for consistent display
4
- * @author @darianrosebrook
5
- */
6
-
7
- const chalk = require('chalk');
8
-
9
- /**
10
- * Spec types and their metadata
11
- */
12
- const SPEC_TYPES = {
13
- feature: {
14
- color: chalk.green,
15
- icon: '',
16
- description: 'New feature development',
17
- },
18
- fix: {
19
- color: chalk.red,
20
- icon: '',
21
- description: 'Bug fixes and patches',
22
- },
23
- refactor: {
24
- color: chalk.blue,
25
- icon: '',
26
- description: 'Code refactoring and improvements',
27
- },
28
- chore: {
29
- color: chalk.gray,
30
- icon: '',
31
- description: 'Maintenance and cleanup',
32
- },
33
- docs: {
34
- color: chalk.cyan,
35
- icon: '',
36
- description: 'Documentation updates',
37
- },
38
- };
39
-
40
- /**
41
- * Spec statuses and lifecycle metadata.
42
- * Terminal statuses mean the spec is done — its scope restrictions
43
- * should NOT be enforced by the scope guard.
44
- */
45
- const SPEC_STATUSES = {
46
- draft: { label: 'Draft', color: chalk.yellow, terminal: false },
47
- active: { label: 'Active', color: chalk.green, terminal: false },
48
- in_progress: { label: 'In Progress', color: chalk.green, terminal: false },
49
- completed: { label: 'Completed', color: chalk.blue, terminal: true },
50
- closed: { label: 'Closed', color: chalk.gray, terminal: true },
51
- archived: { label: 'Archived', color: chalk.gray, terminal: true },
52
- };
53
-
54
- /**
55
- * Status keys that indicate a spec is done (scope no longer enforced).
56
- */
57
- const TERMINAL_STATUSES = Object.entries(SPEC_STATUSES)
58
- .filter(([, v]) => v.terminal)
59
- .map(([k]) => k);
60
-
61
- module.exports = {
62
- SPEC_TYPES,
63
- SPEC_STATUSES,
64
- TERMINAL_STATUSES,
65
- };
@@ -1,121 +0,0 @@
1
- /**
2
- * @fileoverview Budget enforcement gate
3
- * Checks changes against tier budget limits from policy.
4
- * Context-aware: commit context counts staged changes, cli context skips (budget is per-change, not per-repo).
5
- * @author @darianrosebrook
6
- */
7
-
8
- const { deriveBudget, checkBudgetCompliance } = require('../budget-derivation');
9
- const { execSync } = require('child_process');
10
-
11
- const name = 'budget_limit';
12
-
13
- /**
14
- * Count staged files and lines of code from git diff
15
- * @param {string[]} stagedFiles - List of staged file paths
16
- * @param {string} projectRoot - Project root directory
17
- * @returns {Object} Stats with files_changed and lines_changed
18
- */
19
- function getStagedStats(stagedFiles, projectRoot) {
20
- const filesChanged = stagedFiles.length;
21
- let linesChanged = 0;
22
-
23
- try {
24
- const numstat = execSync('git diff --cached --numstat', {
25
- cwd: projectRoot,
26
- encoding: 'utf8',
27
- stdio: ['ignore', 'pipe', 'pipe'],
28
- });
29
- for (const line of numstat.trim().split('\n').filter(Boolean)) {
30
- const [added, removed] = line.split('\t');
31
- const addedNum = added === '-' ? 0 : parseInt(added, 10) || 0;
32
- const removedNum = removed === '-' ? 0 : parseInt(removed, 10) || 0;
33
- linesChanged += addedNum + removedNum;
34
- }
35
- } catch (err) {
36
- // Fail-closed: if git fails, we cannot verify budget compliance
37
- return {
38
- files_changed: filesChanged,
39
- lines_changed: -1,
40
- error: `Cannot count staged line changes: ${err.message}`,
41
- };
42
- }
43
-
44
- return { files_changed: filesChanged, lines_changed: linesChanged };
45
- }
46
-
47
- /**
48
- * Run the budget limit gate
49
- * @param {Object} params - Gate parameters
50
- * @param {string[]} params.stagedFiles - Staged file paths
51
- * @param {Object} params.spec - Working spec
52
- * @param {Object} params.policy - Policy configuration
53
- * @param {string} params.projectRoot - Project root
54
- * @param {number} params.riskTier - Risk tier number
55
- * @param {string} [params.context] - Execution context (commit, cli, edit)
56
- * @returns {Promise<Object>} Gate result with status and messages
57
- */
58
- async function run({ stagedFiles, spec, _policy, projectRoot, riskTier, context }) {
59
- const messages = [];
60
-
61
- // Budget limits apply to changes, not to the entire repo.
62
- // In cli context with all tracked files, budget check is meaningless.
63
- // Return 'skipped' (not 'pass') so the pipeline summary counts this gate under
64
- // `skipped`, matching pipeline.js semantics for gates that did not actually run.
65
- if (context === 'cli') {
66
- return {
67
- status: 'skipped',
68
- messages: ['Budget check skipped in CLI context (budget applies to changes, not full repo)'],
69
- };
70
- }
71
-
72
- // Build a minimal spec for deriveBudget
73
- const specForBudget = {
74
- risk_tier: riskTier,
75
- waiver_ids: spec?.waiver_ids || [],
76
- };
77
-
78
- try {
79
- const budget = await deriveBudget(specForBudget, projectRoot, { useCache: true });
80
- const stats = getStagedStats(stagedFiles, projectRoot);
81
-
82
- // Fail-closed: if git stats errored, report it
83
- if (stats.error) {
84
- messages.push(stats.error);
85
- return { status: 'fail', messages };
86
- }
87
-
88
- const compliance = checkBudgetCompliance(budget, stats);
89
-
90
- if (!compliance.compliant) {
91
- for (const violation of compliance.violations) {
92
- messages.push(violation.message);
93
- }
94
- return { status: 'fail', messages };
95
- }
96
-
97
- // Emit budget:pressure if usage > 80% but still compliant
98
- try {
99
- const filePercent = budget.max_files > 0 ? stats.files_changed / budget.max_files : 0;
100
- const locPercent = budget.max_loc > 0 ? stats.lines_changed / budget.max_loc : 0;
101
- if (filePercent > 0.8 || locPercent > 0.8) {
102
- const { lifecycle, EVENTS } = require('../utils/lifecycle-events');
103
- lifecycle.emit(EVENTS.BUDGET_PRESSURE, {
104
- specId: spec?.id || null,
105
- filesUsed: stats.files_changed,
106
- filesLimit: budget.max_files,
107
- locUsed: stats.lines_changed,
108
- locLimit: budget.max_loc,
109
- percentUsed: Math.round(Math.max(filePercent, locPercent) * 100),
110
- timestamp: new Date().toISOString(),
111
- });
112
- }
113
- } catch { /* non-fatal */ }
114
-
115
- return { status: 'pass', messages };
116
- } catch (err) {
117
- return { status: 'fail', messages: [`Budget check error: ${err.message}`] };
118
- }
119
- }
120
-
121
- module.exports = { name, run };