@paths.design/caws-cli 10.2.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 (421) hide show
  1. package/README.md +125 -374
  2. package/dist/index.js +43 -785
  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/agents.js +0 -124
  183. package/dist/commands/archive.js +0 -500
  184. package/dist/commands/burnup.js +0 -198
  185. package/dist/commands/diagnose.js +0 -525
  186. package/dist/commands/evaluate.js +0 -314
  187. package/dist/commands/gates.js +0 -149
  188. package/dist/commands/init.js +0 -857
  189. package/dist/commands/iterate.js +0 -417
  190. package/dist/commands/mode.js +0 -269
  191. package/dist/commands/parallel.js +0 -242
  192. package/dist/commands/plan.js +0 -438
  193. package/dist/commands/provenance.js +0 -1143
  194. package/dist/commands/quality-monitor.js +0 -284
  195. package/dist/commands/scope.js +0 -264
  196. package/dist/commands/session.js +0 -312
  197. package/dist/commands/sidecar.js +0 -74
  198. package/dist/commands/specs.js +0 -1656
  199. package/dist/commands/status.js +0 -1172
  200. package/dist/commands/templates.js +0 -237
  201. package/dist/commands/tool.js +0 -136
  202. package/dist/commands/tutorial.js +0 -480
  203. package/dist/commands/validate.js +0 -357
  204. package/dist/commands/verify-acs.js +0 -443
  205. package/dist/commands/waivers.js +0 -599
  206. package/dist/commands/workflow.js +0 -243
  207. package/dist/commands/worktree.js +0 -502
  208. package/dist/config/lite-scope.js +0 -158
  209. package/dist/config/modes.js +0 -347
  210. package/dist/constants/spec-types.js +0 -65
  211. package/dist/gates/budget-limit.js +0 -121
  212. package/dist/gates/feedback.js +0 -260
  213. package/dist/gates/format.js +0 -179
  214. package/dist/gates/god-object.js +0 -117
  215. package/dist/gates/pipeline.js +0 -167
  216. package/dist/gates/scope-boundary.js +0 -112
  217. package/dist/gates/spec-completeness.js +0 -109
  218. package/dist/gates/todo-detection.js +0 -205
  219. package/dist/generators/jest-config-generator.js +0 -242
  220. package/dist/generators/working-spec.js +0 -237
  221. package/dist/minimal-cli.js +0 -88
  222. package/dist/parallel/parallel-manager.js +0 -433
  223. package/dist/policy/PolicyManager.js +0 -470
  224. package/dist/scaffold/claude-hooks.js +0 -443
  225. package/dist/scaffold/cursor-hooks.js +0 -177
  226. package/dist/scaffold/git-hooks.js +0 -928
  227. package/dist/scaffold/index.js +0 -794
  228. package/dist/session/session-manager.js +0 -653
  229. package/dist/sidecars/index.js +0 -33
  230. package/dist/sidecars/listeners.js +0 -40
  231. package/dist/sidecars/provenance-summary.js +0 -238
  232. package/dist/sidecars/quality-gaps.js +0 -258
  233. package/dist/sidecars/schema.js +0 -149
  234. package/dist/sidecars/spec-drift.js +0 -151
  235. package/dist/sidecars/waiver-draft.js +0 -176
  236. package/dist/spec/SpecFileManager.js +0 -419
  237. package/dist/templates/.caws/schemas/policy.schema.json +0 -117
  238. package/dist/templates/.caws/schemas/scope.schema.json +0 -52
  239. package/dist/templates/.caws/schemas/waivers.schema.json +0 -106
  240. package/dist/templates/.caws/schemas/working-spec.schema.json +0 -340
  241. package/dist/templates/.caws/schemas/worktrees.schema.json +0 -38
  242. package/dist/templates/.caws/templates/working-spec.template.yml +0 -80
  243. package/dist/templates/.caws/tools/README.md +0 -18
  244. package/dist/templates/.caws/tools/scope-guard.js +0 -203
  245. package/dist/templates/.caws/tools-allow.json +0 -331
  246. package/dist/templates/.caws/waivers.yml +0 -19
  247. package/dist/templates/.claude/README.md +0 -190
  248. package/dist/templates/.claude/hooks/audit.sh +0 -121
  249. package/dist/templates/.claude/hooks/block-dangerous.sh +0 -203
  250. package/dist/templates/.claude/hooks/classify_command.py +0 -592
  251. package/dist/templates/.claude/hooks/doc-frontmatter-check.sh +0 -173
  252. package/dist/templates/.claude/hooks/lite-sprawl-check.sh +0 -145
  253. package/dist/templates/.claude/hooks/naming-check.sh +0 -100
  254. package/dist/templates/.claude/hooks/protected-paths.sh +0 -39
  255. package/dist/templates/.claude/hooks/quality-check.sh +0 -81
  256. package/dist/templates/.claude/hooks/scan-secrets.sh +0 -85
  257. package/dist/templates/.claude/hooks/scope-guard.sh +0 -381
  258. package/dist/templates/.claude/hooks/session-caws-status.sh +0 -117
  259. package/dist/templates/.claude/hooks/session-log.sh +0 -634
  260. package/dist/templates/.claude/hooks/simplification-guard.sh +0 -92
  261. package/dist/templates/.claude/hooks/stop-worktree-check.sh +0 -46
  262. package/dist/templates/.claude/hooks/test_classify_command.py +0 -370
  263. package/dist/templates/.claude/hooks/test_wrapper_smoke.sh +0 -96
  264. package/dist/templates/.claude/hooks/validate-spec.sh +0 -76
  265. package/dist/templates/.claude/hooks/worktree-guard.sh +0 -220
  266. package/dist/templates/.claude/hooks/worktree-write-guard.sh +0 -190
  267. package/dist/templates/.claude/rules/git-safety.md +0 -26
  268. package/dist/templates/.claude/rules/worktree-isolation.md +0 -101
  269. package/dist/templates/.claude/settings.json +0 -141
  270. package/dist/templates/.cursor/README.md +0 -299
  271. package/dist/templates/.cursor/hooks/audit.sh +0 -55
  272. package/dist/templates/.cursor/hooks/block-dangerous.sh +0 -84
  273. package/dist/templates/.cursor/hooks/caws-quality-check.sh +0 -52
  274. package/dist/templates/.cursor/hooks/caws-scope-guard.sh +0 -130
  275. package/dist/templates/.cursor/hooks/format.sh +0 -38
  276. package/dist/templates/.cursor/hooks/naming-check.sh +0 -64
  277. package/dist/templates/.cursor/hooks/scan-secrets.sh +0 -51
  278. package/dist/templates/.cursor/hooks/scope-guard.sh +0 -52
  279. package/dist/templates/.cursor/hooks/session-log.sh +0 -924
  280. package/dist/templates/.cursor/hooks/validate-spec.sh +0 -83
  281. package/dist/templates/.cursor/hooks.json +0 -76
  282. package/dist/templates/.cursor/rules/00-claims-verification.mdc +0 -144
  283. package/dist/templates/.cursor/rules/01-working-style.mdc +0 -50
  284. package/dist/templates/.cursor/rules/02-quality-gates.mdc +0 -368
  285. package/dist/templates/.cursor/rules/03-naming-and-refactor.mdc +0 -33
  286. package/dist/templates/.cursor/rules/04-logging-language-style.mdc +0 -23
  287. package/dist/templates/.cursor/rules/05-safe-defaults-guards.mdc +0 -23
  288. package/dist/templates/.cursor/rules/06-typescript-conventions.mdc +0 -36
  289. package/dist/templates/.cursor/rules/07-process-ops.mdc +0 -20
  290. package/dist/templates/.cursor/rules/08-solid-and-architecture.mdc +0 -16
  291. package/dist/templates/.cursor/rules/09-docstrings.mdc +0 -89
  292. package/dist/templates/.cursor/rules/10-documentation-quality-standards.mdc +0 -385
  293. package/dist/templates/.cursor/rules/11-scope-management-waivers.mdc +0 -381
  294. package/dist/templates/.cursor/rules/12-implementation-completeness.mdc +0 -516
  295. package/dist/templates/.cursor/rules/13-language-agnostic-standards.mdc +0 -578
  296. package/dist/templates/.cursor/rules/README.md +0 -148
  297. package/dist/templates/.github/copilot-instructions.md +0 -82
  298. package/dist/templates/.idea/runConfigurations/CAWS_Evaluate.xml +0 -5
  299. package/dist/templates/.idea/runConfigurations/CAWS_Validate.xml +0 -5
  300. package/dist/templates/.junie/guidelines.md +0 -73
  301. package/dist/templates/.vscode/launch.json +0 -17
  302. package/dist/templates/.vscode/settings.json +0 -95
  303. package/dist/templates/.windsurf/rules/caws-quality-standards.md +0 -54
  304. package/dist/templates/.windsurf/workflows/caws-guided-development.md +0 -92
  305. package/dist/templates/CLAUDE.md +0 -196
  306. package/dist/templates/COMMIT_CONVENTIONS.md +0 -86
  307. package/dist/templates/OIDC_SETUP.md +0 -300
  308. package/dist/templates/agents.md +0 -171
  309. package/dist/templates/codemod/README.md +0 -1
  310. package/dist/templates/codemod/test.js +0 -93
  311. package/dist/templates/docs/README.md +0 -151
  312. package/dist/templates/scripts/new_feature.sh +0 -80
  313. package/dist/templates/scripts/quality-gates/check-god-objects.js +0 -146
  314. package/dist/templates/scripts/quality-gates/run-quality-gates.js +0 -50
  315. package/dist/templates/scripts/v3/analysis/todo_analyzer.py +0 -1997
  316. package/dist/test-analysis.js +0 -786
  317. package/dist/tool-interface.js +0 -314
  318. package/dist/tool-loader.js +0 -303
  319. package/dist/tool-validator.js +0 -393
  320. package/dist/utils/agent-display.js +0 -210
  321. package/dist/utils/agent-session.js +0 -344
  322. package/dist/utils/async-utils.js +0 -188
  323. package/dist/utils/command-wrapper.js +0 -200
  324. package/dist/utils/event-log.js +0 -584
  325. package/dist/utils/event-renderer.js +0 -521
  326. package/dist/utils/finalization.js +0 -230
  327. package/dist/utils/git-lock.js +0 -119
  328. package/dist/utils/gitignore-updater.js +0 -158
  329. package/dist/utils/ide-detection.js +0 -133
  330. package/dist/utils/lifecycle-events.js +0 -94
  331. package/dist/utils/project-analysis.js +0 -367
  332. package/dist/utils/promise-utils.js +0 -72
  333. package/dist/utils/quality-gates-errors.js +0 -520
  334. package/dist/utils/quality-gates-utils.js +0 -387
  335. package/dist/utils/schema-validator.js +0 -50
  336. package/dist/utils/spec-resolver.js +0 -711
  337. package/dist/utils/typescript-detector.js +0 -369
  338. package/dist/utils/working-state.js +0 -530
  339. package/dist/utils/yaml-validation.js +0 -156
  340. package/dist/validation/spec-validation.js +0 -924
  341. package/dist/waivers-manager.js +0 -732
  342. package/dist/worktree/worktree-manager.js +0 -1735
  343. package/templates/.caws/schemas/policy.schema.json +0 -117
  344. package/templates/.caws/schemas/scope.schema.json +0 -52
  345. package/templates/.caws/schemas/waivers.schema.json +0 -106
  346. package/templates/.caws/schemas/working-spec.schema.json +0 -340
  347. package/templates/.caws/schemas/worktrees.schema.json +0 -38
  348. package/templates/.caws/templates/working-spec.template.yml +0 -80
  349. package/templates/.caws/tools/README.md +0 -18
  350. package/templates/.caws/tools/scope-guard.js +0 -203
  351. package/templates/.caws/tools-allow.json +0 -331
  352. package/templates/.caws/waivers.yml +0 -19
  353. package/templates/.claude/README.md +0 -190
  354. package/templates/.claude/hooks/audit.sh +0 -121
  355. package/templates/.claude/hooks/block-dangerous.sh +0 -203
  356. package/templates/.claude/hooks/classify_command.py +0 -592
  357. package/templates/.claude/hooks/doc-frontmatter-check.sh +0 -173
  358. package/templates/.claude/hooks/lite-sprawl-check.sh +0 -145
  359. package/templates/.claude/hooks/naming-check.sh +0 -100
  360. package/templates/.claude/hooks/protected-paths.sh +0 -39
  361. package/templates/.claude/hooks/quality-check.sh +0 -81
  362. package/templates/.claude/hooks/scan-secrets.sh +0 -85
  363. package/templates/.claude/hooks/scope-guard.sh +0 -381
  364. package/templates/.claude/hooks/session-caws-status.sh +0 -117
  365. package/templates/.claude/hooks/session-log.sh +0 -634
  366. package/templates/.claude/hooks/simplification-guard.sh +0 -92
  367. package/templates/.claude/hooks/stop-worktree-check.sh +0 -46
  368. package/templates/.claude/hooks/test_classify_command.py +0 -370
  369. package/templates/.claude/hooks/test_wrapper_smoke.sh +0 -96
  370. package/templates/.claude/hooks/validate-spec.sh +0 -76
  371. package/templates/.claude/hooks/worktree-guard.sh +0 -220
  372. package/templates/.claude/hooks/worktree-write-guard.sh +0 -190
  373. package/templates/.claude/rules/git-safety.md +0 -26
  374. package/templates/.claude/rules/worktree-isolation.md +0 -101
  375. package/templates/.claude/settings.json +0 -141
  376. package/templates/.cursor/README.md +0 -299
  377. package/templates/.cursor/hooks/audit.sh +0 -55
  378. package/templates/.cursor/hooks/block-dangerous.sh +0 -84
  379. package/templates/.cursor/hooks/caws-quality-check.sh +0 -52
  380. package/templates/.cursor/hooks/caws-scope-guard.sh +0 -130
  381. package/templates/.cursor/hooks/format.sh +0 -38
  382. package/templates/.cursor/hooks/naming-check.sh +0 -64
  383. package/templates/.cursor/hooks/scan-secrets.sh +0 -51
  384. package/templates/.cursor/hooks/scope-guard.sh +0 -52
  385. package/templates/.cursor/hooks/session-log.sh +0 -924
  386. package/templates/.cursor/hooks/validate-spec.sh +0 -83
  387. package/templates/.cursor/hooks.json +0 -76
  388. package/templates/.cursor/rules/00-claims-verification.mdc +0 -144
  389. package/templates/.cursor/rules/01-working-style.mdc +0 -50
  390. package/templates/.cursor/rules/02-quality-gates.mdc +0 -368
  391. package/templates/.cursor/rules/03-naming-and-refactor.mdc +0 -33
  392. package/templates/.cursor/rules/04-logging-language-style.mdc +0 -23
  393. package/templates/.cursor/rules/05-safe-defaults-guards.mdc +0 -23
  394. package/templates/.cursor/rules/06-typescript-conventions.mdc +0 -36
  395. package/templates/.cursor/rules/07-process-ops.mdc +0 -20
  396. package/templates/.cursor/rules/08-solid-and-architecture.mdc +0 -16
  397. package/templates/.cursor/rules/09-docstrings.mdc +0 -89
  398. package/templates/.cursor/rules/10-documentation-quality-standards.mdc +0 -385
  399. package/templates/.cursor/rules/11-scope-management-waivers.mdc +0 -381
  400. package/templates/.cursor/rules/12-implementation-completeness.mdc +0 -516
  401. package/templates/.cursor/rules/13-language-agnostic-standards.mdc +0 -578
  402. package/templates/.cursor/rules/README.md +0 -148
  403. package/templates/.github/copilot-instructions.md +0 -82
  404. package/templates/.idea/runConfigurations/CAWS_Evaluate.xml +0 -5
  405. package/templates/.idea/runConfigurations/CAWS_Validate.xml +0 -5
  406. package/templates/.junie/guidelines.md +0 -73
  407. package/templates/.vscode/launch.json +0 -17
  408. package/templates/.vscode/settings.json +0 -95
  409. package/templates/.windsurf/rules/caws-quality-standards.md +0 -54
  410. package/templates/.windsurf/workflows/caws-guided-development.md +0 -92
  411. package/templates/CLAUDE.md +0 -196
  412. package/templates/COMMIT_CONVENTIONS.md +0 -86
  413. package/templates/OIDC_SETUP.md +0 -300
  414. package/templates/agents.md +0 -171
  415. package/templates/codemod/README.md +0 -1
  416. package/templates/codemod/test.js +0 -93
  417. package/templates/docs/README.md +0 -151
  418. package/templates/scripts/new_feature.sh +0 -80
  419. package/templates/scripts/quality-gates/check-god-objects.js +0 -146
  420. package/templates/scripts/quality-gates/run-quality-gates.js +0 -50
  421. package/templates/scripts/v3/analysis/todo_analyzer.py +0 -1997
@@ -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 };