@paths.design/caws-cli 10.2.0 → 11.1.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 (493) hide show
  1. package/README.md +125 -374
  2. package/dist/index.js +45 -787
  3. package/dist/init/harness-detect.d.ts +18 -0
  4. package/dist/init/harness-detect.d.ts.map +1 -0
  5. package/dist/init/harness-detect.js +90 -0
  6. package/dist/init/harness-detect.js.map +1 -0
  7. package/dist/init/hook-install.d.ts +53 -0
  8. package/dist/init/hook-install.d.ts.map +1 -0
  9. package/dist/init/hook-install.js +421 -0
  10. package/dist/init/hook-install.js.map +1 -0
  11. package/dist/init/hook-packs/manifest-claude-code.d.ts +4 -0
  12. package/dist/init/hook-packs/manifest-claude-code.d.ts.map +1 -0
  13. package/dist/init/hook-packs/manifest-claude-code.js +190 -0
  14. package/dist/init/hook-packs/manifest-claude-code.js.map +1 -0
  15. package/dist/init/hook-packs/register.d.ts +19 -0
  16. package/dist/init/hook-packs/register.d.ts.map +1 -0
  17. package/dist/init/hook-packs/register.js +37 -0
  18. package/dist/init/hook-packs/register.js.map +1 -0
  19. package/dist/init/hook-packs/types.d.ts +123 -0
  20. package/dist/init/hook-packs/types.d.ts.map +1 -0
  21. package/dist/init/hook-packs/types.js +29 -0
  22. package/dist/init/hook-packs/types.js.map +1 -0
  23. package/dist/shell/binding/resolve-binding.d.ts +4 -0
  24. package/dist/shell/binding/resolve-binding.d.ts.map +1 -0
  25. package/dist/shell/binding/resolve-binding.js +228 -0
  26. package/dist/shell/binding/resolve-binding.js.map +1 -0
  27. package/dist/shell/binding/types.d.ts +42 -0
  28. package/dist/shell/binding/types.d.ts.map +1 -0
  29. package/dist/shell/binding/types.js +21 -0
  30. package/dist/shell/binding/types.js.map +1 -0
  31. package/dist/shell/commands/claim.d.ts +14 -0
  32. package/dist/shell/commands/claim.d.ts.map +1 -0
  33. package/dist/shell/commands/claim.js +197 -0
  34. package/dist/shell/commands/claim.js.map +1 -0
  35. package/dist/shell/commands/doctor.d.ts +13 -0
  36. package/dist/shell/commands/doctor.d.ts.map +1 -0
  37. package/dist/shell/commands/doctor.js +97 -0
  38. package/dist/shell/commands/doctor.js.map +1 -0
  39. package/dist/shell/commands/evidence.d.ts +28 -0
  40. package/dist/shell/commands/evidence.d.ts.map +1 -0
  41. package/dist/shell/commands/evidence.js +166 -0
  42. package/dist/shell/commands/evidence.js.map +1 -0
  43. package/dist/shell/commands/gates.d.ts +19 -0
  44. package/dist/shell/commands/gates.d.ts.map +1 -0
  45. package/dist/shell/commands/gates.js +208 -0
  46. package/dist/shell/commands/gates.js.map +1 -0
  47. package/dist/shell/commands/init.d.ts +17 -0
  48. package/dist/shell/commands/init.d.ts.map +1 -0
  49. package/dist/shell/commands/init.js +168 -0
  50. package/dist/shell/commands/init.js.map +1 -0
  51. package/dist/shell/commands/scope.d.ts +11 -0
  52. package/dist/shell/commands/scope.d.ts.map +1 -0
  53. package/dist/shell/commands/scope.js +92 -0
  54. package/dist/shell/commands/scope.js.map +1 -0
  55. package/dist/shell/commands/specs.d.ts +41 -0
  56. package/dist/shell/commands/specs.d.ts.map +1 -0
  57. package/dist/shell/commands/specs.js +264 -0
  58. package/dist/shell/commands/specs.js.map +1 -0
  59. package/dist/shell/commands/status.d.ts +15 -0
  60. package/dist/shell/commands/status.d.ts.map +1 -0
  61. package/dist/shell/commands/status.js +106 -0
  62. package/dist/shell/commands/status.js.map +1 -0
  63. package/dist/shell/commands/waiver.d.ts +38 -0
  64. package/dist/shell/commands/waiver.d.ts.map +1 -0
  65. package/dist/shell/commands/waiver.js +240 -0
  66. package/dist/shell/commands/waiver.js.map +1 -0
  67. package/dist/shell/commands/worktree.d.ts +38 -0
  68. package/dist/shell/commands/worktree.d.ts.map +1 -0
  69. package/dist/shell/commands/worktree.js +286 -0
  70. package/dist/shell/commands/worktree.js.map +1 -0
  71. package/dist/shell/gates/disposition.d.ts +23 -0
  72. package/dist/shell/gates/disposition.d.ts.map +1 -0
  73. package/dist/shell/gates/disposition.js +117 -0
  74. package/dist/shell/gates/disposition.js.map +1 -0
  75. package/dist/shell/gates/gate-result-contract.d.ts +39 -0
  76. package/dist/shell/gates/gate-result-contract.d.ts.map +1 -0
  77. package/dist/shell/gates/gate-result-contract.js +150 -0
  78. package/dist/shell/gates/gate-result-contract.js.map +1 -0
  79. package/dist/shell/gates/local-evaluators/budget-limit.d.ts +24 -0
  80. package/dist/shell/gates/local-evaluators/budget-limit.d.ts.map +1 -0
  81. package/dist/shell/gates/local-evaluators/budget-limit.js +67 -0
  82. package/dist/shell/gates/local-evaluators/budget-limit.js.map +1 -0
  83. package/dist/shell/gates/local-evaluators/diff-helpers.d.ts +25 -0
  84. package/dist/shell/gates/local-evaluators/diff-helpers.d.ts.map +1 -0
  85. package/dist/shell/gates/local-evaluators/diff-helpers.js +74 -0
  86. package/dist/shell/gates/local-evaluators/diff-helpers.js.map +1 -0
  87. package/dist/shell/gates/local-evaluators/index.d.ts +28 -0
  88. package/dist/shell/gates/local-evaluators/index.d.ts.map +1 -0
  89. package/dist/shell/gates/local-evaluators/index.js +67 -0
  90. package/dist/shell/gates/local-evaluators/index.js.map +1 -0
  91. package/dist/shell/gates/local-evaluators/scope-boundary.d.ts +23 -0
  92. package/dist/shell/gates/local-evaluators/scope-boundary.d.ts.map +1 -0
  93. package/dist/shell/gates/local-evaluators/scope-boundary.js +67 -0
  94. package/dist/shell/gates/local-evaluators/scope-boundary.js.map +1 -0
  95. package/dist/shell/gates/local-evaluators/spec-completeness.d.ts +12 -0
  96. package/dist/shell/gates/local-evaluators/spec-completeness.d.ts.map +1 -0
  97. package/dist/shell/gates/local-evaluators/spec-completeness.js +73 -0
  98. package/dist/shell/gates/local-evaluators/spec-completeness.js.map +1 -0
  99. package/dist/shell/gates/quality-gates-adapter.d.ts +55 -0
  100. package/dist/shell/gates/quality-gates-adapter.d.ts.map +1 -0
  101. package/dist/shell/gates/quality-gates-adapter.js +161 -0
  102. package/dist/shell/gates/quality-gates-adapter.js.map +1 -0
  103. package/dist/shell/gates/waiver-filter.d.ts +58 -0
  104. package/dist/shell/gates/waiver-filter.d.ts.map +1 -0
  105. package/dist/shell/gates/waiver-filter.js +119 -0
  106. package/dist/shell/gates/waiver-filter.js.map +1 -0
  107. package/dist/shell/index.d.ts +54 -0
  108. package/dist/shell/index.d.ts.map +1 -0
  109. package/dist/shell/index.js +85 -0
  110. package/dist/shell/index.js.map +1 -0
  111. package/dist/shell/register.d.ts +11 -0
  112. package/dist/shell/register.d.ts.map +1 -0
  113. package/dist/shell/register.js +464 -0
  114. package/dist/shell/register.js.map +1 -0
  115. package/dist/shell/render/claim.d.ts +22 -0
  116. package/dist/shell/render/claim.d.ts.map +1 -0
  117. package/dist/shell/render/claim.js +75 -0
  118. package/dist/shell/render/claim.js.map +1 -0
  119. package/dist/shell/render/decision.d.ts +15 -0
  120. package/dist/shell/render/decision.d.ts.map +1 -0
  121. package/dist/shell/render/decision.js +66 -0
  122. package/dist/shell/render/decision.js.map +1 -0
  123. package/dist/shell/render/diagnostic.d.ts +19 -0
  124. package/dist/shell/render/diagnostic.d.ts.map +1 -0
  125. package/dist/shell/render/diagnostic.js +76 -0
  126. package/dist/shell/render/diagnostic.js.map +1 -0
  127. package/dist/shell/render/finding.d.ts +15 -0
  128. package/dist/shell/render/finding.d.ts.map +1 -0
  129. package/dist/shell/render/finding.js +57 -0
  130. package/dist/shell/render/finding.js.map +1 -0
  131. package/dist/shell/render/gates.d.ts +3 -0
  132. package/dist/shell/render/gates.d.ts.map +1 -0
  133. package/dist/shell/render/gates.js +56 -0
  134. package/dist/shell/render/gates.js.map +1 -0
  135. package/dist/shell/render/init-hook-pack.d.ts +16 -0
  136. package/dist/shell/render/init-hook-pack.d.ts.map +1 -0
  137. package/dist/shell/render/init-hook-pack.js +206 -0
  138. package/dist/shell/render/init-hook-pack.js.map +1 -0
  139. package/dist/shell/render/init.d.ts +11 -0
  140. package/dist/shell/render/init.d.ts.map +1 -0
  141. package/dist/shell/render/init.js +32 -0
  142. package/dist/shell/render/init.js.map +1 -0
  143. package/dist/shell/render/status.d.ts +26 -0
  144. package/dist/shell/render/status.d.ts.map +1 -0
  145. package/dist/shell/render/status.js +143 -0
  146. package/dist/shell/render/status.js.map +1 -0
  147. package/dist/shell/render/waiver.d.ts +21 -0
  148. package/dist/shell/render/waiver.d.ts.map +1 -0
  149. package/dist/shell/render/waiver.js +94 -0
  150. package/dist/shell/render/waiver.js.map +1 -0
  151. package/dist/shell/rules.d.ts +37 -0
  152. package/dist/shell/rules.d.ts.map +1 -0
  153. package/dist/shell/rules.js +51 -0
  154. package/dist/shell/rules.js.map +1 -0
  155. package/dist/shell/session/actor.d.ts +14 -0
  156. package/dist/shell/session/actor.d.ts.map +1 -0
  157. package/dist/shell/session/actor.js +34 -0
  158. package/dist/shell/session/actor.js.map +1 -0
  159. package/dist/shell/session/resolve-session.d.ts +5 -0
  160. package/dist/shell/session/resolve-session.d.ts.map +1 -0
  161. package/dist/shell/session/resolve-session.js +239 -0
  162. package/dist/shell/session/resolve-session.js.map +1 -0
  163. package/dist/shell/session/types.d.ts +56 -0
  164. package/dist/shell/session/types.d.ts.map +1 -0
  165. package/dist/shell/session/types.js +15 -0
  166. package/dist/shell/session/types.js.map +1 -0
  167. package/dist/store/agents-store.d.ts +3 -0
  168. package/dist/store/agents-store.d.ts.map +1 -0
  169. package/dist/store/agents-store.js +63 -0
  170. package/dist/store/agents-store.js.map +1 -0
  171. package/dist/store/apply-patch.d.ts +16 -0
  172. package/dist/store/apply-patch.d.ts.map +1 -0
  173. package/dist/store/apply-patch.js +191 -0
  174. package/dist/store/apply-patch.js.map +1 -0
  175. package/dist/store/atomic-write.d.ts +34 -0
  176. package/dist/store/atomic-write.d.ts.map +1 -0
  177. package/dist/store/atomic-write.js +174 -0
  178. package/dist/store/atomic-write.js.map +1 -0
  179. package/dist/store/doctor-snapshot.d.ts +20 -0
  180. package/dist/store/doctor-snapshot.d.ts.map +1 -0
  181. package/dist/store/doctor-snapshot.js +176 -0
  182. package/dist/store/doctor-snapshot.js.map +1 -0
  183. package/dist/store/events-store.d.ts +33 -0
  184. package/dist/store/events-store.d.ts.map +1 -0
  185. package/dist/store/events-store.js +297 -0
  186. package/dist/store/events-store.js.map +1 -0
  187. package/dist/store/index.d.ts +21 -0
  188. package/dist/store/index.d.ts.map +1 -0
  189. package/dist/store/index.js +47 -0
  190. package/dist/store/index.js.map +1 -0
  191. package/dist/store/init-store.d.ts +21 -0
  192. package/dist/store/init-store.d.ts.map +1 -0
  193. package/dist/store/init-store.js +295 -0
  194. package/dist/store/init-store.js.map +1 -0
  195. package/dist/store/json-store.d.ts +3 -0
  196. package/dist/store/json-store.d.ts.map +1 -0
  197. package/dist/store/json-store.js +65 -0
  198. package/dist/store/json-store.js.map +1 -0
  199. package/dist/store/lifecycle-lock.d.ts +34 -0
  200. package/dist/store/lifecycle-lock.d.ts.map +1 -0
  201. package/dist/store/lifecycle-lock.js +168 -0
  202. package/dist/store/lifecycle-lock.js.map +1 -0
  203. package/dist/store/lifecycle-transaction.d.ts +79 -0
  204. package/dist/store/lifecycle-transaction.d.ts.map +1 -0
  205. package/dist/store/lifecycle-transaction.js +319 -0
  206. package/dist/store/lifecycle-transaction.js.map +1 -0
  207. package/dist/store/policy-store.d.ts +3 -0
  208. package/dist/store/policy-store.d.ts.map +1 -0
  209. package/dist/store/policy-store.js +65 -0
  210. package/dist/store/policy-store.js.map +1 -0
  211. package/dist/store/repo-root.d.ts +46 -0
  212. package/dist/store/repo-root.d.ts.map +1 -0
  213. package/dist/store/repo-root.js +145 -0
  214. package/dist/store/repo-root.js.map +1 -0
  215. package/dist/store/rules.d.ts +69 -0
  216. package/dist/store/rules.d.ts.map +1 -0
  217. package/dist/store/rules.js +95 -0
  218. package/dist/store/rules.js.map +1 -0
  219. package/dist/store/specs-store.d.ts +3 -0
  220. package/dist/store/specs-store.d.ts.map +1 -0
  221. package/dist/store/specs-store.js +131 -0
  222. package/dist/store/specs-store.js.map +1 -0
  223. package/dist/store/specs-writer.d.ts +61 -0
  224. package/dist/store/specs-writer.d.ts.map +1 -0
  225. package/dist/store/specs-writer.js +506 -0
  226. package/dist/store/specs-writer.js.map +1 -0
  227. package/dist/store/types.d.ts +84 -0
  228. package/dist/store/types.d.ts.map +1 -0
  229. package/dist/store/types.js +14 -0
  230. package/dist/store/types.js.map +1 -0
  231. package/dist/store/waivers-store.d.ts +25 -0
  232. package/dist/store/waivers-store.d.ts.map +1 -0
  233. package/dist/store/waivers-store.js +232 -0
  234. package/dist/store/waivers-store.js.map +1 -0
  235. package/dist/store/worktrees-store.d.ts +3 -0
  236. package/dist/store/worktrees-store.d.ts.map +1 -0
  237. package/dist/store/worktrees-store.js +62 -0
  238. package/dist/store/worktrees-store.js.map +1 -0
  239. package/dist/store/worktrees-writer.d.ts +77 -0
  240. package/dist/store/worktrees-writer.d.ts.map +1 -0
  241. package/dist/store/worktrees-writer.js +674 -0
  242. package/dist/store/worktrees-writer.js.map +1 -0
  243. package/dist/store/yaml-patch.d.ts +7 -0
  244. package/dist/store/yaml-patch.d.ts.map +1 -0
  245. package/dist/store/yaml-patch.js +250 -0
  246. package/dist/store/yaml-patch.js.map +1 -0
  247. package/dist/store/yaml-store.d.ts +9 -0
  248. package/dist/store/yaml-store.d.ts.map +1 -0
  249. package/dist/store/yaml-store.js +121 -0
  250. package/dist/store/yaml-store.js.map +1 -0
  251. package/package.json +15 -13
  252. package/dist/budget-derivation.js +0 -751
  253. package/dist/cicd-optimizer.js +0 -504
  254. package/dist/commands/agents.js +0 -124
  255. package/dist/commands/archive.js +0 -500
  256. package/dist/commands/burnup.js +0 -198
  257. package/dist/commands/diagnose.js +0 -525
  258. package/dist/commands/evaluate.js +0 -314
  259. package/dist/commands/gates.js +0 -149
  260. package/dist/commands/init.js +0 -857
  261. package/dist/commands/iterate.js +0 -417
  262. package/dist/commands/mode.js +0 -269
  263. package/dist/commands/parallel.js +0 -242
  264. package/dist/commands/plan.js +0 -438
  265. package/dist/commands/provenance.js +0 -1143
  266. package/dist/commands/quality-monitor.js +0 -284
  267. package/dist/commands/scope.js +0 -264
  268. package/dist/commands/session.js +0 -312
  269. package/dist/commands/sidecar.js +0 -74
  270. package/dist/commands/specs.js +0 -1656
  271. package/dist/commands/status.js +0 -1172
  272. package/dist/commands/templates.js +0 -237
  273. package/dist/commands/tool.js +0 -136
  274. package/dist/commands/tutorial.js +0 -480
  275. package/dist/commands/validate.js +0 -357
  276. package/dist/commands/verify-acs.js +0 -443
  277. package/dist/commands/waivers.js +0 -599
  278. package/dist/commands/workflow.js +0 -243
  279. package/dist/commands/worktree.js +0 -502
  280. package/dist/config/lite-scope.js +0 -158
  281. package/dist/config/modes.js +0 -347
  282. package/dist/constants/spec-types.js +0 -65
  283. package/dist/gates/budget-limit.js +0 -121
  284. package/dist/gates/feedback.js +0 -260
  285. package/dist/gates/format.js +0 -179
  286. package/dist/gates/god-object.js +0 -117
  287. package/dist/gates/pipeline.js +0 -167
  288. package/dist/gates/scope-boundary.js +0 -112
  289. package/dist/gates/spec-completeness.js +0 -109
  290. package/dist/gates/todo-detection.js +0 -205
  291. package/dist/generators/jest-config-generator.js +0 -242
  292. package/dist/generators/working-spec.js +0 -237
  293. package/dist/minimal-cli.js +0 -88
  294. package/dist/parallel/parallel-manager.js +0 -433
  295. package/dist/policy/PolicyManager.js +0 -470
  296. package/dist/scaffold/claude-hooks.js +0 -443
  297. package/dist/scaffold/cursor-hooks.js +0 -177
  298. package/dist/scaffold/git-hooks.js +0 -928
  299. package/dist/scaffold/index.js +0 -794
  300. package/dist/session/session-manager.js +0 -653
  301. package/dist/sidecars/index.js +0 -33
  302. package/dist/sidecars/listeners.js +0 -40
  303. package/dist/sidecars/provenance-summary.js +0 -238
  304. package/dist/sidecars/quality-gaps.js +0 -258
  305. package/dist/sidecars/schema.js +0 -149
  306. package/dist/sidecars/spec-drift.js +0 -151
  307. package/dist/sidecars/waiver-draft.js +0 -176
  308. package/dist/spec/SpecFileManager.js +0 -419
  309. package/dist/templates/.caws/schemas/policy.schema.json +0 -117
  310. package/dist/templates/.caws/schemas/scope.schema.json +0 -52
  311. package/dist/templates/.caws/schemas/waivers.schema.json +0 -106
  312. package/dist/templates/.caws/schemas/working-spec.schema.json +0 -340
  313. package/dist/templates/.caws/schemas/worktrees.schema.json +0 -38
  314. package/dist/templates/.caws/templates/working-spec.template.yml +0 -80
  315. package/dist/templates/.caws/tools/README.md +0 -18
  316. package/dist/templates/.caws/tools/scope-guard.js +0 -203
  317. package/dist/templates/.caws/tools-allow.json +0 -331
  318. package/dist/templates/.caws/waivers.yml +0 -19
  319. package/dist/templates/.claude/README.md +0 -190
  320. package/dist/templates/.claude/hooks/audit.sh +0 -121
  321. package/dist/templates/.claude/hooks/block-dangerous.sh +0 -203
  322. package/dist/templates/.claude/hooks/classify_command.py +0 -592
  323. package/dist/templates/.claude/hooks/doc-frontmatter-check.sh +0 -173
  324. package/dist/templates/.claude/hooks/lite-sprawl-check.sh +0 -145
  325. package/dist/templates/.claude/hooks/naming-check.sh +0 -100
  326. package/dist/templates/.claude/hooks/protected-paths.sh +0 -39
  327. package/dist/templates/.claude/hooks/quality-check.sh +0 -81
  328. package/dist/templates/.claude/hooks/scan-secrets.sh +0 -85
  329. package/dist/templates/.claude/hooks/scope-guard.sh +0 -381
  330. package/dist/templates/.claude/hooks/session-caws-status.sh +0 -117
  331. package/dist/templates/.claude/hooks/session-log.sh +0 -634
  332. package/dist/templates/.claude/hooks/simplification-guard.sh +0 -92
  333. package/dist/templates/.claude/hooks/stop-worktree-check.sh +0 -46
  334. package/dist/templates/.claude/hooks/test_classify_command.py +0 -370
  335. package/dist/templates/.claude/hooks/test_wrapper_smoke.sh +0 -96
  336. package/dist/templates/.claude/hooks/validate-spec.sh +0 -76
  337. package/dist/templates/.claude/hooks/worktree-guard.sh +0 -220
  338. package/dist/templates/.claude/hooks/worktree-write-guard.sh +0 -190
  339. package/dist/templates/.claude/rules/git-safety.md +0 -26
  340. package/dist/templates/.claude/rules/worktree-isolation.md +0 -101
  341. package/dist/templates/.claude/settings.json +0 -141
  342. package/dist/templates/.cursor/README.md +0 -299
  343. package/dist/templates/.cursor/hooks/audit.sh +0 -55
  344. package/dist/templates/.cursor/hooks/block-dangerous.sh +0 -84
  345. package/dist/templates/.cursor/hooks/caws-quality-check.sh +0 -52
  346. package/dist/templates/.cursor/hooks/caws-scope-guard.sh +0 -130
  347. package/dist/templates/.cursor/hooks/format.sh +0 -38
  348. package/dist/templates/.cursor/hooks/naming-check.sh +0 -64
  349. package/dist/templates/.cursor/hooks/scan-secrets.sh +0 -51
  350. package/dist/templates/.cursor/hooks/scope-guard.sh +0 -52
  351. package/dist/templates/.cursor/hooks/session-log.sh +0 -924
  352. package/dist/templates/.cursor/hooks/validate-spec.sh +0 -83
  353. package/dist/templates/.cursor/hooks.json +0 -76
  354. package/dist/templates/.cursor/rules/00-claims-verification.mdc +0 -144
  355. package/dist/templates/.cursor/rules/01-working-style.mdc +0 -50
  356. package/dist/templates/.cursor/rules/02-quality-gates.mdc +0 -368
  357. package/dist/templates/.cursor/rules/03-naming-and-refactor.mdc +0 -33
  358. package/dist/templates/.cursor/rules/04-logging-language-style.mdc +0 -23
  359. package/dist/templates/.cursor/rules/05-safe-defaults-guards.mdc +0 -23
  360. package/dist/templates/.cursor/rules/06-typescript-conventions.mdc +0 -36
  361. package/dist/templates/.cursor/rules/07-process-ops.mdc +0 -20
  362. package/dist/templates/.cursor/rules/08-solid-and-architecture.mdc +0 -16
  363. package/dist/templates/.cursor/rules/09-docstrings.mdc +0 -89
  364. package/dist/templates/.cursor/rules/10-documentation-quality-standards.mdc +0 -385
  365. package/dist/templates/.cursor/rules/11-scope-management-waivers.mdc +0 -381
  366. package/dist/templates/.cursor/rules/12-implementation-completeness.mdc +0 -516
  367. package/dist/templates/.cursor/rules/13-language-agnostic-standards.mdc +0 -578
  368. package/dist/templates/.cursor/rules/README.md +0 -148
  369. package/dist/templates/.github/copilot-instructions.md +0 -82
  370. package/dist/templates/.idea/runConfigurations/CAWS_Evaluate.xml +0 -5
  371. package/dist/templates/.idea/runConfigurations/CAWS_Validate.xml +0 -5
  372. package/dist/templates/.junie/guidelines.md +0 -73
  373. package/dist/templates/.vscode/launch.json +0 -17
  374. package/dist/templates/.vscode/settings.json +0 -95
  375. package/dist/templates/.windsurf/rules/caws-quality-standards.md +0 -54
  376. package/dist/templates/.windsurf/workflows/caws-guided-development.md +0 -92
  377. package/dist/templates/CLAUDE.md +0 -196
  378. package/dist/templates/COMMIT_CONVENTIONS.md +0 -86
  379. package/dist/templates/OIDC_SETUP.md +0 -300
  380. package/dist/templates/agents.md +0 -171
  381. package/dist/templates/codemod/README.md +0 -1
  382. package/dist/templates/codemod/test.js +0 -93
  383. package/dist/templates/docs/README.md +0 -151
  384. package/dist/templates/scripts/new_feature.sh +0 -80
  385. package/dist/templates/scripts/quality-gates/check-god-objects.js +0 -146
  386. package/dist/templates/scripts/quality-gates/run-quality-gates.js +0 -50
  387. package/dist/templates/scripts/v3/analysis/todo_analyzer.py +0 -1997
  388. package/dist/test-analysis.js +0 -786
  389. package/dist/tool-interface.js +0 -314
  390. package/dist/tool-loader.js +0 -303
  391. package/dist/tool-validator.js +0 -393
  392. package/dist/utils/agent-display.js +0 -210
  393. package/dist/utils/agent-session.js +0 -344
  394. package/dist/utils/async-utils.js +0 -188
  395. package/dist/utils/command-wrapper.js +0 -200
  396. package/dist/utils/event-log.js +0 -584
  397. package/dist/utils/event-renderer.js +0 -521
  398. package/dist/utils/finalization.js +0 -230
  399. package/dist/utils/git-lock.js +0 -119
  400. package/dist/utils/gitignore-updater.js +0 -158
  401. package/dist/utils/ide-detection.js +0 -133
  402. package/dist/utils/lifecycle-events.js +0 -94
  403. package/dist/utils/project-analysis.js +0 -367
  404. package/dist/utils/promise-utils.js +0 -72
  405. package/dist/utils/quality-gates-errors.js +0 -520
  406. package/dist/utils/quality-gates-utils.js +0 -387
  407. package/dist/utils/schema-validator.js +0 -50
  408. package/dist/utils/spec-resolver.js +0 -711
  409. package/dist/utils/typescript-detector.js +0 -369
  410. package/dist/utils/working-state.js +0 -530
  411. package/dist/utils/yaml-validation.js +0 -156
  412. package/dist/validation/spec-validation.js +0 -924
  413. package/dist/waivers-manager.js +0 -732
  414. package/dist/worktree/worktree-manager.js +0 -1735
  415. package/templates/.caws/schemas/policy.schema.json +0 -117
  416. package/templates/.caws/schemas/scope.schema.json +0 -52
  417. package/templates/.caws/schemas/waivers.schema.json +0 -106
  418. package/templates/.caws/schemas/working-spec.schema.json +0 -340
  419. package/templates/.caws/schemas/worktrees.schema.json +0 -38
  420. package/templates/.caws/templates/working-spec.template.yml +0 -80
  421. package/templates/.caws/tools/README.md +0 -18
  422. package/templates/.caws/tools/scope-guard.js +0 -203
  423. package/templates/.caws/tools-allow.json +0 -331
  424. package/templates/.caws/waivers.yml +0 -19
  425. package/templates/.claude/README.md +0 -190
  426. package/templates/.claude/hooks/audit.sh +0 -121
  427. package/templates/.claude/hooks/block-dangerous.sh +0 -203
  428. package/templates/.claude/hooks/classify_command.py +0 -592
  429. package/templates/.claude/hooks/doc-frontmatter-check.sh +0 -173
  430. package/templates/.claude/hooks/lite-sprawl-check.sh +0 -145
  431. package/templates/.claude/hooks/naming-check.sh +0 -100
  432. package/templates/.claude/hooks/protected-paths.sh +0 -39
  433. package/templates/.claude/hooks/quality-check.sh +0 -81
  434. package/templates/.claude/hooks/scan-secrets.sh +0 -85
  435. package/templates/.claude/hooks/scope-guard.sh +0 -381
  436. package/templates/.claude/hooks/session-caws-status.sh +0 -117
  437. package/templates/.claude/hooks/session-log.sh +0 -634
  438. package/templates/.claude/hooks/simplification-guard.sh +0 -92
  439. package/templates/.claude/hooks/stop-worktree-check.sh +0 -46
  440. package/templates/.claude/hooks/test_classify_command.py +0 -370
  441. package/templates/.claude/hooks/test_wrapper_smoke.sh +0 -96
  442. package/templates/.claude/hooks/validate-spec.sh +0 -76
  443. package/templates/.claude/hooks/worktree-guard.sh +0 -220
  444. package/templates/.claude/hooks/worktree-write-guard.sh +0 -190
  445. package/templates/.claude/rules/git-safety.md +0 -26
  446. package/templates/.claude/rules/worktree-isolation.md +0 -101
  447. package/templates/.claude/settings.json +0 -141
  448. package/templates/.cursor/README.md +0 -299
  449. package/templates/.cursor/hooks/audit.sh +0 -55
  450. package/templates/.cursor/hooks/block-dangerous.sh +0 -84
  451. package/templates/.cursor/hooks/caws-quality-check.sh +0 -52
  452. package/templates/.cursor/hooks/caws-scope-guard.sh +0 -130
  453. package/templates/.cursor/hooks/format.sh +0 -38
  454. package/templates/.cursor/hooks/naming-check.sh +0 -64
  455. package/templates/.cursor/hooks/scan-secrets.sh +0 -51
  456. package/templates/.cursor/hooks/scope-guard.sh +0 -52
  457. package/templates/.cursor/hooks/session-log.sh +0 -924
  458. package/templates/.cursor/hooks/validate-spec.sh +0 -83
  459. package/templates/.cursor/hooks.json +0 -76
  460. package/templates/.cursor/rules/00-claims-verification.mdc +0 -144
  461. package/templates/.cursor/rules/01-working-style.mdc +0 -50
  462. package/templates/.cursor/rules/02-quality-gates.mdc +0 -368
  463. package/templates/.cursor/rules/03-naming-and-refactor.mdc +0 -33
  464. package/templates/.cursor/rules/04-logging-language-style.mdc +0 -23
  465. package/templates/.cursor/rules/05-safe-defaults-guards.mdc +0 -23
  466. package/templates/.cursor/rules/06-typescript-conventions.mdc +0 -36
  467. package/templates/.cursor/rules/07-process-ops.mdc +0 -20
  468. package/templates/.cursor/rules/08-solid-and-architecture.mdc +0 -16
  469. package/templates/.cursor/rules/09-docstrings.mdc +0 -89
  470. package/templates/.cursor/rules/10-documentation-quality-standards.mdc +0 -385
  471. package/templates/.cursor/rules/11-scope-management-waivers.mdc +0 -381
  472. package/templates/.cursor/rules/12-implementation-completeness.mdc +0 -516
  473. package/templates/.cursor/rules/13-language-agnostic-standards.mdc +0 -578
  474. package/templates/.cursor/rules/README.md +0 -148
  475. package/templates/.github/copilot-instructions.md +0 -82
  476. package/templates/.idea/runConfigurations/CAWS_Evaluate.xml +0 -5
  477. package/templates/.idea/runConfigurations/CAWS_Validate.xml +0 -5
  478. package/templates/.junie/guidelines.md +0 -73
  479. package/templates/.vscode/launch.json +0 -17
  480. package/templates/.vscode/settings.json +0 -95
  481. package/templates/.windsurf/rules/caws-quality-standards.md +0 -54
  482. package/templates/.windsurf/workflows/caws-guided-development.md +0 -92
  483. package/templates/CLAUDE.md +0 -196
  484. package/templates/COMMIT_CONVENTIONS.md +0 -86
  485. package/templates/OIDC_SETUP.md +0 -300
  486. package/templates/agents.md +0 -171
  487. package/templates/codemod/README.md +0 -1
  488. package/templates/codemod/test.js +0 -93
  489. package/templates/docs/README.md +0 -151
  490. package/templates/scripts/new_feature.sh +0 -80
  491. package/templates/scripts/quality-gates/check-god-objects.js +0 -146
  492. package/templates/scripts/quality-gates/run-quality-gates.js +0 -50
  493. package/templates/scripts/v3/analysis/todo_analyzer.py +0 -1997
@@ -1,368 +0,0 @@
1
- ---
2
- description: Comprehensive testing standards and verification requirements
3
- globs:
4
- alwaysApply: true
5
- ---
6
-
7
- # Testing Standards & Verification Requirements
8
-
9
- ## Testing Pyramid Requirements
10
-
11
- ### Unit Tests (Foundation Layer)
12
-
13
- - **Coverage Thresholds**: 80% line coverage, 90% branch coverage minimum
14
- - **Test Isolation**: Each test completely independent, no shared state
15
- - **Mock Strategy**: Mock external dependencies, test business logic in isolation
16
- - **Naming Convention**: `describe('ComponentName', () => { it('should do something', () => {}) })`
17
- - **Assertion Style**: Use descriptive assertions, avoid generic `toBe(true)`
18
-
19
- ### Integration Tests (Middle Layer)
20
-
21
- - **Database Integration**: Real database connections, not mocked
22
- - **External APIs**: Test actual HTTP calls with proper error handling
23
- - **Component Communication**: Test inter-component contracts
24
- - **Setup/Teardown**: Proper database seeding and cleanup
25
- - **Async Handling**: All async operations properly awaited and tested
26
-
27
- ### End-to-End Tests (Top Layer)
28
-
29
- - **Full User Journeys**: Complete workflows from start to finish
30
- - **Real Browsers**: Use actual browser automation, not mocked DOM
31
- - **Data Persistence**: Verify data survives application restarts
32
- - **Performance Baselines**: Include timing assertions where relevant
33
-
34
- ## Test Quality Standards
35
-
36
- ### Test Structure Requirements
37
-
38
- ```typescript
39
- describe('ComponentName', () => {
40
- describe('when condition A', () => {
41
- it('should behave correctly', () => {
42
- // Given: Setup preconditions
43
- // When: Execute the action
44
- // Then: Verify the outcome
45
- });
46
- });
47
- });
48
- ```
49
-
50
- ### Edge Case Coverage
51
-
52
- - **Null/Undefined**: Test with null, undefined, empty arrays, empty objects
53
- - **Boundary Values**: Test minimums, maximums, and edge boundaries
54
- - **Error Conditions**: Test all error paths and exception handling
55
- - **Concurrency**: Test race conditions and concurrent access
56
- - **Resource Limits**: Test memory limits, timeouts, rate limits
57
-
58
- ### Test Data Management
59
-
60
- - **Realistic Fixtures**: Use representative data, not just minimal examples
61
- - **Factory Pattern**: Create test data factories for consistent object creation
62
- - **Cleanup Strategy**: Ensure tests don't leave persistent state
63
- - **Isolation**: Tests must not interfere with each other
64
-
65
- ## Verification Requirements
66
-
67
- ### Pre-Commit Verification
68
-
69
- - [ ] All unit tests pass (`npm test`)
70
- - [ ] No tests skipped in production code
71
- - [ ] Coverage thresholds met
72
- - [ ] No console errors or warnings in tests
73
- - [ ] Database tests use real connections
74
-
75
- ### Integration Verification
76
-
77
- - [ ] Database schema matches migrations
78
- - [ ] External API contracts validated
79
- - [ ] Authentication/authorization tested
80
- - [ ] Error handling verified end-to-end
81
-
82
- ### Performance Verification
83
-
84
- - [ ] Response times within documented SLAs
85
- - [ ] Memory usage within limits
86
- - [ ] Database query performance acceptable
87
- - [ ] Concurrent user load handled
88
-
89
- ## Test Infrastructure Standards
90
-
91
- ### Testing Tools & Frameworks
92
-
93
- - **Test Runner**: Jest, Vitest, or equivalent with parallel execution
94
- - **Assertion Library**: Built-in assertions with descriptive matchers
95
- - **Mocking**: Comprehensive mocking for external dependencies
96
- - **Coverage**: Istanbul/NYC for coverage reporting
97
- - **CI Integration**: Automated test execution in CI pipeline
98
-
99
- ### Database Testing
100
-
101
- - **Test Database**: Separate database instance for tests
102
- - **Schema Sync**: Automatic schema setup/teardown
103
- - **Data Seeding**: Deterministic test data seeding
104
- - **Transaction Rollback**: Tests wrapped in transactions for cleanup
105
-
106
- ### CI/CD Testing
107
-
108
- - **Parallel Execution**: Tests run in parallel for speed
109
- - **Flaky Test Detection**: Automatic retry for known flaky tests
110
- - **Coverage Reporting**: Coverage reports uploaded to CI
111
- - **Test Result Storage**: Historical test results tracked
112
-
113
- ## Testing Anti-Patterns (Forbidden)
114
-
115
- ### ❌ Mocking Core Business Logic
116
-
117
- ```typescript
118
- // DON'T: Mock the function you're supposed to test
119
- jest.mock('./businessLogic', () => ({
120
- calculateTotal: jest.fn(() => 100),
121
- }));
122
-
123
- test('calculateTotal', () => {
124
- expect(calculateTotal()).toBe(100); // Tests the mock, not the logic
125
- });
126
- ```
127
-
128
- ### ❌ Testing Implementation Details
129
-
130
- ```typescript
131
- // DON'T: Test private methods or internal state
132
- test('internal counter increments', () => {
133
- component.privateCounter = 5; // Accessing private state
134
- expect(component.privateCounter).toBe(5);
135
- });
136
- ```
137
-
138
- ### ❌ Inadequate Error Testing
139
-
140
- ```typescript
141
- // DON'T: Generic error testing
142
- test('throws error', () => {
143
- expect(() => riskyOperation()).toThrow(); // Too vague
144
- });
145
- ```
146
-
147
- ### ❌ No Cleanup in Integration Tests
148
-
149
- ```typescript
150
- // DON'T: Leave test data behind
151
- test('creates user', async () => {
152
- await createUser({ name: 'test' });
153
- // No cleanup - data persists
154
- });
155
- ```
156
-
157
- ## Testing Best Practices
158
-
159
- ### ✅ Proper Error Testing
160
-
161
- ```typescript
162
- test('throws specific error for invalid input', () => {
163
- expect(() => validateEmail('invalid')).toThrow(ValidationError);
164
- expect(() => validateEmail('invalid')).toThrow('Invalid email format');
165
- });
166
- ```
167
-
168
- ### ✅ Realistic Test Data
169
-
170
- ```typescript
171
- const realisticUser = {
172
- id: 'user-123',
173
- email: 'user@example.com',
174
- name: 'John Doe',
175
- createdAt: new Date('2024-01-01'),
176
- preferences: { theme: 'dark', notifications: true },
177
- };
178
- ```
179
-
180
- ### ✅ Proper Async Testing
181
-
182
- ```typescript
183
- test('resolves with correct data', async () => {
184
- const result = await fetchUserData('user-123');
185
- expect(result).toEqual(expectedUserData);
186
- });
187
- ```
188
-
189
- ### ✅ Database Test Cleanup
190
-
191
- ```typescript
192
- describe('UserService', () => {
193
- let dbClient;
194
-
195
- beforeEach(async () => {
196
- dbClient = await createTestDbConnection();
197
- await seedTestData(dbClient);
198
- });
199
-
200
- afterEach(async () => {
201
- await cleanupTestData(dbClient);
202
- await dbClient.end();
203
- });
204
- });
205
- ```
206
-
207
- ## Test Documentation Requirements
208
-
209
- ### Test Comments for Complex Logic
210
-
211
- ```typescript
212
- test('calculates compound interest with monthly compounding', () => {
213
- // Formula: A = P(1 + r/n)^(nt)
214
- // Where: A = final amount, P = principal, r = rate, n = compounding frequency, t = time
215
- const principal = 1000;
216
- const rate = 0.05; // 5%
217
- const compoundingFrequency = 12; // monthly
218
- const timeInYears = 2;
219
-
220
- const result = calculateCompoundInterest(principal, rate, compoundingFrequency, timeInYears);
221
- const expected = 1104.54; // Pre-calculated expected value
222
-
223
- expect(result).toBeCloseTo(expected, 2);
224
- });
225
- ```
226
-
227
- ### Test Coverage Comments
228
-
229
- ```typescript
230
- // Test Coverage:
231
- // ✅ Happy path: valid input -> correct output
232
- // ✅ Edge case: zero principal -> zero result
233
- // ✅ Edge case: negative rate -> throws error
234
- // ✅ Error case: invalid compounding frequency -> throws error
235
- // ✅ Boundary: very large numbers -> handles precision
236
- ```
237
-
238
- ## Performance Testing Standards
239
-
240
- ### Response Time Assertions
241
-
242
- ```typescript
243
- test('responds within SLA', async () => {
244
- const startTime = Date.now();
245
- const result = await expensiveOperation();
246
- const duration = Date.now() - startTime;
247
-
248
- expect(duration).toBeLessThan(5000); // 5 second SLA
249
- expect(result).toBeDefined();
250
- });
251
- ```
252
-
253
- ### Load Testing Guidelines
254
-
255
- - Test with realistic concurrent users
256
- - Include warm-up periods
257
- - Measure 95th percentile response times
258
- - Test memory usage under load
259
- - Verify graceful degradation
260
-
261
- ## Mutation Testing Standards
262
-
263
- ### Mutation Operators to Cover
264
-
265
- - **Arithmetic Operators**: `+`, `-`, `*`, `/`, `%`
266
- - **Logical Operators**: `&&`, `||`, `!`
267
- - **Comparison Operators**: `==`, `!=`, `<`, `>`, `<=`, `>=`
268
- - **Conditional Boundaries**: `if` conditions, ternary operators
269
- - **Return Statements**: Missing/incorrect returns
270
- - **Variable Assignments**: Wrong variable assignments
271
-
272
- ### Mutation Score Targets
273
-
274
- - **Critical Components**: 80%+ mutation score
275
- - **Business Logic**: 70%+ mutation score
276
- - **Utilities**: 60%+ mutation score
277
- - **UI Components**: 50%+ mutation score (may be lower due to test complexity)
278
-
279
- ## Accessibility Testing (Web Components)
280
-
281
- ### Screen Reader Testing
282
-
283
- ```typescript
284
- test("is accessible to screen readers", () => {
285
- render(<Button>Click me</Button>);
286
-
287
- // Test ARIA labels
288
- expect(screen.getByRole("button")).toHaveAttribute("aria-label", "Click me");
289
-
290
- // Test keyboard navigation
291
- userEvent.tab();
292
- expect(screen.getByRole("button")).toHaveFocus();
293
- });
294
- ```
295
-
296
- ### Color Contrast Testing
297
-
298
- ```typescript
299
- test("meets color contrast requirements", () => {
300
- render(<Text variant="error">Error message</Text>);
301
-
302
- const element = screen.getByText("Error message");
303
- const styles = window.getComputedStyle(element);
304
-
305
- // Verify contrast ratio programmatically
306
- expect(
307
- getContrastRatio(styles.color, styles.backgroundColor)
308
- ).toBeGreaterThan(4.5);
309
- });
310
- ```
311
-
312
- ## Execution Discipline
313
-
314
- - Run unit tests and lints after any major change; iterate until green.
315
- - If the project defines an engine, confirm Node version via console before running scripts.
316
- - `.env` files exist; do **not** attempt to cat protected dotfiles. Use framework tooling or documented env loaders.
317
-
318
- ## Commits
319
-
320
- - `--no-verify` is **not allowed**. If hooks fail, **fix the cause** or split work into smaller audited commits.
321
- - Commit subjects: **what + why** in one sentence. Bodies for context only when needed.
322
-
323
- ## TODOs & Placeholders
324
-
325
- Tag placeholders explicitly in code:
326
-
327
- - `// TODO: ...` (critical, must block if reached)
328
- - `// PLACEHOLDER: ...` (non-critical placeholder, warn)
329
- - `// MOCK DATA: ...` (remove before release)
330
-
331
- **Critical TODOs**: throw at execution site with clear message.
332
-
333
- ## Diagrams/Charts
334
-
335
- - In Markdown, use **Mermaid** only. Ensure contrast (dark text on light, light on dark backgrounds).
336
-
337
- ## CAWS Integration
338
-
339
- ### Quality Gate Commands
340
-
341
- ```bash
342
- # Run comprehensive test suite
343
- caws quality-gates --test-coverage --mutation-testing
344
-
345
- # Metrics are tracked automatically via working state
346
-
347
- # Verify acceptance criteria for test completion
348
- caws verify-acs --spec-id <id>
349
- ```
350
-
351
- ### Test Analysis
352
-
353
- ```bash
354
- # Analyze test patterns and budget prediction
355
- caws test-analysis assess-budget
356
- caws test-analysis analyze-patterns
357
- caws test-analysis find-similar
358
- ```
359
-
360
- ## Acceptance
361
-
362
- - `test`, `lint`, `typecheck` succeed.
363
- - No TODOs executed at runtime.
364
- - No style violations flagged by project linters.
365
- - Coverage thresholds met (80%+ line, 90%+ branch)
366
- - Mutation testing scores meet targets (70%+ for critical components)
367
- - All integration tests use real database connections
368
- - Performance tests meet documented SLAs
@@ -1,33 +0,0 @@
1
- ---
2
- description: Canonical naming; forbid enhanced/new/final forks; refactor rules
3
- globs:
4
- alwaysApply: true
5
- ---
6
-
7
- # Canonical Naming & Refactor Rules
8
-
9
- ## No Duplicate/Fork Names
10
-
11
- Reject or remove modules/files named with these modifiers:
12
- `enhanced | unified | better | new | next | final | copy | revamp | improved` (case-insensitive).
13
-
14
- **Pre-flight check (human-run or agent-run shell):**
15
-
16
- ```bash
17
- rg -n --no-ignore -g '!node_modules' '(?i)\b(enhanced|unified|better|new|next|final|copy|revamp|improved)\b'
18
- rg -n --no-ignore -g '!node_modules' '(?i)(enhanced|unified|new|final|copy).*\.([tj]sx?|mjs|cjs|mts|cts)$'
19
- ```
20
-
21
- If hits exist in proposed filenames/symbols: **do not proceed**. Use **purpose-first canonical names** and edit the existing module.
22
-
23
- ## Refactor Strategy
24
-
25
- - **Merge, then delete**: If two files cover one domain, merge into the canonical name, update imports, remove the duplicate.
26
- - Prefer **Strategy** + feature flags over file forks.
27
- - Every refactor must include tests proving no behavior change (or updated tests + CHANGELOG if behavior changes).
28
-
29
- ## Acceptance
30
-
31
- - No banned modifiers present in filenames or public symbols.
32
- - Imports updated; build is green.
33
- - Duplicates removed from tree.
@@ -1,23 +0,0 @@
1
- ---
2
- description: Logging, language tone, emoji policy
3
- globs:
4
- alwaysApply: true
5
- ---
6
-
7
- # Logging & Language
8
-
9
- ## Clarity over chronology
10
-
11
- Remove "phase/week" phrasing in docs/logs. State the **specific improvement**:
12
-
13
- - ❌ "PHASE 1 optimization"
14
- - ✅ "Initialize workload analyzer for parallelization"
15
-
16
- ## Emojis
17
-
18
- - Emojis are banned across code, docs, and commits.
19
- - Exception (debug logs only): ⚠️, ✅, 🚫.
20
-
21
- ## Commit Tone
22
-
23
- Professional, neutral, and specific. Avoid hype or vague framing.
@@ -1,23 +0,0 @@
1
- ---
2
- description: Safe defaults, guard clauses, early returns
3
- globs:
4
- alwaysApply: false
5
- ---
6
-
7
- # Safe Defaults & Guard Clauses
8
-
9
- ## Intent
10
-
11
- Minimize null/undefined faults and nesting.
12
-
13
- ## Guidelines (language-agnostic)
14
-
15
- - Prefer **guard clauses** at top of function to fail fast.
16
- - Default parameter objects in signatures.
17
- - Prefer **short-circuiting** / optional access / null-coalescing where supported.
18
- - Loop defensively on possibly-empty collections.
19
-
20
- ## Acceptance
21
-
22
- - No deep nesting introduced where guard clauses apply.
23
- - Inputs validated at boundaries; failures are explicit and early.
@@ -1,36 +0,0 @@
1
- ---
2
- description: TypeScript/JS conventions (alias imports, const, types source of truth)
3
- globs:
4
- - '**/*.ts'
5
- - '**/*.tsx'
6
- - '**/*.mts'
7
- - '**/*.cts'
8
- alwaysApply: false
9
- ---
10
-
11
- # TS/JS Conventions
12
-
13
- ## Variables
14
-
15
- - Prefer `const` over `let` where possible.
16
-
17
- ## Imports
18
-
19
- - Use aliased imports from `@/` (mapped to `src`).
20
- - Replace deep relative paths (`../../x`) with `@/...` when available.
21
-
22
- ## Types
23
-
24
- - Single source of truth at `src/types`.
25
- - Before creating a new type, check and extend the canonical definition.
26
- - Avoid duplicate declarations; prefer composition or augmentation.
27
-
28
- ## Modularity
29
-
30
- - As files approach ~1000 LOC, evaluate separation of concerns; extract cohesive units.
31
-
32
- ## Acceptance
33
-
34
- - No unnecessary `let`.
35
- - No duplicate type declarations.
36
- - No deep relative paths where alias exists.
@@ -1,20 +0,0 @@
1
- ---
2
- description: Process discipline for local servers and hung commands
3
- globs:
4
- alwaysApply: true
5
- ---
6
-
7
- # Process Discipline
8
-
9
- ## Servers
10
-
11
- - Before starting a dev server, check if one is already running on the port; reuse or stop it to avoid duplicates.
12
- - If multiple processes are attached to the port, list and kill explicitly; document PIDs in the PR note if non-obvious.
13
-
14
- ## Hung/Canceled Commands
15
-
16
- If a command is canceled or stalls:
17
-
18
- 1. Assume it hung or waited for input.
19
- 2. Re-run with verbose/debug flags.
20
- 3. Surface the prompt/interaction in the PR so reviewers understand the resolution.
@@ -1,16 +0,0 @@
1
- ---
2
- description: Architecture invariants (SOLID) and change isolation
3
- globs:
4
- alwaysApply: true
5
- ---
6
-
7
- # Architecture Invariants
8
-
9
- - SRP: Each module/class has one reason to change.
10
- - OCP: Prefer extension points over editing stable internals.
11
- - LSP/ISP/DIP: Respect substitution; segregate interfaces; depend on abstractions.
12
-
13
- ## Change Isolation
14
-
15
- - Introduce seams (interfaces/strategies) near integration points.
16
- - Add tests at seams; assert unchanged public behavior.
@@ -1,89 +0,0 @@
1
- ---
2
- description: Language-specific docstring formats and checklists
3
- globs:
4
- alwaysApply: false
5
- ---
6
-
7
- # Docstrings by Language (Reference)
8
-
9
- Provide docstrings for public APIs and exported functions, using the language's native format. Include: summary, params, returns, errors, and an example if helpful.
10
-
11
- | Language | Doc Type | Include |
12
- | -------- | -------- | ----------------------------------------------- |
13
- | C# | XML | `<summary>`, `<param>`, `<returns>`, exceptions |
14
- | C++ | Doxygen | \brief, \param, \return, \exception |
15
- | Go | GoDoc | Full-sentence summary; examples via `ExampleX` |
16
- | Java | Javadoc | One-sentence summary; @param/@return/@throws |
17
- | JS/TS | JSDoc | Description; @param/@returns; @example |
18
- | Kotlin | KDoc | Summary; @param/@return; @throws |
19
- | PHP | PHPDoc | Summary; @param/@return; @throws |
20
- | Python | PEP257 | One-liner; Args/Returns/Raises; example |
21
- | Ruby | RDoc | Description; @param/@return; @raise |
22
- | Rust | rustdoc | `///`; Examples/Panics/Errors sections |
23
- | Swift | DocC | `///`; - Parameters/Returns/Throws; example |
24
-
25
- ## Examples by Language
26
-
27
- ### C# (XML comments)
28
-
29
- ```csharp
30
- /// <summary>
31
- /// Adds two integers.
32
- /// </summary>
33
- /// <param name="a">First integer.</param>
34
- /// <param name="b">Second integer.</param>
35
- /// <returns>The sum of <paramref name="a"/> and <paramref name="b"/>.</returns>
36
- /// <example>
37
- /// <code>
38
- /// var result = calculator.Add(2, 3); // 5
39
- /// </code>
40
- /// </example>
41
- public int Add(int a, int b) => a + b;
42
- ```
43
-
44
- ### JavaScript / TypeScript (JSDoc)
45
-
46
- ```ts
47
- /**
48
- * Adds two numbers.
49
- *
50
- * @param {number} a - First number.
51
- * @param {number} b - Second number.
52
- * @returns {number} Sum of a and b.
53
- * @example
54
- * add(2, 3); // 5
55
- */
56
- function add(a, b) {
57
- return a + b;
58
- }
59
- ```
60
-
61
- ### Python (PEP 257 / Google style)
62
-
63
- ```python
64
- def add(a: int, b: int) -> int:
65
- """Add two integers.
66
-
67
- Args:
68
- a (int): First integer.
69
- b (int): Second integer.
70
-
71
- Returns:
72
- int: Sum of a and b.
73
-
74
- Raises:
75
- ValueError: If a or b is negative.
76
-
77
- Example:
78
- >>> add(2, 3)
79
- 5
80
- """
81
- if a < 0 or b < 0:
82
- raise ValueError("Negative not allowed")
83
- return a + b
84
- ```
85
-
86
- ## Acceptance
87
-
88
- - Public APIs have docstrings in native style.
89
- - Docstrings describe behavior, inputs, outputs, and failure modes.