@dewtech/dare-cli 3.1.0 → 3.3.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 (345) hide show
  1. package/README.md +5 -1
  2. package/dist/__tests__/dag-runner/ralph-loop.test.js +107 -45
  3. package/dist/__tests__/dag-runner/ralph-loop.test.js.map +1 -1
  4. package/dist/__tests__/dag-runner/state-store.test.d.ts +2 -0
  5. package/dist/__tests__/dag-runner/state-store.test.d.ts.map +1 -0
  6. package/dist/__tests__/dag-runner/state-store.test.js +74 -0
  7. package/dist/__tests__/dag-runner/state-store.test.js.map +1 -0
  8. package/dist/__tests__/ensure-skills.test.d.ts +2 -0
  9. package/dist/__tests__/ensure-skills.test.d.ts.map +1 -0
  10. package/dist/__tests__/ensure-skills.test.js +67 -0
  11. package/dist/__tests__/ensure-skills.test.js.map +1 -0
  12. package/dist/__tests__/ide-command-parity.test.d.ts +2 -0
  13. package/dist/__tests__/ide-command-parity.test.d.ts.map +1 -0
  14. package/dist/__tests__/ide-command-parity.test.js +59 -0
  15. package/dist/__tests__/ide-command-parity.test.js.map +1 -0
  16. package/dist/__tests__/project-generator.test.d.ts +2 -0
  17. package/dist/__tests__/project-generator.test.d.ts.map +1 -0
  18. package/dist/__tests__/project-generator.test.js +56 -0
  19. package/dist/__tests__/project-generator.test.js.map +1 -0
  20. package/dist/__tests__/reverse-collection.test.d.ts +2 -0
  21. package/dist/__tests__/reverse-collection.test.d.ts.map +1 -0
  22. package/dist/__tests__/reverse-collection.test.js +87 -0
  23. package/dist/__tests__/reverse-collection.test.js.map +1 -0
  24. package/dist/bin/dare.js +2 -0
  25. package/dist/bin/dare.js.map +1 -1
  26. package/dist/commands/__tests__/bench.spec.d.ts +2 -0
  27. package/dist/commands/__tests__/bench.spec.d.ts.map +1 -0
  28. package/dist/commands/__tests__/bench.spec.js +106 -0
  29. package/dist/commands/__tests__/bench.spec.js.map +1 -0
  30. package/dist/commands/__tests__/execute.best-of.spec.d.ts +2 -0
  31. package/dist/commands/__tests__/execute.best-of.spec.d.ts.map +1 -0
  32. package/dist/commands/__tests__/execute.best-of.spec.js +24 -0
  33. package/dist/commands/__tests__/execute.best-of.spec.js.map +1 -0
  34. package/dist/commands/__tests__/execute.telemetry.spec.d.ts +2 -0
  35. package/dist/commands/__tests__/execute.telemetry.spec.d.ts.map +1 -0
  36. package/dist/commands/__tests__/execute.telemetry.spec.js +93 -0
  37. package/dist/commands/__tests__/execute.telemetry.spec.js.map +1 -0
  38. package/dist/commands/__tests__/execute.verify.spec.d.ts +2 -0
  39. package/dist/commands/__tests__/execute.verify.spec.d.ts.map +1 -0
  40. package/dist/commands/__tests__/execute.verify.spec.js +150 -0
  41. package/dist/commands/__tests__/execute.verify.spec.js.map +1 -0
  42. package/dist/commands/bench.d.ts +10 -0
  43. package/dist/commands/bench.d.ts.map +1 -0
  44. package/dist/commands/bench.js +64 -0
  45. package/dist/commands/bench.js.map +1 -0
  46. package/dist/commands/dna.d.ts.map +1 -1
  47. package/dist/commands/dna.js +4 -0
  48. package/dist/commands/dna.js.map +1 -1
  49. package/dist/commands/execute-verification.d.ts +51 -0
  50. package/dist/commands/execute-verification.d.ts.map +1 -0
  51. package/dist/commands/execute-verification.js +201 -0
  52. package/dist/commands/execute-verification.js.map +1 -0
  53. package/dist/commands/execute.d.ts.map +1 -1
  54. package/dist/commands/execute.js +139 -2
  55. package/dist/commands/execute.js.map +1 -1
  56. package/dist/commands/migrate.d.ts.map +1 -1
  57. package/dist/commands/migrate.js +4 -0
  58. package/dist/commands/migrate.js.map +1 -1
  59. package/dist/commands/reverse.d.ts.map +1 -1
  60. package/dist/commands/reverse.js +27 -8
  61. package/dist/commands/reverse.js.map +1 -1
  62. package/dist/dag-runner/ralph-loop.d.ts +9 -9
  63. package/dist/dag-runner/ralph-loop.d.ts.map +1 -1
  64. package/dist/dag-runner/ralph-loop.js +89 -113
  65. package/dist/dag-runner/ralph-loop.js.map +1 -1
  66. package/dist/dag-runner/state-store.d.ts +14 -1
  67. package/dist/dag-runner/state-store.d.ts.map +1 -1
  68. package/dist/dag-runner/state-store.js +39 -8
  69. package/dist/dag-runner/state-store.js.map +1 -1
  70. package/dist/exec/npm-invoke.d.ts +8 -0
  71. package/dist/exec/npm-invoke.d.ts.map +1 -0
  72. package/dist/exec/npm-invoke.js +45 -0
  73. package/dist/exec/npm-invoke.js.map +1 -0
  74. package/dist/exec/safe-spawn.d.ts +21 -0
  75. package/dist/exec/safe-spawn.d.ts.map +1 -0
  76. package/dist/exec/safe-spawn.js +108 -0
  77. package/dist/exec/safe-spawn.js.map +1 -0
  78. package/dist/graphrag/types.d.ts +2 -2
  79. package/dist/graphrag/types.d.ts.map +1 -1
  80. package/dist/stacks/dna-emitter.d.ts.map +1 -1
  81. package/dist/stacks/dna-emitter.js +1 -10
  82. package/dist/stacks/dna-emitter.js.map +1 -1
  83. package/dist/utils/UpdateApplier.d.ts.map +1 -1
  84. package/dist/utils/UpdateApplier.js +8 -0
  85. package/dist/utils/UpdateApplier.js.map +1 -1
  86. package/dist/utils/datamodel.d.ts.map +1 -1
  87. package/dist/utils/datamodel.js +97 -20
  88. package/dist/utils/datamodel.js.map +1 -1
  89. package/dist/utils/logger.d.ts +7 -0
  90. package/dist/utils/logger.d.ts.map +1 -0
  91. package/dist/utils/logger.js +23 -0
  92. package/dist/utils/logger.js.map +1 -0
  93. package/dist/utils/path-safety.d.ts +22 -0
  94. package/dist/utils/path-safety.d.ts.map +1 -0
  95. package/dist/utils/path-safety.js +83 -0
  96. package/dist/utils/path-safety.js.map +1 -0
  97. package/dist/utils/project-generator.d.ts +21 -0
  98. package/dist/utils/project-generator.d.ts.map +1 -1
  99. package/dist/utils/project-generator.js +71 -0
  100. package/dist/utils/project-generator.js.map +1 -1
  101. package/dist/utils/reverse-facts.d.ts +3 -2
  102. package/dist/utils/reverse-facts.d.ts.map +1 -1
  103. package/dist/utils/reverse-facts.js +89 -8
  104. package/dist/utils/reverse-facts.js.map +1 -1
  105. package/dist/utils/stack-bootstrap.js +2 -2
  106. package/dist/utils/stack-bootstrap.js.map +1 -1
  107. package/dist/verification/__tests__/anti-tamper.test.d.ts +2 -0
  108. package/dist/verification/__tests__/anti-tamper.test.d.ts.map +1 -0
  109. package/dist/verification/__tests__/anti-tamper.test.js +73 -0
  110. package/dist/verification/__tests__/anti-tamper.test.js.map +1 -0
  111. package/dist/verification/__tests__/bench-fixtures.test.d.ts +2 -0
  112. package/dist/verification/__tests__/bench-fixtures.test.d.ts.map +1 -0
  113. package/dist/verification/__tests__/bench-fixtures.test.js +35 -0
  114. package/dist/verification/__tests__/bench-fixtures.test.js.map +1 -0
  115. package/dist/verification/__tests__/bench-harness.test.d.ts +2 -0
  116. package/dist/verification/__tests__/bench-harness.test.d.ts.map +1 -0
  117. package/dist/verification/__tests__/bench-harness.test.js +75 -0
  118. package/dist/verification/__tests__/bench-harness.test.js.map +1 -0
  119. package/dist/verification/__tests__/bench-report.test.d.ts +2 -0
  120. package/dist/verification/__tests__/bench-report.test.d.ts.map +1 -0
  121. package/dist/verification/__tests__/bench-report.test.js +73 -0
  122. package/dist/verification/__tests__/bench-report.test.js.map +1 -0
  123. package/dist/verification/__tests__/best-of-n-runner.test.d.ts +2 -0
  124. package/dist/verification/__tests__/best-of-n-runner.test.d.ts.map +1 -0
  125. package/dist/verification/__tests__/best-of-n-runner.test.js +94 -0
  126. package/dist/verification/__tests__/best-of-n-runner.test.js.map +1 -0
  127. package/dist/verification/__tests__/config.test.d.ts +2 -0
  128. package/dist/verification/__tests__/config.test.d.ts.map +1 -0
  129. package/dist/verification/__tests__/config.test.js +50 -0
  130. package/dist/verification/__tests__/config.test.js.map +1 -0
  131. package/dist/verification/__tests__/decay-policy.test.d.ts +2 -0
  132. package/dist/verification/__tests__/decay-policy.test.d.ts.map +1 -0
  133. package/dist/verification/__tests__/decay-policy.test.js +130 -0
  134. package/dist/verification/__tests__/decay-policy.test.js.map +1 -0
  135. package/dist/verification/__tests__/fail-to-pass.test.d.ts +2 -0
  136. package/dist/verification/__tests__/fail-to-pass.test.d.ts.map +1 -0
  137. package/dist/verification/__tests__/fail-to-pass.test.js +107 -0
  138. package/dist/verification/__tests__/fail-to-pass.test.js.map +1 -0
  139. package/dist/verification/__tests__/failure-signature.test.d.ts +2 -0
  140. package/dist/verification/__tests__/failure-signature.test.d.ts.map +1 -0
  141. package/dist/verification/__tests__/failure-signature.test.js +40 -0
  142. package/dist/verification/__tests__/failure-signature.test.js.map +1 -0
  143. package/dist/verification/__tests__/logger.test.d.ts +2 -0
  144. package/dist/verification/__tests__/logger.test.d.ts.map +1 -0
  145. package/dist/verification/__tests__/logger.test.js +23 -0
  146. package/dist/verification/__tests__/logger.test.js.map +1 -0
  147. package/dist/verification/__tests__/mutation-cargo-mutants.test.d.ts +2 -0
  148. package/dist/verification/__tests__/mutation-cargo-mutants.test.d.ts.map +1 -0
  149. package/dist/verification/__tests__/mutation-cargo-mutants.test.js +96 -0
  150. package/dist/verification/__tests__/mutation-cargo-mutants.test.js.map +1 -0
  151. package/dist/verification/__tests__/mutation-infection.test.d.ts +2 -0
  152. package/dist/verification/__tests__/mutation-infection.test.d.ts.map +1 -0
  153. package/dist/verification/__tests__/mutation-infection.test.js +101 -0
  154. package/dist/verification/__tests__/mutation-infection.test.js.map +1 -0
  155. package/dist/verification/__tests__/mutation-mutmut.test.d.ts +2 -0
  156. package/dist/verification/__tests__/mutation-mutmut.test.d.ts.map +1 -0
  157. package/dist/verification/__tests__/mutation-mutmut.test.js +102 -0
  158. package/dist/verification/__tests__/mutation-mutmut.test.js.map +1 -0
  159. package/dist/verification/__tests__/mutation-registry.test.d.ts +2 -0
  160. package/dist/verification/__tests__/mutation-registry.test.d.ts.map +1 -0
  161. package/dist/verification/__tests__/mutation-registry.test.js +28 -0
  162. package/dist/verification/__tests__/mutation-registry.test.js.map +1 -0
  163. package/dist/verification/__tests__/mutation-stryker.test.d.ts +2 -0
  164. package/dist/verification/__tests__/mutation-stryker.test.d.ts.map +1 -0
  165. package/dist/verification/__tests__/mutation-stryker.test.js +88 -0
  166. package/dist/verification/__tests__/mutation-stryker.test.js.map +1 -0
  167. package/dist/verification/__tests__/no-shell-true.test.d.ts +2 -0
  168. package/dist/verification/__tests__/no-shell-true.test.d.ts.map +1 -0
  169. package/dist/verification/__tests__/no-shell-true.test.js +43 -0
  170. package/dist/verification/__tests__/no-shell-true.test.js.map +1 -0
  171. package/dist/verification/__tests__/path-safety.test.d.ts +2 -0
  172. package/dist/verification/__tests__/path-safety.test.d.ts.map +1 -0
  173. package/dist/verification/__tests__/path-safety.test.js +59 -0
  174. package/dist/verification/__tests__/path-safety.test.js.map +1 -0
  175. package/dist/verification/__tests__/prerank.test.d.ts +2 -0
  176. package/dist/verification/__tests__/prerank.test.d.ts.map +1 -0
  177. package/dist/verification/__tests__/prerank.test.js +44 -0
  178. package/dist/verification/__tests__/prerank.test.js.map +1 -0
  179. package/dist/verification/__tests__/runner.test.d.ts +2 -0
  180. package/dist/verification/__tests__/runner.test.d.ts.map +1 -0
  181. package/dist/verification/__tests__/runner.test.js +200 -0
  182. package/dist/verification/__tests__/runner.test.js.map +1 -0
  183. package/dist/verification/__tests__/safe-spawn.test.d.ts +2 -0
  184. package/dist/verification/__tests__/safe-spawn.test.d.ts.map +1 -0
  185. package/dist/verification/__tests__/safe-spawn.test.js +36 -0
  186. package/dist/verification/__tests__/safe-spawn.test.js.map +1 -0
  187. package/dist/verification/__tests__/security.test.d.ts +2 -0
  188. package/dist/verification/__tests__/security.test.d.ts.map +1 -0
  189. package/dist/verification/__tests__/security.test.js +79 -0
  190. package/dist/verification/__tests__/security.test.js.map +1 -0
  191. package/dist/verification/__tests__/selector-pareto.test.d.ts +2 -0
  192. package/dist/verification/__tests__/selector-pareto.test.d.ts.map +1 -0
  193. package/dist/verification/__tests__/selector-pareto.test.js +77 -0
  194. package/dist/verification/__tests__/selector-pareto.test.js.map +1 -0
  195. package/dist/verification/__tests__/telemetry.test.d.ts +2 -0
  196. package/dist/verification/__tests__/telemetry.test.d.ts.map +1 -0
  197. package/dist/verification/__tests__/telemetry.test.js +116 -0
  198. package/dist/verification/__tests__/telemetry.test.js.map +1 -0
  199. package/dist/verification/__tests__/type-check.test.d.ts +2 -0
  200. package/dist/verification/__tests__/type-check.test.d.ts.map +1 -0
  201. package/dist/verification/__tests__/type-check.test.js +52 -0
  202. package/dist/verification/__tests__/type-check.test.js.map +1 -0
  203. package/dist/verification/__tests__/worktree.test.d.ts +2 -0
  204. package/dist/verification/__tests__/worktree.test.d.ts.map +1 -0
  205. package/dist/verification/__tests__/worktree.test.js +41 -0
  206. package/dist/verification/__tests__/worktree.test.js.map +1 -0
  207. package/dist/verification/bench/fixtures.d.ts +11 -0
  208. package/dist/verification/bench/fixtures.d.ts.map +1 -0
  209. package/dist/verification/bench/fixtures.js +66 -0
  210. package/dist/verification/bench/fixtures.js.map +1 -0
  211. package/dist/verification/bench/harness.d.ts +19 -0
  212. package/dist/verification/bench/harness.d.ts.map +1 -0
  213. package/dist/verification/bench/harness.js +138 -0
  214. package/dist/verification/bench/harness.js.map +1 -0
  215. package/dist/verification/bench/report.d.ts +53 -0
  216. package/dist/verification/bench/report.d.ts.map +1 -0
  217. package/dist/verification/bench/report.js +47 -0
  218. package/dist/verification/bench/report.js.map +1 -0
  219. package/dist/verification/best-of-n/runner.d.ts +29 -0
  220. package/dist/verification/best-of-n/runner.d.ts.map +1 -0
  221. package/dist/verification/best-of-n/runner.js +76 -0
  222. package/dist/verification/best-of-n/runner.js.map +1 -0
  223. package/dist/verification/best-of-n/selector/pareto.d.ts +10 -0
  224. package/dist/verification/best-of-n/selector/pareto.d.ts.map +1 -0
  225. package/dist/verification/best-of-n/selector/pareto.js +65 -0
  226. package/dist/verification/best-of-n/selector/pareto.js.map +1 -0
  227. package/dist/verification/best-of-n/selector/prerank.d.ts +23 -0
  228. package/dist/verification/best-of-n/selector/prerank.d.ts.map +1 -0
  229. package/dist/verification/best-of-n/selector/prerank.js +32 -0
  230. package/dist/verification/best-of-n/selector/prerank.js.map +1 -0
  231. package/dist/verification/best-of-n/worktree.d.ts +9 -0
  232. package/dist/verification/best-of-n/worktree.d.ts.map +1 -0
  233. package/dist/verification/best-of-n/worktree.js +100 -0
  234. package/dist/verification/best-of-n/worktree.js.map +1 -0
  235. package/dist/verification/config.d.ts +24 -0
  236. package/dist/verification/config.d.ts.map +1 -0
  237. package/dist/verification/config.js +168 -0
  238. package/dist/verification/config.js.map +1 -0
  239. package/dist/verification/decay/policy.d.ts +16 -0
  240. package/dist/verification/decay/policy.d.ts.map +1 -0
  241. package/dist/verification/decay/policy.js +64 -0
  242. package/dist/verification/decay/policy.js.map +1 -0
  243. package/dist/verification/decay/signature.d.ts +6 -0
  244. package/dist/verification/decay/signature.d.ts.map +1 -0
  245. package/dist/verification/decay/signature.js +18 -0
  246. package/dist/verification/decay/signature.js.map +1 -0
  247. package/dist/verification/gates/anti-tamper.d.ts +16 -0
  248. package/dist/verification/gates/anti-tamper.d.ts.map +1 -0
  249. package/dist/verification/gates/anti-tamper.js +142 -0
  250. package/dist/verification/gates/anti-tamper.js.map +1 -0
  251. package/dist/verification/gates/fail-to-pass.d.ts +39 -0
  252. package/dist/verification/gates/fail-to-pass.d.ts.map +1 -0
  253. package/dist/verification/gates/fail-to-pass.js +173 -0
  254. package/dist/verification/gates/fail-to-pass.js.map +1 -0
  255. package/dist/verification/gates/mutation/adapter.d.ts +34 -0
  256. package/dist/verification/gates/mutation/adapter.d.ts.map +1 -0
  257. package/dist/verification/gates/mutation/adapter.js +22 -0
  258. package/dist/verification/gates/mutation/adapter.js.map +1 -0
  259. package/dist/verification/gates/mutation/cargo-mutants.d.ts +28 -0
  260. package/dist/verification/gates/mutation/cargo-mutants.d.ts.map +1 -0
  261. package/dist/verification/gates/mutation/cargo-mutants.js +170 -0
  262. package/dist/verification/gates/mutation/cargo-mutants.js.map +1 -0
  263. package/dist/verification/gates/mutation/infection.d.ts +28 -0
  264. package/dist/verification/gates/mutation/infection.d.ts.map +1 -0
  265. package/dist/verification/gates/mutation/infection.js +149 -0
  266. package/dist/verification/gates/mutation/infection.js.map +1 -0
  267. package/dist/verification/gates/mutation/mutmut.d.ts +23 -0
  268. package/dist/verification/gates/mutation/mutmut.d.ts.map +1 -0
  269. package/dist/verification/gates/mutation/mutmut.js +148 -0
  270. package/dist/verification/gates/mutation/mutmut.js.map +1 -0
  271. package/dist/verification/gates/mutation/stryker.d.ts +19 -0
  272. package/dist/verification/gates/mutation/stryker.d.ts.map +1 -0
  273. package/dist/verification/gates/mutation/stryker.js +103 -0
  274. package/dist/verification/gates/mutation/stryker.js.map +1 -0
  275. package/dist/verification/gates/type-check.d.ts +11 -0
  276. package/dist/verification/gates/type-check.d.ts.map +1 -0
  277. package/dist/verification/gates/type-check.js +84 -0
  278. package/dist/verification/gates/type-check.js.map +1 -0
  279. package/dist/verification/registry.d.ts +6 -0
  280. package/dist/verification/registry.d.ts.map +1 -0
  281. package/dist/verification/registry.js +49 -0
  282. package/dist/verification/registry.js.map +1 -0
  283. package/dist/verification/runner.d.ts +27 -0
  284. package/dist/verification/runner.d.ts.map +1 -0
  285. package/dist/verification/runner.js +173 -0
  286. package/dist/verification/runner.js.map +1 -0
  287. package/dist/verification/telemetry.d.ts +18 -0
  288. package/dist/verification/telemetry.d.ts.map +1 -0
  289. package/dist/verification/telemetry.js +71 -0
  290. package/dist/verification/telemetry.js.map +1 -0
  291. package/dist/verification/types.d.ts +89 -0
  292. package/dist/verification/types.d.ts.map +1 -0
  293. package/dist/verification/types.js +3 -0
  294. package/dist/verification/types.js.map +1 -0
  295. package/package.json +5 -3
  296. package/templates/UPDATE-MANIFEST.json +20 -0
  297. package/templates/ide/antigravity/.agents/skills/dare-bench/SKILL.md +21 -0
  298. package/templates/ide/antigravity/.agents/skills/dare-bootstrap/SKILL.md +32 -0
  299. package/templates/ide/antigravity/.agents/skills/dare-dag/SKILL.md +32 -0
  300. package/templates/ide/antigravity/.agents/skills/dare-discover/SKILL.md +33 -0
  301. package/templates/ide/antigravity/.agents/skills/dare-graph/SKILL.md +35 -0
  302. package/templates/ide/antigravity/.agents/skills/dare-info/SKILL.md +31 -0
  303. package/templates/ide/antigravity/.agents/skills/dare-init/SKILL.md +35 -0
  304. package/templates/ide/antigravity/.agents/skills/dare-skill/SKILL.md +35 -0
  305. package/templates/ide/antigravity/.agents/skills/dare-update/SKILL.md +33 -0
  306. package/templates/ide/antigravity/.agents/skills/dare-validate/SKILL.md +33 -0
  307. package/templates/ide/antigravity/.agents/skills/dare-welcome/SKILL.md +30 -0
  308. package/templates/ide/claude/.claude/commands/dare-bench.md +18 -0
  309. package/templates/ide/claude/.claude/commands/dare-bootstrap.md +27 -0
  310. package/templates/ide/claude/.claude/commands/dare-dag.md +27 -0
  311. package/templates/ide/claude/.claude/commands/dare-discover.md +28 -0
  312. package/templates/ide/claude/.claude/commands/dare-graph.md +30 -0
  313. package/templates/ide/claude/.claude/commands/dare-info.md +26 -0
  314. package/templates/ide/claude/.claude/commands/dare-init.md +30 -0
  315. package/templates/ide/claude/.claude/commands/dare-skill.md +30 -0
  316. package/templates/ide/claude/.claude/commands/dare-update.md +28 -0
  317. package/templates/ide/claude/.claude/commands/dare-validate.md +28 -0
  318. package/templates/ide/claude/.claude/commands/dare-welcome.md +25 -0
  319. package/templates/ide/cursor/.cursor/commands/dare-bench.md +18 -0
  320. package/templates/ide/cursor/.cursor/commands/{generate-blueprint.md → dare-blueprint.md} +1 -1
  321. package/templates/ide/cursor/.cursor/commands/dare-bootstrap.md +27 -0
  322. package/templates/ide/cursor/.cursor/commands/{run-dag.md → dare-dag-run.md} +1 -1
  323. package/templates/ide/cursor/.cursor/commands/{dag-viz.md → dare-dag-viz.md} +1 -1
  324. package/templates/ide/cursor/.cursor/commands/dare-dag.md +27 -0
  325. package/templates/ide/cursor/.cursor/commands/{generate-design.md → dare-design.md} +1 -1
  326. package/templates/ide/cursor/.cursor/commands/dare-discover.md +28 -0
  327. package/templates/ide/cursor/.cursor/commands/dare-dna.md +75 -0
  328. package/templates/ide/cursor/.cursor/commands/{generate-docker-compose.md → dare-docker-compose.md} +1 -1
  329. package/templates/ide/cursor/.cursor/commands/{generate-dockerfile.md → dare-dockerfile.md} +1 -1
  330. package/templates/ide/cursor/.cursor/commands/{execute-task.md → dare-execute.md} +1 -1
  331. package/templates/ide/cursor/.cursor/commands/dare-graph.md +30 -0
  332. package/templates/ide/cursor/.cursor/commands/dare-info.md +26 -0
  333. package/templates/ide/cursor/.cursor/commands/dare-init.md +30 -0
  334. package/templates/ide/cursor/.cursor/commands/dare-migrate.md +72 -0
  335. package/templates/ide/cursor/.cursor/commands/{refine-task.md → dare-refine.md} +1 -1
  336. package/templates/ide/cursor/.cursor/commands/dare-reverse.md +139 -0
  337. package/templates/ide/cursor/.cursor/commands/{review-task.md → dare-review.md} +1 -1
  338. package/templates/ide/cursor/.cursor/commands/dare-skill.md +30 -0
  339. package/templates/ide/cursor/.cursor/commands/{generate-tasks.md → dare-tasks.md} +1 -1
  340. package/templates/ide/cursor/.cursor/commands/{telemetry-report.md → dare-telemetry.md} +1 -1
  341. package/templates/ide/cursor/.cursor/commands/dare-update.md +28 -0
  342. package/templates/ide/cursor/.cursor/commands/dare-validate.md +28 -0
  343. package/templates/ide/cursor/.cursor/commands/dare-welcome.md +25 -0
  344. /package/templates/ide/cursor/.cursor/commands/{generate-bugfix-design.md → dare-bugfix-design.md} +0 -0
  345. /package/templates/ide/cursor/.cursor/commands/{generate-feature-design.md → dare-feature-design.md} +0 -0
@@ -0,0 +1,139 @@
1
+ # Comando: /dare-reverse
2
+
3
+ Camada semântica da engenharia reversa (Fase 0 / brownfield). Roda **depois** do comando
4
+ `dare reverse`, que já varreu o código e gerou os esqueletos. Sua função é **preencher as
5
+ inferências** que o CLI determinístico não faz: propósito, domínio, responsabilidades e os
6
+ **diagramas de fluxo** ("como a coisa funciona").
7
+
8
+ ## Como usar
9
+
10
+ ```
11
+ /dare-reverse # preenche os artefatos gerados por `dare reverse`
12
+ ```
13
+
14
+ > Pré-requisito: rodar `dare reverse` antes (gera `DARE/IDEIA.md`, `DARE/REVERSE/module-*.md`
15
+ > e `DARE/REVERSE/reverse-facts.json`). Se não existirem, instrua o usuário a rodar `dare reverse` primeiro.
16
+
17
+ ## Quando usar
18
+
19
+ - O usuário quer entender / documentar um projeto **legado** antes de adotar o DARE.
20
+ - Acabou de rodar `dare reverse` e os artefatos têm seções `<!-- AGENT: ... -->` em aberto.
21
+ - O objetivo é gerar uma **pré-arquitetura** (`IDEIA.md`) que depois vira `DESIGN.md`.
22
+
23
+ ## Marcação de confiança (obrigatória)
24
+
25
+ Ao preencher cada `<!-- AGENT -->`, marque **cada afirmação** com seu nível de confiança + evidência:
26
+
27
+ - `- 🟢 <claim>. ` + `` `arquivo:linha` `` — **CONFIRMED**: evidência direta no código.
28
+ - `- 🟡 <claim>. ` + `` `arquivo:linha` `` — **INFERRED**: padrão/dedução; pode estar errado.
29
+ - `- 🔴 <claim>. → ver gaps.md` — **GAP**: não determinável pelo código.
30
+
31
+ Regra: só 🟢 com evidência direta; na dúvida, 🟡; sem base, 🔴 (e registre em `gaps.md`). Os fatos
32
+ estruturais (caminho, LOC, deps) já vêm pré-marcados 🟢 pelo CLI — **não os altere**.
33
+
34
+ ## O que fazer
35
+
36
+ ### 1. Carregar os fatos (não re-varrer tudo)
37
+
38
+ - Leia `DARE/REVERSE/reverse-facts.json` — é a fonte de fatos determinística (stack, módulos,
39
+ LOC, grafo de dependências). **Confie nela** para o inventário; não reconte arquivos.
40
+ - Para cada módulo, abra **2-5 arquivos representativos** (entrypoints, controllers, services,
41
+ models) — o suficiente para inferir responsabilidade e fluxo. Não leia o módulo inteiro.
42
+
43
+ ### 2. Preencher `DARE/IDEIA.md`
44
+
45
+ Substitua cada bloco `<!-- AGENT: ... -->` por conteúdo real:
46
+
47
+ - **Propósito Inferido** — 2-4 frases: o que o software faz e por quê.
48
+ - **Domínio & Conceitos** — entidades de negócio + glossário (inferidos de models/migrations/nomes).
49
+ - **Modelo de Dados (reconstruído)** — entidades, campos-chave, relacionamentos (de migrations/ORM).
50
+ - **Superfície de API** — endpoints inferidos de rotas/controllers (método, rota, propósito).
51
+ - **Fluxo do Sistema** — um `flowchart TD` Mermaid do caminho principal de request/dados
52
+ atravessando os módulos. Ex.:
53
+ ```mermaid
54
+ flowchart TD
55
+ Client[Cliente] --> API[API/Rotas]
56
+ API --> Auth[auth: valida token]
57
+ Auth --> Domain[users: regra de negócio]
58
+ Domain --> DB[(Persistência)]
59
+ ```
60
+ - **⚠️ Incertezas / Gaps** — seja honesto: o que NÃO deu pra inferir com segurança, e perguntas
61
+ objetivas para o humano confirmar. Esta seção é o que protege o checkpoint human-in-the-loop.
62
+
63
+ **Não toque** no Mapa de Módulos nem na tabela (são determinísticos, gerados pelo CLI).
64
+
65
+ ### 3. Preencher cada `DARE/REVERSE/module-*.md`
66
+
67
+ Para cada módulo, substitua os `<!-- AGENT -->`:
68
+
69
+ - **Responsabilidade** — 1-3 frases sobre o papel do módulo no sistema.
70
+ - **Superfície Pública** — o que ele expõe (funções/classes/endpoints/tipos exportados).
71
+ - **Como Funciona (fluxo)** — um `sequenceDiagram` Mermaid do fluxo de execução típico. Ex.:
72
+ ```mermaid
73
+ sequenceDiagram
74
+ participant C as Caller
75
+ participant S as Service
76
+ participant R as Repository
77
+ participant DB as Database
78
+ C->>S: chamada(args)
79
+ S->>R: busca/persiste
80
+ R->>DB: query
81
+ DB-->>R: linhas
82
+ R-->>S: entidade
83
+ S-->>C: resultado
84
+ ```
85
+ - **Dependências & Acoplamento** — comente as dependências listadas em "Depende de" e riscos
86
+ de acoplamento (ex.: dependência circular, módulo-hotspot HIGH com muitos dependentes).
87
+
88
+ ### 4. Apresentar ao usuário
89
+
90
+ Mostre um resumo: propósito inferido, nº de módulos, principais incertezas. Reforce que o
91
+ `IDEIA.md` é um **rascunho a ser validado** — peça para o humano revisar antes de promover a DESIGN.
92
+
93
+ ## Passo final — Gaps, Questions e Reviewer
94
+
95
+ 1. **`gaps.md`** — consolide todos os 🔴 em `DARE/REVERSE/gaps.md`, classificados por severidade
96
+ (crítico / moderado / cosmético / fora-escopo) e com o tratamento sugerido.
97
+ 2. **`questions.md`** — perguntas objetivas ao humano em `DARE/REVERSE/questions.md`.
98
+ 3. **Reviewer (releia e reclassifique)** — reabra os arquivos-chave e revise os claims; rebaixe os
99
+ que não têm evidência suficiente (🟢→🟡 ou 🟡→🔴). Um spec honesto sobre suas incertezas vale mais
100
+ que um spec fluente que apresenta suposição como fato.
101
+ 4. **Rode `dare reverse --report`** — o CLI conta os marcadores e gera `confidence-report.md` +
102
+ `traceability/code-spec-matrix.md` com o índice determinístico. Mostre o índice ao usuário.
103
+
104
+ ## Modo `--deep` (Fase 3)
105
+
106
+ Se `dare reverse --deep` foi usado, há artefatos extras em `DARE/REVERSE/` a completar:
107
+
108
+ - **`erd.md`** — o CLI extraiu entidades de migrations/Prisma/ORM (🟢, com evidência). Complete
109
+ relações/entidades **não-explícitas** no schema (🟡) e corrija o que estiver errado.
110
+ - **`domain-rules.md`** — regras de negócio (validações, invariantes, cálculos, políticas), 🟢/🟡/🔴.
111
+ - **`state-machines.md`** — um `stateDiagram-v2` por entidade/fluxo com estados e transições reais.
112
+ - **`permissions.md`** — papéis, recursos e regras de autorização (quem pode o quê).
113
+ - **`c4/c4-context.md`** e **`c4/c4-container.md`** — atores/sistemas externos e containers de deploy.
114
+ (O nível *component* já é o mapa de módulos em `c4/c4-component.md`, gerado pelo CLI.)
115
+
116
+ ## Regras de ouro
117
+
118
+ 1. **Não invente.** Se um fluxo não está claro no código, marque 🔴 (gap) em vez de chutar.
119
+ 2. **Fidelidade ao código real** — descreva o que o código faz, não o que deveria fazer.
120
+ 3. **Diagramas enxutos** — um fluxo legível vale mais que um diagrama exaustivo e ilegível.
121
+ 4. **Não re-varra** — os fatos já estão em `reverse-facts.json`; foque na inferência semântica.
122
+ 5. **Preserve o determinístico** — nunca edite o Mapa de Módulos/tabela/grafo gerados pelo CLI.
123
+
124
+ ## Antipatterns
125
+
126
+ | AP | Antipattern | Por quê |
127
+ |---|---|---|
128
+ | AP-01 | Inventar endpoints/entidades não presentes no código | Polui a pré-arquitetura com ficção |
129
+ | AP-02 | Reescrever a tabela de módulos do CLI | Quebra a fonte determinística |
130
+ | AP-03 | `sequenceDiagram` gigante e ilegível | Anula o propósito do diagrama |
131
+ | AP-04 | Pular a seção de Incertezas | Remove o ponto de validação humana |
132
+ | AP-05 | Ler o projeto inteiro arquivo a arquivo | Desperdiça contexto; os fatos já estão no JSON |
133
+ | AP-06 | Marcar tudo 🟢 sem evidência `file:line` | Infla a confiança e engana o humano — o valor está em separar 🟢/🟡/🔴 |
134
+
135
+ $ARGUMENTS
136
+
137
+ ---
138
+
139
+ Skill MIT — parte do DARE Method. Fase 0 (brownfield). Pareia com o comando `dare reverse`.
@@ -1,4 +1,4 @@
1
- # Comando: /review-task
1
+ # Comando: /dare-review
2
2
 
3
3
  ## Descrição
4
4
 
@@ -0,0 +1,30 @@
1
+ # Comando: /dare-skill
2
+
3
+ Adiciona, remove, lista, inspeciona, atualiza ou publica skills DARE neste projeto.
4
+
5
+ > Este comando expõe o CLI `dare skill` na IDE. O agente pode **rodar o comando no terminal** e interpretar a saída.
6
+
7
+ ## Quando usar
8
+
9
+ - Você quer instalar uma skill extra (ex.: uma skill de stack) no projeto.
10
+ - Quer listar/inspecionar as skills disponíveis ou publicar uma própria.
11
+
12
+ ## Como rodar
13
+
14
+ ```bash
15
+ dare skill list
16
+ dare skill info <nome>
17
+ dare skill add <nome>
18
+ dare skill remove <nome>
19
+ dare skill update
20
+ ```
21
+
22
+ ## O que fazer
23
+
24
+ 1. Use `dare skill list` para ver o que está instalado/disponível.
25
+ 2. Rode o subcomando desejado (`add`/`remove`/`info`/`update`/`publish`).
26
+ 3. Confirme o resultado e, se mudou comandos de IDE, recarregue a IDE.
27
+
28
+ ## Comandos relacionados
29
+
30
+ `/dare-update` · `/dare-info`
@@ -1,4 +1,4 @@
1
- # Comando: /generate-tasks
1
+ # Comando: /dare-tasks
2
2
 
3
3
  ## Descrição
4
4
  Avança o Método DARE lendo o Blueprint aprovado e gerando os **três artefatos**
@@ -1,4 +1,4 @@
1
- # Comando: /telemetry-report
1
+ # Comando: /dare-telemetry
2
2
 
3
3
  ## Descrição
4
4
  Este comando gera um relatório detalhado de consumo de tokens e modelos utilizados em todas as etapas do projeto DARE, incluindo análise de custos e recomendações de otimização.
@@ -0,0 +1,28 @@
1
+ # Comando: /dare-update
2
+
3
+ Sincroniza os artefatos do projeto (comandos de IDE, skills, templates) com a versão instalada do DARE CLI, preservando customizações.
4
+
5
+ > Este comando expõe o CLI `dare update` na IDE. O agente pode **rodar o comando no terminal** e interpretar a saída.
6
+
7
+ ## Quando usar
8
+
9
+ - Depois de atualizar o `@dewtech/dare-cli` para uma versão nova.
10
+ - Quando `dare info` apontar artefatos desatualizados.
11
+
12
+ ## Como rodar
13
+
14
+ ```bash
15
+ dare update --dry-run # mostra o que mudaria, sem escrever
16
+ dare update -y # aplica tudo, mantém customizações
17
+ dare update --target 3.2.0
18
+ ```
19
+
20
+ ## O que fazer
21
+
22
+ 1. Rode `dare update --dry-run` e revise o diff proposto.
23
+ 2. Se estiver ok, rode `dare update -y`.
24
+ 3. Evite `--force` salvo se o usuário aceitar sobrescrever arquivos customizados.
25
+
26
+ ## Comandos relacionados
27
+
28
+ `/dare-info` · `/dare-welcome`
@@ -0,0 +1,28 @@
1
+ # Comando: /dare-validate
2
+
3
+ Valida `DARE/dare-dag.yaml` (ciclos, referências quebradas, campos obrigatórios). Adequado para pre-commit hooks e CI.
4
+
5
+ > Este comando expõe o CLI `dare validate` na IDE. O agente pode **rodar o comando no terminal** e interpretar a saída.
6
+
7
+ ## Quando usar
8
+
9
+ - Antes de commitar mudanças no DAG.
10
+ - Em CI, como gate de integridade do plano de execução.
11
+
12
+ ## Como rodar
13
+
14
+ ```bash
15
+ dare validate
16
+ dare validate --strict # trata warnings como erros (CI-friendly)
17
+ dare validate --dag DARE/dare-dag.yaml
18
+ ```
19
+
20
+ ## O que fazer
21
+
22
+ 1. Rode `dare validate` (use `--strict` em CI).
23
+ 2. Se houver erros, corrija o `dare-dag.yaml` apontado e rode de novo até passar.
24
+ 3. Saída limpa = DAG íntegro e pronto para `/dare-execute`.
25
+
26
+ ## Comandos relacionados
27
+
28
+ `/dare-dag` · `/dare-execute`
@@ -0,0 +1,25 @@
1
+ # Comando: /dare-welcome
2
+
3
+ Mostra o banner do DARE e um guia de início rápido com o fluxo Design → Architecture → Review → Execute.
4
+
5
+ > Este comando expõe o CLI `dare welcome` na IDE. O agente pode **rodar o comando no terminal** e interpretar a saída.
6
+
7
+ ## Quando usar
8
+
9
+ - Primeiro contato com o DARE neste projeto.
10
+ - O usuário quer relembrar o fluxo canônico de comandos.
11
+
12
+ ## Como rodar
13
+
14
+ ```bash
15
+ dare welcome
16
+ ```
17
+
18
+ ## O que fazer
19
+
20
+ 1. Rode `dare welcome`.
21
+ 2. Apresente o fluxo: `/dare-design` → `/dare-blueprint` → `/dare-tasks` → `/dare-execute`.
22
+
23
+ ## Comandos relacionados
24
+
25
+ `/dare-design` · `/dare-info`