@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,516 +0,0 @@
1
- ---
2
- description: Anti-fake implementation guardrails to prevent incomplete, stubbed, or fake implementations
3
- globs:
4
- alwaysApply: true
5
- ---
6
-
7
- # Implementation Completeness Guardrails
8
-
9
- ## Core Principle
10
-
11
- **No incomplete, stubbed, or fake implementations in production code.** All business logic must be fully implemented with proper error handling and real integrations.
12
-
13
- ## Implementation Quality Detection
14
-
15
- ### PLACEHOLDER Detection
16
-
17
- **Automated Detection Patterns:**
18
-
19
- ```bash
20
- # Find all placeholder implementations
21
- rg -n "PLACEHOLDER|TODO|MOCK_DATA|FIXME|HACK" src/
22
- rg -n "throw new Error.*not implemented" src/
23
- rg -n "return.*mock|fake|dummy" src/
24
- rg -n "console\.log.*placeholder" src/
25
- ```
26
-
27
- **Required Tagging:**
28
-
29
- ```typescript
30
- // PLACEHOLDER: Real payment processing not implemented
31
- function processPayment(amount: number): Promise<PaymentResult> {
32
- throw new Error('PLACEHOLDER: Payment processing not implemented');
33
- }
34
-
35
- // TODO: Implement actual tax calculation
36
- function calculateTax(amount: number): number {
37
- if (process.env.NODE_ENV === 'production') {
38
- throw new Error('TODO: Tax calculation must be implemented before production');
39
- }
40
- return amount * 0.1; // Mock calculation
41
- }
42
-
43
- // MOCK DATA: Remove before production
44
- const mockUsers = [{ id: 1, name: 'John Doe', email: 'john@example.com' }];
45
- ```
46
-
47
- ### Stub Implementation Prevention
48
-
49
- **Forbidden Patterns:**
50
-
51
- ```typescript
52
- // ❌ BAD: Silent stub implementation
53
- function getUserData(id: string) {
54
- return { id, name: 'Mock User' }; // No indication this is fake
55
- }
56
-
57
- // ❌ BAD: Console.log stub
58
- function processOrder(order: Order) {
59
- console.log('Processing order:', order); // Not real implementation
60
- return { success: true };
61
- }
62
-
63
- // ❌ BAD: Empty implementation
64
- function calculateTotal(items: Item[]) {
65
- // Implementation coming soon
66
- return 0;
67
- }
68
- ```
69
-
70
- **Required Patterns:**
71
-
72
- ```typescript
73
- // ✅ GOOD: Explicit placeholder with error
74
- function getUserData(id: string) {
75
- // PLACEHOLDER: Real user data fetching not implemented
76
- throw new Error('PLACEHOLDER: getUserData not implemented');
77
- }
78
-
79
- // ✅ GOOD: Proper implementation
80
- function processOrder(order: Order) {
81
- const total = calculateTotal(order.items);
82
- const tax = calculateTax(total);
83
- return { success: true, total, tax };
84
- }
85
- ```
86
-
87
- ## Fake Persistence Detection
88
-
89
- ### Database Mock Detection
90
-
91
- **Forbidden Patterns:**
92
-
93
- ```typescript
94
- // ❌ BAD: In-memory "database"
95
- class UserRepository {
96
- private users: User[] = []; // Not real persistence
97
-
98
- async save(user: User) {
99
- this.users.push(user); // Fake persistence
100
- }
101
- }
102
-
103
- // ❌ BAD: Mock database operations
104
- async function createUser(userData: CreateUserRequest) {
105
- // Mock database call
106
- return { id: Math.random(), ...userData };
107
- }
108
- ```
109
-
110
- **Required Patterns:**
111
-
112
- ```typescript
113
- // ✅ GOOD: Real database implementation
114
- class UserRepository {
115
- constructor(private db: Database) {}
116
-
117
- async save(user: User) {
118
- const result = await this.db.query(
119
- 'INSERT INTO users (name, email) VALUES ($1, $2) RETURNING *',
120
- [user.name, user.email]
121
- );
122
- return result.rows[0];
123
- }
124
- }
125
- ```
126
-
127
- ### API Mock Detection
128
-
129
- **Forbidden Patterns:**
130
-
131
- ```typescript
132
- // ❌ BAD: Fake API responses
133
- async function fetchUserData(id: string) {
134
- // Mock API response
135
- return { id, name: 'Mock User', email: 'mock@example.com' };
136
- }
137
-
138
- // ❌ BAD: Hardcoded responses
139
- async function getWeatherData(city: string) {
140
- return { city, temperature: 72, condition: 'sunny' }; // Fake data
141
- }
142
- ```
143
-
144
- **Required Patterns:**
145
-
146
- ```typescript
147
- // ✅ GOOD: Real API implementation
148
- async function fetchUserData(id: string) {
149
- const response = await fetch(`/api/users/${id}`, {
150
- headers: { Authorization: `Bearer ${token}` },
151
- });
152
-
153
- if (!response.ok) {
154
- throw new Error(`Failed to fetch user: ${response.statusText}`);
155
- }
156
-
157
- return await response.json();
158
- }
159
- ```
160
-
161
- ## Business Logic Completeness
162
-
163
- ### Core Business Functions
164
-
165
- **Must be fully implemented:**
166
-
167
- - Authentication and authorization
168
- - Data validation and sanitization
169
- - Business rule enforcement
170
- - Error handling and recovery
171
- - Audit logging and monitoring
172
-
173
- **Implementation Requirements:**
174
-
175
- ```typescript
176
- // ✅ GOOD: Complete business logic
177
- class OrderService {
178
- async processOrder(order: Order): Promise<OrderResult> {
179
- // Validate input
180
- if (!order.items || order.items.length === 0) {
181
- throw new ValidationError('Order must contain items');
182
- }
183
-
184
- // Check inventory
185
- const inventoryCheck = await this.inventoryService.checkAvailability(order.items);
186
- if (!inventoryCheck.available) {
187
- throw new InsufficientInventoryError(inventoryCheck.unavailableItems);
188
- }
189
-
190
- // Calculate pricing
191
- const pricing = await this.pricingService.calculateOrder(order);
192
-
193
- // Process payment
194
- const payment = await this.paymentService.processPayment({
195
- amount: pricing.total,
196
- method: order.paymentMethod,
197
- });
198
-
199
- // Create order record
200
- const orderRecord = await this.orderRepository.create({
201
- ...order,
202
- total: pricing.total,
203
- paymentId: payment.id,
204
- status: 'confirmed',
205
- });
206
-
207
- // Send confirmation
208
- await this.notificationService.sendOrderConfirmation(orderRecord);
209
-
210
- return {
211
- orderId: orderRecord.id,
212
- total: pricing.total,
213
- estimatedDelivery: pricing.estimatedDelivery,
214
- };
215
- }
216
- }
217
- ```
218
-
219
- ## Quality Gates for Implementation
220
-
221
- ### Pre-Production Checks
222
-
223
- **Automated Verification:**
224
-
225
- ```bash
226
- # Check for incomplete implementations
227
- npm run check:completeness
228
- # - Scan for PLACEHOLDER/TODO/MOCK_DATA
229
- # - Verify all business logic is implemented
230
- # - Check for real database connections
231
- # - Validate API integrations
232
-
233
- # Check for fake persistence
234
- npm run check:persistence
235
- # - Verify database connections are real
236
- # - Check for in-memory storage patterns
237
- # - Validate migration scripts exist
238
- ```
239
-
240
- ### Implementation Completeness Matrix
241
-
242
- | Component | Real DB | Real APIs | Error Handling | Validation | Logging |
243
- | ------------------- | ----------- | ----------- | -------------- | ----------- | ----------- |
244
- | **Auth** | ✅ Required | ✅ Required | ✅ Required | ✅ Required | ✅ Required |
245
- | **Billing** | ✅ Required | ✅ Required | ✅ Required | ✅ Required | ✅ Required |
246
- | **Data Processing** | ✅ Required | ✅ Required | ✅ Required | ✅ Required | ✅ Required |
247
- | **UI Components** | N/A | ✅ Required | ✅ Required | ✅ Required | Optional |
248
- | **Utilities** | N/A | ✅ Required | ✅ Required | ✅ Required | Optional |
249
-
250
- ## Advanced Detection Patterns
251
-
252
- ### Hidden TODO Detection
253
-
254
- **High-Confidence Hidden TODO Patterns:**
255
-
256
- ```python
257
- # Sophisticated patterns for detecting incomplete implementations
258
- high_confidence_patterns = {
259
- 'incomplete_implementation': [
260
- r'\bnot\s+yet\s+implemented\b',
261
- r'\bmissing\s+implementation\b',
262
- r'\bincomplete\s+implementation\b',
263
- r'\bpartial\s+implementation\b',
264
- r'\bunimplemented\b',
265
- r'\bnot\s+done\b',
266
- r'\bpending\s+implementation\b',
267
- r'\bto\s+be\s+implemented\b',
268
- r'\bwill\s+be\s+implemented\b',
269
- ],
270
-
271
- 'placeholder_code': [
272
- r'\bplaceholder\s+code\b',
273
- r'\bplaceholder\s+implementation\b',
274
- r'\bstub\s+implementation\b',
275
- r'\bdummy\s+implementation\b',
276
- r'\bfake\s+implementation\b',
277
- r'\bsimplified\s+.*?\s+implementation\b',
278
- r'\bfor\s+now\b.*?(just|simply|only)\s+(concatenate|return|use)',
279
- ],
280
-
281
- 'temporary_solutions': [
282
- r'\btemporary\s+solution\b',
283
- r'\btemporary\s+fix\b',
284
- r'\bquick\s+fix\b',
285
- r'\bworkaround\b',
286
- r'\bhack\b.*?(fix|solution)',
287
- ],
288
-
289
- 'hardcoded_values': [
290
- r'\bhardcoded\s+value\b',
291
- r'\bmagic\s+number\b',
292
- r'\bmagic\s+string\b',
293
- r'\bconstant\s+value\b.*?(replace|change|make\s+configurable)',
294
- ],
295
-
296
- 'future_improvements': [
297
- r'\bin\s+production\b.*?(implement|add|fix)',
298
- r'\bin\s+a\s+real\s+implementation\b',
299
- r'\beventually\b.*?(implement|add|fix)',
300
- r'\bshould\s+be\b.*?(implemented|added|fixed)',
301
- r'\bwould\s+be\b.*?(implemented|added|fixed)',
302
- ],
303
- }
304
- ```
305
-
306
- **Code Stub Detection:**
307
-
308
- ```python
309
- # Language-specific stub patterns
310
- code_stub_patterns = {
311
- 'javascript': {
312
- 'function_stub': re.compile(r'^\s*(async\s+)?function\s+\w+\(.*\)\s*{'),
313
- 'throw_not_impl': re.compile(r"^\s*throw\s+new\s+Error\((\"|')(TODO|Not\s+Implemented)"),
314
- 'return_todo': re.compile(r"^\s*return\s+(null|undefined);\s*//\s*TODO"),
315
- },
316
- 'typescript': {
317
- 'function_stub': re.compile(r'^\s*(async\s+)?function\s+\w+\(.*\)\s*{'),
318
- 'throw_not_impl': re.compile(r"^\s*throw\s+new\s+Error\((\"|')(TODO|Not\s+Implemented)"),
319
- 'return_todo': re.compile(r"^\s*return\s+(null|undefined);\s*//\s*TODO"),
320
- },
321
- 'python': {
322
- 'function_stub': re.compile(r'^\s*def\s+\w+\(.*\):'),
323
- 'pass_stmt': re.compile(r'^\s*pass\s*$'),
324
- 'ellipsis_stmt': re.compile(r'^\s*\.\.\.\s*$'),
325
- 'raise_not_impl': re.compile(r'^\s*raise\s+NotImplementedError'),
326
- },
327
- }
328
- ```
329
-
330
- ## Enforcement Mechanisms
331
-
332
- ### Pre-Commit Hooks
333
-
334
- ```bash
335
- # Check for incomplete implementations
336
- check-implementation-completeness() {
337
- echo "🔍 Running implementation completeness check..."
338
-
339
- # Check for placeholder implementations
340
- local placeholders=$(git diff --cached | grep -E "PLACEHOLDER|TODO|MOCK_DATA" | wc -l)
341
- if [ "$placeholders" -gt 0 ]; then
342
- echo "❌ Found $placeholders placeholder implementations"
343
- echo "All business logic must be fully implemented"
344
- exit 1
345
- fi
346
-
347
- # Check for fake persistence patterns
348
- local fake_persistence=$(git diff --cached | grep -E "private.*\[\]|mock.*database|fake.*persistence" | wc -l)
349
- if [ "$fake_persistence" -gt 0 ]; then
350
- echo "❌ Found $fake_persistence fake persistence patterns"
351
- echo "Real database connections required"
352
- exit 1
353
- fi
354
-
355
- echo "✅ No incomplete implementations found"
356
- }
357
- ```
358
-
359
- ### CI/CD Integration
360
-
361
- ```yaml
362
- # Implementation completeness checks
363
- - name: Check Implementation Completeness
364
- run: |
365
- echo "🔍 Running implementation completeness analysis..."
366
-
367
- # Check for placeholder implementations
368
- placeholder_count=$(grep -r "PLACEHOLDER\|TODO\|MOCK_DATA" src/ | wc -l)
369
- if [ "$placeholder_count" -gt 0 ]; then
370
- echo "❌ Found $placeholder_count placeholder implementations"
371
- echo "All business logic must be fully implemented"
372
- exit 1
373
- fi
374
-
375
- # Check for fake persistence
376
- fake_persistence_count=$(grep -r "private.*\[\]\|mock.*database\|fake.*persistence" src/ | wc -l)
377
- if [ "$fake_persistence_count" -gt 0 ]; then
378
- echo "❌ Found $fake_persistence_count fake persistence patterns"
379
- echo "Real database connections required"
380
- exit 1
381
- fi
382
-
383
- echo "✅ No incomplete implementations found"
384
-
385
- - name: Check for Hidden TODOs
386
- run: |
387
- # Use sophisticated pattern detection
388
- hidden_todos=$(grep -r -E "(not yet implemented|missing implementation|incomplete implementation|partial implementation|unimplemented|not done|pending implementation|to be implemented|will be implemented)" src/ | wc -l)
389
- if [ "$hidden_todos" -gt 0 ]; then
390
- echo "❌ Found $hidden_todos hidden incomplete implementations"
391
- echo "All implementations must be complete"
392
- exit 1
393
- fi
394
-
395
- echo "✅ No hidden incomplete implementations found"
396
- ```
397
-
398
- ## Testing Requirements
399
-
400
- ### Implementation Testing
401
-
402
- **Must test real implementations:**
403
-
404
- ```typescript
405
- // ✅ GOOD: Test real database operations
406
- describe('UserRepository', () => {
407
- let db: Database;
408
-
409
- beforeEach(async () => {
410
- db = await createTestDatabase();
411
- await seedTestData(db);
412
- });
413
-
414
- afterEach(async () => {
415
- await cleanupTestData(db);
416
- await db.end();
417
- });
418
-
419
- it('should save user to database', async () => {
420
- const user = { name: 'John Doe', email: 'john@example.com' };
421
- const savedUser = await userRepository.save(user);
422
-
423
- expect(savedUser.id).toBeDefined();
424
- expect(savedUser.name).toBe(user.name);
425
-
426
- // Verify in database
427
- const dbUser = await db.query('SELECT * FROM users WHERE id = $1', [savedUser.id]);
428
- expect(dbUser.rows[0]).toEqual(savedUser);
429
- });
430
- });
431
- ```
432
-
433
- **Forbidden test patterns:**
434
-
435
- ```typescript
436
- // ❌ BAD: Mock the system under test
437
- jest.mock('./userRepository', () => ({
438
- save: jest.fn(() => ({ id: 1, name: 'Mock User' })),
439
- }));
440
-
441
- // ❌ BAD: Test fake implementations
442
- test('save user', () => {
443
- const result = userRepository.save({ name: 'John' });
444
- expect(result.name).toBe('John'); // Tests mock, not real implementation
445
- });
446
- ```
447
-
448
- ## Quality Metrics
449
-
450
- ### Implementation Completeness Score
451
-
452
- **Calculation Formula:**
453
-
454
- ```python
455
- def calculate_completeness_score(analysis_results):
456
- total_files = analysis_results['total_files']
457
- files_with_todos = analysis_results['files_with_todos']
458
- high_conf_todos = analysis_results['high_confidence_todos']
459
-
460
- # Completeness score (higher is better)
461
- completeness_score = 1.0 - (files_with_todos / total_files) if total_files > 0 else 1.0
462
-
463
- # Quality score based on confidence levels
464
- quality_score = 1.0 - (high_conf_todos / total_files) if total_files > 0 else 1.0
465
-
466
- return {
467
- 'completeness_score': completeness_score,
468
- 'quality_score': quality_score,
469
- 'files_with_todos': files_with_todos,
470
- 'high_confidence_todos': high_conf_todos,
471
- 'total_files_analyzed': total_files
472
- }
473
- ```
474
-
475
- **Anti-Pattern Detection Metrics:**
476
-
477
- - **Placeholder Density**: Number of high-confidence TODOs per 1000 lines
478
- - **Stub Implementation Rate**: % of functions with stub patterns detected
479
- - **Temporary Solution Rate**: % of code marked as temporary/workaround
480
- - **Hardcoded Value Rate**: % of magic numbers/strings detected
481
-
482
- ## Integration with CAWS
483
-
484
- ### CAWS Quality Monitoring
485
-
486
- ```bash
487
- # Run quality gates after code changes
488
- caws gates run
489
-
490
- # Verify acceptance criteria for TODO resolution
491
- caws verify-acs --spec-id <id>
492
- ```
493
-
494
- ### Continuous Improvement
495
-
496
- **Monthly Audits:**
497
-
498
- ```bash
499
- # Generate monthly completeness report
500
- grep -r "PLACEHOLDER\|TODO\|MOCK_DATA" src/ > monthly-todo-report.txt
501
- grep -r -E "(not yet implemented|missing implementation|incomplete implementation)" src/ > monthly-hidden-todos.txt
502
-
503
- # Track trends over time
504
- echo "Implementation completeness trends:" >> monthly-report.md
505
- echo "- Placeholder implementations: $(wc -l < monthly-todo-report.txt)" >> monthly-report.md
506
- echo "- Hidden incomplete implementations: $(wc -l < monthly-hidden-todos.txt)" >> monthly-report.md
507
- ```
508
-
509
- **Quarterly Reviews:**
510
-
511
- - Full implementation audit across entire codebase
512
- - Review integration reality and persistence patterns
513
- - Update quality gates based on project evolution
514
- - Refine detection patterns based on new anti-patterns
515
-
516
- This rule ensures all implementations are complete, real, and production-ready, preventing the accumulation of incomplete or fake code that could cause production issues.