ridgeline 0.4.4 → 0.5.7

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 (323) hide show
  1. package/README.md +1 -14
  2. package/dist/agents/core/builder.md +15 -15
  3. package/dist/agents/core/planner.md +12 -12
  4. package/dist/agents/core/reviewer.md +19 -19
  5. package/dist/agents/core/shaper.md +44 -45
  6. package/dist/agents/core/specifier.md +20 -23
  7. package/dist/agents/planners/context.md +10 -10
  8. package/dist/agents/planners/simplicity.md +1 -1
  9. package/dist/agents/planners/thoroughness.md +2 -2
  10. package/dist/agents/planners/velocity.md +2 -2
  11. package/dist/agents/specialists/auditor.md +34 -33
  12. package/dist/agents/specialists/explorer.md +74 -0
  13. package/dist/agents/specialists/tester.md +24 -24
  14. package/dist/agents/specialists/verifier.md +17 -20
  15. package/dist/agents/specifiers/clarity.md +1 -1
  16. package/dist/agents/specifiers/completeness.md +2 -2
  17. package/dist/agents/specifiers/pragmatism.md +2 -2
  18. package/dist/cli.js +15 -10
  19. package/dist/cli.js.map +1 -1
  20. package/dist/commands/build.js +42 -75
  21. package/dist/commands/build.js.map +1 -1
  22. package/dist/commands/clean.d.ts +1 -1
  23. package/dist/commands/clean.js +2 -5
  24. package/dist/commands/clean.js.map +1 -1
  25. package/dist/commands/create.d.ts +1 -0
  26. package/dist/commands/create.js +5 -1
  27. package/dist/commands/create.js.map +1 -1
  28. package/dist/commands/dry-run.js +1 -1
  29. package/dist/commands/dry-run.js.map +1 -1
  30. package/dist/commands/plan.js +3 -3
  31. package/dist/commands/plan.js.map +1 -1
  32. package/dist/commands/rewind.js +1 -6
  33. package/dist/commands/rewind.js.map +1 -1
  34. package/dist/commands/shape.d.ts +1 -0
  35. package/dist/commands/shape.js +9 -7
  36. package/dist/commands/shape.js.map +1 -1
  37. package/dist/commands/spec.d.ts +1 -0
  38. package/dist/commands/spec.js +2 -1
  39. package/dist/commands/spec.js.map +1 -1
  40. package/dist/config.js +3 -3
  41. package/dist/config.js.map +1 -1
  42. package/dist/engine/claude/claude.exec.js +2 -2
  43. package/dist/engine/claude/stream.display.d.ts +17 -0
  44. package/dist/engine/claude/stream.display.js +101 -0
  45. package/dist/engine/claude/stream.display.js.map +1 -0
  46. package/dist/engine/claude/stream.parse.d.ts +21 -0
  47. package/dist/engine/claude/stream.parse.js +119 -0
  48. package/dist/engine/claude/stream.parse.js.map +1 -0
  49. package/dist/engine/claude/stream.result.d.ts +6 -0
  50. package/dist/engine/claude/stream.result.js +61 -0
  51. package/dist/engine/claude/stream.result.js.map +1 -0
  52. package/dist/engine/discovery/agent.registry.d.ts +27 -0
  53. package/dist/engine/discovery/agent.registry.js +152 -0
  54. package/dist/engine/discovery/agent.registry.js.map +1 -0
  55. package/dist/engine/discovery/agent.scan.d.ts +0 -1
  56. package/dist/engine/discovery/agent.scan.js +1 -20
  57. package/dist/engine/discovery/agent.scan.js.map +1 -1
  58. package/dist/engine/discovery/flavour.resolve.d.ts +11 -0
  59. package/dist/engine/discovery/flavour.resolve.js +98 -0
  60. package/dist/engine/discovery/flavour.resolve.js.map +1 -0
  61. package/dist/engine/index.d.ts +6 -3
  62. package/dist/engine/index.js +12 -9
  63. package/dist/engine/index.js.map +1 -1
  64. package/dist/engine/pipeline/build.exec.js +7 -5
  65. package/dist/engine/pipeline/build.exec.js.map +1 -1
  66. package/dist/engine/pipeline/ensemble.exec.d.ts +3 -4
  67. package/dist/engine/pipeline/ensemble.exec.js +12 -104
  68. package/dist/engine/pipeline/ensemble.exec.js.map +1 -1
  69. package/dist/engine/pipeline/phase.sequence.js +69 -67
  70. package/dist/engine/pipeline/phase.sequence.js.map +1 -1
  71. package/dist/engine/pipeline/pipeline.shared.js +5 -4
  72. package/dist/engine/pipeline/pipeline.shared.js.map +1 -1
  73. package/dist/engine/pipeline/review.exec.js +9 -7
  74. package/dist/engine/pipeline/review.exec.js.map +1 -1
  75. package/dist/engine/pipeline/specify.exec.d.ts +1 -0
  76. package/dist/engine/pipeline/specify.exec.js +5 -3
  77. package/dist/engine/pipeline/specify.exec.js.map +1 -1
  78. package/dist/engine/worktree.d.ts +0 -8
  79. package/dist/engine/worktree.js +2 -163
  80. package/dist/engine/worktree.js.map +1 -1
  81. package/dist/flavours/data-analysis/core/builder.md +119 -0
  82. package/dist/flavours/data-analysis/core/planner.md +102 -0
  83. package/dist/flavours/data-analysis/core/reviewer.md +148 -0
  84. package/dist/flavours/data-analysis/core/shaper.md +139 -0
  85. package/dist/flavours/data-analysis/core/specifier.md +74 -0
  86. package/dist/flavours/data-analysis/planners/context.md +50 -0
  87. package/dist/flavours/data-analysis/planners/simplicity.md +7 -0
  88. package/dist/flavours/data-analysis/planners/thoroughness.md +7 -0
  89. package/dist/flavours/data-analysis/planners/velocity.md +7 -0
  90. package/dist/flavours/data-analysis/specialists/auditor.md +94 -0
  91. package/dist/flavours/data-analysis/specialists/explorer.md +93 -0
  92. package/dist/flavours/data-analysis/specialists/tester.md +107 -0
  93. package/dist/flavours/data-analysis/specialists/verifier.md +103 -0
  94. package/dist/flavours/data-analysis/specifiers/clarity.md +7 -0
  95. package/dist/flavours/data-analysis/specifiers/completeness.md +15 -0
  96. package/dist/flavours/data-analysis/specifiers/pragmatism.md +7 -0
  97. package/dist/flavours/game-dev/core/builder.md +104 -0
  98. package/dist/flavours/game-dev/core/planner.md +90 -0
  99. package/dist/flavours/game-dev/core/reviewer.md +151 -0
  100. package/dist/flavours/game-dev/core/shaper.md +139 -0
  101. package/dist/flavours/game-dev/core/specifier.md +73 -0
  102. package/dist/flavours/game-dev/planners/context.md +50 -0
  103. package/dist/flavours/game-dev/planners/simplicity.md +7 -0
  104. package/dist/flavours/game-dev/planners/thoroughness.md +7 -0
  105. package/dist/flavours/game-dev/planners/velocity.md +7 -0
  106. package/dist/flavours/game-dev/specialists/auditor.md +91 -0
  107. package/dist/flavours/game-dev/specialists/explorer.md +78 -0
  108. package/dist/flavours/game-dev/specialists/tester.md +73 -0
  109. package/dist/flavours/game-dev/specialists/verifier.md +104 -0
  110. package/dist/flavours/game-dev/specifiers/clarity.md +7 -0
  111. package/dist/flavours/game-dev/specifiers/completeness.md +7 -0
  112. package/dist/flavours/game-dev/specifiers/pragmatism.md +7 -0
  113. package/dist/flavours/legal-drafting/core/builder.md +118 -0
  114. package/dist/flavours/legal-drafting/core/planner.md +92 -0
  115. package/dist/flavours/legal-drafting/core/reviewer.md +150 -0
  116. package/dist/flavours/legal-drafting/core/shaper.md +137 -0
  117. package/dist/flavours/legal-drafting/core/specifier.md +68 -0
  118. package/dist/flavours/legal-drafting/planners/context.md +48 -0
  119. package/dist/flavours/legal-drafting/planners/simplicity.md +7 -0
  120. package/dist/flavours/legal-drafting/planners/thoroughness.md +7 -0
  121. package/dist/flavours/legal-drafting/planners/velocity.md +7 -0
  122. package/dist/flavours/legal-drafting/specialists/auditor.md +92 -0
  123. package/dist/flavours/legal-drafting/specialists/explorer.md +78 -0
  124. package/dist/flavours/legal-drafting/specialists/tester.md +76 -0
  125. package/dist/flavours/legal-drafting/specialists/verifier.md +111 -0
  126. package/dist/flavours/legal-drafting/specifiers/clarity.md +7 -0
  127. package/dist/flavours/legal-drafting/specifiers/completeness.md +7 -0
  128. package/dist/flavours/legal-drafting/specifiers/pragmatism.md +7 -0
  129. package/dist/flavours/machine-learning/core/builder.md +127 -0
  130. package/dist/flavours/machine-learning/core/planner.md +90 -0
  131. package/dist/flavours/machine-learning/core/reviewer.md +152 -0
  132. package/dist/flavours/machine-learning/core/shaper.md +141 -0
  133. package/dist/flavours/machine-learning/core/specifier.md +71 -0
  134. package/dist/flavours/machine-learning/planners/context.md +49 -0
  135. package/dist/flavours/machine-learning/planners/simplicity.md +7 -0
  136. package/dist/flavours/machine-learning/planners/thoroughness.md +7 -0
  137. package/dist/flavours/machine-learning/planners/velocity.md +7 -0
  138. package/dist/flavours/machine-learning/specialists/auditor.md +96 -0
  139. package/dist/flavours/machine-learning/specialists/explorer.md +81 -0
  140. package/dist/flavours/machine-learning/specialists/tester.md +82 -0
  141. package/dist/flavours/machine-learning/specialists/verifier.md +100 -0
  142. package/dist/flavours/machine-learning/specifiers/clarity.md +7 -0
  143. package/dist/flavours/machine-learning/specifiers/completeness.md +7 -0
  144. package/dist/flavours/machine-learning/specifiers/pragmatism.md +7 -0
  145. package/dist/flavours/mobile-app/core/builder.md +108 -0
  146. package/dist/flavours/mobile-app/core/planner.md +90 -0
  147. package/dist/flavours/mobile-app/core/reviewer.md +144 -0
  148. package/dist/flavours/mobile-app/core/shaper.md +146 -0
  149. package/dist/flavours/mobile-app/core/specifier.md +73 -0
  150. package/dist/flavours/mobile-app/planners/context.md +41 -0
  151. package/dist/flavours/mobile-app/planners/simplicity.md +7 -0
  152. package/dist/flavours/mobile-app/planners/thoroughness.md +7 -0
  153. package/dist/flavours/mobile-app/planners/velocity.md +7 -0
  154. package/dist/flavours/mobile-app/specialists/auditor.md +92 -0
  155. package/dist/flavours/mobile-app/specialists/explorer.md +84 -0
  156. package/dist/flavours/mobile-app/specialists/tester.md +75 -0
  157. package/dist/flavours/mobile-app/specialists/verifier.md +114 -0
  158. package/dist/flavours/mobile-app/specifiers/clarity.md +7 -0
  159. package/dist/flavours/mobile-app/specifiers/completeness.md +7 -0
  160. package/dist/flavours/mobile-app/specifiers/pragmatism.md +7 -0
  161. package/dist/flavours/music-composition/core/builder.md +112 -0
  162. package/dist/flavours/music-composition/core/planner.md +102 -0
  163. package/dist/flavours/music-composition/core/reviewer.md +139 -0
  164. package/dist/flavours/music-composition/core/shaper.md +139 -0
  165. package/dist/flavours/music-composition/core/specifier.md +72 -0
  166. package/dist/flavours/music-composition/planners/context.md +39 -0
  167. package/dist/flavours/music-composition/planners/simplicity.md +7 -0
  168. package/dist/flavours/music-composition/planners/thoroughness.md +7 -0
  169. package/dist/flavours/music-composition/planners/velocity.md +7 -0
  170. package/dist/flavours/music-composition/specialists/auditor.md +90 -0
  171. package/dist/flavours/music-composition/specialists/explorer.md +87 -0
  172. package/dist/flavours/music-composition/specialists/tester.md +74 -0
  173. package/dist/flavours/music-composition/specialists/verifier.md +89 -0
  174. package/dist/flavours/music-composition/specifiers/clarity.md +7 -0
  175. package/dist/flavours/music-composition/specifiers/completeness.md +7 -0
  176. package/dist/flavours/music-composition/specifiers/pragmatism.md +7 -0
  177. package/dist/flavours/novel-writing/core/builder.md +116 -0
  178. package/dist/flavours/novel-writing/core/planner.md +92 -0
  179. package/dist/flavours/novel-writing/core/reviewer.md +152 -0
  180. package/dist/flavours/novel-writing/core/shaper.md +143 -0
  181. package/dist/flavours/novel-writing/core/specifier.md +76 -0
  182. package/dist/flavours/novel-writing/planners/context.md +39 -0
  183. package/dist/flavours/novel-writing/planners/simplicity.md +7 -0
  184. package/dist/flavours/novel-writing/planners/thoroughness.md +7 -0
  185. package/dist/flavours/novel-writing/planners/velocity.md +7 -0
  186. package/dist/flavours/novel-writing/specialists/auditor.md +87 -0
  187. package/dist/flavours/novel-writing/specialists/explorer.md +83 -0
  188. package/dist/flavours/novel-writing/specialists/tester.md +89 -0
  189. package/dist/flavours/novel-writing/specialists/verifier.md +122 -0
  190. package/dist/flavours/novel-writing/specifiers/clarity.md +7 -0
  191. package/dist/flavours/novel-writing/specifiers/completeness.md +7 -0
  192. package/dist/flavours/novel-writing/specifiers/pragmatism.md +7 -0
  193. package/dist/flavours/screenwriting/core/builder.md +115 -0
  194. package/dist/flavours/screenwriting/core/planner.md +92 -0
  195. package/dist/flavours/screenwriting/core/reviewer.md +151 -0
  196. package/dist/flavours/screenwriting/core/shaper.md +143 -0
  197. package/dist/flavours/screenwriting/core/specifier.md +78 -0
  198. package/dist/flavours/screenwriting/planners/context.md +52 -0
  199. package/dist/flavours/screenwriting/planners/simplicity.md +7 -0
  200. package/dist/flavours/screenwriting/planners/thoroughness.md +7 -0
  201. package/dist/flavours/screenwriting/planners/velocity.md +7 -0
  202. package/dist/flavours/screenwriting/specialists/auditor.md +98 -0
  203. package/dist/flavours/screenwriting/specialists/explorer.md +87 -0
  204. package/dist/flavours/screenwriting/specialists/tester.md +90 -0
  205. package/dist/flavours/screenwriting/specialists/verifier.md +129 -0
  206. package/dist/flavours/screenwriting/specifiers/clarity.md +7 -0
  207. package/dist/flavours/screenwriting/specifiers/completeness.md +7 -0
  208. package/dist/flavours/screenwriting/specifiers/pragmatism.md +7 -0
  209. package/dist/flavours/security-audit/core/builder.md +123 -0
  210. package/dist/flavours/security-audit/core/planner.md +92 -0
  211. package/dist/flavours/security-audit/core/reviewer.md +150 -0
  212. package/dist/flavours/security-audit/core/shaper.md +145 -0
  213. package/dist/flavours/security-audit/core/specifier.md +69 -0
  214. package/dist/flavours/security-audit/planners/context.md +51 -0
  215. package/dist/flavours/security-audit/planners/simplicity.md +7 -0
  216. package/dist/flavours/security-audit/planners/thoroughness.md +7 -0
  217. package/dist/flavours/security-audit/planners/velocity.md +7 -0
  218. package/dist/flavours/security-audit/specialists/auditor.md +100 -0
  219. package/dist/flavours/security-audit/specialists/explorer.md +84 -0
  220. package/dist/flavours/security-audit/specialists/tester.md +80 -0
  221. package/dist/flavours/security-audit/specialists/verifier.md +101 -0
  222. package/dist/flavours/security-audit/specifiers/clarity.md +7 -0
  223. package/dist/flavours/security-audit/specifiers/completeness.md +7 -0
  224. package/dist/flavours/security-audit/specifiers/pragmatism.md +7 -0
  225. package/dist/flavours/software-engineering/core/builder.md +100 -0
  226. package/dist/flavours/software-engineering/core/planner.md +90 -0
  227. package/dist/flavours/software-engineering/core/reviewer.md +137 -0
  228. package/dist/flavours/software-engineering/core/shaper.md +137 -0
  229. package/dist/flavours/software-engineering/core/specifier.md +69 -0
  230. package/dist/flavours/software-engineering/planners/context.md +37 -0
  231. package/dist/flavours/software-engineering/planners/simplicity.md +7 -0
  232. package/dist/flavours/software-engineering/planners/thoroughness.md +7 -0
  233. package/dist/flavours/software-engineering/planners/velocity.md +7 -0
  234. package/dist/flavours/software-engineering/specialists/auditor.md +88 -0
  235. package/dist/{agents/specialists/scout.md → flavours/software-engineering/specialists/explorer.md} +2 -2
  236. package/dist/flavours/software-engineering/specialists/tester.md +72 -0
  237. package/dist/flavours/software-engineering/specialists/verifier.md +89 -0
  238. package/dist/flavours/software-engineering/specifiers/clarity.md +7 -0
  239. package/dist/flavours/software-engineering/specifiers/completeness.md +7 -0
  240. package/dist/flavours/software-engineering/specifiers/pragmatism.md +7 -0
  241. package/dist/flavours/technical-writing/core/builder.md +119 -0
  242. package/dist/flavours/technical-writing/core/planner.md +102 -0
  243. package/dist/flavours/technical-writing/core/reviewer.md +138 -0
  244. package/dist/flavours/technical-writing/core/shaper.md +137 -0
  245. package/dist/flavours/technical-writing/core/specifier.md +69 -0
  246. package/dist/flavours/technical-writing/planners/context.md +49 -0
  247. package/dist/flavours/technical-writing/planners/simplicity.md +7 -0
  248. package/dist/flavours/technical-writing/planners/thoroughness.md +7 -0
  249. package/dist/flavours/technical-writing/planners/velocity.md +7 -0
  250. package/dist/flavours/technical-writing/specialists/auditor.md +94 -0
  251. package/dist/flavours/technical-writing/specialists/explorer.md +85 -0
  252. package/dist/flavours/technical-writing/specialists/tester.md +93 -0
  253. package/dist/flavours/technical-writing/specialists/verifier.md +113 -0
  254. package/dist/flavours/technical-writing/specifiers/clarity.md +7 -0
  255. package/dist/flavours/technical-writing/specifiers/completeness.md +7 -0
  256. package/dist/flavours/technical-writing/specifiers/pragmatism.md +7 -0
  257. package/dist/flavours/test-suite/core/builder.md +114 -0
  258. package/dist/flavours/test-suite/core/planner.md +101 -0
  259. package/dist/flavours/test-suite/core/reviewer.md +161 -0
  260. package/dist/flavours/test-suite/core/shaper.md +144 -0
  261. package/dist/flavours/test-suite/core/specifier.md +71 -0
  262. package/dist/flavours/test-suite/planners/context.md +52 -0
  263. package/dist/flavours/test-suite/planners/simplicity.md +7 -0
  264. package/dist/flavours/test-suite/planners/thoroughness.md +7 -0
  265. package/dist/flavours/test-suite/planners/velocity.md +7 -0
  266. package/dist/flavours/test-suite/specialists/auditor.md +85 -0
  267. package/dist/flavours/test-suite/specialists/explorer.md +88 -0
  268. package/dist/flavours/test-suite/specialists/tester.md +88 -0
  269. package/dist/flavours/test-suite/specialists/verifier.md +100 -0
  270. package/dist/flavours/test-suite/specifiers/clarity.md +7 -0
  271. package/dist/flavours/test-suite/specifiers/completeness.md +7 -0
  272. package/dist/flavours/test-suite/specifiers/pragmatism.md +7 -0
  273. package/dist/flavours/translation/core/builder.md +120 -0
  274. package/dist/flavours/translation/core/planner.md +90 -0
  275. package/dist/flavours/translation/core/reviewer.md +151 -0
  276. package/dist/flavours/translation/core/shaper.md +137 -0
  277. package/dist/flavours/translation/core/specifier.md +71 -0
  278. package/dist/flavours/translation/planners/context.md +53 -0
  279. package/dist/flavours/translation/planners/simplicity.md +7 -0
  280. package/dist/flavours/translation/planners/thoroughness.md +7 -0
  281. package/dist/flavours/translation/planners/velocity.md +7 -0
  282. package/dist/flavours/translation/specialists/auditor.md +109 -0
  283. package/dist/flavours/translation/specialists/explorer.md +98 -0
  284. package/dist/flavours/translation/specialists/tester.md +82 -0
  285. package/dist/flavours/translation/specialists/verifier.md +121 -0
  286. package/dist/flavours/translation/specifiers/clarity.md +7 -0
  287. package/dist/flavours/translation/specifiers/completeness.md +7 -0
  288. package/dist/flavours/translation/specifiers/pragmatism.md +7 -0
  289. package/dist/stores/budget.d.ts +5 -0
  290. package/dist/stores/budget.js +74 -0
  291. package/dist/stores/budget.js.map +1 -0
  292. package/dist/stores/feedback.io.d.ts +6 -0
  293. package/dist/stores/feedback.io.js +64 -0
  294. package/dist/stores/feedback.io.js.map +1 -0
  295. package/dist/stores/feedback.verdict.d.ts +4 -0
  296. package/dist/stores/feedback.verdict.js +179 -0
  297. package/dist/stores/feedback.verdict.js.map +1 -0
  298. package/dist/stores/handoff.d.ts +2 -0
  299. package/dist/stores/handoff.js +54 -0
  300. package/dist/stores/handoff.js.map +1 -0
  301. package/dist/stores/index.d.ts +9 -0
  302. package/dist/stores/index.js +49 -0
  303. package/dist/stores/index.js.map +1 -0
  304. package/dist/stores/inputs.d.ts +2 -0
  305. package/dist/stores/inputs.js +64 -0
  306. package/dist/stores/inputs.js.map +1 -0
  307. package/dist/stores/phases.d.ts +15 -0
  308. package/dist/stores/phases.js +81 -0
  309. package/dist/stores/phases.js.map +1 -0
  310. package/dist/stores/settings.d.ts +12 -0
  311. package/dist/stores/settings.js +85 -0
  312. package/dist/stores/settings.js.map +1 -0
  313. package/dist/stores/state.d.ts +20 -0
  314. package/dist/stores/state.js +264 -0
  315. package/dist/stores/state.js.map +1 -0
  316. package/dist/stores/tags.d.ts +6 -0
  317. package/dist/stores/tags.js +34 -0
  318. package/dist/stores/tags.js.map +1 -0
  319. package/dist/stores/trajectory.d.ts +11 -0
  320. package/dist/stores/trajectory.js +66 -0
  321. package/dist/stores/trajectory.js.map +1 -0
  322. package/dist/types.d.ts +1 -2
  323. package/package.json +2 -2
@@ -0,0 +1,179 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.generateFeedback = exports.formatIssue = exports.parseVerdict = void 0;
4
+ // Normalize an issue entry — accept both string and object forms
5
+ const normalizeIssue = (item, severity) => {
6
+ if (typeof item === "string") {
7
+ return { description: item, severity };
8
+ }
9
+ if (typeof item === "object" && item !== null) {
10
+ const obj = item;
11
+ return {
12
+ criterion: typeof obj.criterion === "number" ? obj.criterion : undefined,
13
+ description: typeof obj.description === "string" ? obj.description : String(obj.description ?? ""),
14
+ file: typeof obj.file === "string" ? obj.file : undefined,
15
+ severity,
16
+ requiredState: typeof obj.requiredState === "string" ? obj.requiredState : undefined,
17
+ };
18
+ }
19
+ return { description: String(item), severity };
20
+ };
21
+ // Try to parse a raw object as a ReviewVerdict
22
+ const tryParseVerdict = (raw) => {
23
+ if (typeof raw !== "object" || raw === null)
24
+ return null;
25
+ const obj = raw;
26
+ if (typeof obj.passed !== "boolean")
27
+ return null;
28
+ return {
29
+ passed: obj.passed,
30
+ summary: typeof obj.summary === "string" ? obj.summary : "",
31
+ criteriaResults: Array.isArray(obj.criteriaResults)
32
+ ? obj.criteriaResults.map((cr) => ({
33
+ criterion: typeof cr.criterion === "number" ? cr.criterion : 0,
34
+ passed: typeof cr.passed === "boolean" ? cr.passed : false,
35
+ notes: typeof cr.notes === "string" ? cr.notes : "",
36
+ }))
37
+ : [],
38
+ issues: Array.isArray(obj.issues)
39
+ ? obj.issues.map((i) => normalizeIssue(i, "blocking"))
40
+ : [],
41
+ suggestions: Array.isArray(obj.suggestions)
42
+ ? obj.suggestions.map((s) => normalizeIssue(s, "suggestion"))
43
+ : [],
44
+ };
45
+ };
46
+ // Find the end index of a balanced JSON object starting at position 0 in `text`.
47
+ // Returns the index of the closing brace, or -1 if no balanced pair is found.
48
+ const findBalancedBrace = (text) => {
49
+ let depth = 0;
50
+ let inString = false;
51
+ let escape = false;
52
+ for (let j = 0; j < text.length; j++) {
53
+ const ch = text[j];
54
+ if (escape) {
55
+ escape = false;
56
+ continue;
57
+ }
58
+ if (ch === "\\") {
59
+ escape = true;
60
+ continue;
61
+ }
62
+ if (ch === '"') {
63
+ inString = !inString;
64
+ continue;
65
+ }
66
+ if (inString)
67
+ continue;
68
+ if (ch === "{")
69
+ depth++;
70
+ if (ch === "}") {
71
+ depth--;
72
+ if (depth === 0)
73
+ return j;
74
+ }
75
+ }
76
+ return -1;
77
+ };
78
+ // Try to parse a JSON object starting at `text` as a ReviewVerdict.
79
+ // First tries the full slice, then tries balanced brace extraction.
80
+ const tryExtractVerdictAt = (text) => {
81
+ try {
82
+ return tryParseVerdict(JSON.parse(text));
83
+ }
84
+ catch {
85
+ const end = findBalancedBrace(text);
86
+ if (end === -1)
87
+ return null;
88
+ try {
89
+ return tryParseVerdict(JSON.parse(text.slice(0, end + 1)));
90
+ }
91
+ catch {
92
+ return null;
93
+ }
94
+ }
95
+ };
96
+ const UNPARSEABLE_VERDICT = {
97
+ passed: false,
98
+ summary: "Could not parse reviewer verdict from output",
99
+ criteriaResults: [],
100
+ issues: [{ description: "Reviewer output did not contain a valid JSON verdict", severity: "blocking" }],
101
+ suggestions: [],
102
+ };
103
+ // Extract the JSON verdict block from reviewer's text output
104
+ const parseVerdict = (text) => {
105
+ // Try extracting from fenced code block first
106
+ const fencedMatch = text.match(/```(?:json)?\s*\n?([\s\S]*?)\n?```/);
107
+ if (fencedMatch) {
108
+ const result = tryExtractVerdictAt(fencedMatch[1]);
109
+ if (result)
110
+ return result;
111
+ }
112
+ // Scan every { and try to parse a verdict from that position
113
+ for (let i = text.indexOf("{"); i !== -1; i = text.indexOf("{", i + 1)) {
114
+ const result = tryExtractVerdictAt(text.slice(i));
115
+ if (result)
116
+ return result;
117
+ }
118
+ return UNPARSEABLE_VERDICT;
119
+ };
120
+ exports.parseVerdict = parseVerdict;
121
+ // Format a ReviewIssue for display
122
+ const formatIssue = (issue) => {
123
+ const parts = [];
124
+ if (issue.file)
125
+ parts.push(issue.file);
126
+ parts.push(issue.description);
127
+ return parts.join(": ");
128
+ };
129
+ exports.formatIssue = formatIssue;
130
+ // Generate feedback markdown from a structured verdict
131
+ const generateFeedback = (phaseId, verdict) => {
132
+ const lines = [];
133
+ lines.push(`# Reviewer Feedback: Phase ${phaseId}`);
134
+ lines.push("");
135
+ // Failed criteria
136
+ const failed = verdict.criteriaResults.filter((cr) => !cr.passed);
137
+ if (failed.length > 0) {
138
+ lines.push("## Failed Criteria");
139
+ lines.push("");
140
+ for (const cr of failed) {
141
+ lines.push(`### Criterion ${cr.criterion}`);
142
+ lines.push(`**Status:** FAIL`);
143
+ lines.push(`**Evidence:** ${cr.notes}`);
144
+ // Find matching issue with requiredState
145
+ const matchingIssue = verdict.issues.find((i) => i.criterion === cr.criterion);
146
+ if (matchingIssue?.requiredState) {
147
+ lines.push(`**Required state:** ${matchingIssue.requiredState}`);
148
+ }
149
+ lines.push("");
150
+ }
151
+ }
152
+ // Blocking issues
153
+ const blocking = verdict.issues.filter((i) => i.severity === "blocking");
154
+ if (blocking.length > 0) {
155
+ lines.push("## Issues");
156
+ lines.push("");
157
+ for (const issue of blocking) {
158
+ const filePart = issue.file ? ` (${issue.file})` : "";
159
+ lines.push(`- ${issue.description}${filePart}`);
160
+ if (issue.requiredState) {
161
+ lines.push(` - **Required:** ${issue.requiredState}`);
162
+ }
163
+ }
164
+ lines.push("");
165
+ }
166
+ // What passed
167
+ const passed = verdict.criteriaResults.filter((cr) => cr.passed);
168
+ if (passed.length > 0) {
169
+ lines.push("## What Passed");
170
+ lines.push("");
171
+ for (const cr of passed) {
172
+ lines.push(`- Criterion ${cr.criterion}: ${cr.notes}`);
173
+ }
174
+ lines.push("");
175
+ }
176
+ return lines.join("\n");
177
+ };
178
+ exports.generateFeedback = generateFeedback;
179
+ //# sourceMappingURL=feedback.verdict.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"feedback.verdict.js","sourceRoot":"","sources":["../../src/stores/feedback.verdict.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare const readHandoff: (buildDir: string) => string;
2
+ export declare const ensureHandoffExists: (buildDir: string) => void;
@@ -0,0 +1,54 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.ensureHandoffExists = exports.readHandoff = void 0;
37
+ const fs = __importStar(require("node:fs"));
38
+ const path = __importStar(require("node:path"));
39
+ const readHandoff = (buildDir) => {
40
+ const fp = path.join(buildDir, "handoff.md");
41
+ if (fs.existsSync(fp)) {
42
+ return fs.readFileSync(fp, "utf-8");
43
+ }
44
+ return "";
45
+ };
46
+ exports.readHandoff = readHandoff;
47
+ const ensureHandoffExists = (buildDir) => {
48
+ const fp = path.join(buildDir, "handoff.md");
49
+ if (!fs.existsSync(fp)) {
50
+ fs.writeFileSync(fp, "");
51
+ }
52
+ };
53
+ exports.ensureHandoffExists = ensureHandoffExists;
54
+ //# sourceMappingURL=handoff.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"handoff.js","sourceRoot":"","sources":["../../src/stores/handoff.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,4CAA6B;AAC7B,gDAAiC;AAE1B,MAAM,WAAW,GAAG,CAAC,QAAgB,EAAU,EAAE;IACtD,MAAM,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAA;IAC5C,IAAI,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,EAAE,CAAC;QACtB,OAAO,EAAE,CAAC,YAAY,CAAC,EAAE,EAAE,OAAO,CAAC,CAAA;IACrC,CAAC;IACD,OAAO,EAAE,CAAA;AACX,CAAC,CAAA;AANY,QAAA,WAAW,eAMvB;AAEM,MAAM,mBAAmB,GAAG,CAAC,QAAgB,EAAQ,EAAE;IAC5D,MAAM,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAA;IAC5C,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,EAAE,CAAC;QACvB,EAAE,CAAC,aAAa,CAAC,EAAE,EAAE,EAAE,CAAC,CAAA;IAC1B,CAAC;AACH,CAAC,CAAA;AALY,QAAA,mBAAmB,uBAK/B"}
@@ -0,0 +1,9 @@
1
+ export { loadBudget, saveBudget, recordCost, getTotalCost } from './budget';
2
+ export { parseVerdict, formatIssue, generateFeedback, } from './feedback.verdict';
3
+ export { feedbackPath, archiveFeedbackPath, readFeedback, writeFeedback, archiveFeedback, } from './feedback.io';
4
+ export { readHandoff, ensureHandoffExists } from './handoff';
5
+ export { resolveFile, parseCheckCommand } from './inputs';
6
+ export { PHASE_FILENAME_PATTERN, isPhaseFile, parsePhaseFilename, parsePhaseContent, scanPhases, } from './phases';
7
+ export { loadState, saveState, initState, updatePhaseStatus, resetRetries, getNextIncompletePhase, } from './state';
8
+ export { checkpointTagName, completionTagName, createCheckpoint, createCompletionTag, verifyCompletionTag, cleanupBuildTags, } from './tags';
9
+ export { logTrajectory, makeTrajectoryEntry, readTrajectory } from './trajectory';
@@ -0,0 +1,49 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.readTrajectory = exports.makeTrajectoryEntry = exports.logTrajectory = exports.cleanupBuildTags = exports.verifyCompletionTag = exports.createCompletionTag = exports.createCheckpoint = exports.completionTagName = exports.checkpointTagName = exports.getNextIncompletePhase = exports.resetRetries = exports.updatePhaseStatus = exports.initState = exports.saveState = exports.loadState = exports.scanPhases = exports.parsePhaseContent = exports.parsePhaseFilename = exports.isPhaseFile = exports.PHASE_FILENAME_PATTERN = exports.parseCheckCommand = exports.resolveFile = exports.ensureHandoffExists = exports.readHandoff = exports.archiveFeedback = exports.writeFeedback = exports.readFeedback = exports.archiveFeedbackPath = exports.feedbackPath = exports.generateFeedback = exports.formatIssue = exports.parseVerdict = exports.getTotalCost = exports.recordCost = exports.saveBudget = exports.loadBudget = void 0;
4
+ var budget_1 = require("./budget");
5
+ Object.defineProperty(exports, "loadBudget", { enumerable: true, get: function () { return budget_1.loadBudget; } });
6
+ Object.defineProperty(exports, "saveBudget", { enumerable: true, get: function () { return budget_1.saveBudget; } });
7
+ Object.defineProperty(exports, "recordCost", { enumerable: true, get: function () { return budget_1.recordCost; } });
8
+ Object.defineProperty(exports, "getTotalCost", { enumerable: true, get: function () { return budget_1.getTotalCost; } });
9
+ var feedback_verdict_1 = require("./feedback.verdict");
10
+ Object.defineProperty(exports, "parseVerdict", { enumerable: true, get: function () { return feedback_verdict_1.parseVerdict; } });
11
+ Object.defineProperty(exports, "formatIssue", { enumerable: true, get: function () { return feedback_verdict_1.formatIssue; } });
12
+ Object.defineProperty(exports, "generateFeedback", { enumerable: true, get: function () { return feedback_verdict_1.generateFeedback; } });
13
+ var feedback_io_1 = require("./feedback.io");
14
+ Object.defineProperty(exports, "feedbackPath", { enumerable: true, get: function () { return feedback_io_1.feedbackPath; } });
15
+ Object.defineProperty(exports, "archiveFeedbackPath", { enumerable: true, get: function () { return feedback_io_1.archiveFeedbackPath; } });
16
+ Object.defineProperty(exports, "readFeedback", { enumerable: true, get: function () { return feedback_io_1.readFeedback; } });
17
+ Object.defineProperty(exports, "writeFeedback", { enumerable: true, get: function () { return feedback_io_1.writeFeedback; } });
18
+ Object.defineProperty(exports, "archiveFeedback", { enumerable: true, get: function () { return feedback_io_1.archiveFeedback; } });
19
+ var handoff_1 = require("./handoff");
20
+ Object.defineProperty(exports, "readHandoff", { enumerable: true, get: function () { return handoff_1.readHandoff; } });
21
+ Object.defineProperty(exports, "ensureHandoffExists", { enumerable: true, get: function () { return handoff_1.ensureHandoffExists; } });
22
+ var inputs_1 = require("./inputs");
23
+ Object.defineProperty(exports, "resolveFile", { enumerable: true, get: function () { return inputs_1.resolveFile; } });
24
+ Object.defineProperty(exports, "parseCheckCommand", { enumerable: true, get: function () { return inputs_1.parseCheckCommand; } });
25
+ var phases_1 = require("./phases");
26
+ Object.defineProperty(exports, "PHASE_FILENAME_PATTERN", { enumerable: true, get: function () { return phases_1.PHASE_FILENAME_PATTERN; } });
27
+ Object.defineProperty(exports, "isPhaseFile", { enumerable: true, get: function () { return phases_1.isPhaseFile; } });
28
+ Object.defineProperty(exports, "parsePhaseFilename", { enumerable: true, get: function () { return phases_1.parsePhaseFilename; } });
29
+ Object.defineProperty(exports, "parsePhaseContent", { enumerable: true, get: function () { return phases_1.parsePhaseContent; } });
30
+ Object.defineProperty(exports, "scanPhases", { enumerable: true, get: function () { return phases_1.scanPhases; } });
31
+ var state_1 = require("./state");
32
+ Object.defineProperty(exports, "loadState", { enumerable: true, get: function () { return state_1.loadState; } });
33
+ Object.defineProperty(exports, "saveState", { enumerable: true, get: function () { return state_1.saveState; } });
34
+ Object.defineProperty(exports, "initState", { enumerable: true, get: function () { return state_1.initState; } });
35
+ Object.defineProperty(exports, "updatePhaseStatus", { enumerable: true, get: function () { return state_1.updatePhaseStatus; } });
36
+ Object.defineProperty(exports, "resetRetries", { enumerable: true, get: function () { return state_1.resetRetries; } });
37
+ Object.defineProperty(exports, "getNextIncompletePhase", { enumerable: true, get: function () { return state_1.getNextIncompletePhase; } });
38
+ var tags_1 = require("./tags");
39
+ Object.defineProperty(exports, "checkpointTagName", { enumerable: true, get: function () { return tags_1.checkpointTagName; } });
40
+ Object.defineProperty(exports, "completionTagName", { enumerable: true, get: function () { return tags_1.completionTagName; } });
41
+ Object.defineProperty(exports, "createCheckpoint", { enumerable: true, get: function () { return tags_1.createCheckpoint; } });
42
+ Object.defineProperty(exports, "createCompletionTag", { enumerable: true, get: function () { return tags_1.createCompletionTag; } });
43
+ Object.defineProperty(exports, "verifyCompletionTag", { enumerable: true, get: function () { return tags_1.verifyCompletionTag; } });
44
+ Object.defineProperty(exports, "cleanupBuildTags", { enumerable: true, get: function () { return tags_1.cleanupBuildTags; } });
45
+ var trajectory_1 = require("./trajectory");
46
+ Object.defineProperty(exports, "logTrajectory", { enumerable: true, get: function () { return trajectory_1.logTrajectory; } });
47
+ Object.defineProperty(exports, "makeTrajectoryEntry", { enumerable: true, get: function () { return trajectory_1.makeTrajectoryEntry; } });
48
+ Object.defineProperty(exports, "readTrajectory", { enumerable: true, get: function () { return trajectory_1.readTrajectory; } });
49
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/stores/index.ts"],"names":[],"mappings":";;;AAAA,mCAA2E;AAAlE,oGAAA,UAAU,OAAA;AAAE,oGAAA,UAAU,OAAA;AAAE,oGAAA,UAAU,OAAA;AAAE,sGAAA,YAAY,OAAA;AACzD,uDAI2B;AAHzB,gHAAA,YAAY,OAAA;AACZ,+GAAA,WAAW,OAAA;AACX,oHAAA,gBAAgB,OAAA;AAElB,6CAMsB;AALpB,2GAAA,YAAY,OAAA;AACZ,kHAAA,mBAAmB,OAAA;AACnB,2GAAA,YAAY,OAAA;AACZ,4GAAA,aAAa,OAAA;AACb,8GAAA,eAAe,OAAA;AAEjB,qCAA4D;AAAnD,sGAAA,WAAW,OAAA;AAAE,8GAAA,mBAAmB,OAAA;AACzC,mCAAyD;AAAhD,qGAAA,WAAW,OAAA;AAAE,2GAAA,iBAAiB,OAAA;AACvC,mCAMiB;AALf,gHAAA,sBAAsB,OAAA;AACtB,qGAAA,WAAW,OAAA;AACX,4GAAA,kBAAkB,OAAA;AAClB,2GAAA,iBAAiB,OAAA;AACjB,oGAAA,UAAU,OAAA;AAEZ,iCAOgB;AANd,kGAAA,SAAS,OAAA;AACT,kGAAA,SAAS,OAAA;AACT,kGAAA,SAAS,OAAA;AACT,0GAAA,iBAAiB,OAAA;AACjB,qGAAA,YAAY,OAAA;AACZ,+GAAA,sBAAsB,OAAA;AAExB,+BAOe;AANb,yGAAA,iBAAiB,OAAA;AACjB,yGAAA,iBAAiB,OAAA;AACjB,wGAAA,gBAAgB,OAAA;AAChB,2GAAA,mBAAmB,OAAA;AACnB,2GAAA,mBAAmB,OAAA;AACnB,wGAAA,gBAAgB,OAAA;AAElB,2CAAiF;AAAxE,2GAAA,aAAa,OAAA;AAAE,iHAAA,mBAAmB,OAAA;AAAE,4GAAA,cAAc,OAAA"}
@@ -0,0 +1,2 @@
1
+ export declare const resolveFile: (cliFlag: string | undefined, buildDir: string, filename: string, projectDir: string) => string | null;
2
+ export declare const parseCheckCommand: (constraintsPath: string) => string | null;
@@ -0,0 +1,64 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.parseCheckCommand = exports.resolveFile = void 0;
37
+ const fs = __importStar(require("node:fs"));
38
+ const path = __importStar(require("node:path"));
39
+ // Resolve a file through the fallback chain: CLI flag > build-level > project-level
40
+ const resolveFile = (cliFlag, buildDir, filename, projectDir) => {
41
+ if (cliFlag && fs.existsSync(cliFlag))
42
+ return path.resolve(cliFlag);
43
+ const buildLevel = path.join(buildDir, filename);
44
+ if (fs.existsSync(buildLevel))
45
+ return buildLevel;
46
+ const projectLevel = path.join(projectDir, filename);
47
+ if (fs.existsSync(projectLevel))
48
+ return projectLevel;
49
+ return null;
50
+ };
51
+ exports.resolveFile = resolveFile;
52
+ // Parse the check command from constraints.md
53
+ const parseCheckCommand = (constraintsPath) => {
54
+ try {
55
+ const content = fs.readFileSync(constraintsPath, "utf-8");
56
+ const match = content.match(/## Check Command\s*\n+```[^\n]*\n([\s\S]*?)```/);
57
+ return match ? match[1].trim() : null;
58
+ }
59
+ catch {
60
+ return null;
61
+ }
62
+ };
63
+ exports.parseCheckCommand = parseCheckCommand;
64
+ //# sourceMappingURL=inputs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"inputs.js","sourceRoot":"","sources":["../../src/stores/inputs.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,4CAA6B;AAC7B,gDAAiC;AAEjC,oFAAoF;AAC7E,MAAM,WAAW,GAAG,CACzB,OAA2B,EAC3B,QAAgB,EAChB,QAAgB,EAChB,UAAkB,EACH,EAAE;IACjB,IAAI,OAAO,IAAI,EAAE,CAAC,UAAU,CAAC,OAAO,CAAC;QAAE,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAA;IACnE,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAA;IAChD,IAAI,EAAE,CAAC,UAAU,CAAC,UAAU,CAAC;QAAE,OAAO,UAAU,CAAA;IAChD,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAA;IACpD,IAAI,EAAE,CAAC,UAAU,CAAC,YAAY,CAAC;QAAE,OAAO,YAAY,CAAA;IACpD,OAAO,IAAI,CAAA;AACb,CAAC,CAAA;AAZY,QAAA,WAAW,eAYvB;AAED,8CAA8C;AACvC,MAAM,iBAAiB,GAAG,CAAC,eAAuB,EAAiB,EAAE;IAC1E,IAAI,CAAC;QACH,MAAM,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,eAAe,EAAE,OAAO,CAAC,CAAA;QACzD,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,gDAAgD,CAAC,CAAA;QAC7E,OAAO,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,IAAI,CAAA;IACvC,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAA;IACb,CAAC;AACH,CAAC,CAAA;AARY,QAAA,iBAAiB,qBAQ7B"}
@@ -0,0 +1,15 @@
1
+ import { PhaseInfo } from "../types";
2
+ export declare const PHASE_FILENAME_PATTERN: RegExp;
3
+ export declare const isPhaseFile: (filename: string) => boolean;
4
+ export declare const parsePhaseFilename: (filename: string) => {
5
+ id: string;
6
+ index: number;
7
+ slug: string;
8
+ };
9
+ export type PhaseContent = {
10
+ title: string;
11
+ goal: string;
12
+ criteria: string;
13
+ };
14
+ export declare const parsePhaseContent: (content: string) => PhaseContent;
15
+ export declare const scanPhases: (phasesDir: string) => PhaseInfo[];
@@ -0,0 +1,81 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.scanPhases = exports.parsePhaseContent = exports.parsePhaseFilename = exports.isPhaseFile = exports.PHASE_FILENAME_PATTERN = void 0;
37
+ const fs = __importStar(require("node:fs"));
38
+ const path = __importStar(require("node:path"));
39
+ exports.PHASE_FILENAME_PATTERN = /^\d{2}-.*\.md$/;
40
+ const isPhaseFile = (filename) => exports.PHASE_FILENAME_PATTERN.test(filename) && !filename.includes(".feedback");
41
+ exports.isPhaseFile = isPhaseFile;
42
+ const parsePhaseFilename = (filename) => {
43
+ const match = filename.match(/^(\d{2})-(.+)\.md$/);
44
+ return {
45
+ id: filename.replace(/\.md$/, ""),
46
+ index: match ? parseInt(match[1], 10) : 0,
47
+ slug: match ? match[2] : filename,
48
+ };
49
+ };
50
+ exports.parsePhaseFilename = parsePhaseFilename;
51
+ // Extract title, goal, and acceptance criteria from phase markdown content
52
+ const parsePhaseContent = (content) => {
53
+ const titleMatch = content.match(/^#\s+(.+)/m);
54
+ const goalMatch = content.match(/## Goal\s*\n([\s\S]*?)(?=\n## |\n$)/);
55
+ const criteriaMatch = content.match(/## Acceptance Criteria\s*\n([\s\S]*?)(?=\n## |\n$)/);
56
+ return {
57
+ title: titleMatch ? titleMatch[1] : "",
58
+ goal: goalMatch ? goalMatch[1].trim() : "",
59
+ criteria: criteriaMatch ? criteriaMatch[1].trim() : "",
60
+ };
61
+ };
62
+ exports.parsePhaseContent = parsePhaseContent;
63
+ const scanPhases = (phasesDir) => {
64
+ if (!fs.existsSync(phasesDir))
65
+ return [];
66
+ const files = fs.readdirSync(phasesDir)
67
+ .filter(exports.isPhaseFile)
68
+ .sort();
69
+ return files.map((filename) => {
70
+ const { id, index, slug } = (0, exports.parsePhaseFilename)(filename);
71
+ return {
72
+ id,
73
+ index,
74
+ slug,
75
+ filename,
76
+ filepath: path.join(phasesDir, filename),
77
+ };
78
+ });
79
+ };
80
+ exports.scanPhases = scanPhases;
81
+ //# sourceMappingURL=phases.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"phases.js","sourceRoot":"","sources":["../../src/stores/phases.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,4CAA6B;AAC7B,gDAAiC;AAGpB,QAAA,sBAAsB,GAAG,gBAAgB,CAAA;AAE/C,MAAM,WAAW,GAAG,CAAC,QAAgB,EAAW,EAAE,CACvD,8BAAsB,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAA;AAD7D,QAAA,WAAW,eACkD;AAEnE,MAAM,kBAAkB,GAAG,CAAC,QAAgB,EAA+C,EAAE;IAClG,MAAM,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC,oBAAoB,CAAC,CAAA;IAClD,OAAO;QACL,EAAE,EAAE,QAAQ,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC;QACjC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACzC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ;KAClC,CAAA;AACH,CAAC,CAAA;AAPY,QAAA,kBAAkB,sBAO9B;AAQD,2EAA2E;AACpE,MAAM,iBAAiB,GAAG,CAAC,OAAe,EAAgB,EAAE;IACjE,MAAM,UAAU,GAAG,OAAO,CAAC,KAAK,CAAC,YAAY,CAAC,CAAA;IAC9C,MAAM,SAAS,GAAG,OAAO,CAAC,KAAK,CAAC,qCAAqC,CAAC,CAAA;IACtE,MAAM,aAAa,GAAG,OAAO,CAAC,KAAK,CAAC,oDAAoD,CAAC,CAAA;IAEzF,OAAO;QACL,KAAK,EAAE,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE;QACtC,IAAI,EAAE,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE;QAC1C,QAAQ,EAAE,aAAa,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE;KACvD,CAAA;AACH,CAAC,CAAA;AAVY,QAAA,iBAAiB,qBAU7B;AAEM,MAAM,UAAU,GAAG,CAAC,SAAiB,EAAe,EAAE;IAC3D,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC;QAAE,OAAO,EAAE,CAAA;IACxC,MAAM,KAAK,GAAG,EAAE,CAAC,WAAW,CAAC,SAAS,CAAC;SACpC,MAAM,CAAC,mBAAW,CAAC;SACnB,IAAI,EAAE,CAAA;IAET,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE;QAC5B,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,IAAA,0BAAkB,EAAC,QAAQ,CAAC,CAAA;QACxD,OAAO;YACL,EAAE;YACF,KAAK;YACL,IAAI;YACJ,QAAQ;YACR,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,QAAQ,CAAC;SACzC,CAAA;IACH,CAAC,CAAC,CAAA;AACJ,CAAC,CAAA;AAhBY,QAAA,UAAU,cAgBtB"}
@@ -0,0 +1,12 @@
1
+ /** Domains Claude needs for authentication and API access — always allowlisted. */
2
+ export declare const CLAUDE_REQUIRED_DOMAINS: string[];
3
+ export declare const DEFAULT_NETWORK_ALLOWLIST: string[];
4
+ type RidgelineSettings = {
5
+ network?: {
6
+ allowlist?: string[];
7
+ };
8
+ flavour?: string;
9
+ };
10
+ export declare const loadSettings: (ridgelineDir: string) => RidgelineSettings;
11
+ export declare const resolveNetworkAllowlist: (ridgelineDir: string) => string[];
12
+ export {};
@@ -0,0 +1,85 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.resolveNetworkAllowlist = exports.loadSettings = exports.DEFAULT_NETWORK_ALLOWLIST = exports.CLAUDE_REQUIRED_DOMAINS = void 0;
37
+ const fs = __importStar(require("node:fs"));
38
+ const path = __importStar(require("node:path"));
39
+ /** Domains Claude needs for authentication and API access — always allowlisted. */
40
+ exports.CLAUDE_REQUIRED_DOMAINS = [
41
+ "api.anthropic.com",
42
+ "downloads.claude.ai",
43
+ "http-intake.logs.us5.datadoghq.com",
44
+ ];
45
+ exports.DEFAULT_NETWORK_ALLOWLIST = [
46
+ ...exports.CLAUDE_REQUIRED_DOMAINS,
47
+ "registry.npmjs.org",
48
+ "nodejs.org",
49
+ "objects.githubusercontent.com",
50
+ "raw.githubusercontent.com",
51
+ "pypi.org",
52
+ "files.pythonhosted.org",
53
+ "crates.io",
54
+ "static.crates.io",
55
+ "rubygems.org",
56
+ "proxy.golang.org",
57
+ "github.com",
58
+ "gitlab.com",
59
+ "bitbucket.org",
60
+ ];
61
+ const loadSettings = (ridgelineDir) => {
62
+ const settingsPath = path.join(ridgelineDir, "settings.json");
63
+ try {
64
+ const raw = fs.readFileSync(settingsPath, "utf-8");
65
+ return JSON.parse(raw);
66
+ }
67
+ catch {
68
+ return {};
69
+ }
70
+ };
71
+ exports.loadSettings = loadSettings;
72
+ const resolveNetworkAllowlist = (ridgelineDir) => {
73
+ const settings = (0, exports.loadSettings)(ridgelineDir);
74
+ const base = (settings.network?.allowlist && settings.network.allowlist.length > 0)
75
+ ? settings.network.allowlist
76
+ : [...exports.DEFAULT_NETWORK_ALLOWLIST];
77
+ // Wildcard means unrestricted — return empty so greywall omits network filtering
78
+ if (base.includes("*"))
79
+ return [];
80
+ // Always include Claude's required domains even if the user overrides the list
81
+ const merged = new Set([...exports.CLAUDE_REQUIRED_DOMAINS, ...base]);
82
+ return [...merged];
83
+ };
84
+ exports.resolveNetworkAllowlist = resolveNetworkAllowlist;
85
+ //# sourceMappingURL=settings.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"settings.js","sourceRoot":"","sources":["../../src/stores/settings.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,4CAA6B;AAC7B,gDAAiC;AAEjC,mFAAmF;AACtE,QAAA,uBAAuB,GAAa;IAC/C,mBAAmB;IACnB,qBAAqB;IACrB,oCAAoC;CACrC,CAAA;AAEY,QAAA,yBAAyB,GAAa;IACjD,GAAG,+BAAuB;IAC1B,oBAAoB;IACpB,YAAY;IACZ,+BAA+B;IAC/B,2BAA2B;IAC3B,UAAU;IACV,wBAAwB;IACxB,WAAW;IACX,kBAAkB;IAClB,cAAc;IACd,kBAAkB;IAClB,YAAY;IACZ,YAAY;IACZ,eAAe;CAChB,CAAA;AASM,MAAM,YAAY,GAAG,CAAC,YAAoB,EAAqB,EAAE;IACtE,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,eAAe,CAAC,CAAA;IAC7D,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,EAAE,CAAC,YAAY,CAAC,YAAY,EAAE,OAAO,CAAC,CAAA;QAClD,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAsB,CAAA;IAC7C,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,CAAA;IACX,CAAC;AACH,CAAC,CAAA;AARY,QAAA,YAAY,gBAQxB;AAEM,MAAM,uBAAuB,GAAG,CAAC,YAAoB,EAAY,EAAE;IACxE,MAAM,QAAQ,GAAG,IAAA,oBAAY,EAAC,YAAY,CAAC,CAAA;IAC3C,MAAM,IAAI,GAAG,CAAC,QAAQ,CAAC,OAAO,EAAE,SAAS,IAAI,QAAQ,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC;QACjF,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,SAAS;QAC5B,CAAC,CAAC,CAAC,GAAG,iCAAyB,CAAC,CAAA;IAClC,iFAAiF;IACjF,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC;QAAE,OAAO,EAAE,CAAA;IACjC,+EAA+E;IAC/E,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,CAAC,GAAG,+BAAuB,EAAE,GAAG,IAAI,CAAC,CAAC,CAAA;IAC7D,OAAO,CAAC,GAAG,MAAM,CAAC,CAAA;AACpB,CAAC,CAAA;AAVY,QAAA,uBAAuB,2BAUnC"}
@@ -0,0 +1,20 @@
1
+ import { BuildState, PhaseState, PhaseInfo, PipelineState, PipelineStage } from "../types";
2
+ export declare const loadState: (buildDir: string) => BuildState | null;
3
+ export declare const saveState: (buildDir: string, state: BuildState) => void;
4
+ export declare const initState: (buildName: string, phases: PhaseInfo[]) => BuildState;
5
+ export declare const updatePhaseStatus: (buildDir: string, state: BuildState, phaseId: string, update: Partial<PhaseState>) => void;
6
+ export declare const resetRetries: (buildDir: string, state: BuildState) => void;
7
+ export declare const getNextIncompletePhase: (state: BuildState, cwd?: string) => PhaseState | null;
8
+ /** Get pipeline status, verifying against both state.json and file existence. */
9
+ export declare const getPipelineStatus: (buildDir: string) => PipelineState;
10
+ /** Mark a pipeline stage as complete and persist. */
11
+ export declare const advancePipeline: (buildDir: string, buildName: string, stage: PipelineStage) => void;
12
+ /** Set build pipeline stage to "running". */
13
+ export declare const markBuildRunning: (buildDir: string, buildName: string) => void;
14
+ /** Determine the next incomplete pipeline stage. */
15
+ export declare const getNextPipelineStage: (buildDir: string) => PipelineStage | null;
16
+ /**
17
+ * Rewind to a given stage: mark downstream stages as pending,
18
+ * return list of files/dirs to delete from disk.
19
+ */
20
+ export declare const rewindTo: (buildDir: string, buildName: string, targetStage: PipelineStage) => string[];