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.
- package/README.md +1 -14
- package/dist/agents/core/builder.md +15 -15
- package/dist/agents/core/planner.md +12 -12
- package/dist/agents/core/reviewer.md +19 -19
- package/dist/agents/core/shaper.md +44 -45
- package/dist/agents/core/specifier.md +20 -23
- package/dist/agents/planners/context.md +10 -10
- package/dist/agents/planners/simplicity.md +1 -1
- package/dist/agents/planners/thoroughness.md +2 -2
- package/dist/agents/planners/velocity.md +2 -2
- package/dist/agents/specialists/auditor.md +34 -33
- package/dist/agents/specialists/explorer.md +74 -0
- package/dist/agents/specialists/tester.md +24 -24
- package/dist/agents/specialists/verifier.md +17 -20
- package/dist/agents/specifiers/clarity.md +1 -1
- package/dist/agents/specifiers/completeness.md +2 -2
- package/dist/agents/specifiers/pragmatism.md +2 -2
- package/dist/cli.js +15 -10
- package/dist/cli.js.map +1 -1
- package/dist/commands/build.js +42 -75
- package/dist/commands/build.js.map +1 -1
- package/dist/commands/clean.d.ts +1 -1
- package/dist/commands/clean.js +2 -5
- package/dist/commands/clean.js.map +1 -1
- package/dist/commands/create.d.ts +1 -0
- package/dist/commands/create.js +5 -1
- package/dist/commands/create.js.map +1 -1
- package/dist/commands/dry-run.js +1 -1
- package/dist/commands/dry-run.js.map +1 -1
- package/dist/commands/plan.js +3 -3
- package/dist/commands/plan.js.map +1 -1
- package/dist/commands/rewind.js +1 -6
- package/dist/commands/rewind.js.map +1 -1
- package/dist/commands/shape.d.ts +1 -0
- package/dist/commands/shape.js +9 -7
- package/dist/commands/shape.js.map +1 -1
- package/dist/commands/spec.d.ts +1 -0
- package/dist/commands/spec.js +2 -1
- package/dist/commands/spec.js.map +1 -1
- package/dist/config.js +3 -3
- package/dist/config.js.map +1 -1
- package/dist/engine/claude/claude.exec.js +2 -2
- package/dist/engine/claude/stream.display.d.ts +17 -0
- package/dist/engine/claude/stream.display.js +101 -0
- package/dist/engine/claude/stream.display.js.map +1 -0
- package/dist/engine/claude/stream.parse.d.ts +21 -0
- package/dist/engine/claude/stream.parse.js +119 -0
- package/dist/engine/claude/stream.parse.js.map +1 -0
- package/dist/engine/claude/stream.result.d.ts +6 -0
- package/dist/engine/claude/stream.result.js +61 -0
- package/dist/engine/claude/stream.result.js.map +1 -0
- package/dist/engine/discovery/agent.registry.d.ts +27 -0
- package/dist/engine/discovery/agent.registry.js +152 -0
- package/dist/engine/discovery/agent.registry.js.map +1 -0
- package/dist/engine/discovery/agent.scan.d.ts +0 -1
- package/dist/engine/discovery/agent.scan.js +1 -20
- package/dist/engine/discovery/agent.scan.js.map +1 -1
- package/dist/engine/discovery/flavour.resolve.d.ts +11 -0
- package/dist/engine/discovery/flavour.resolve.js +98 -0
- package/dist/engine/discovery/flavour.resolve.js.map +1 -0
- package/dist/engine/index.d.ts +6 -3
- package/dist/engine/index.js +12 -9
- package/dist/engine/index.js.map +1 -1
- package/dist/engine/pipeline/build.exec.js +7 -5
- package/dist/engine/pipeline/build.exec.js.map +1 -1
- package/dist/engine/pipeline/ensemble.exec.d.ts +3 -4
- package/dist/engine/pipeline/ensemble.exec.js +12 -104
- package/dist/engine/pipeline/ensemble.exec.js.map +1 -1
- package/dist/engine/pipeline/phase.sequence.js +69 -67
- package/dist/engine/pipeline/phase.sequence.js.map +1 -1
- package/dist/engine/pipeline/pipeline.shared.js +5 -4
- package/dist/engine/pipeline/pipeline.shared.js.map +1 -1
- package/dist/engine/pipeline/review.exec.js +9 -7
- 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 +5 -3
- package/dist/engine/pipeline/specify.exec.js.map +1 -1
- package/dist/engine/worktree.d.ts +0 -8
- package/dist/engine/worktree.js +2 -163
- package/dist/engine/worktree.js.map +1 -1
- package/dist/flavours/data-analysis/core/builder.md +119 -0
- package/dist/flavours/data-analysis/core/planner.md +102 -0
- package/dist/flavours/data-analysis/core/reviewer.md +148 -0
- package/dist/flavours/data-analysis/core/shaper.md +139 -0
- package/dist/flavours/data-analysis/core/specifier.md +74 -0
- package/dist/flavours/data-analysis/planners/context.md +50 -0
- package/dist/flavours/data-analysis/planners/simplicity.md +7 -0
- package/dist/flavours/data-analysis/planners/thoroughness.md +7 -0
- package/dist/flavours/data-analysis/planners/velocity.md +7 -0
- package/dist/flavours/data-analysis/specialists/auditor.md +94 -0
- package/dist/flavours/data-analysis/specialists/explorer.md +93 -0
- package/dist/flavours/data-analysis/specialists/tester.md +107 -0
- package/dist/flavours/data-analysis/specialists/verifier.md +103 -0
- package/dist/flavours/data-analysis/specifiers/clarity.md +7 -0
- package/dist/flavours/data-analysis/specifiers/completeness.md +15 -0
- package/dist/flavours/data-analysis/specifiers/pragmatism.md +7 -0
- package/dist/flavours/game-dev/core/builder.md +104 -0
- package/dist/flavours/game-dev/core/planner.md +90 -0
- package/dist/flavours/game-dev/core/reviewer.md +151 -0
- package/dist/flavours/game-dev/core/shaper.md +139 -0
- package/dist/flavours/game-dev/core/specifier.md +73 -0
- package/dist/flavours/game-dev/planners/context.md +50 -0
- package/dist/flavours/game-dev/planners/simplicity.md +7 -0
- package/dist/flavours/game-dev/planners/thoroughness.md +7 -0
- package/dist/flavours/game-dev/planners/velocity.md +7 -0
- package/dist/flavours/game-dev/specialists/auditor.md +91 -0
- package/dist/flavours/game-dev/specialists/explorer.md +78 -0
- package/dist/flavours/game-dev/specialists/tester.md +73 -0
- package/dist/flavours/game-dev/specialists/verifier.md +104 -0
- package/dist/flavours/game-dev/specifiers/clarity.md +7 -0
- package/dist/flavours/game-dev/specifiers/completeness.md +7 -0
- package/dist/flavours/game-dev/specifiers/pragmatism.md +7 -0
- package/dist/flavours/legal-drafting/core/builder.md +118 -0
- package/dist/flavours/legal-drafting/core/planner.md +92 -0
- package/dist/flavours/legal-drafting/core/reviewer.md +150 -0
- package/dist/flavours/legal-drafting/core/shaper.md +137 -0
- package/dist/flavours/legal-drafting/core/specifier.md +68 -0
- package/dist/flavours/legal-drafting/planners/context.md +48 -0
- package/dist/flavours/legal-drafting/planners/simplicity.md +7 -0
- package/dist/flavours/legal-drafting/planners/thoroughness.md +7 -0
- package/dist/flavours/legal-drafting/planners/velocity.md +7 -0
- package/dist/flavours/legal-drafting/specialists/auditor.md +92 -0
- package/dist/flavours/legal-drafting/specialists/explorer.md +78 -0
- package/dist/flavours/legal-drafting/specialists/tester.md +76 -0
- package/dist/flavours/legal-drafting/specialists/verifier.md +111 -0
- package/dist/flavours/legal-drafting/specifiers/clarity.md +7 -0
- package/dist/flavours/legal-drafting/specifiers/completeness.md +7 -0
- package/dist/flavours/legal-drafting/specifiers/pragmatism.md +7 -0
- package/dist/flavours/machine-learning/core/builder.md +127 -0
- package/dist/flavours/machine-learning/core/planner.md +90 -0
- package/dist/flavours/machine-learning/core/reviewer.md +152 -0
- package/dist/flavours/machine-learning/core/shaper.md +141 -0
- package/dist/flavours/machine-learning/core/specifier.md +71 -0
- package/dist/flavours/machine-learning/planners/context.md +49 -0
- package/dist/flavours/machine-learning/planners/simplicity.md +7 -0
- package/dist/flavours/machine-learning/planners/thoroughness.md +7 -0
- package/dist/flavours/machine-learning/planners/velocity.md +7 -0
- package/dist/flavours/machine-learning/specialists/auditor.md +96 -0
- package/dist/flavours/machine-learning/specialists/explorer.md +81 -0
- package/dist/flavours/machine-learning/specialists/tester.md +82 -0
- package/dist/flavours/machine-learning/specialists/verifier.md +100 -0
- package/dist/flavours/machine-learning/specifiers/clarity.md +7 -0
- package/dist/flavours/machine-learning/specifiers/completeness.md +7 -0
- package/dist/flavours/machine-learning/specifiers/pragmatism.md +7 -0
- package/dist/flavours/mobile-app/core/builder.md +108 -0
- package/dist/flavours/mobile-app/core/planner.md +90 -0
- package/dist/flavours/mobile-app/core/reviewer.md +144 -0
- package/dist/flavours/mobile-app/core/shaper.md +146 -0
- package/dist/flavours/mobile-app/core/specifier.md +73 -0
- package/dist/flavours/mobile-app/planners/context.md +41 -0
- package/dist/flavours/mobile-app/planners/simplicity.md +7 -0
- package/dist/flavours/mobile-app/planners/thoroughness.md +7 -0
- package/dist/flavours/mobile-app/planners/velocity.md +7 -0
- package/dist/flavours/mobile-app/specialists/auditor.md +92 -0
- package/dist/flavours/mobile-app/specialists/explorer.md +84 -0
- package/dist/flavours/mobile-app/specialists/tester.md +75 -0
- package/dist/flavours/mobile-app/specialists/verifier.md +114 -0
- package/dist/flavours/mobile-app/specifiers/clarity.md +7 -0
- package/dist/flavours/mobile-app/specifiers/completeness.md +7 -0
- package/dist/flavours/mobile-app/specifiers/pragmatism.md +7 -0
- package/dist/flavours/music-composition/core/builder.md +112 -0
- package/dist/flavours/music-composition/core/planner.md +102 -0
- package/dist/flavours/music-composition/core/reviewer.md +139 -0
- package/dist/flavours/music-composition/core/shaper.md +139 -0
- package/dist/flavours/music-composition/core/specifier.md +72 -0
- package/dist/flavours/music-composition/planners/context.md +39 -0
- package/dist/flavours/music-composition/planners/simplicity.md +7 -0
- package/dist/flavours/music-composition/planners/thoroughness.md +7 -0
- package/dist/flavours/music-composition/planners/velocity.md +7 -0
- package/dist/flavours/music-composition/specialists/auditor.md +90 -0
- package/dist/flavours/music-composition/specialists/explorer.md +87 -0
- package/dist/flavours/music-composition/specialists/tester.md +74 -0
- package/dist/flavours/music-composition/specialists/verifier.md +89 -0
- package/dist/flavours/music-composition/specifiers/clarity.md +7 -0
- package/dist/flavours/music-composition/specifiers/completeness.md +7 -0
- package/dist/flavours/music-composition/specifiers/pragmatism.md +7 -0
- package/dist/flavours/novel-writing/core/builder.md +116 -0
- package/dist/flavours/novel-writing/core/planner.md +92 -0
- package/dist/flavours/novel-writing/core/reviewer.md +152 -0
- package/dist/flavours/novel-writing/core/shaper.md +143 -0
- package/dist/flavours/novel-writing/core/specifier.md +76 -0
- package/dist/flavours/novel-writing/planners/context.md +39 -0
- package/dist/flavours/novel-writing/planners/simplicity.md +7 -0
- package/dist/flavours/novel-writing/planners/thoroughness.md +7 -0
- package/dist/flavours/novel-writing/planners/velocity.md +7 -0
- package/dist/flavours/novel-writing/specialists/auditor.md +87 -0
- package/dist/flavours/novel-writing/specialists/explorer.md +83 -0
- package/dist/flavours/novel-writing/specialists/tester.md +89 -0
- package/dist/flavours/novel-writing/specialists/verifier.md +122 -0
- package/dist/flavours/novel-writing/specifiers/clarity.md +7 -0
- package/dist/flavours/novel-writing/specifiers/completeness.md +7 -0
- package/dist/flavours/novel-writing/specifiers/pragmatism.md +7 -0
- package/dist/flavours/screenwriting/core/builder.md +115 -0
- package/dist/flavours/screenwriting/core/planner.md +92 -0
- package/dist/flavours/screenwriting/core/reviewer.md +151 -0
- package/dist/flavours/screenwriting/core/shaper.md +143 -0
- package/dist/flavours/screenwriting/core/specifier.md +78 -0
- package/dist/flavours/screenwriting/planners/context.md +52 -0
- package/dist/flavours/screenwriting/planners/simplicity.md +7 -0
- package/dist/flavours/screenwriting/planners/thoroughness.md +7 -0
- package/dist/flavours/screenwriting/planners/velocity.md +7 -0
- package/dist/flavours/screenwriting/specialists/auditor.md +98 -0
- package/dist/flavours/screenwriting/specialists/explorer.md +87 -0
- package/dist/flavours/screenwriting/specialists/tester.md +90 -0
- package/dist/flavours/screenwriting/specialists/verifier.md +129 -0
- package/dist/flavours/screenwriting/specifiers/clarity.md +7 -0
- package/dist/flavours/screenwriting/specifiers/completeness.md +7 -0
- package/dist/flavours/screenwriting/specifiers/pragmatism.md +7 -0
- package/dist/flavours/security-audit/core/builder.md +123 -0
- package/dist/flavours/security-audit/core/planner.md +92 -0
- package/dist/flavours/security-audit/core/reviewer.md +150 -0
- package/dist/flavours/security-audit/core/shaper.md +145 -0
- package/dist/flavours/security-audit/core/specifier.md +69 -0
- package/dist/flavours/security-audit/planners/context.md +51 -0
- package/dist/flavours/security-audit/planners/simplicity.md +7 -0
- package/dist/flavours/security-audit/planners/thoroughness.md +7 -0
- package/dist/flavours/security-audit/planners/velocity.md +7 -0
- package/dist/flavours/security-audit/specialists/auditor.md +100 -0
- package/dist/flavours/security-audit/specialists/explorer.md +84 -0
- package/dist/flavours/security-audit/specialists/tester.md +80 -0
- package/dist/flavours/security-audit/specialists/verifier.md +101 -0
- package/dist/flavours/security-audit/specifiers/clarity.md +7 -0
- package/dist/flavours/security-audit/specifiers/completeness.md +7 -0
- package/dist/flavours/security-audit/specifiers/pragmatism.md +7 -0
- package/dist/flavours/software-engineering/core/builder.md +100 -0
- package/dist/flavours/software-engineering/core/planner.md +90 -0
- package/dist/flavours/software-engineering/core/reviewer.md +137 -0
- package/dist/flavours/software-engineering/core/shaper.md +137 -0
- package/dist/flavours/software-engineering/core/specifier.md +69 -0
- package/dist/flavours/software-engineering/planners/context.md +37 -0
- package/dist/flavours/software-engineering/planners/simplicity.md +7 -0
- package/dist/flavours/software-engineering/planners/thoroughness.md +7 -0
- package/dist/flavours/software-engineering/planners/velocity.md +7 -0
- package/dist/flavours/software-engineering/specialists/auditor.md +88 -0
- package/dist/{agents/specialists/scout.md → flavours/software-engineering/specialists/explorer.md} +2 -2
- package/dist/flavours/software-engineering/specialists/tester.md +72 -0
- package/dist/flavours/software-engineering/specialists/verifier.md +89 -0
- package/dist/flavours/software-engineering/specifiers/clarity.md +7 -0
- package/dist/flavours/software-engineering/specifiers/completeness.md +7 -0
- package/dist/flavours/software-engineering/specifiers/pragmatism.md +7 -0
- package/dist/flavours/technical-writing/core/builder.md +119 -0
- package/dist/flavours/technical-writing/core/planner.md +102 -0
- package/dist/flavours/technical-writing/core/reviewer.md +138 -0
- package/dist/flavours/technical-writing/core/shaper.md +137 -0
- package/dist/flavours/technical-writing/core/specifier.md +69 -0
- package/dist/flavours/technical-writing/planners/context.md +49 -0
- package/dist/flavours/technical-writing/planners/simplicity.md +7 -0
- package/dist/flavours/technical-writing/planners/thoroughness.md +7 -0
- package/dist/flavours/technical-writing/planners/velocity.md +7 -0
- package/dist/flavours/technical-writing/specialists/auditor.md +94 -0
- package/dist/flavours/technical-writing/specialists/explorer.md +85 -0
- package/dist/flavours/technical-writing/specialists/tester.md +93 -0
- package/dist/flavours/technical-writing/specialists/verifier.md +113 -0
- package/dist/flavours/technical-writing/specifiers/clarity.md +7 -0
- package/dist/flavours/technical-writing/specifiers/completeness.md +7 -0
- package/dist/flavours/technical-writing/specifiers/pragmatism.md +7 -0
- package/dist/flavours/test-suite/core/builder.md +114 -0
- package/dist/flavours/test-suite/core/planner.md +101 -0
- package/dist/flavours/test-suite/core/reviewer.md +161 -0
- package/dist/flavours/test-suite/core/shaper.md +144 -0
- package/dist/flavours/test-suite/core/specifier.md +71 -0
- package/dist/flavours/test-suite/planners/context.md +52 -0
- package/dist/flavours/test-suite/planners/simplicity.md +7 -0
- package/dist/flavours/test-suite/planners/thoroughness.md +7 -0
- package/dist/flavours/test-suite/planners/velocity.md +7 -0
- package/dist/flavours/test-suite/specialists/auditor.md +85 -0
- package/dist/flavours/test-suite/specialists/explorer.md +88 -0
- package/dist/flavours/test-suite/specialists/tester.md +88 -0
- package/dist/flavours/test-suite/specialists/verifier.md +100 -0
- package/dist/flavours/test-suite/specifiers/clarity.md +7 -0
- package/dist/flavours/test-suite/specifiers/completeness.md +7 -0
- package/dist/flavours/test-suite/specifiers/pragmatism.md +7 -0
- package/dist/flavours/translation/core/builder.md +120 -0
- package/dist/flavours/translation/core/planner.md +90 -0
- package/dist/flavours/translation/core/reviewer.md +151 -0
- package/dist/flavours/translation/core/shaper.md +137 -0
- package/dist/flavours/translation/core/specifier.md +71 -0
- package/dist/flavours/translation/planners/context.md +53 -0
- package/dist/flavours/translation/planners/simplicity.md +7 -0
- package/dist/flavours/translation/planners/thoroughness.md +7 -0
- package/dist/flavours/translation/planners/velocity.md +7 -0
- package/dist/flavours/translation/specialists/auditor.md +109 -0
- package/dist/flavours/translation/specialists/explorer.md +98 -0
- package/dist/flavours/translation/specialists/tester.md +82 -0
- package/dist/flavours/translation/specialists/verifier.md +121 -0
- package/dist/flavours/translation/specifiers/clarity.md +7 -0
- package/dist/flavours/translation/specifiers/completeness.md +7 -0
- package/dist/flavours/translation/specifiers/pragmatism.md +7 -0
- package/dist/stores/budget.d.ts +5 -0
- package/dist/stores/budget.js +74 -0
- package/dist/stores/budget.js.map +1 -0
- package/dist/stores/feedback.io.d.ts +6 -0
- package/dist/stores/feedback.io.js +64 -0
- package/dist/stores/feedback.io.js.map +1 -0
- package/dist/stores/feedback.verdict.d.ts +4 -0
- package/dist/stores/feedback.verdict.js +179 -0
- package/dist/stores/feedback.verdict.js.map +1 -0
- package/dist/stores/handoff.d.ts +2 -0
- package/dist/stores/handoff.js +54 -0
- package/dist/stores/handoff.js.map +1 -0
- package/dist/stores/index.d.ts +9 -0
- package/dist/stores/index.js +49 -0
- package/dist/stores/index.js.map +1 -0
- package/dist/stores/inputs.d.ts +2 -0
- package/dist/stores/inputs.js +64 -0
- package/dist/stores/inputs.js.map +1 -0
- package/dist/stores/phases.d.ts +15 -0
- package/dist/stores/phases.js +81 -0
- package/dist/stores/phases.js.map +1 -0
- package/dist/stores/settings.d.ts +12 -0
- package/dist/stores/settings.js +85 -0
- package/dist/stores/settings.js.map +1 -0
- package/dist/stores/state.d.ts +20 -0
- package/dist/stores/state.js +264 -0
- package/dist/stores/state.js.map +1 -0
- package/dist/stores/tags.d.ts +6 -0
- package/dist/stores/tags.js +34 -0
- package/dist/stores/tags.js.map +1 -0
- package/dist/stores/trajectory.d.ts +11 -0
- package/dist/stores/trajectory.js +66 -0
- package/dist/stores/trajectory.js.map +1 -0
- package/dist/types.d.ts +1 -2
- 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,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,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[];
|