ridgeline 0.6.0 → 0.7.2
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.
- package/README.md +8 -5
- package/dist/agents/core/designer.md +131 -0
- package/dist/agents/core/refiner.md +28 -1
- package/dist/agents/core/researcher.md +30 -11
- package/dist/agents/core/specifier.md +16 -0
- package/dist/agents/researchers/gaps.md +67 -0
- package/dist/agents/specifiers/visual-coherence.md +55 -0
- package/dist/cli.js +39 -8
- package/dist/cli.js.map +1 -1
- package/dist/commands/create.js +16 -1
- package/dist/commands/create.js.map +1 -1
- package/dist/commands/design.d.ts +8 -0
- package/dist/commands/design.js +130 -0
- package/dist/commands/design.js.map +1 -0
- package/dist/commands/index.d.ts +1 -0
- package/dist/commands/index.js +3 -1
- package/dist/commands/index.js.map +1 -1
- package/dist/commands/plan.js +3 -3
- package/dist/commands/plan.js.map +1 -1
- package/dist/commands/qa-workflow.d.ts +33 -0
- package/dist/commands/qa-workflow.js +139 -0
- package/dist/commands/qa-workflow.js.map +1 -0
- package/dist/commands/refine.d.ts +1 -0
- package/dist/commands/refine.js +17 -4
- package/dist/commands/refine.js.map +1 -1
- package/dist/commands/research.js +22 -8
- package/dist/commands/research.js.map +1 -1
- package/dist/commands/rewind.js +2 -2
- package/dist/commands/rewind.js.map +1 -1
- package/dist/commands/shape.js +36 -121
- package/dist/commands/shape.js.map +1 -1
- package/dist/commands/spec.js +1 -0
- package/dist/commands/spec.js.map +1 -1
- package/dist/engine/claude/stream.display.js +0 -1
- package/dist/engine/claude/stream.display.js.map +1 -1
- package/dist/engine/claude/stream.parse.d.ts +1 -15
- package/dist/engine/claude/stream.parse.js +3 -21
- package/dist/engine/claude/stream.parse.js.map +1 -1
- package/dist/engine/claude/stream.result.js +2 -2
- package/dist/engine/claude/stream.types.d.ts +15 -0
- package/dist/engine/claude/stream.types.js +23 -0
- package/dist/engine/claude/stream.types.js.map +1 -0
- package/dist/engine/discovery/agent.registry.d.ts +4 -0
- package/dist/engine/discovery/agent.registry.js +46 -18
- package/dist/engine/discovery/agent.registry.js.map +1 -1
- package/dist/engine/discovery/flavour.config.d.ts +9 -0
- package/dist/engine/discovery/flavour.config.js +61 -0
- package/dist/engine/discovery/flavour.config.js.map +1 -0
- package/dist/engine/discovery/plugin.scan.d.ts +1 -0
- package/dist/engine/discovery/plugin.scan.js +29 -1
- package/dist/engine/discovery/plugin.scan.js.map +1 -1
- package/dist/engine/discovery/skill.check.d.ts +19 -0
- package/dist/engine/discovery/skill.check.js +145 -0
- package/dist/engine/discovery/skill.check.js.map +1 -0
- package/dist/engine/pipeline/build.exec.js +1 -0
- package/dist/engine/pipeline/build.exec.js.map +1 -1
- package/dist/engine/pipeline/phase.sequence.js +10 -10
- package/dist/engine/pipeline/phase.sequence.js.map +1 -1
- package/dist/engine/pipeline/pipeline.shared.d.ts +6 -0
- package/dist/engine/pipeline/pipeline.shared.js +24 -1
- package/dist/engine/pipeline/pipeline.shared.js.map +1 -1
- package/dist/engine/pipeline/plan.exec.js +1 -0
- package/dist/engine/pipeline/plan.exec.js.map +1 -1
- package/dist/engine/pipeline/refine.exec.d.ts +2 -0
- package/dist/engine/pipeline/refine.exec.js +13 -2
- package/dist/engine/pipeline/refine.exec.js.map +1 -1
- package/dist/engine/pipeline/research.exec.d.ts +3 -0
- package/dist/engine/pipeline/research.exec.js +74 -5
- package/dist/engine/pipeline/research.exec.js.map +1 -1
- package/dist/engine/pipeline/review.exec.js +23 -0
- package/dist/engine/pipeline/review.exec.js.map +1 -1
- package/dist/engine/pipeline/specify.exec.d.ts +1 -0
- package/dist/engine/pipeline/specify.exec.js +114 -44
- package/dist/engine/pipeline/specify.exec.js.map +1 -1
- package/dist/flavours/data-analysis/core/refiner.md +28 -1
- package/dist/flavours/data-analysis/core/researcher.md +30 -11
- package/dist/flavours/data-analysis/researchers/gaps.md +59 -0
- package/dist/flavours/game-dev/core/refiner.md +28 -1
- package/dist/flavours/game-dev/core/researcher.md +30 -11
- package/dist/flavours/game-dev/researchers/gaps.md +59 -0
- package/dist/flavours/legal-drafting/core/refiner.md +28 -1
- package/dist/flavours/legal-drafting/core/researcher.md +30 -11
- package/dist/flavours/legal-drafting/researchers/gaps.md +59 -0
- package/dist/flavours/machine-learning/core/refiner.md +28 -1
- package/dist/flavours/machine-learning/core/researcher.md +30 -11
- package/dist/flavours/machine-learning/researchers/gaps.md +59 -0
- package/dist/flavours/mobile-app/core/refiner.md +28 -1
- package/dist/flavours/mobile-app/core/researcher.md +30 -11
- package/dist/flavours/mobile-app/researchers/gaps.md +59 -0
- package/dist/flavours/music-composition/core/refiner.md +28 -1
- package/dist/flavours/music-composition/core/researcher.md +30 -11
- package/dist/flavours/music-composition/researchers/gaps.md +59 -0
- package/dist/flavours/novel-writing/core/refiner.md +28 -1
- package/dist/flavours/novel-writing/core/researcher.md +30 -11
- package/dist/flavours/novel-writing/researchers/gaps.md +59 -0
- package/dist/flavours/screenwriting/core/refiner.md +28 -1
- package/dist/flavours/screenwriting/core/researcher.md +30 -11
- package/dist/flavours/screenwriting/researchers/gaps.md +59 -0
- package/dist/flavours/security-audit/core/refiner.md +28 -1
- package/dist/flavours/security-audit/core/researcher.md +30 -11
- package/dist/flavours/security-audit/researchers/gaps.md +59 -0
- package/dist/flavours/software-engineering/core/builder.md +2 -0
- package/dist/flavours/software-engineering/core/refiner.md +28 -1
- package/dist/flavours/software-engineering/core/researcher.md +30 -11
- package/dist/flavours/software-engineering/core/reviewer.md +2 -0
- package/dist/flavours/software-engineering/flavour.json +7 -0
- package/dist/flavours/software-engineering/researchers/gaps.md +59 -0
- package/dist/flavours/technical-writing/core/refiner.md +28 -1
- package/dist/flavours/technical-writing/core/researcher.md +30 -11
- package/dist/flavours/technical-writing/researchers/gaps.md +59 -0
- package/dist/flavours/test-suite/core/refiner.md +28 -1
- package/dist/flavours/test-suite/core/researcher.md +30 -11
- package/dist/flavours/test-suite/researchers/gaps.md +59 -0
- package/dist/flavours/translation/core/refiner.md +28 -1
- package/dist/flavours/translation/core/researcher.md +30 -11
- package/dist/flavours/translation/researchers/gaps.md +59 -0
- package/dist/flavours/web-game/core/builder.md +123 -0
- package/dist/flavours/web-game/core/reviewer.md +159 -0
- package/dist/flavours/web-game/flavour.json +9 -0
- package/dist/flavours/web-ui/core/builder.md +117 -0
- package/dist/flavours/web-ui/core/reviewer.md +155 -0
- package/dist/flavours/web-ui/flavour.json +10 -0
- package/dist/plugin/visual-tools/plugin.json +4 -0
- package/dist/plugin/visual-tools/skills/a11y-audit/SKILL.md +57 -0
- package/dist/plugin/visual-tools/skills/agent-browser/SKILL.md +56 -0
- package/dist/plugin/visual-tools/skills/agent-browser/references/viewports.md +17 -0
- package/dist/plugin/visual-tools/skills/canvas-screenshot/SKILL.md +84 -0
- package/dist/plugin/visual-tools/skills/css-audit/SKILL.md +50 -0
- package/dist/plugin/visual-tools/skills/lighthouse/SKILL.md +58 -0
- package/dist/plugin/visual-tools/skills/shader-validate/SKILL.md +77 -0
- package/dist/plugin/visual-tools/skills/visual-diff/SKILL.md +68 -0
- package/dist/shapes/detect.d.ts +8 -0
- package/dist/shapes/detect.js +87 -0
- package/dist/shapes/detect.js.map +1 -0
- package/dist/shapes/game-visual.json +8 -0
- package/dist/shapes/print-layout.json +8 -0
- package/dist/shapes/web-visual.json +9 -0
- package/dist/stores/budget.js +2 -1
- package/dist/stores/budget.js.map +1 -1
- package/dist/stores/feedback.format.d.ts +3 -0
- package/dist/stores/feedback.format.js +62 -0
- package/dist/stores/feedback.format.js.map +1 -0
- package/dist/stores/feedback.parse.d.ts +2 -0
- package/dist/stores/feedback.parse.js +121 -0
- package/dist/stores/feedback.parse.js.map +1 -0
- package/dist/stores/feedback.verdict.d.ts +2 -4
- package/dist/stores/feedback.verdict.js +7 -175
- package/dist/stores/feedback.verdict.js.map +1 -1
- package/dist/stores/index.d.ts +1 -1
- package/dist/stores/index.js +1 -2
- package/dist/stores/index.js.map +1 -1
- package/dist/stores/state.d.ts +4 -0
- package/dist/stores/state.js +37 -5
- package/dist/stores/state.js.map +1 -1
- package/dist/stores/trajectory.d.ts +2 -3
- package/dist/stores/trajectory.js +6 -7
- package/dist/stores/trajectory.js.map +1 -1
- package/dist/types.d.ts +11 -1
- package/dist/utils/atomic-write.d.ts +6 -0
- package/dist/utils/atomic-write.js +62 -0
- package/dist/utils/atomic-write.js.map +1 -0
- package/package.json +2 -2
|
@@ -0,0 +1,130 @@
|
|
|
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.runDesign = void 0;
|
|
37
|
+
const fs = __importStar(require("node:fs"));
|
|
38
|
+
const path = __importStar(require("node:path"));
|
|
39
|
+
const readline = __importStar(require("node:readline"));
|
|
40
|
+
const output_1 = require("../ui/output");
|
|
41
|
+
const agent_registry_1 = require("../engine/discovery/agent.registry");
|
|
42
|
+
const flavour_resolve_1 = require("../engine/discovery/flavour.resolve");
|
|
43
|
+
const state_1 = require("../stores/state");
|
|
44
|
+
const qa_workflow_1 = require("./qa-workflow");
|
|
45
|
+
/** Determine where to write design.md. */
|
|
46
|
+
const resolveDesignOutputPath = (buildDir, ridgelineDir) => {
|
|
47
|
+
if (buildDir)
|
|
48
|
+
return path.join(buildDir, "design.md");
|
|
49
|
+
return path.join(ridgelineDir, "design.md");
|
|
50
|
+
};
|
|
51
|
+
const runDesign = async (buildName, opts) => {
|
|
52
|
+
const ridgelineDir = path.join(process.cwd(), ".ridgeline");
|
|
53
|
+
const buildDir = buildName
|
|
54
|
+
? path.join(ridgelineDir, "builds", buildName)
|
|
55
|
+
: null;
|
|
56
|
+
const outputPath = resolveDesignOutputPath(buildDir, ridgelineDir);
|
|
57
|
+
const timeoutMs = opts.timeout * 60 * 1000;
|
|
58
|
+
(0, output_1.printInfo)(buildDir ? `Build directory: ${buildDir}` : "Project-level design");
|
|
59
|
+
const registry = (0, agent_registry_1.buildAgentRegistry)((0, flavour_resolve_1.resolveFlavour)(opts.flavour ?? null));
|
|
60
|
+
const systemPrompt = registry.getCorePrompt("designer.md");
|
|
61
|
+
const rl = readline.createInterface({ input: process.stdin, output: process.stdout });
|
|
62
|
+
try {
|
|
63
|
+
// Gather existing context
|
|
64
|
+
const contextParts = [];
|
|
65
|
+
const projectDesign = path.join(ridgelineDir, "design.md");
|
|
66
|
+
if (fs.existsSync(projectDesign)) {
|
|
67
|
+
contextParts.push("## Existing Project Design\n");
|
|
68
|
+
contextParts.push(fs.readFileSync(projectDesign, "utf-8"));
|
|
69
|
+
contextParts.push("");
|
|
70
|
+
}
|
|
71
|
+
if (buildDir) {
|
|
72
|
+
const featureDesign = path.join(buildDir, "design.md");
|
|
73
|
+
if (fs.existsSync(featureDesign)) {
|
|
74
|
+
contextParts.push("## Existing Feature Design\n");
|
|
75
|
+
contextParts.push(fs.readFileSync(featureDesign, "utf-8"));
|
|
76
|
+
contextParts.push("");
|
|
77
|
+
}
|
|
78
|
+
const shapePath = path.join(buildDir, "shape.md");
|
|
79
|
+
if (fs.existsSync(shapePath)) {
|
|
80
|
+
contextParts.push("## shape.md\n");
|
|
81
|
+
contextParts.push(fs.readFileSync(shapePath, "utf-8"));
|
|
82
|
+
contextParts.push("");
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
if (opts.matchedShapes && opts.matchedShapes.length > 0) {
|
|
86
|
+
contextParts.push("## Matched Shape Categories\n");
|
|
87
|
+
contextParts.push(opts.matchedShapes.join(", "));
|
|
88
|
+
contextParts.push("");
|
|
89
|
+
}
|
|
90
|
+
const userPrompt = [
|
|
91
|
+
buildName
|
|
92
|
+
? `Gather design system context for build "${buildName}".`
|
|
93
|
+
: "Gather project-level design system context.",
|
|
94
|
+
"",
|
|
95
|
+
...(contextParts.length > 0 ? contextParts : ["No existing design context found."]),
|
|
96
|
+
"",
|
|
97
|
+
"Analyze the context above and ask design-focused questions.",
|
|
98
|
+
"Remember: present ALL questions to the user even when pre-filled.",
|
|
99
|
+
].join("\n");
|
|
100
|
+
// Intake + clarification loop
|
|
101
|
+
const { sessionId, qa } = await (0, qa_workflow_1.runQAIntake)(rl, systemPrompt, userPrompt, { model: opts.model, questionLabel: "Design questions" }, timeoutMs, "Analyzing design context...");
|
|
102
|
+
// Design output turn — no JSON schema, freeform markdown
|
|
103
|
+
if (qa.summary) {
|
|
104
|
+
console.log(`\nDesign summary:\n ${qa.summary}`);
|
|
105
|
+
}
|
|
106
|
+
const designResult = await (0, qa_workflow_1.runOutputTurn)(systemPrompt, "Produce the final design document now. Respond with freeform markdown — NOT JSON. Structure it with headings, specific values (hard tokens), and directional guidance (soft guidance).", opts.model, timeoutMs, sessionId, "Producing design document...");
|
|
107
|
+
// Write design.md
|
|
108
|
+
const designDir = path.dirname(outputPath);
|
|
109
|
+
if (!fs.existsSync(designDir)) {
|
|
110
|
+
fs.mkdirSync(designDir, { recursive: true });
|
|
111
|
+
}
|
|
112
|
+
fs.writeFileSync(outputPath, designResult.result);
|
|
113
|
+
// Update pipeline state if in build context
|
|
114
|
+
if (buildName && buildDir) {
|
|
115
|
+
(0, state_1.advancePipeline)(buildDir, buildName, "design");
|
|
116
|
+
}
|
|
117
|
+
console.log("");
|
|
118
|
+
(0, output_1.printInfo)("Created:");
|
|
119
|
+
console.log(` ${outputPath}`);
|
|
120
|
+
console.log("");
|
|
121
|
+
if (buildName) {
|
|
122
|
+
(0, output_1.printInfo)(`Next: ridgeline spec ${buildName}`);
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
finally {
|
|
126
|
+
rl.close();
|
|
127
|
+
}
|
|
128
|
+
};
|
|
129
|
+
exports.runDesign = runDesign;
|
|
130
|
+
//# sourceMappingURL=design.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"design.js","sourceRoot":"","sources":["../../src/commands/design.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,4CAA6B;AAC7B,gDAAiC;AACjC,wDAAyC;AACzC,yCAAwC;AACxC,uEAAuE;AACvE,yEAAoE;AACpE,2CAAiD;AACjD,+CAA0D;AAE1D,0CAA0C;AAC1C,MAAM,uBAAuB,GAAG,CAC9B,QAAuB,EACvB,YAAoB,EACZ,EAAE;IACV,IAAI,QAAQ;QAAE,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAA;IACrD,OAAO,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,WAAW,CAAC,CAAA;AAC7C,CAAC,CAAA;AASM,MAAM,SAAS,GAAG,KAAK,EAC5B,SAAwB,EACxB,IAAmB,EACJ,EAAE;IACjB,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,YAAY,CAAC,CAAA;IAC3D,MAAM,QAAQ,GAAG,SAAS;QACxB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,QAAQ,EAAE,SAAS,CAAC;QAC9C,CAAC,CAAC,IAAI,CAAA;IAER,MAAM,UAAU,GAAG,uBAAuB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAA;IAClE,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,GAAG,EAAE,GAAG,IAAI,CAAA;IAE1C,IAAA,kBAAS,EAAC,QAAQ,CAAC,CAAC,CAAC,oBAAoB,QAAQ,EAAE,CAAC,CAAC,CAAC,sBAAsB,CAAC,CAAA;IAE7E,MAAM,QAAQ,GAAG,IAAA,mCAAkB,EAAC,IAAA,gCAAc,EAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,CAAC,CAAA;IACzE,MAAM,YAAY,GAAG,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,CAAA;IAE1D,MAAM,EAAE,GAAG,QAAQ,CAAC,eAAe,CAAC,EAAE,KAAK,EAAE,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE,CAAC,CAAA;IAErF,IAAI,CAAC;QACH,0BAA0B;QAC1B,MAAM,YAAY,GAAa,EAAE,CAAA;QAEjC,MAAM,aAAa,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,WAAW,CAAC,CAAA;QAC1D,IAAI,EAAE,CAAC,UAAU,CAAC,aAAa,CAAC,EAAE,CAAC;YACjC,YAAY,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAAA;YACjD,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC,CAAA;YAC1D,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QACvB,CAAC;QAED,IAAI,QAAQ,EAAE,CAAC;YACb,MAAM,aAAa,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAA;YACtD,IAAI,EAAE,CAAC,UAAU,CAAC,aAAa,CAAC,EAAE,CAAC;gBACjC,YAAY,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAAA;gBACjD,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC,CAAA;gBAC1D,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;YACvB,CAAC;YAED,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAA;YACjD,IAAI,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;gBAC7B,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,CAAA;gBAClC,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC,CAAA;gBACtD,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;YACvB,CAAC;QACH,CAAC;QAED,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACxD,YAAY,CAAC,IAAI,CAAC,+BAA+B,CAAC,CAAA;YAClD,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAA;YAChD,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QACvB,CAAC;QAED,MAAM,UAAU,GAAG;YACjB,SAAS;gBACP,CAAC,CAAC,2CAA2C,SAAS,IAAI;gBAC1D,CAAC,CAAC,6CAA6C;YACjD,EAAE;YACF,GAAG,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,mCAAmC,CAAC,CAAC;YACnF,EAAE;YACF,6DAA6D;YAC7D,mEAAmE;SACpE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QAEZ,8BAA8B;QAC9B,MAAM,EAAE,SAAS,EAAE,EAAE,EAAE,GAAG,MAAM,IAAA,yBAAW,EACzC,EAAE,EAAE,YAAY,EAAE,UAAU,EAC5B,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,aAAa,EAAE,kBAAkB,EAAE,EACxD,SAAS,EAAE,6BAA6B,CACzC,CAAA;QAED,yDAAyD;QACzD,IAAI,EAAE,CAAC,OAAO,EAAE,CAAC;YACf,OAAO,CAAC,GAAG,CAAC,wBAAwB,EAAE,CAAC,OAAO,EAAE,CAAC,CAAA;QACnD,CAAC;QAED,MAAM,YAAY,GAAG,MAAM,IAAA,2BAAa,EACtC,YAAY,EACZ,wLAAwL,EACxL,IAAI,CAAC,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,8BAA8B,CACjE,CAAA;QAED,kBAAkB;QAClB,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAA;QAC1C,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;YAC9B,EAAE,CAAC,SAAS,CAAC,SAAS,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAA;QAC9C,CAAC;QACD,EAAE,CAAC,aAAa,CAAC,UAAU,EAAE,YAAY,CAAC,MAAM,CAAC,CAAA;QAEjD,4CAA4C;QAC5C,IAAI,SAAS,IAAI,QAAQ,EAAE,CAAC;YAC1B,IAAA,uBAAe,EAAC,QAAQ,EAAE,SAAS,EAAE,QAAQ,CAAC,CAAA;QAChD,CAAC;QAED,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;QACf,IAAA,kBAAS,EAAC,UAAU,CAAC,CAAA;QACrB,OAAO,CAAC,GAAG,CAAC,KAAK,UAAU,EAAE,CAAC,CAAA;QAC9B,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;QACf,IAAI,SAAS,EAAE,CAAC;YACd,IAAA,kBAAS,EAAC,wBAAwB,SAAS,EAAE,CAAC,CAAA;QAChD,CAAC;IACH,CAAC;YAAS,CAAC;QACT,EAAE,CAAC,KAAK,EAAE,CAAA;IACZ,CAAC;AACH,CAAC,CAAA;AAvGY,QAAA,SAAS,aAuGrB"}
|
package/dist/commands/index.d.ts
CHANGED
package/dist/commands/index.js
CHANGED
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.runSpec = exports.runPlan = exports.runDryRun = exports.runBuild = void 0;
|
|
3
|
+
exports.runSpec = exports.runPlan = exports.runDryRun = exports.runDesign = exports.runBuild = void 0;
|
|
4
4
|
var build_1 = require("./build");
|
|
5
5
|
Object.defineProperty(exports, "runBuild", { enumerable: true, get: function () { return build_1.runBuild; } });
|
|
6
|
+
var design_1 = require("./design");
|
|
7
|
+
Object.defineProperty(exports, "runDesign", { enumerable: true, get: function () { return design_1.runDesign; } });
|
|
6
8
|
var dry_run_1 = require("./dry-run");
|
|
7
9
|
Object.defineProperty(exports, "runDryRun", { enumerable: true, get: function () { return dry_run_1.runDryRun; } });
|
|
8
10
|
var plan_1 = require("./plan");
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/commands/index.ts"],"names":[],"mappings":";;;AAAA,iCAAkC;AAAzB,iGAAA,QAAQ,OAAA;AACjB,qCAAqC;AAA5B,oGAAA,SAAS,OAAA;AAClB,+BAAgC;AAAvB,+FAAA,OAAO,OAAA;AAChB,+BAAgC;AAAvB,+FAAA,OAAO,OAAA"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/commands/index.ts"],"names":[],"mappings":";;;AAAA,iCAAkC;AAAzB,iGAAA,QAAQ,OAAA;AACjB,mCAAoC;AAA3B,mGAAA,SAAS,OAAA;AAClB,qCAAqC;AAA5B,oGAAA,SAAS,OAAA;AAClB,+BAAgC;AAAvB,+FAAA,OAAO,OAAA;AAChB,+BAAgC;AAAvB,+FAAA,OAAO,OAAA"}
|
package/dist/commands/plan.js
CHANGED
|
@@ -53,21 +53,21 @@ const runPlan = async (config) => {
|
|
|
53
53
|
fs.mkdirSync(config.phasesDir, { recursive: true });
|
|
54
54
|
// Run planner
|
|
55
55
|
(0, output_1.printInfo)("Running planner...");
|
|
56
|
-
(0, trajectory_1.logTrajectory)(config.buildDir,
|
|
56
|
+
(0, trajectory_1.logTrajectory)(config.buildDir, "plan_start", null, "Planning started");
|
|
57
57
|
const { phases, ensemble } = await (0, ensemble_exec_1.invokePlanner)(config);
|
|
58
58
|
// Record costs for each specialist
|
|
59
59
|
for (let i = 0; i < ensemble.specialistResults.length; i++) {
|
|
60
60
|
(0, budget_1.recordCost)(config.buildDir, "plan", "specialist", i, ensemble.specialistResults[i]);
|
|
61
61
|
}
|
|
62
62
|
(0, budget_1.recordCost)(config.buildDir, "plan", "synthesizer", 0, ensemble.synthesizerResult);
|
|
63
|
-
(0, trajectory_1.logTrajectory)(config.buildDir,
|
|
63
|
+
(0, trajectory_1.logTrajectory)(config.buildDir, "plan_complete", null, `Generated ${phases.length} phases`, {
|
|
64
64
|
duration: ensemble.totalDurationMs,
|
|
65
65
|
tokens: {
|
|
66
66
|
input: ensemble.specialistResults.reduce((sum, r) => sum + r.usage.inputTokens, 0) + ensemble.synthesizerResult.usage.inputTokens,
|
|
67
67
|
output: ensemble.specialistResults.reduce((sum, r) => sum + r.usage.outputTokens, 0) + ensemble.synthesizerResult.usage.outputTokens,
|
|
68
68
|
},
|
|
69
69
|
costUsd: ensemble.totalCostUsd,
|
|
70
|
-
})
|
|
70
|
+
});
|
|
71
71
|
// Advance pipeline state
|
|
72
72
|
(0, state_1.advancePipeline)(config.buildDir, config.buildName, "plan");
|
|
73
73
|
// Print summary
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plan.js","sourceRoot":"","sources":["../../src/commands/plan.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,4CAA6B;AAC7B,gDAAiC;AAEjC,yCAAwC;AACxC,
|
|
1
|
+
{"version":3,"file":"plan.js","sourceRoot":"","sources":["../../src/commands/plan.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import * as readline from "node:readline";
|
|
2
|
+
type QAQuestion = {
|
|
3
|
+
question: string;
|
|
4
|
+
suggestedAnswer?: string;
|
|
5
|
+
};
|
|
6
|
+
type QAResponse = {
|
|
7
|
+
ready: boolean;
|
|
8
|
+
questions?: (string | QAQuestion)[];
|
|
9
|
+
summary?: string;
|
|
10
|
+
};
|
|
11
|
+
export declare const normalizeQuestion: (q: string | QAQuestion) => QAQuestion;
|
|
12
|
+
export declare const parseQAResponse: (resultText: string) => QAResponse;
|
|
13
|
+
export declare const askQuestion: (rl: readline.Interface, prompt: string) => Promise<string>;
|
|
14
|
+
type QAOpts = {
|
|
15
|
+
model: string;
|
|
16
|
+
questionLabel?: string;
|
|
17
|
+
};
|
|
18
|
+
/**
|
|
19
|
+
* Run the QA intake turn — invoke Claude with the QA JSON schema to gather
|
|
20
|
+
* initial questions, then run the clarification loop until ready.
|
|
21
|
+
*/
|
|
22
|
+
export declare const runQAIntake: (rl: readline.Interface, systemPrompt: string, userPrompt: string, opts: QAOpts, timeoutMs: number, statusMessage: string) => Promise<{
|
|
23
|
+
sessionId: string;
|
|
24
|
+
qa: QAResponse;
|
|
25
|
+
}>;
|
|
26
|
+
/**
|
|
27
|
+
* Run the output turn — invoke Claude for the final output (no QA schema).
|
|
28
|
+
*/
|
|
29
|
+
export declare const runOutputTurn: (systemPrompt: string, userPrompt: string, model: string, timeoutMs: number, sessionId: string, statusMessage: string, jsonSchema?: string) => Promise<{
|
|
30
|
+
result: string;
|
|
31
|
+
sessionId: string;
|
|
32
|
+
}>;
|
|
33
|
+
export {};
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.runOutputTurn = exports.runQAIntake = exports.askQuestion = exports.parseQAResponse = exports.normalizeQuestion = void 0;
|
|
4
|
+
const claude_exec_1 = require("../engine/claude/claude.exec");
|
|
5
|
+
const stream_display_1 = require("../engine/claude/stream.display");
|
|
6
|
+
const MAX_CLARIFICATION_ROUNDS = 4;
|
|
7
|
+
const QA_JSON_SCHEMA = JSON.stringify({
|
|
8
|
+
type: "object",
|
|
9
|
+
properties: {
|
|
10
|
+
ready: { type: "boolean" },
|
|
11
|
+
questions: {
|
|
12
|
+
type: "array",
|
|
13
|
+
items: {
|
|
14
|
+
type: "object",
|
|
15
|
+
properties: {
|
|
16
|
+
question: { type: "string" },
|
|
17
|
+
suggestedAnswer: { type: "string" },
|
|
18
|
+
},
|
|
19
|
+
required: ["question"],
|
|
20
|
+
},
|
|
21
|
+
},
|
|
22
|
+
summary: { type: "string" },
|
|
23
|
+
},
|
|
24
|
+
required: ["ready"],
|
|
25
|
+
});
|
|
26
|
+
const normalizeQuestion = (q) => typeof q === "string" ? { question: q } : q;
|
|
27
|
+
exports.normalizeQuestion = normalizeQuestion;
|
|
28
|
+
const parseQAResponse = (resultText) => {
|
|
29
|
+
try {
|
|
30
|
+
return JSON.parse(resultText);
|
|
31
|
+
}
|
|
32
|
+
catch {
|
|
33
|
+
return { ready: true, summary: resultText };
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
exports.parseQAResponse = parseQAResponse;
|
|
37
|
+
const askQuestion = (rl, prompt) => {
|
|
38
|
+
return new Promise((resolve) => {
|
|
39
|
+
rl.question(prompt, (answer) => {
|
|
40
|
+
resolve(answer.trim());
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
};
|
|
44
|
+
exports.askQuestion = askQuestion;
|
|
45
|
+
/**
|
|
46
|
+
* Run the QA intake turn — invoke Claude with the QA JSON schema to gather
|
|
47
|
+
* initial questions, then run the clarification loop until ready.
|
|
48
|
+
*/
|
|
49
|
+
const runQAIntake = async (rl, systemPrompt, userPrompt, opts, timeoutMs, statusMessage) => {
|
|
50
|
+
process.stderr.write(`\n\x1b[90m${statusMessage}\x1b[0m\n`);
|
|
51
|
+
const display = (0, stream_display_1.createDisplayCallbacks)({ projectRoot: process.cwd() });
|
|
52
|
+
const intakeResult = await (0, claude_exec_1.invokeClaude)({
|
|
53
|
+
systemPrompt,
|
|
54
|
+
userPrompt,
|
|
55
|
+
model: opts.model,
|
|
56
|
+
allowedTools: ["Read", "Glob", "Grep"],
|
|
57
|
+
cwd: process.cwd(),
|
|
58
|
+
timeoutMs,
|
|
59
|
+
jsonSchema: QA_JSON_SCHEMA,
|
|
60
|
+
onStdout: display.onStdout,
|
|
61
|
+
});
|
|
62
|
+
display.flush();
|
|
63
|
+
return runClarificationLoop(rl, systemPrompt, opts, timeoutMs, {
|
|
64
|
+
sessionId: intakeResult.sessionId,
|
|
65
|
+
qa: (0, exports.parseQAResponse)(intakeResult.result),
|
|
66
|
+
});
|
|
67
|
+
};
|
|
68
|
+
exports.runQAIntake = runQAIntake;
|
|
69
|
+
/**
|
|
70
|
+
* Run the output turn — invoke Claude for the final output (no QA schema).
|
|
71
|
+
*/
|
|
72
|
+
const runOutputTurn = async (systemPrompt, userPrompt, model, timeoutMs, sessionId, statusMessage, jsonSchema) => {
|
|
73
|
+
process.stderr.write(`\n\x1b[90m${statusMessage}\x1b[0m\n`);
|
|
74
|
+
const display = (0, stream_display_1.createDisplayCallbacks)({ projectRoot: process.cwd() });
|
|
75
|
+
const result = await (0, claude_exec_1.invokeClaude)({
|
|
76
|
+
systemPrompt,
|
|
77
|
+
userPrompt,
|
|
78
|
+
model,
|
|
79
|
+
cwd: process.cwd(),
|
|
80
|
+
timeoutMs,
|
|
81
|
+
sessionId,
|
|
82
|
+
jsonSchema,
|
|
83
|
+
onStdout: display.onStdout,
|
|
84
|
+
});
|
|
85
|
+
display.flush();
|
|
86
|
+
return { result: result.result, sessionId: result.sessionId };
|
|
87
|
+
};
|
|
88
|
+
exports.runOutputTurn = runOutputTurn;
|
|
89
|
+
const runClarificationLoop = async (rl, systemPrompt, opts, timeoutMs, initialResult) => {
|
|
90
|
+
let { sessionId, qa } = initialResult;
|
|
91
|
+
for (let round = 0; round < MAX_CLARIFICATION_ROUNDS && !qa.ready; round++) {
|
|
92
|
+
if (qa.summary) {
|
|
93
|
+
console.log(`\nHere's what I understand so far:\n ${qa.summary}`);
|
|
94
|
+
}
|
|
95
|
+
if (!qa.questions || qa.questions.length === 0)
|
|
96
|
+
break;
|
|
97
|
+
const normalized = qa.questions.map(exports.normalizeQuestion);
|
|
98
|
+
const label = opts.questionLabel ?? "Questions";
|
|
99
|
+
console.log(`\n${label}:\n`);
|
|
100
|
+
console.log(` \x1b[90m(tip: you can enter a file path for longer answers)\x1b[0m\n`);
|
|
101
|
+
const answers = [];
|
|
102
|
+
for (let i = 0; i < normalized.length; i++) {
|
|
103
|
+
if (i > 0)
|
|
104
|
+
console.log("");
|
|
105
|
+
const q = normalized[i];
|
|
106
|
+
if (q.suggestedAnswer) {
|
|
107
|
+
console.log(` ${i + 1}. ${q.question}`);
|
|
108
|
+
console.log(` \x1b[90m(suggested: ${q.suggestedAnswer})\x1b[0m`);
|
|
109
|
+
const answer = await (0, exports.askQuestion)(rl, ` > `);
|
|
110
|
+
answers.push(answer || q.suggestedAnswer);
|
|
111
|
+
}
|
|
112
|
+
else {
|
|
113
|
+
const answer = await (0, exports.askQuestion)(rl, ` ${i + 1}. ${q.question}\n > `);
|
|
114
|
+
answers.push(answer);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
process.stderr.write(`\n\x1b[90mProcessing your answers...\x1b[0m\n`);
|
|
118
|
+
const answersPrompt = normalized
|
|
119
|
+
.map((q, i) => `Q: ${q.question}\nA: ${answers[i]}`)
|
|
120
|
+
.join("\n\n");
|
|
121
|
+
const display = (0, stream_display_1.createDisplayCallbacks)({ projectRoot: process.cwd() });
|
|
122
|
+
const result = await (0, claude_exec_1.invokeClaude)({
|
|
123
|
+
systemPrompt,
|
|
124
|
+
userPrompt: `User answers to follow-up questions:\n\n${answersPrompt}`,
|
|
125
|
+
model: opts.model,
|
|
126
|
+
allowedTools: ["Read", "Glob", "Grep"],
|
|
127
|
+
cwd: process.cwd(),
|
|
128
|
+
timeoutMs,
|
|
129
|
+
sessionId,
|
|
130
|
+
jsonSchema: QA_JSON_SCHEMA,
|
|
131
|
+
onStdout: display.onStdout,
|
|
132
|
+
});
|
|
133
|
+
display.flush();
|
|
134
|
+
sessionId = result.sessionId;
|
|
135
|
+
qa = (0, exports.parseQAResponse)(result.result);
|
|
136
|
+
}
|
|
137
|
+
return { sessionId, qa };
|
|
138
|
+
};
|
|
139
|
+
//# sourceMappingURL=qa-workflow.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"qa-workflow.js","sourceRoot":"","sources":["../../src/commands/qa-workflow.ts"],"names":[],"mappings":"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"}
|
package/dist/commands/refine.js
CHANGED
|
@@ -41,6 +41,13 @@ const refine_exec_1 = require("../engine/pipeline/refine.exec");
|
|
|
41
41
|
const state_1 = require("../stores/state");
|
|
42
42
|
const trajectory_1 = require("../stores/trajectory");
|
|
43
43
|
const budget_1 = require("../stores/budget");
|
|
44
|
+
/** Derive the next iteration number from existing spec.changelog.md content. */
|
|
45
|
+
const deriveRefineIterationNumber = (changelogMd) => {
|
|
46
|
+
if (!changelogMd)
|
|
47
|
+
return 1;
|
|
48
|
+
const matches = changelogMd.match(/^## Iteration \d+/gm);
|
|
49
|
+
return (matches?.length ?? 0) + 1;
|
|
50
|
+
};
|
|
44
51
|
const runRefine = async (buildName, opts) => {
|
|
45
52
|
const buildDir = path.join(process.cwd(), ".ridgeline", "builds", buildName);
|
|
46
53
|
if (!fs.existsSync(buildDir)) {
|
|
@@ -67,25 +74,31 @@ const runRefine = async (buildName, opts) => {
|
|
|
67
74
|
const constraintsMd = fs.readFileSync(constraintsPath, "utf-8");
|
|
68
75
|
const tastePath = path.join(buildDir, "taste.md");
|
|
69
76
|
const tasteMd = fs.existsSync(tastePath) ? fs.readFileSync(tastePath, "utf-8") : null;
|
|
77
|
+
const changelogPath = path.join(buildDir, "spec.changelog.md");
|
|
78
|
+
const changelogMd = fs.existsSync(changelogPath) ? fs.readFileSync(changelogPath, "utf-8") : null;
|
|
79
|
+
const iterationNumber = opts.iterationNumber ?? deriveRefineIterationNumber(changelogMd);
|
|
70
80
|
const config = {
|
|
71
81
|
model: opts.model,
|
|
72
82
|
timeoutMinutes: opts.timeout,
|
|
73
83
|
buildDir,
|
|
74
84
|
flavour: opts.flavour ?? null,
|
|
85
|
+
changelogMd,
|
|
86
|
+
iterationNumber,
|
|
75
87
|
};
|
|
76
|
-
(0, trajectory_1.logTrajectory)(buildDir,
|
|
88
|
+
(0, trajectory_1.logTrajectory)(buildDir, "refine_start", null, `Refine started (iteration ${iterationNumber})`);
|
|
77
89
|
const result = await (0, refine_exec_1.invokeRefiner)(specMd, researchMd, constraintsMd, tasteMd, config);
|
|
78
90
|
(0, budget_1.recordCost)(buildDir, "refine", "refiner", 0, result);
|
|
79
|
-
(0, trajectory_1.logTrajectory)(buildDir,
|
|
91
|
+
(0, trajectory_1.logTrajectory)(buildDir, "refine_complete", null, `Refine complete (iteration ${iterationNumber})`, {
|
|
80
92
|
duration: result.durationMs,
|
|
81
93
|
tokens: { input: result.usage.inputTokens, output: result.usage.outputTokens },
|
|
82
94
|
costUsd: result.costUsd,
|
|
83
|
-
})
|
|
95
|
+
});
|
|
84
96
|
(0, state_1.advancePipeline)(buildDir, buildName, "refine");
|
|
85
|
-
(0, output_1.printInfo)(`\nSpec refined with research findings.`);
|
|
97
|
+
(0, output_1.printInfo)(`\nSpec refined with research findings (iteration ${iterationNumber}).`);
|
|
86
98
|
(0, output_1.printInfo)(`Cost: $${result.costUsd.toFixed(2)}`);
|
|
87
99
|
console.log("");
|
|
88
100
|
(0, output_1.printInfo)(`Review: ${path.join(buildDir, "spec.md")}`);
|
|
101
|
+
(0, output_1.printInfo)(`Changelog: ${path.join(buildDir, "spec.changelog.md")}`);
|
|
89
102
|
(0, output_1.printInfo)(`Next: ridgeline plan ${buildName}`);
|
|
90
103
|
};
|
|
91
104
|
exports.runRefine = runRefine;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"refine.js","sourceRoot":"","sources":["../../src/commands/refine.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,4CAA6B;AAC7B,gDAAiC;AACjC,yCAAoD;AACpD,gEAA4E;AAC5E,2CAAiD;AACjD,
|
|
1
|
+
{"version":3,"file":"refine.js","sourceRoot":"","sources":["../../src/commands/refine.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,4CAA6B;AAC7B,gDAAiC;AACjC,yCAAoD;AACpD,gEAA4E;AAC5E,2CAAiD;AACjD,qDAAoD;AACpD,6CAA6C;AAS7C,gFAAgF;AAChF,MAAM,2BAA2B,GAAG,CAAC,WAA0B,EAAU,EAAE;IACzE,IAAI,CAAC,WAAW;QAAE,OAAO,CAAC,CAAA;IAC1B,MAAM,OAAO,GAAG,WAAW,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAA;IACxD,OAAO,CAAC,OAAO,EAAE,MAAM,IAAI,CAAC,CAAC,GAAG,CAAC,CAAA;AACnC,CAAC,CAAA;AAEM,MAAM,SAAS,GAAG,KAAK,EAAE,SAAiB,EAAE,IAAmB,EAAiB,EAAE;IACvF,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,YAAY,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAA;IAE5E,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;QAC7B,IAAA,mBAAU,EAAC,8BAA8B,QAAQ,EAAE,CAAC,CAAA;QACpD,OAAM;IACR,CAAC;IAED,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAA;IAC/C,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,aAAa,CAAC,CAAA;IACvD,MAAM,eAAe,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,gBAAgB,CAAC,CAAA;IAE7D,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;QAC7B,IAAA,mBAAU,EAAC,0CAA0C,SAAS,UAAU,CAAC,CAAA;QACzE,OAAM;IACR,CAAC;IACD,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,YAAY,CAAC,EAAE,CAAC;QACjC,IAAA,mBAAU,EAAC,kDAAkD,SAAS,UAAU,CAAC,CAAA;QACjF,OAAM;IACR,CAAC;IACD,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,eAAe,CAAC,EAAE,CAAC;QACpC,IAAA,mBAAU,EAAC,iDAAiD,SAAS,UAAU,CAAC,CAAA;QAChF,OAAM;IACR,CAAC;IAED,MAAM,MAAM,GAAG,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAA;IACjD,MAAM,UAAU,GAAG,EAAE,CAAC,YAAY,CAAC,YAAY,EAAE,OAAO,CAAC,CAAA;IACzD,MAAM,aAAa,GAAG,EAAE,CAAC,YAAY,CAAC,eAAe,EAAE,OAAO,CAAC,CAAA;IAC/D,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAA;IACjD,MAAM,OAAO,GAAG,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,YAAY,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;IACrF,MAAM,aAAa,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,mBAAmB,CAAC,CAAA;IAC9D,MAAM,WAAW,GAAG,EAAE,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,YAAY,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;IAEjG,MAAM,eAAe,GAAG,IAAI,CAAC,eAAe,IAAI,2BAA2B,CAAC,WAAW,CAAC,CAAA;IAExF,MAAM,MAAM,GAAiB;QAC3B,KAAK,EAAE,IAAI,CAAC,KAAK;QACjB,cAAc,EAAE,IAAI,CAAC,OAAO;QAC5B,QAAQ;QACR,OAAO,EAAE,IAAI,CAAC,OAAO,IAAI,IAAI;QAC7B,WAAW;QACX,eAAe;KAChB,CAAA;IAED,IAAA,0BAAa,EAAC,QAAQ,EAAE,cAAc,EAAE,IAAI,EAAE,6BAA6B,eAAe,GAAG,CAAC,CAAA;IAE9F,MAAM,MAAM,GAAG,MAAM,IAAA,2BAAa,EAAC,MAAM,EAAE,UAAU,EAAE,aAAa,EAAE,OAAO,EAAE,MAAM,CAAC,CAAA;IAEtF,IAAA,mBAAU,EAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC,EAAE,MAAM,CAAC,CAAA;IAEpD,IAAA,0BAAa,EAAC,QAAQ,EAAE,iBAAiB,EAAE,IAAI,EAAE,8BAA8B,eAAe,GAAG,EAAE;QACjG,QAAQ,EAAE,MAAM,CAAC,UAAU;QAC3B,MAAM,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,CAAC,WAAW,EAAE,MAAM,EAAE,MAAM,CAAC,KAAK,CAAC,YAAY,EAAE;QAC9E,OAAO,EAAE,MAAM,CAAC,OAAO;KACxB,CAAC,CAAA;IAEF,IAAA,uBAAe,EAAC,QAAQ,EAAE,SAAS,EAAE,QAAQ,CAAC,CAAA;IAE9C,IAAA,kBAAS,EAAC,oDAAoD,eAAe,IAAI,CAAC,CAAA;IAClF,IAAA,kBAAS,EAAC,UAAU,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAA;IAChD,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;IACf,IAAA,kBAAS,EAAC,WAAW,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,SAAS,CAAC,EAAE,CAAC,CAAA;IACtD,IAAA,kBAAS,EAAC,cAAc,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,mBAAmB,CAAC,EAAE,CAAC,CAAA;IACnE,IAAA,kBAAS,EAAC,wBAAwB,SAAS,EAAE,CAAC,CAAA;AAChD,CAAC,CAAA;AAhEY,QAAA,SAAS,aAgErB"}
|
|
@@ -47,7 +47,14 @@ const readBuildFile = (buildDir, filename) => {
|
|
|
47
47
|
const fp = path.join(buildDir, filename);
|
|
48
48
|
return fs.existsSync(fp) ? fs.readFileSync(fp, "utf-8") : null;
|
|
49
49
|
};
|
|
50
|
-
|
|
50
|
+
/** Derive the next iteration number from existing research.md content. */
|
|
51
|
+
const deriveIterationNumber = (existingResearchMd) => {
|
|
52
|
+
if (!existingResearchMd)
|
|
53
|
+
return 1;
|
|
54
|
+
const matches = existingResearchMd.match(/^### Iteration \d+/gm);
|
|
55
|
+
return (matches?.length ?? 0) + 1;
|
|
56
|
+
};
|
|
57
|
+
const runSingleResearch = async (buildName, buildDir, opts, iterationNumber) => {
|
|
51
58
|
const specMd = readBuildFile(buildDir, "spec.md");
|
|
52
59
|
if (!specMd) {
|
|
53
60
|
(0, output_1.printError)(`spec.md not found. Run 'ridgeline spec ${buildName}' first.`);
|
|
@@ -59,7 +66,10 @@ const runSingleResearch = async (buildName, buildDir, opts) => {
|
|
|
59
66
|
return;
|
|
60
67
|
}
|
|
61
68
|
const tasteMd = readBuildFile(buildDir, "taste.md");
|
|
69
|
+
const existingResearchMd = readBuildFile(buildDir, "research.md");
|
|
70
|
+
const changelogMd = readBuildFile(buildDir, "spec.changelog.md");
|
|
62
71
|
const ridgelineDir = path.join(process.cwd(), ".ridgeline");
|
|
72
|
+
const iteration = iterationNumber ?? deriveIterationNumber(existingResearchMd);
|
|
63
73
|
const config = {
|
|
64
74
|
model: opts.model,
|
|
65
75
|
timeoutMinutes: opts.timeout,
|
|
@@ -68,32 +78,36 @@ const runSingleResearch = async (buildName, buildDir, opts) => {
|
|
|
68
78
|
flavour: opts.flavour ?? null,
|
|
69
79
|
isDeep: opts.isDeep,
|
|
70
80
|
networkAllowlist: (0, settings_1.resolveResearchAllowlist)(ridgelineDir),
|
|
81
|
+
existingResearchMd,
|
|
82
|
+
changelogMd,
|
|
83
|
+
iterationNumber: iteration,
|
|
71
84
|
};
|
|
72
|
-
(0, trajectory_1.logTrajectory)(buildDir,
|
|
85
|
+
(0, trajectory_1.logTrajectory)(buildDir, "research_start", null, `Research started (${opts.isDeep ? "deep" : "quick"} mode, iteration ${iteration})`);
|
|
73
86
|
const result = await (0, research_exec_1.invokeResearcher)(specMd, constraintsMd, tasteMd, config);
|
|
74
87
|
// Record costs
|
|
75
88
|
for (let i = 0; i < result.specialistResults.length; i++) {
|
|
76
89
|
(0, budget_1.recordCost)(buildDir, "research", "researcher", i, result.specialistResults[i]);
|
|
77
90
|
}
|
|
78
91
|
(0, budget_1.recordCost)(buildDir, "research", "synthesizer", 0, result.synthesizerResult);
|
|
79
|
-
(0, trajectory_1.logTrajectory)(buildDir,
|
|
92
|
+
(0, trajectory_1.logTrajectory)(buildDir, "research_complete", null, `Research complete (${result.specialistResults.length} specialists, iteration ${iteration})`, {
|
|
80
93
|
duration: result.totalDurationMs,
|
|
81
94
|
tokens: {
|
|
82
95
|
input: result.specialistResults.reduce((sum, r) => sum + r.usage.inputTokens, 0) + result.synthesizerResult.usage.inputTokens,
|
|
83
96
|
output: result.specialistResults.reduce((sum, r) => sum + r.usage.outputTokens, 0) + result.synthesizerResult.usage.outputTokens,
|
|
84
97
|
},
|
|
85
98
|
costUsd: result.totalCostUsd,
|
|
86
|
-
})
|
|
99
|
+
});
|
|
87
100
|
(0, state_1.advancePipeline)(buildDir, buildName, "research");
|
|
88
|
-
(0, output_1.printInfo)(`\nResearch complete: ${result.specialistResults.length} specialist(s) + synthesizer`);
|
|
101
|
+
(0, output_1.printInfo)(`\nResearch complete: ${result.specialistResults.length} specialist(s) + synthesizer (iteration ${iteration})`);
|
|
89
102
|
(0, output_1.printInfo)(`Cost: $${result.totalCostUsd.toFixed(2)}`);
|
|
90
103
|
(0, output_1.printInfo)(`Output: ${path.join(buildDir, "research.md")}`);
|
|
91
104
|
};
|
|
92
|
-
const runSingleRefine = async (buildName, _buildDir, opts) => {
|
|
105
|
+
const runSingleRefine = async (buildName, _buildDir, opts, iterationNumber) => {
|
|
93
106
|
await (0, refine_1.runRefine)(buildName, {
|
|
94
107
|
model: opts.model,
|
|
95
108
|
timeout: opts.timeout,
|
|
96
109
|
flavour: opts.flavour,
|
|
110
|
+
iterationNumber,
|
|
97
111
|
});
|
|
98
112
|
};
|
|
99
113
|
const runResearch = async (buildName, opts) => {
|
|
@@ -108,8 +122,8 @@ const runResearch = async (buildName, opts) => {
|
|
|
108
122
|
(0, output_1.printInfo)(`Auto-research: ${iterations} iteration(s) (${opts.isDeep ? "deep" : "quick"} mode)\n`);
|
|
109
123
|
for (let i = 1; i <= iterations; i++) {
|
|
110
124
|
(0, output_1.printInfo)(`--- Iteration ${i} of ${iterations} ---\n`);
|
|
111
|
-
await runSingleResearch(buildName, buildDir, opts);
|
|
112
|
-
await runSingleRefine(buildName, buildDir, opts);
|
|
125
|
+
await runSingleResearch(buildName, buildDir, opts, i);
|
|
126
|
+
await runSingleRefine(buildName, buildDir, opts, i);
|
|
113
127
|
if (i < iterations) {
|
|
114
128
|
(0, output_1.printInfo)(""); // blank line between iterations
|
|
115
129
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"research.js","sourceRoot":"","sources":["../../src/commands/research.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,4CAA6B;AAC7B,gDAAiC;AACjC,yCAAoD;AACpD,oEAAmF;AACnF,2CAAiD;AACjD,
|
|
1
|
+
{"version":3,"file":"research.js","sourceRoot":"","sources":["../../src/commands/research.ts"],"names":[],"mappings":"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"}
|
package/dist/commands/rewind.js
CHANGED
|
@@ -38,7 +38,7 @@ const fs = __importStar(require("node:fs"));
|
|
|
38
38
|
const path = __importStar(require("node:path"));
|
|
39
39
|
const output_1 = require("../ui/output");
|
|
40
40
|
const state_1 = require("../stores/state");
|
|
41
|
-
const VALID_STAGES = ["shape", "spec", "research", "refine", "plan"];
|
|
41
|
+
const VALID_STAGES = ["shape", "design", "spec", "research", "refine", "plan"];
|
|
42
42
|
const runRewind = (buildName, to) => {
|
|
43
43
|
if (!VALID_STAGES.includes(to)) {
|
|
44
44
|
(0, output_1.printError)(`Invalid stage: ${to}. Must be one of: ${VALID_STAGES.join(", ")}`);
|
|
@@ -67,7 +67,7 @@ const runRewind = (buildName, to) => {
|
|
|
67
67
|
(0, output_1.printInfo)(`Removed ${filesToDelete.length} file(s)`);
|
|
68
68
|
}
|
|
69
69
|
console.log("");
|
|
70
|
-
const ALL_DISPLAY_STAGES = ["shape", "spec", "research", "refine", "plan", "build"];
|
|
70
|
+
const ALL_DISPLAY_STAGES = ["shape", "design", "spec", "research", "refine", "plan", "build"];
|
|
71
71
|
for (const stage of ALL_DISPLAY_STAGES) {
|
|
72
72
|
const status = statusAfter[stage];
|
|
73
73
|
const icon = status === "complete" ? "done" : status === "skipped" ? "skip" : "---";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rewind.js","sourceRoot":"","sources":["../../src/commands/rewind.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,4CAA6B;AAC7B,gDAAiC;AACjC,yCAAoD;AACpD,2CAA6D;AAG7D,MAAM,YAAY,GAAoB,CAAC,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;
|
|
1
|
+
{"version":3,"file":"rewind.js","sourceRoot":"","sources":["../../src/commands/rewind.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,4CAA6B;AAC7B,gDAAiC;AACjC,yCAAoD;AACpD,2CAA6D;AAG7D,MAAM,YAAY,GAAoB,CAAC,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;AAExF,MAAM,SAAS,GAAG,CAAC,SAAiB,EAAE,EAAU,EAAQ,EAAE;IAC/D,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,EAAmB,CAAC,EAAE,CAAC;QAChD,IAAA,mBAAU,EAAC,kBAAkB,EAAE,qBAAqB,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QAC9E,OAAM;IACR,CAAC;IAED,MAAM,WAAW,GAAG,EAAmB,CAAA;IACvC,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,YAAY,CAAC,CAAA;IAC3D,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAA;IAE7D,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;QAC7B,IAAA,mBAAU,EAAC,8BAA8B,QAAQ,EAAE,CAAC,CAAA;QACpD,OAAM;IACR,CAAC;IAED,IAAA,kBAAS,EAAC,oBAAoB,SAAS,SAAS,WAAW,EAAE,CAAC,CAAA;IAE9D,MAAM,aAAa,GAAG,IAAA,gBAAQ,EAAC,QAAQ,EAAE,SAAS,EAAE,WAAW,CAAC,CAAA;IAEhE,0BAA0B;IAC1B,KAAK,MAAM,EAAE,IAAI,aAAa,EAAE,CAAC;QAC/B,IAAI,CAAC;YACH,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,CAAA;QACnB,CAAC;QAAC,MAAM,CAAC;YACP,2BAA2B;QAC7B,CAAC;IACH,CAAC;IAED,MAAM,WAAW,GAAG,IAAA,yBAAiB,EAAC,QAAQ,CAAC,CAAA;IAE/C,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC7B,IAAA,kBAAS,EAAC,WAAW,aAAa,CAAC,MAAM,UAAU,CAAC,CAAA;IACtD,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;IACf,MAAM,kBAAkB,GAAoB,CAAC,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,CAAC,CAAA;IAC9G,KAAK,MAAM,KAAK,IAAI,kBAAkB,EAAE,CAAC;QACvC,MAAM,MAAM,GAAG,WAAW,CAAC,KAAK,CAAC,CAAA;QACjC,MAAM,IAAI,GAAG,MAAM,KAAK,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAA;QACnF,OAAO,CAAC,GAAG,CAAC,KAAK,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,IAAI,EAAE,CAAC,CAAA;IAC9C,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;IACf,IAAA,kBAAS,EAAC,mBAAmB,SAAS,EAAE,CAAC,CAAA;AAC3C,CAAC,CAAA;AA5CY,QAAA,SAAS,aA4CrB"}
|