@neonwatty/limner 0.1.5 → 0.1.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 +27 -1
- package/dist/commands/compare-image-reference.d.ts +3 -0
- package/dist/commands/compare-image-reference.js +16 -1
- package/dist/commands/compare-image-reference.js.map +1 -1
- package/dist/commands/compare-output.d.ts +2 -0
- package/dist/commands/compare-output.js +20 -0
- package/dist/commands/compare-output.js.map +1 -0
- package/dist/commands/compare.d.ts +3 -0
- package/dist/commands/compare.js +10 -19
- package/dist/commands/compare.js.map +1 -1
- package/dist/commands/ledger.d.ts +4 -1
- package/dist/commands/loop-actions.d.ts +22 -0
- package/dist/commands/loop-actions.js +54 -0
- package/dist/commands/loop-actions.js.map +1 -0
- package/dist/commands/loop-cli.js +96 -2
- package/dist/commands/loop-cli.js.map +1 -1
- package/dist/commands/loop-comparison-adapters.d.ts +3 -0
- package/dist/commands/loop-comparison-adapters.js +15 -1
- package/dist/commands/loop-comparison-adapters.js.map +1 -1
- package/dist/commands/loop-task.d.ts +17 -0
- package/dist/commands/loop-task.js +95 -0
- package/dist/commands/loop-task.js.map +1 -0
- package/dist/commands/loop.d.ts +3 -1
- package/dist/commands/loop.js +31 -14
- package/dist/commands/loop.js.map +1 -1
- package/dist/core/agent-comparison-pack.d.ts +13 -0
- package/dist/core/agent-comparison-pack.js +27 -21
- package/dist/core/agent-comparison-pack.js.map +1 -1
- package/dist/core/agent-comparison-response.d.ts +19 -0
- package/dist/core/agent-comparison-response.js +34 -0
- package/dist/core/agent-comparison-response.js.map +1 -0
- package/dist/core/agent-task-brief.d.ts +30 -0
- package/dist/core/agent-task-brief.js +158 -0
- package/dist/core/agent-task-brief.js.map +1 -0
- package/dist/core/comparison-artifacts.d.ts +12 -0
- package/dist/core/comparison-artifacts.js +50 -0
- package/dist/core/comparison-artifacts.js.map +1 -0
- package/dist/core/current-artifacts.d.ts +14 -0
- package/dist/core/current-artifacts.js +16 -0
- package/dist/core/current-artifacts.js.map +1 -0
- package/dist/core/ledger-agent-responses.d.ts +21 -0
- package/dist/core/ledger-agent-responses.js +13 -0
- package/dist/core/ledger-agent-responses.js.map +1 -0
- package/dist/core/ledger-db.js +28 -0
- package/dist/core/ledger-db.js.map +1 -1
- package/dist/core/ledger-events.js +46 -7
- package/dist/core/ledger-events.js.map +1 -1
- package/dist/core/ledger-markdown.d.ts +23 -4
- package/dist/core/ledger-markdown.js +133 -4
- package/dist/core/ledger-markdown.js.map +1 -1
- package/dist/core/ledger-queries.d.ts +5 -1
- package/dist/core/ledger-queries.js +14 -4
- package/dist/core/ledger-queries.js.map +1 -1
- package/dist/core/ledger-store.d.ts +11 -3
- package/dist/core/ledger-store.js +4 -0
- package/dist/core/ledger-store.js.map +1 -1
- package/dist/core/loop-rerun-command.d.ts +4 -0
- package/dist/core/loop-rerun-command.js +36 -0
- package/dist/core/loop-rerun-command.js.map +1 -0
- package/dist/core/runtime-context.d.ts +1 -0
- package/dist/core/runtime-context.js +18 -0
- package/dist/core/runtime-context.js.map +1 -0
- package/dist/schemas/ledger.d.ts +33 -0
- package/dist/schemas/ledger.js +13 -0
- package/dist/schemas/ledger.js.map +1 -1
- package/docs/agent-workflow.md +31 -1
- package/docs/superpowers/plans/2026-06-13-agent-response-sqlite.md +70 -0
- package/docs/superpowers/plans/2026-06-13-loop-action-ledger.md +257 -0
- package/package.json +1 -1
- package/skills/limner/SKILL.md +15 -4
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
import { existsSync } from 'node:fs';
|
|
2
|
+
import { buildAgentTaskBrief } from '../core/agent-task-brief.js';
|
|
3
|
+
import { openLedgerDatabase } from '../core/ledger-db.js';
|
|
4
|
+
import { resolveLedgerPaths } from '../core/ledger-paths.js';
|
|
5
|
+
import { buildLoopCompareRerunCommand } from '../core/loop-rerun-command.js';
|
|
6
|
+
import { createLedgerStore } from '../core/ledger-store.js';
|
|
7
|
+
import { ledgerActionExecutorSchema } from '../schemas/ledger.js';
|
|
8
|
+
export async function getLoopTask(input) {
|
|
9
|
+
return withStoreAsync(input.ledgerEnv, async (store) => {
|
|
10
|
+
const format = taskOutputFormat(input.format);
|
|
11
|
+
const desiredExecutor = ledgerActionExecutorSchema.parse(input.executor ?? 'subagent');
|
|
12
|
+
const trajectory = store.resolveTrajectory(selector(input));
|
|
13
|
+
const exported = store.exportTrajectoryJson(trajectory.trajectoryId);
|
|
14
|
+
const latestComparison = latestValidatedComparison(exported);
|
|
15
|
+
if (!latestComparison.ok)
|
|
16
|
+
throw new Error(latestComparisonError(latestComparison));
|
|
17
|
+
const brief = await buildAgentTaskBrief({
|
|
18
|
+
trajectoryId: trajectory.trajectoryId,
|
|
19
|
+
target: trajectory.target,
|
|
20
|
+
mode: trajectory.mode,
|
|
21
|
+
workspaceRoot: input.workspaceRoot ?? process.cwd(),
|
|
22
|
+
comparisonSummaryPath: latestComparison.summaryPath,
|
|
23
|
+
sourceRunId: latestComparison.runId,
|
|
24
|
+
desiredExecutor,
|
|
25
|
+
rerunCommand: buildLoopCompareRerunCommand(trajectory, latestComparison.inputsSummary),
|
|
26
|
+
});
|
|
27
|
+
store.appendEvent({
|
|
28
|
+
trajectoryId: trajectory.trajectoryId,
|
|
29
|
+
iterationId: trajectory.activeIterationId ?? undefined,
|
|
30
|
+
eventType: 'loop.task.viewed',
|
|
31
|
+
actor: 'agent',
|
|
32
|
+
command: 'loop task',
|
|
33
|
+
resultStatus: 'ok',
|
|
34
|
+
inputsSummary: JSON.stringify({ sourceRunId: latestComparison.runId, desiredExecutor }),
|
|
35
|
+
});
|
|
36
|
+
return { output: format === 'json' ? `${JSON.stringify(brief.json, null, 2)}\n` : brief.markdown };
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
async function withStoreAsync(env, callback) {
|
|
40
|
+
const db = openLedgerDatabase({ databasePath: resolveLedgerPaths(env).databasePath });
|
|
41
|
+
try {
|
|
42
|
+
return await callback(createLedgerStore(db));
|
|
43
|
+
}
|
|
44
|
+
finally {
|
|
45
|
+
db.close();
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
function selector(input) {
|
|
49
|
+
return { trajectoryId: input.trajectoryId, target: input.target, mode: input.mode };
|
|
50
|
+
}
|
|
51
|
+
function taskOutputFormat(format) {
|
|
52
|
+
if (format === undefined || format === 'markdown' || format === 'json')
|
|
53
|
+
return format ?? 'markdown';
|
|
54
|
+
throw new Error(`Unsupported loop task format: ${format}`);
|
|
55
|
+
}
|
|
56
|
+
function latestValidatedComparison(exported) {
|
|
57
|
+
for (const event of [...exported.events].reverse()) {
|
|
58
|
+
if (event.eventType !== 'loop.compare.validated' || event.resultStatus !== 'validated')
|
|
59
|
+
continue;
|
|
60
|
+
if (!event.runId)
|
|
61
|
+
return { ok: false, reason: 'missing-run-id' };
|
|
62
|
+
const summary = parseArtifactRefs(event.artifactRefsJson).find((artifact) => artifact.kind === 'comparison-summary');
|
|
63
|
+
if (!summary)
|
|
64
|
+
return { ok: false, reason: 'missing-summary-artifact', runId: event.runId };
|
|
65
|
+
if (summary.exists === false)
|
|
66
|
+
return { ok: false, reason: 'summary-marked-missing', runId: event.runId, summaryPath: summary.path };
|
|
67
|
+
if (!existsSync(summary.path))
|
|
68
|
+
return { ok: false, reason: 'summary-missing-on-disk', runId: event.runId, summaryPath: summary.path };
|
|
69
|
+
return { ok: true, summaryPath: summary.path, inputsSummary: event.inputsSummary, runId: event.runId };
|
|
70
|
+
}
|
|
71
|
+
return { ok: false, reason: 'none' };
|
|
72
|
+
}
|
|
73
|
+
function latestComparisonError(result) {
|
|
74
|
+
switch (result.reason) {
|
|
75
|
+
case 'none':
|
|
76
|
+
return 'No validated comparison summary found. Write agent-response.json, then run limner loop compare first.';
|
|
77
|
+
case 'missing-run-id':
|
|
78
|
+
return 'Latest validated comparison is missing a run id, so loop task cannot create a sourceRunId.';
|
|
79
|
+
case 'missing-summary-artifact':
|
|
80
|
+
return `Latest validated comparison run ${result.runId} did not include a comparison-summary artifact. Rerun limner loop compare.`;
|
|
81
|
+
case 'summary-marked-missing':
|
|
82
|
+
return `Latest validated comparison run ${result.runId} has a comparison summary marked missing: ${result.summaryPath}. Rerun limner loop compare.`;
|
|
83
|
+
case 'summary-missing-on-disk':
|
|
84
|
+
return `Latest validated comparison run ${result.runId} references a comparison summary that is missing on disk: ${result.summaryPath}. Rerun limner loop compare.`;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
function parseArtifactRefs(raw) {
|
|
88
|
+
if (!raw)
|
|
89
|
+
return [];
|
|
90
|
+
const parsed = JSON.parse(raw);
|
|
91
|
+
return Array.isArray(parsed)
|
|
92
|
+
? parsed.filter((value) => typeof value === 'object' && value !== null && 'path' in value && 'kind' in value && typeof value.path === 'string' && typeof value.kind === 'string')
|
|
93
|
+
: [];
|
|
94
|
+
}
|
|
95
|
+
//# sourceMappingURL=loop-task.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loop-task.js","sourceRoot":"","sources":["../../src/commands/loop-task.ts"],"names":[],"mappings":"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"}
|
package/dist/commands/loop.d.ts
CHANGED
|
@@ -25,6 +25,9 @@ export type CompareLoopInput = TrajectorySelector & {
|
|
|
25
25
|
headed?: boolean;
|
|
26
26
|
fullPage?: boolean;
|
|
27
27
|
};
|
|
28
|
+
export { getLoopTask } from './loop-task.js';
|
|
29
|
+
export { recordLoopAction } from './loop-actions.js';
|
|
30
|
+
export type { LoopActionInput } from './loop-actions.js';
|
|
28
31
|
export declare function startLoop(input: StartLoopInput): {
|
|
29
32
|
trajectoryId: string;
|
|
30
33
|
iterationId: string | null;
|
|
@@ -38,4 +41,3 @@ export declare function advanceLoop(input: TrajectorySelector): {
|
|
|
38
41
|
};
|
|
39
42
|
export declare function closeLoop(input: TrajectorySelector): import("../core/ledger-store.js").TrajectorySummary;
|
|
40
43
|
export declare function compareLoop(input: CompareLoopInput): Promise<import("./loop-comparison-adapters.js").LoopCompareResult>;
|
|
41
|
-
export {};
|
package/dist/commands/loop.js
CHANGED
|
@@ -2,8 +2,11 @@ import { ledgerModeSchema } from '../schemas/ledger.js';
|
|
|
2
2
|
import { openLedgerDatabase } from '../core/ledger-db.js';
|
|
3
3
|
import { defaultLoopInstructions } from '../core/loop-instructions.js';
|
|
4
4
|
import { resolveLedgerPaths } from '../core/ledger-paths.js';
|
|
5
|
+
import { getRuntimeContext } from '../core/runtime-context.js';
|
|
5
6
|
import { createLedgerStore } from '../core/ledger-store.js';
|
|
6
7
|
import { runLoopComparison } from './loop-comparison-adapters.js';
|
|
8
|
+
export { getLoopTask } from './loop-task.js';
|
|
9
|
+
export { recordLoopAction } from './loop-actions.js';
|
|
7
10
|
export function startLoop(input) {
|
|
8
11
|
return withStore(input.ledgerEnv, (store) => {
|
|
9
12
|
const mode = ledgerModeSchema.parse(input.mode);
|
|
@@ -65,16 +68,10 @@ export function getLoopStatus(input) {
|
|
|
65
68
|
});
|
|
66
69
|
}
|
|
67
70
|
export function advanceLoop(input) {
|
|
68
|
-
return withStore(input.ledgerEnv, (store) =>
|
|
69
|
-
const trajectory = store.resolveTrajectory(selector(input));
|
|
70
|
-
return store.advanceIteration(trajectory.trajectoryId);
|
|
71
|
-
});
|
|
71
|
+
return withStore(input.ledgerEnv, (store) => store.advanceIteration(store.resolveTrajectory(selector(input)).trajectoryId));
|
|
72
72
|
}
|
|
73
73
|
export function closeLoop(input) {
|
|
74
|
-
return withStore(input.ledgerEnv, (store) =>
|
|
75
|
-
const trajectory = store.resolveTrajectory(selector(input));
|
|
76
|
-
return store.closeTrajectory(trajectory.trajectoryId);
|
|
77
|
-
});
|
|
74
|
+
return withStore(input.ledgerEnv, (store) => store.closeTrajectory(store.resolveTrajectory(selector(input)).trajectoryId));
|
|
78
75
|
}
|
|
79
76
|
export async function compareLoop(input) {
|
|
80
77
|
return withStoreAsync(input.ledgerEnv, async (store) => {
|
|
@@ -86,6 +83,7 @@ export async function compareLoop(input) {
|
|
|
86
83
|
actor: 'cli',
|
|
87
84
|
command: 'loop compare',
|
|
88
85
|
resultStatus: 'running',
|
|
86
|
+
inputsSummary: JSON.stringify(compareContext(input)),
|
|
89
87
|
});
|
|
90
88
|
try {
|
|
91
89
|
const result = await runLoopComparison({
|
|
@@ -104,9 +102,28 @@ export async function compareLoop(input) {
|
|
|
104
102
|
eventType,
|
|
105
103
|
actor: 'cli',
|
|
106
104
|
command: 'loop compare',
|
|
105
|
+
runId: result.runId,
|
|
107
106
|
resultStatus: result.agentComparison?.status ?? 'ok',
|
|
108
|
-
|
|
107
|
+
inputsSummary: JSON.stringify(compareContext(input)),
|
|
108
|
+
artifactRefs: result.artifacts,
|
|
109
109
|
});
|
|
110
|
+
if (result.agentComparison) {
|
|
111
|
+
store.recordAgentResponse({
|
|
112
|
+
trajectoryId: trajectory.trajectoryId,
|
|
113
|
+
iterationId: trajectory.activeIterationId ?? undefined,
|
|
114
|
+
runId: result.runId,
|
|
115
|
+
mode: trajectory.mode,
|
|
116
|
+
profile: result.agentComparison.profile,
|
|
117
|
+
responsePath: result.agentComparison.responsePath,
|
|
118
|
+
responseHash: result.agentComparison.responseHash,
|
|
119
|
+
freshness: result.agentComparison.freshness,
|
|
120
|
+
validationStatus: result.agentComparison.status,
|
|
121
|
+
inputFingerprint: result.agentComparison.inputFingerprint,
|
|
122
|
+
responseJson: result.agentComparison.responseJson,
|
|
123
|
+
score: result.agentComparison.score,
|
|
124
|
+
topFix: result.agentComparison.topFix,
|
|
125
|
+
});
|
|
126
|
+
}
|
|
110
127
|
return result;
|
|
111
128
|
}
|
|
112
129
|
catch (error) {
|
|
@@ -117,6 +134,7 @@ export async function compareLoop(input) {
|
|
|
117
134
|
actor: 'cli',
|
|
118
135
|
command: 'loop compare',
|
|
119
136
|
resultStatus: 'failed',
|
|
137
|
+
inputsSummary: JSON.stringify(compareContext(input)),
|
|
120
138
|
notes: error instanceof Error ? error.message : String(error),
|
|
121
139
|
});
|
|
122
140
|
throw error;
|
|
@@ -142,10 +160,9 @@ async function withStoreAsync(env, callback) {
|
|
|
142
160
|
}
|
|
143
161
|
}
|
|
144
162
|
function selector(input) {
|
|
145
|
-
return {
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
};
|
|
163
|
+
return { trajectoryId: input.trajectoryId, target: input.target, mode: input.mode };
|
|
164
|
+
}
|
|
165
|
+
function compareContext(input) {
|
|
166
|
+
return { ...getRuntimeContext(), headed: input.headed === true, headless: input.headed !== true, fullPage: input.fullPage === true, hasUrl: Boolean(input.url), hasStorageState: Boolean(input.storageState), ...(input.url ? { url: input.url } : {}), ...(input.storageState ? { storageState: input.storageState } : {}) };
|
|
150
167
|
}
|
|
151
168
|
//# sourceMappingURL=loop.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"loop.js","sourceRoot":"","sources":["../../src/commands/loop.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAmB,MAAM,sBAAsB,CAAC;AACzE,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;AACvE,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,EAAE,iBAAiB,EAA+B,MAAM,yBAAyB,CAAC;AACzF,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;
|
|
1
|
+
{"version":3,"file":"loop.js","sourceRoot":"","sources":["../../src/commands/loop.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
+
import { type AgentComparisonInputFingerprint } from '../schemas/comparison.js';
|
|
1
2
|
import type { AgentComparisonProfileName } from './agent-comparison-profiles.js';
|
|
3
|
+
import { type AgentResponseFreshness } from './agent-comparison-response.js';
|
|
2
4
|
export type AgentComparisonPackResult = {
|
|
3
5
|
promptPath: string;
|
|
4
6
|
codexPromptPath: string;
|
|
@@ -7,11 +9,22 @@ export type AgentComparisonPackResult = {
|
|
|
7
9
|
examplePath: string;
|
|
8
10
|
responsePath: string;
|
|
9
11
|
status: 'awaiting-agent' | 'validated' | 'invalid';
|
|
12
|
+
profile: AgentComparisonProfileName;
|
|
13
|
+
inputFingerprint: AgentComparisonInputFingerprint;
|
|
14
|
+
freshness: AgentResponseFreshness;
|
|
15
|
+
responseExistedBefore: boolean;
|
|
16
|
+
responseHash?: string;
|
|
17
|
+
responseJson?: string;
|
|
10
18
|
validationErrors?: string[];
|
|
11
19
|
imageComparisonPath?: string;
|
|
12
20
|
structureComparisonPath?: string;
|
|
13
21
|
summaryPath?: string;
|
|
14
22
|
scoreHighlights?: string[];
|
|
23
|
+
score?: {
|
|
24
|
+
imageOverall: number;
|
|
25
|
+
structureOverall?: number;
|
|
26
|
+
};
|
|
27
|
+
topFix?: string;
|
|
15
28
|
};
|
|
16
29
|
export declare function writeAgentComparisonPack(input: {
|
|
17
30
|
workspaceRoot: string;
|
|
@@ -1,7 +1,8 @@
|
|
|
1
|
-
import { mkdir,
|
|
1
|
+
import { mkdir, writeFile } from 'node:fs/promises';
|
|
2
2
|
import path from 'node:path';
|
|
3
3
|
import { agentComparisonBundleSchema, createAgentComparisonBundleExample, createAgentComparisonJsonSchema, } from '../schemas/comparison.js';
|
|
4
4
|
import { clearAgentComparisonOutputs, createInputFingerprint } from './agent-comparison-fingerprint.js';
|
|
5
|
+
import { readAgentResponse, responseExists } from './agent-comparison-response.js';
|
|
5
6
|
import { buildAgentComparisonPrompt, buildClaudeAgentComparisonPrompt, buildCodexAgentComparisonPrompt, } from './agent-comparison-prompts.js';
|
|
6
7
|
import { validateFixTargets } from './agent-comparison-validation.js';
|
|
7
8
|
export async function writeAgentComparisonPack(input) {
|
|
@@ -12,6 +13,7 @@ export async function writeAgentComparisonPack(input) {
|
|
|
12
13
|
const schemaPath = path.join(packDir, 'agent-response.schema.json');
|
|
13
14
|
const examplePath = path.join(packDir, 'agent-response.example.json');
|
|
14
15
|
const responsePath = path.join(packDir, 'agent-response.json');
|
|
16
|
+
const responseExistedBefore = await responseExists(responsePath);
|
|
15
17
|
const inputFingerprint = await createInputFingerprint(input);
|
|
16
18
|
const promptInput = { ...input, schemaPath, responsePath, inputFingerprint };
|
|
17
19
|
await mkdir(packDir, { recursive: true });
|
|
@@ -23,21 +25,33 @@ export async function writeAgentComparisonPack(input) {
|
|
|
23
25
|
writeFile(codexPromptPath, buildCodexAgentComparisonPrompt(promptInput)),
|
|
24
26
|
writeFile(claudePromptPath, buildClaudeAgentComparisonPrompt(promptInput)),
|
|
25
27
|
]);
|
|
26
|
-
const response = await
|
|
27
|
-
const base = {
|
|
28
|
+
const response = await readAgentResponse(responsePath, responseExistedBefore);
|
|
29
|
+
const base = {
|
|
30
|
+
promptPath,
|
|
31
|
+
codexPromptPath,
|
|
32
|
+
claudePromptPath,
|
|
33
|
+
schemaPath,
|
|
34
|
+
examplePath,
|
|
35
|
+
responsePath,
|
|
36
|
+
profile: input.profile,
|
|
37
|
+
inputFingerprint,
|
|
38
|
+
responseExistedBefore,
|
|
39
|
+
responseHash: 'responseHash' in response ? response.responseHash : undefined,
|
|
40
|
+
responseJson: 'responseJson' in response ? response.responseJson : undefined,
|
|
41
|
+
};
|
|
28
42
|
if (response.status === 'missing') {
|
|
29
|
-
return { ...base, status: 'awaiting-agent' };
|
|
43
|
+
return { ...base, status: 'awaiting-agent', freshness: 'missing' };
|
|
30
44
|
}
|
|
31
45
|
if (response.status === 'invalid-json') {
|
|
32
|
-
return { ...base, status: 'invalid', validationErrors: ['agent-response.json: Invalid JSON.'] };
|
|
46
|
+
return { ...base, status: 'invalid', freshness: 'invalid', validationErrors: ['agent-response.json: Invalid JSON.'] };
|
|
33
47
|
}
|
|
34
48
|
const parsed = agentComparisonBundleSchema.safeParse(response.value);
|
|
35
49
|
if (!parsed.success) {
|
|
36
|
-
return { ...base, status: 'invalid', validationErrors: parsed.error.issues.map((issue) => `${issue.path.join('.')}: ${issue.message}`) };
|
|
50
|
+
return { ...base, status: 'invalid', freshness: 'invalid', validationErrors: parsed.error.issues.map((issue) => `${issue.path.join('.')}: ${issue.message}`) };
|
|
37
51
|
}
|
|
38
52
|
const activeErrors = validateActiveComparison({ ...input, inputFingerprint }, parsed.data);
|
|
39
53
|
if (activeErrors.length > 0) {
|
|
40
|
-
return { ...base, status: 'invalid', validationErrors: activeErrors };
|
|
54
|
+
return { ...base, status: 'invalid', freshness: 'stale', validationErrors: activeErrors };
|
|
41
55
|
}
|
|
42
56
|
const imageComparisonPath = path.join(input.captureDir, 'image-comparison.json');
|
|
43
57
|
const structureComparisonPath = parsed.data.structureComparison ? path.join(input.captureDir, 'structure-comparison.json') : undefined;
|
|
@@ -50,29 +64,21 @@ export async function writeAgentComparisonPack(input) {
|
|
|
50
64
|
return {
|
|
51
65
|
...base,
|
|
52
66
|
status: 'validated',
|
|
67
|
+
freshness: response.existedBefore ? 'cached' : 'fresh',
|
|
53
68
|
imageComparisonPath,
|
|
54
69
|
structureComparisonPath,
|
|
55
70
|
summaryPath,
|
|
71
|
+
score: {
|
|
72
|
+
imageOverall: parsed.data.imageComparison.score.overall,
|
|
73
|
+
structureOverall: parsed.data.structureComparison?.score.overall,
|
|
74
|
+
},
|
|
75
|
+
topFix: parsed.data.recommendation.topFix,
|
|
56
76
|
scoreHighlights: [
|
|
57
77
|
`Agent image score: ${parsed.data.imageComparison.score.overall}`,
|
|
58
78
|
...(parsed.data.structureComparison ? [`Agent structure score: ${parsed.data.structureComparison.score.overall}`] : []),
|
|
59
79
|
],
|
|
60
80
|
};
|
|
61
81
|
}
|
|
62
|
-
async function readBundle(filePath) {
|
|
63
|
-
try {
|
|
64
|
-
return { status: 'ok', value: JSON.parse(await readFile(filePath, 'utf8')) };
|
|
65
|
-
}
|
|
66
|
-
catch {
|
|
67
|
-
try {
|
|
68
|
-
await readFile(filePath, 'utf8');
|
|
69
|
-
return { status: 'invalid-json' };
|
|
70
|
-
}
|
|
71
|
-
catch {
|
|
72
|
-
return { status: 'missing' };
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
82
|
function createExample(input, inputFingerprint) {
|
|
77
83
|
const example = createAgentComparisonBundleExample(input.structureInputs ? 'image-and-structure' : 'image-only', inputFingerprint);
|
|
78
84
|
example.profile = input.profile;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"agent-comparison-pack.js","sourceRoot":"","sources":["../../src/core/agent-comparison-pack.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"agent-comparison-pack.js","sourceRoot":"","sources":["../../src/core/agent-comparison-pack.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { AgentComparisonBundle } from '../schemas/comparison.js';
|
|
2
|
+
export type AgentResponseFreshness = 'missing' | 'fresh' | 'cached' | 'stale' | 'invalid';
|
|
3
|
+
export type AgentResponseRead = {
|
|
4
|
+
status: 'missing';
|
|
5
|
+
existedBefore: boolean;
|
|
6
|
+
} | {
|
|
7
|
+
status: 'invalid-json';
|
|
8
|
+
existedBefore: boolean;
|
|
9
|
+
responseJson: string;
|
|
10
|
+
responseHash: string;
|
|
11
|
+
} | {
|
|
12
|
+
status: 'ok';
|
|
13
|
+
existedBefore: boolean;
|
|
14
|
+
responseJson: string;
|
|
15
|
+
responseHash: string;
|
|
16
|
+
value: AgentComparisonBundle;
|
|
17
|
+
};
|
|
18
|
+
export declare function responseExists(filePath: string): Promise<boolean>;
|
|
19
|
+
export declare function readAgentResponse(filePath: string, existedBefore: boolean): Promise<AgentResponseRead>;
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { createHash } from 'node:crypto';
|
|
2
|
+
import { readFile } from 'node:fs/promises';
|
|
3
|
+
export async function responseExists(filePath) {
|
|
4
|
+
try {
|
|
5
|
+
await readFile(filePath);
|
|
6
|
+
return true;
|
|
7
|
+
}
|
|
8
|
+
catch {
|
|
9
|
+
return false;
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
export async function readAgentResponse(filePath, existedBefore) {
|
|
13
|
+
let responseJson;
|
|
14
|
+
try {
|
|
15
|
+
responseJson = await readFile(filePath, 'utf8');
|
|
16
|
+
}
|
|
17
|
+
catch {
|
|
18
|
+
return { status: 'missing', existedBefore };
|
|
19
|
+
}
|
|
20
|
+
const responseHash = createHash('sha256').update(responseJson).digest('hex');
|
|
21
|
+
try {
|
|
22
|
+
return {
|
|
23
|
+
status: 'ok',
|
|
24
|
+
existedBefore,
|
|
25
|
+
responseJson,
|
|
26
|
+
responseHash,
|
|
27
|
+
value: JSON.parse(responseJson),
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
catch {
|
|
31
|
+
return { status: 'invalid-json', existedBefore, responseJson, responseHash };
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=agent-comparison-response.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-comparison-response.js","sourceRoot":"","sources":["../../src/core/agent-comparison-response.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAW5C,MAAM,CAAC,KAAK,UAAU,cAAc,CAAC,QAAgB;IACnD,IAAI,CAAC;QACH,MAAM,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACzB,OAAO,IAAI,CAAC;IACd,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,KAAK,CAAC;IACf,CAAC;AACH,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,iBAAiB,CAAC,QAAgB,EAAE,aAAsB;IAC9E,IAAI,YAAoB,CAAC;IACzB,IAAI,CAAC;QACH,YAAY,GAAG,MAAM,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;IAClD,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,aAAa,EAAE,CAAC;IAC9C,CAAC;IACD,MAAM,YAAY,GAAG,UAAU,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAC7E,IAAI,CAAC;QACH,OAAO;YACL,MAAM,EAAE,IAAI;YACZ,aAAa;YACb,YAAY;YACZ,YAAY;YACZ,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,YAAY,CAA0B;SACzD,CAAC;IACJ,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,aAAa,EAAE,YAAY,EAAE,YAAY,EAAE,CAAC;IAC/E,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { type AgentComparisonBundle } from '../schemas/comparison.js';
|
|
2
|
+
import type { LedgerActionExecutor, LedgerMode } from '../schemas/ledger.js';
|
|
3
|
+
export type AgentTaskBriefInput = {
|
|
4
|
+
trajectoryId: string;
|
|
5
|
+
target: string;
|
|
6
|
+
mode: LedgerMode;
|
|
7
|
+
workspaceRoot: string;
|
|
8
|
+
comparisonSummaryPath: string;
|
|
9
|
+
sourceRunId: string;
|
|
10
|
+
desiredExecutor: LedgerActionExecutor;
|
|
11
|
+
rerunCommand: string;
|
|
12
|
+
};
|
|
13
|
+
export type AgentTaskBrief = {
|
|
14
|
+
json: {
|
|
15
|
+
trajectoryId: string;
|
|
16
|
+
target: string;
|
|
17
|
+
mode: LedgerMode;
|
|
18
|
+
profile: AgentComparisonBundle['profile'];
|
|
19
|
+
topFix?: string;
|
|
20
|
+
editableFiles: string[];
|
|
21
|
+
selectors: string[];
|
|
22
|
+
sourceRunId: string;
|
|
23
|
+
desiredExecutor: LedgerActionExecutor;
|
|
24
|
+
actionStartCommand: string;
|
|
25
|
+
actionCompleteCommandExample: string;
|
|
26
|
+
rerunCommand: string;
|
|
27
|
+
};
|
|
28
|
+
markdown: string;
|
|
29
|
+
};
|
|
30
|
+
export declare function buildAgentTaskBrief(input: AgentTaskBriefInput): Promise<AgentTaskBrief>;
|