@tangle-network/agent-runtime 0.36.0 → 0.38.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/agent.d.ts +3 -3
- package/dist/analyst-loop.d.ts +2 -2
- package/dist/analyst-loop.js +3 -257
- package/dist/analyst-loop.js.map +1 -1
- package/dist/{chunk-NYGEI3NV.js → chunk-M65QJD35.js} +5 -211
- package/dist/chunk-M65QJD35.js.map +1 -0
- package/dist/{chunk-HSX6PFZR.js → chunk-V6GURW4W.js} +209 -1
- package/dist/chunk-V6GURW4W.js.map +1 -0
- package/dist/chunk-VOX6Z3II.js +90 -0
- package/dist/chunk-VOX6Z3II.js.map +1 -0
- package/dist/chunk-XBUG326M.js +261 -0
- package/dist/chunk-XBUG326M.js.map +1 -0
- package/dist/{chunk-7ZECSZ3C.js → chunk-Z523NPJK.js} +59 -2
- package/dist/chunk-Z523NPJK.js.map +1 -0
- package/dist/dynamic-DeOPeeAw.d.ts +106 -0
- package/dist/{improvement-adapter-CaZxFxTd.d.ts → improvement-adapter-BC4HhuAR.d.ts} +1 -1
- package/dist/improvement.d.ts +6 -130
- package/dist/improvement.js +4 -85
- package/dist/improvement.js.map +1 -1
- package/dist/index.d.ts +148 -3
- package/dist/index.js +109 -2
- package/dist/index.js.map +1 -1
- package/dist/loops.d.ts +5 -107
- package/dist/mcp/bin.js +4 -3
- package/dist/mcp/bin.js.map +1 -1
- package/dist/mcp/index.d.ts +6 -440
- package/dist/mcp/index.js +7 -62
- package/dist/mcp/index.js.map +1 -1
- package/dist/optimize-prompt-cmH9wZdH.d.ts +129 -0
- package/dist/otel-export-CNmeg_7B.d.ts +627 -0
- package/dist/profiles.d.ts +1 -2
- package/dist/{types-DrXVR2Fu.d.ts → types-CmkQl8qE.d.ts} +137 -3
- package/dist/{types-D_MXrmJP.d.ts → types-p8dWBIXL.d.ts} +1 -1
- package/package.json +1 -1
- package/dist/chunk-7ZECSZ3C.js.map +0 -1
- package/dist/chunk-HSX6PFZR.js.map +0 -1
- package/dist/chunk-NYGEI3NV.js.map +0 -1
- package/dist/otel-export-xgf4J6bo.d.ts +0 -191
- package/dist/runtime-run-B8VIiOhI.d.ts +0 -137
package/dist/agent.d.ts
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import * as _tangle_network_agent_eval from '@tangle-network/agent-eval';
|
|
2
2
|
import { TraceAnalystKindSpec, AnalystFinding } from '@tangle-network/agent-eval';
|
|
3
3
|
import { R as RuntimeStreamEvent } from './types-CsCCryln.js';
|
|
4
|
-
import { A as AgentSurfaces } from './improvement-adapter-
|
|
5
|
-
export { C as CreateSurfaceImprovementAdapterOpts, D as DraftPatchInput, a as DraftPatchOutput, R as ResolvedSurface, S as SurfaceImprovementEdit, b as SurfaceValidationIssue, c as createSurfaceImprovementAdapter, r as renderSurfaceIssues, d as resolveSubjectPath, v as validateSurfaces } from './improvement-adapter-
|
|
6
|
-
import { K as KnowledgeAdapter, a as RunAnalystLoopResult } from './types-
|
|
4
|
+
import { A as AgentSurfaces } from './improvement-adapter-BC4HhuAR.js';
|
|
5
|
+
export { C as CreateSurfaceImprovementAdapterOpts, D as DraftPatchInput, a as DraftPatchOutput, R as ResolvedSurface, S as SurfaceImprovementEdit, b as SurfaceValidationIssue, c as createSurfaceImprovementAdapter, r as renderSurfaceIssues, d as resolveSubjectPath, v as validateSurfaces } from './improvement-adapter-BC4HhuAR.js';
|
|
6
|
+
import { K as KnowledgeAdapter, a as RunAnalystLoopResult } from './types-p8dWBIXL.js';
|
|
7
7
|
|
|
8
8
|
/**
|
|
9
9
|
* The full agent manifest. Each agent ships ONE of these.
|
package/dist/analyst-loop.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { R as RunAnalystLoopOpts, a as RunAnalystLoopResult } from './types-
|
|
2
|
-
export { A as AnalystLoopEvent, b as AnalystRegistryLike, c as AnalystRegistryStreamingLike, d as AutoApplyPolicy, F as FindingsStoreLike, I as ImprovementAdapter, e as ImprovementEditBatch, f as ImprovementReport, K as KnowledgeAdapter, g as KnowledgeProposalBatch, h as KnowledgeReport } from './types-
|
|
1
|
+
import { R as RunAnalystLoopOpts, a as RunAnalystLoopResult } from './types-p8dWBIXL.js';
|
|
2
|
+
export { A as AnalystLoopEvent, b as AnalystRegistryLike, c as AnalystRegistryStreamingLike, d as AutoApplyPolicy, F as FindingsStoreLike, I as ImprovementAdapter, e as ImprovementEditBatch, f as ImprovementReport, K as KnowledgeAdapter, g as KnowledgeProposalBatch, h as KnowledgeReport } from './types-p8dWBIXL.js';
|
|
3
3
|
import '@tangle-network/agent-eval';
|
|
4
4
|
|
|
5
5
|
/**
|
package/dist/analyst-loop.js
CHANGED
|
@@ -1,261 +1,7 @@
|
|
|
1
|
+
import {
|
|
2
|
+
runAnalystLoop
|
|
3
|
+
} from "./chunk-XBUG326M.js";
|
|
1
4
|
import "./chunk-DGUM43GV.js";
|
|
2
|
-
|
|
3
|
-
// src/analyst-loop/run-analyst-loop.ts
|
|
4
|
-
import { diffFindings } from "@tangle-network/agent-eval";
|
|
5
|
-
async function runAnalystLoop(opts) {
|
|
6
|
-
const log = opts.log ?? defaultLog;
|
|
7
|
-
const strategy = opts.priorFindingsStrategy ?? "per-kind";
|
|
8
|
-
const emit = makeEmitter(opts.onEvent);
|
|
9
|
-
const startedAt = Date.now();
|
|
10
|
-
const baselineRunId = resolveBaselineRunId(opts);
|
|
11
|
-
const priorAll = baselineRunId ? opts.findingsStore?.loadRun(baselineRunId) ?? [] : [];
|
|
12
|
-
log("baseline resolved", { baselineRunId, prior_findings: priorAll.length });
|
|
13
|
-
await emit({
|
|
14
|
-
type: "baseline-resolved",
|
|
15
|
-
runId: opts.runId,
|
|
16
|
-
baselineRunId,
|
|
17
|
-
priorFindingCount: priorAll.length
|
|
18
|
-
});
|
|
19
|
-
const priorFindings = buildPriorFindingsInput(priorAll, strategy, opts.registry.list());
|
|
20
|
-
const analystResult = await runRegistry(opts, priorFindings, emit);
|
|
21
|
-
log("analyst run complete", {
|
|
22
|
-
findings: analystResult.findings.length,
|
|
23
|
-
cost_usd: analystResult.total_cost_usd,
|
|
24
|
-
per_analyst: analystResult.per_analyst.map((s) => ({
|
|
25
|
-
id: s.analyst_id,
|
|
26
|
-
status: s.status,
|
|
27
|
-
n: s.findings_count
|
|
28
|
-
}))
|
|
29
|
-
});
|
|
30
|
-
if (opts.findingsStore && analystResult.findings.length > 0) {
|
|
31
|
-
await opts.findingsStore.append(opts.runId, analystResult.findings);
|
|
32
|
-
await emit({
|
|
33
|
-
type: "findings-persisted",
|
|
34
|
-
runId: opts.runId,
|
|
35
|
-
count: analystResult.findings.length
|
|
36
|
-
});
|
|
37
|
-
}
|
|
38
|
-
let diff = null;
|
|
39
|
-
if (baselineRunId && analystResult.findings.length > 0) {
|
|
40
|
-
diff = diffFindings(
|
|
41
|
-
priorAll.map((f) => ({ ...f })),
|
|
42
|
-
analystResult.findings.map((f) => ({ ...f, run_id: opts.runId }))
|
|
43
|
-
);
|
|
44
|
-
log("diff vs baseline", {
|
|
45
|
-
appeared: diff.appeared.length,
|
|
46
|
-
disappeared: diff.disappeared.length,
|
|
47
|
-
persisted: diff.persisted.length,
|
|
48
|
-
changed: diff.changed.length
|
|
49
|
-
});
|
|
50
|
-
await emit({
|
|
51
|
-
type: "diff-computed",
|
|
52
|
-
runId: opts.runId,
|
|
53
|
-
baselineRunId,
|
|
54
|
-
appeared: diff.appeared.length,
|
|
55
|
-
disappeared: diff.disappeared.length,
|
|
56
|
-
persisted: diff.persisted.length,
|
|
57
|
-
changed: diff.changed.length
|
|
58
|
-
});
|
|
59
|
-
}
|
|
60
|
-
let knowledge = null;
|
|
61
|
-
if (opts.knowledgeAdapter) {
|
|
62
|
-
knowledge = await runKnowledgeAdapter(opts, analystResult.findings, log, emit);
|
|
63
|
-
}
|
|
64
|
-
let improvement = null;
|
|
65
|
-
if (opts.improvementAdapter) {
|
|
66
|
-
improvement = await runImprovementAdapter(opts, analystResult.findings, log, emit);
|
|
67
|
-
}
|
|
68
|
-
await emit({
|
|
69
|
-
type: "loop-completed",
|
|
70
|
-
runId: opts.runId,
|
|
71
|
-
durationMs: Date.now() - startedAt
|
|
72
|
-
});
|
|
73
|
-
return {
|
|
74
|
-
runId: opts.runId,
|
|
75
|
-
baselineRunId,
|
|
76
|
-
analystResult,
|
|
77
|
-
diff,
|
|
78
|
-
knowledge,
|
|
79
|
-
improvement
|
|
80
|
-
};
|
|
81
|
-
}
|
|
82
|
-
function makeEmitter(onEvent) {
|
|
83
|
-
if (!onEvent) return async () => {
|
|
84
|
-
};
|
|
85
|
-
return async (event) => {
|
|
86
|
-
await onEvent(event);
|
|
87
|
-
};
|
|
88
|
-
}
|
|
89
|
-
async function runRegistry(opts, priorFindings, emit) {
|
|
90
|
-
const reg = opts.registry;
|
|
91
|
-
if (typeof reg.runStream === "function" && opts.onEvent) {
|
|
92
|
-
let final = null;
|
|
93
|
-
for await (const ev of reg.runStream(opts.runId, opts.inputs, { priorFindings })) {
|
|
94
|
-
await emit({ type: "analyst", runId: opts.runId, event: ev });
|
|
95
|
-
if (ev.type === "run-completed") final = ev.result;
|
|
96
|
-
}
|
|
97
|
-
if (!final) {
|
|
98
|
-
throw new Error("runAnalystLoop: registry.runStream ended without run-completed event");
|
|
99
|
-
}
|
|
100
|
-
return final;
|
|
101
|
-
}
|
|
102
|
-
return opts.registry.run(opts.runId, opts.inputs, { priorFindings });
|
|
103
|
-
}
|
|
104
|
-
function resolveBaselineRunId(opts) {
|
|
105
|
-
if (opts.baselineRunId === null) return null;
|
|
106
|
-
if (typeof opts.baselineRunId === "string") return opts.baselineRunId;
|
|
107
|
-
if (!opts.findingsStore) return null;
|
|
108
|
-
const all = opts.findingsStore.loadAll();
|
|
109
|
-
let last = null;
|
|
110
|
-
for (const row of all) {
|
|
111
|
-
if (row.run_id === opts.runId) continue;
|
|
112
|
-
last = row.run_id;
|
|
113
|
-
}
|
|
114
|
-
return last;
|
|
115
|
-
}
|
|
116
|
-
function buildPriorFindingsInput(prior, strategy, registry) {
|
|
117
|
-
if (strategy === "none" || prior.length === 0) return void 0;
|
|
118
|
-
const stripped = prior.map(({ run_id: _run_id, ...rest }) => rest);
|
|
119
|
-
if (strategy === "wildcard") {
|
|
120
|
-
return { "*": stripped };
|
|
121
|
-
}
|
|
122
|
-
void registry;
|
|
123
|
-
return stripped;
|
|
124
|
-
}
|
|
125
|
-
async function runKnowledgeAdapter(opts, findings, log, emit) {
|
|
126
|
-
const adapter = opts.knowledgeAdapter;
|
|
127
|
-
const batch = await adapter.proposeFromFindings(findings);
|
|
128
|
-
log("knowledge.proposeFromFindings", {
|
|
129
|
-
proposals: batch.proposals.length,
|
|
130
|
-
skipped: batch.skipped,
|
|
131
|
-
errors: batch.errors.length
|
|
132
|
-
});
|
|
133
|
-
await emit({
|
|
134
|
-
type: "knowledge-proposed",
|
|
135
|
-
runId: opts.runId,
|
|
136
|
-
proposalCount: batch.proposals.length,
|
|
137
|
-
skipped: batch.skipped,
|
|
138
|
-
errors: batch.errors.length
|
|
139
|
-
});
|
|
140
|
-
const auto = opts.autoApply?.knowledge ?? false;
|
|
141
|
-
const threshold = opts.autoApply?.knowledgeConfidenceThreshold ?? 0.85;
|
|
142
|
-
if (!auto || !adapter.apply) {
|
|
143
|
-
await emit({
|
|
144
|
-
type: "knowledge-applied",
|
|
145
|
-
runId: opts.runId,
|
|
146
|
-
writtenCount: 0,
|
|
147
|
-
withheldForReview: batch.proposals.length
|
|
148
|
-
});
|
|
149
|
-
return {
|
|
150
|
-
proposals: batch.proposals,
|
|
151
|
-
applied: [],
|
|
152
|
-
skipped: batch.skipped,
|
|
153
|
-
errors: batch.errors,
|
|
154
|
-
withheld_for_review: batch.proposals.length
|
|
155
|
-
};
|
|
156
|
-
}
|
|
157
|
-
const findingsById = new Map(findings.map((f) => [f.finding_id, f]));
|
|
158
|
-
const safe = [];
|
|
159
|
-
let withheld = 0;
|
|
160
|
-
for (const p of batch.proposals) {
|
|
161
|
-
const src = p.sourceFindingId ? findingsById.get(p.sourceFindingId) : void 0;
|
|
162
|
-
if (!src) {
|
|
163
|
-
withheld += 1;
|
|
164
|
-
continue;
|
|
165
|
-
}
|
|
166
|
-
if (src.confidence < threshold) {
|
|
167
|
-
withheld += 1;
|
|
168
|
-
continue;
|
|
169
|
-
}
|
|
170
|
-
safe.push(p);
|
|
171
|
-
}
|
|
172
|
-
const result = await adapter.apply(safe);
|
|
173
|
-
log("knowledge.apply", {
|
|
174
|
-
applied: result.written.length,
|
|
175
|
-
withheld_for_review: withheld,
|
|
176
|
-
warnings: result.warnings.length
|
|
177
|
-
});
|
|
178
|
-
await emit({
|
|
179
|
-
type: "knowledge-applied",
|
|
180
|
-
runId: opts.runId,
|
|
181
|
-
writtenCount: result.written.length,
|
|
182
|
-
withheldForReview: withheld
|
|
183
|
-
});
|
|
184
|
-
return {
|
|
185
|
-
proposals: batch.proposals,
|
|
186
|
-
applied: result.written,
|
|
187
|
-
skipped: batch.skipped,
|
|
188
|
-
errors: batch.errors,
|
|
189
|
-
withheld_for_review: withheld
|
|
190
|
-
};
|
|
191
|
-
}
|
|
192
|
-
async function runImprovementAdapter(opts, findings, log, emit) {
|
|
193
|
-
const adapter = opts.improvementAdapter;
|
|
194
|
-
const batch = await adapter.proposeFromFindings(findings);
|
|
195
|
-
log("improvement.proposeFromFindings", {
|
|
196
|
-
edits: batch.edits.length,
|
|
197
|
-
skipped: batch.skipped,
|
|
198
|
-
errors: batch.errors.length
|
|
199
|
-
});
|
|
200
|
-
await emit({
|
|
201
|
-
type: "improvement-proposed",
|
|
202
|
-
runId: opts.runId,
|
|
203
|
-
editCount: batch.edits.length,
|
|
204
|
-
skipped: batch.skipped,
|
|
205
|
-
errors: batch.errors.length
|
|
206
|
-
});
|
|
207
|
-
const auto = opts.autoApply?.improvement ?? false;
|
|
208
|
-
const threshold = opts.autoApply?.improvementConfidenceThreshold ?? 0.9;
|
|
209
|
-
if (!auto || !adapter.apply) {
|
|
210
|
-
await emit({
|
|
211
|
-
type: "improvement-applied",
|
|
212
|
-
runId: opts.runId,
|
|
213
|
-
appliedCount: 0,
|
|
214
|
-
withheldForReview: batch.edits.length
|
|
215
|
-
});
|
|
216
|
-
return {
|
|
217
|
-
edits: batch.edits,
|
|
218
|
-
applied: [],
|
|
219
|
-
skipped: batch.skipped,
|
|
220
|
-
errors: batch.errors,
|
|
221
|
-
withheld_for_review: batch.edits.length
|
|
222
|
-
};
|
|
223
|
-
}
|
|
224
|
-
const findingsById = new Map(findings.map((f) => [f.finding_id, f]));
|
|
225
|
-
const safe = [];
|
|
226
|
-
let withheld = 0;
|
|
227
|
-
for (const e of batch.edits) {
|
|
228
|
-
const src = e.sourceFindingId ? findingsById.get(e.sourceFindingId) : void 0;
|
|
229
|
-
if (!src || src.confidence < threshold) {
|
|
230
|
-
withheld += 1;
|
|
231
|
-
continue;
|
|
232
|
-
}
|
|
233
|
-
safe.push(e);
|
|
234
|
-
}
|
|
235
|
-
const result = await adapter.apply(safe);
|
|
236
|
-
log("improvement.apply", {
|
|
237
|
-
applied: result.applied.length,
|
|
238
|
-
withheld_for_review: withheld,
|
|
239
|
-
warnings: result.warnings.length
|
|
240
|
-
});
|
|
241
|
-
await emit({
|
|
242
|
-
type: "improvement-applied",
|
|
243
|
-
runId: opts.runId,
|
|
244
|
-
appliedCount: result.applied.length,
|
|
245
|
-
withheldForReview: withheld
|
|
246
|
-
});
|
|
247
|
-
return {
|
|
248
|
-
edits: batch.edits,
|
|
249
|
-
applied: result.applied,
|
|
250
|
-
skipped: batch.skipped,
|
|
251
|
-
errors: batch.errors,
|
|
252
|
-
withheld_for_review: withheld
|
|
253
|
-
};
|
|
254
|
-
}
|
|
255
|
-
function defaultLog(msg, fields) {
|
|
256
|
-
if (fields) console.log(`[analyst-loop] ${msg}`, fields);
|
|
257
|
-
else console.log(`[analyst-loop] ${msg}`);
|
|
258
|
-
}
|
|
259
5
|
export {
|
|
260
6
|
runAnalystLoop
|
|
261
7
|
};
|
package/dist/analyst-loop.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/analyst-loop/run-analyst-loop.ts"],"sourcesContent":["/**\n * `runAnalystLoop` — the one call agent apps reach for to close the\n * recursive-self-improvement loop.\n *\n * 1. Load baseline findings (last run, or the slice the caller specifies)\n * 2. Run the analyst registry with priorFindings injected\n * 3. Persist the new run's findings to the ledger\n * 4. Diff the new run against the baseline\n * 5. Hand the findings to the knowledge adapter → proposals (and\n * optionally apply them) → wiki edits\n * 6. Hand the findings to the improvement adapter → prompt / tool /\n * scaffolding edits (review-only by default)\n * 7. Return a single report the consumer renders / persists / acts on.\n *\n * Adapters are optional: the loop works as a \"run + diff + report\"\n * primitive when no adapters are wired; it closes end-to-end when\n * both adapters are wired.\n */\n\nimport type { AnalystFinding, AnalystRunResult, FindingsDiff } from '@tangle-network/agent-eval'\nimport { diffFindings } from '@tangle-network/agent-eval'\n\nimport type {\n AnalystLoopEvent,\n AnalystRegistryStreamingLike,\n ImprovementReport,\n KnowledgeReport,\n RunAnalystLoopOpts,\n RunAnalystLoopResult,\n} from './types'\n\nexport async function runAnalystLoop<TProposal = unknown, TEdit = unknown>(\n opts: RunAnalystLoopOpts,\n): Promise<RunAnalystLoopResult<TProposal, TEdit>> {\n const log = opts.log ?? defaultLog\n const strategy = opts.priorFindingsStrategy ?? 'per-kind'\n const emit = makeEmitter(opts.onEvent)\n const startedAt = Date.now()\n\n // 1. Resolve baseline + load prior findings.\n const baselineRunId = resolveBaselineRunId(opts)\n const priorAll: ReadonlyArray<AnalystFinding & { run_id: string }> = baselineRunId\n ? (opts.findingsStore?.loadRun(baselineRunId) ?? [])\n : []\n log('baseline resolved', { baselineRunId, prior_findings: priorAll.length })\n await emit({\n type: 'baseline-resolved',\n runId: opts.runId,\n baselineRunId,\n priorFindingCount: priorAll.length,\n })\n\n // 2. Run the registry. Strategy controls how analysts see priors.\n // When the registry exposes runStream, forward each event verbatim\n // so subscribers see per-analyst progress in real time.\n const priorFindings = buildPriorFindingsInput(priorAll, strategy, opts.registry.list())\n const analystResult = await runRegistry(opts, priorFindings, emit)\n log('analyst run complete', {\n findings: analystResult.findings.length,\n cost_usd: analystResult.total_cost_usd,\n per_analyst: analystResult.per_analyst.map((s) => ({\n id: s.analyst_id,\n status: s.status,\n n: s.findings_count,\n })),\n })\n\n // 3. Persist the new run before any side-effecting adapter runs so\n // the ledger is the source of truth even if an adapter throws.\n if (opts.findingsStore && analystResult.findings.length > 0) {\n await opts.findingsStore.append(opts.runId, analystResult.findings)\n await emit({\n type: 'findings-persisted',\n runId: opts.runId,\n count: analystResult.findings.length,\n })\n }\n\n // 4. Diff vs baseline.\n let diff: FindingsDiff | null = null\n if (baselineRunId && analystResult.findings.length > 0) {\n diff = diffFindings(\n priorAll.map((f) => ({ ...f })),\n analystResult.findings.map((f) => ({ ...f, run_id: opts.runId })),\n )\n log('diff vs baseline', {\n appeared: diff.appeared.length,\n disappeared: diff.disappeared.length,\n persisted: diff.persisted.length,\n changed: diff.changed.length,\n })\n await emit({\n type: 'diff-computed',\n runId: opts.runId,\n baselineRunId,\n appeared: diff.appeared.length,\n disappeared: diff.disappeared.length,\n persisted: diff.persisted.length,\n changed: diff.changed.length,\n })\n }\n\n // 5. Knowledge adapter — proposals + optional auto-apply.\n let knowledge: KnowledgeReport<TProposal> | null = null\n if (opts.knowledgeAdapter) {\n knowledge = await runKnowledgeAdapter(opts, analystResult.findings, log, emit)\n }\n\n // 6. Improvement adapter — prompt / tool / scaffolding edits.\n let improvement: ImprovementReport<TEdit> | null = null\n if (opts.improvementAdapter) {\n improvement = await runImprovementAdapter(opts, analystResult.findings, log, emit)\n }\n\n await emit({\n type: 'loop-completed',\n runId: opts.runId,\n durationMs: Date.now() - startedAt,\n })\n\n return {\n runId: opts.runId,\n baselineRunId,\n analystResult,\n diff,\n knowledge,\n improvement,\n }\n}\n\ntype Emitter = (event: AnalystLoopEvent) => Promise<void>\n\nfunction makeEmitter(onEvent: RunAnalystLoopOpts['onEvent']): Emitter {\n if (!onEvent) return async () => {}\n return async (event) => {\n await onEvent(event)\n }\n}\n\nasync function runRegistry(\n opts: RunAnalystLoopOpts,\n priorFindings: ReturnType<typeof buildPriorFindingsInput>,\n emit: Emitter,\n): Promise<AnalystRunResult> {\n const reg = opts.registry as AnalystRegistryStreamingLike\n if (typeof reg.runStream === 'function' && opts.onEvent) {\n let final: AnalystRunResult | null = null\n for await (const ev of reg.runStream(opts.runId, opts.inputs, { priorFindings })) {\n await emit({ type: 'analyst', runId: opts.runId, event: ev })\n if (ev.type === 'run-completed') final = ev.result\n }\n if (!final) {\n throw new Error('runAnalystLoop: registry.runStream ended without run-completed event')\n }\n return final\n }\n return opts.registry.run(opts.runId, opts.inputs, { priorFindings })\n}\n\nfunction resolveBaselineRunId(opts: RunAnalystLoopOpts): string | null {\n if (opts.baselineRunId === null) return null\n if (typeof opts.baselineRunId === 'string') return opts.baselineRunId\n if (!opts.findingsStore) return null\n const all = opts.findingsStore.loadAll()\n let last: string | null = null\n for (const row of all) {\n if (row.run_id === opts.runId) continue\n last = row.run_id\n }\n return last\n}\n\nfunction buildPriorFindingsInput(\n prior: ReadonlyArray<AnalystFinding & { run_id: string }>,\n strategy: 'per-kind' | 'wildcard' | 'none',\n registry: ReadonlyArray<{ id: string }>,\n): ReadonlyArray<AnalystFinding> | Record<string, ReadonlyArray<AnalystFinding>> | undefined {\n if (strategy === 'none' || prior.length === 0) return undefined\n const stripped = prior.map(({ run_id: _run_id, ...rest }) => rest as AnalystFinding)\n if (strategy === 'wildcard') {\n return { '*': stripped }\n }\n void registry\n return stripped\n}\n\nasync function runKnowledgeAdapter<TProposal>(\n opts: RunAnalystLoopOpts,\n findings: ReadonlyArray<AnalystFinding>,\n log: NonNullable<RunAnalystLoopOpts['log']>,\n emit: Emitter,\n): Promise<KnowledgeReport<TProposal>> {\n const adapter = opts.knowledgeAdapter!\n const batch = await adapter.proposeFromFindings(findings)\n log('knowledge.proposeFromFindings', {\n proposals: batch.proposals.length,\n skipped: batch.skipped,\n errors: batch.errors.length,\n })\n await emit({\n type: 'knowledge-proposed',\n runId: opts.runId,\n proposalCount: batch.proposals.length,\n skipped: batch.skipped,\n errors: batch.errors.length,\n })\n\n const auto = opts.autoApply?.knowledge ?? false\n const threshold = opts.autoApply?.knowledgeConfidenceThreshold ?? 0.85\n\n if (!auto || !adapter.apply) {\n await emit({\n type: 'knowledge-applied',\n runId: opts.runId,\n writtenCount: 0,\n withheldForReview: batch.proposals.length,\n })\n return {\n proposals: batch.proposals as TProposal[],\n applied: [],\n skipped: batch.skipped,\n errors: batch.errors,\n withheld_for_review: batch.proposals.length,\n }\n }\n\n const findingsById = new Map(findings.map((f) => [f.finding_id, f]))\n const safe: TProposal[] = []\n let withheld = 0\n for (const p of batch.proposals as Array<TProposal & { sourceFindingId?: string }>) {\n const src = p.sourceFindingId ? findingsById.get(p.sourceFindingId) : undefined\n if (!src) {\n withheld += 1\n continue\n }\n if (src.confidence < threshold) {\n withheld += 1\n continue\n }\n safe.push(p)\n }\n const result = await adapter.apply(safe)\n log('knowledge.apply', {\n applied: result.written.length,\n withheld_for_review: withheld,\n warnings: result.warnings.length,\n })\n await emit({\n type: 'knowledge-applied',\n runId: opts.runId,\n writtenCount: result.written.length,\n withheldForReview: withheld,\n })\n return {\n proposals: batch.proposals as TProposal[],\n applied: result.written,\n skipped: batch.skipped,\n errors: batch.errors,\n withheld_for_review: withheld,\n }\n}\n\nasync function runImprovementAdapter<TEdit>(\n opts: RunAnalystLoopOpts,\n findings: ReadonlyArray<AnalystFinding>,\n log: NonNullable<RunAnalystLoopOpts['log']>,\n emit: Emitter,\n): Promise<ImprovementReport<TEdit>> {\n const adapter = opts.improvementAdapter!\n const batch = await adapter.proposeFromFindings(findings)\n log('improvement.proposeFromFindings', {\n edits: batch.edits.length,\n skipped: batch.skipped,\n errors: batch.errors.length,\n })\n await emit({\n type: 'improvement-proposed',\n runId: opts.runId,\n editCount: batch.edits.length,\n skipped: batch.skipped,\n errors: batch.errors.length,\n })\n\n const auto = opts.autoApply?.improvement ?? false\n const threshold = opts.autoApply?.improvementConfidenceThreshold ?? 0.9\n\n if (!auto || !adapter.apply) {\n await emit({\n type: 'improvement-applied',\n runId: opts.runId,\n appliedCount: 0,\n withheldForReview: batch.edits.length,\n })\n return {\n edits: batch.edits as TEdit[],\n applied: [],\n skipped: batch.skipped,\n errors: batch.errors,\n withheld_for_review: batch.edits.length,\n }\n }\n\n const findingsById = new Map(findings.map((f) => [f.finding_id, f]))\n const safe: TEdit[] = []\n let withheld = 0\n for (const e of batch.edits as Array<TEdit & { sourceFindingId?: string }>) {\n const src = e.sourceFindingId ? findingsById.get(e.sourceFindingId) : undefined\n if (!src || src.confidence < threshold) {\n withheld += 1\n continue\n }\n safe.push(e)\n }\n const result = await adapter.apply(safe)\n log('improvement.apply', {\n applied: result.applied.length,\n withheld_for_review: withheld,\n warnings: result.warnings.length,\n })\n await emit({\n type: 'improvement-applied',\n runId: opts.runId,\n appliedCount: result.applied.length,\n withheldForReview: withheld,\n })\n return {\n edits: batch.edits as TEdit[],\n applied: result.applied,\n skipped: batch.skipped,\n errors: batch.errors,\n withheld_for_review: withheld,\n }\n}\n\nfunction defaultLog(msg: string, fields?: Record<string, unknown>): void {\n if (fields) console.log(`[analyst-loop] ${msg}`, fields)\n else console.log(`[analyst-loop] ${msg}`)\n}\n"],"mappings":"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","names":[]}
|
|
1
|
+
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
|
@@ -20,84 +20,13 @@ import {
|
|
|
20
20
|
createDelegateFeedbackHandler,
|
|
21
21
|
createDelegateResearchHandler,
|
|
22
22
|
createDelegationHistoryHandler,
|
|
23
|
-
createDelegationStatusHandler
|
|
24
|
-
|
|
23
|
+
createDelegationStatusHandler,
|
|
24
|
+
createFleetWorkspaceExecutor,
|
|
25
|
+
createSiblingSandboxExecutor
|
|
26
|
+
} from "./chunk-V6GURW4W.js";
|
|
25
27
|
import {
|
|
26
28
|
runLocalHarness
|
|
27
29
|
} from "./chunk-GLR25NG7.js";
|
|
28
|
-
import {
|
|
29
|
-
runLoop
|
|
30
|
-
} from "./chunk-7JBDJQLO.js";
|
|
31
|
-
import {
|
|
32
|
-
coderProfile,
|
|
33
|
-
multiHarnessCoderFanout
|
|
34
|
-
} from "./chunk-3HMHSN22.js";
|
|
35
|
-
|
|
36
|
-
// src/mcp/executor.ts
|
|
37
|
-
function createSiblingSandboxExecutor(options) {
|
|
38
|
-
const underlying = options.client;
|
|
39
|
-
const client = {
|
|
40
|
-
create(opts) {
|
|
41
|
-
return underlying.create(opts);
|
|
42
|
-
},
|
|
43
|
-
describePlacement(box) {
|
|
44
|
-
return { kind: "sibling", sandboxId: readId(box) };
|
|
45
|
-
}
|
|
46
|
-
};
|
|
47
|
-
return {
|
|
48
|
-
client,
|
|
49
|
-
describe() {
|
|
50
|
-
return "sibling-sandbox (each delegation = fresh sandbox via client.create)";
|
|
51
|
-
}
|
|
52
|
-
};
|
|
53
|
-
}
|
|
54
|
-
function createFleetWorkspaceExecutor(options) {
|
|
55
|
-
const fleet = options.fleet;
|
|
56
|
-
const exclude = new Set(options.excludeMachineIds ?? []);
|
|
57
|
-
let callIndex = 0;
|
|
58
|
-
const placementBySandboxId = /* @__PURE__ */ new Map();
|
|
59
|
-
const client = {
|
|
60
|
-
async create() {
|
|
61
|
-
const ids = fleet.ids.filter((id) => !exclude.has(id));
|
|
62
|
-
if (ids.length === 0) {
|
|
63
|
-
throw new Error(
|
|
64
|
-
`agent-runtime: fleet ${fleet.fleetId} has no eligible worker machines (ids=[${fleet.ids.join(",")}], excluded=[${[...exclude].join(",")}])`
|
|
65
|
-
);
|
|
66
|
-
}
|
|
67
|
-
const selector = options.selectMachine;
|
|
68
|
-
const machineId = selector ? selector({ callIndex, ids }) : ids[callIndex % ids.length];
|
|
69
|
-
callIndex += 1;
|
|
70
|
-
if (typeof machineId !== "string" || machineId.length === 0) {
|
|
71
|
-
throw new Error("agent-runtime: fleet executor selectMachine returned an empty machine id");
|
|
72
|
-
}
|
|
73
|
-
const box = await fleet.sandbox(machineId);
|
|
74
|
-
const sandboxId = readId(box);
|
|
75
|
-
if (sandboxId) placementBySandboxId.set(sandboxId, { machineId });
|
|
76
|
-
return box;
|
|
77
|
-
},
|
|
78
|
-
describePlacement(box) {
|
|
79
|
-
const sandboxId = readId(box);
|
|
80
|
-
const recorded = sandboxId ? placementBySandboxId.get(sandboxId) : void 0;
|
|
81
|
-
return {
|
|
82
|
-
kind: "fleet",
|
|
83
|
-
sandboxId,
|
|
84
|
-
fleetId: fleet.fleetId,
|
|
85
|
-
machineId: recorded?.machineId
|
|
86
|
-
};
|
|
87
|
-
}
|
|
88
|
-
};
|
|
89
|
-
return {
|
|
90
|
-
client,
|
|
91
|
-
describe() {
|
|
92
|
-
const excluded = exclude.size > 0 ? ` (excluded=[${[...exclude].join(",")}])` : "";
|
|
93
|
-
return `fleet-workspace (fleetId=${fleet.fleetId}, machines=[${fleet.ids.join(",")}]${excluded})`;
|
|
94
|
-
}
|
|
95
|
-
};
|
|
96
|
-
}
|
|
97
|
-
function readId(box) {
|
|
98
|
-
const raw = box.id;
|
|
99
|
-
return typeof raw === "string" && raw.length > 0 ? raw : void 0;
|
|
100
|
-
}
|
|
101
30
|
|
|
102
31
|
// src/mcp/worktree.ts
|
|
103
32
|
import { spawn } from "child_process";
|
|
@@ -430,138 +359,6 @@ function parseList(raw) {
|
|
|
430
359
|
return list.length > 0 ? list : void 0;
|
|
431
360
|
}
|
|
432
361
|
|
|
433
|
-
// src/mcp/delegates.ts
|
|
434
|
-
function createDefaultCoderDelegate(options) {
|
|
435
|
-
const executor = resolveExecutor(options);
|
|
436
|
-
const sandboxClient = executor.client;
|
|
437
|
-
const fanoutHarnesses = options.fanoutHarnesses;
|
|
438
|
-
const maxConcurrency = options.maxConcurrency ?? 4;
|
|
439
|
-
return async (args, ctx) => {
|
|
440
|
-
const task = {
|
|
441
|
-
goal: buildCoderGoal(args),
|
|
442
|
-
repoRoot: args.repoRoot,
|
|
443
|
-
testCmd: args.config?.testCmd,
|
|
444
|
-
typecheckCmd: args.config?.typecheckCmd,
|
|
445
|
-
forbiddenPaths: args.config?.forbiddenPaths,
|
|
446
|
-
maxDiffLines: args.config?.maxDiffLines
|
|
447
|
-
};
|
|
448
|
-
const variants = Math.max(1, Math.trunc(args.variants ?? 1));
|
|
449
|
-
ctx.report({ iteration: 0, phase: "starting" });
|
|
450
|
-
if (variants <= 1) {
|
|
451
|
-
const { agentRunSpec, output, validator } = coderProfile({ task });
|
|
452
|
-
const result2 = await runLoop({
|
|
453
|
-
driver: singleShotDriver,
|
|
454
|
-
agentRun: agentRunSpec,
|
|
455
|
-
output,
|
|
456
|
-
validator,
|
|
457
|
-
task,
|
|
458
|
-
ctx: { sandboxClient, signal: ctx.signal },
|
|
459
|
-
maxIterations: 1,
|
|
460
|
-
maxConcurrency
|
|
461
|
-
});
|
|
462
|
-
const chosen2 = await pickCoderWinner({
|
|
463
|
-
iterations: result2.iterations,
|
|
464
|
-
reviewer: options.reviewer,
|
|
465
|
-
selection: options.winnerSelection ?? "highest-score",
|
|
466
|
-
task,
|
|
467
|
-
signal: ctx.signal
|
|
468
|
-
});
|
|
469
|
-
if (!chosen2) throw new Error(noWinnerMessage(options.reviewer));
|
|
470
|
-
ctx.report({ iteration: 1, phase: "completed" });
|
|
471
|
-
return chosen2;
|
|
472
|
-
}
|
|
473
|
-
const fanout = multiHarnessCoderFanout(
|
|
474
|
-
fanoutHarnesses && fanoutHarnesses.length > 0 ? { harnesses: fanoutHarnesses.slice(0, variants) } : { harnesses: void 0 }
|
|
475
|
-
);
|
|
476
|
-
const agentRuns = fanout.agentRuns.slice(0, variants);
|
|
477
|
-
const result = await runLoop({
|
|
478
|
-
driver: fanout.driver,
|
|
479
|
-
agentRuns,
|
|
480
|
-
output: fanout.output,
|
|
481
|
-
validator: fanout.validator,
|
|
482
|
-
task,
|
|
483
|
-
ctx: { sandboxClient, signal: ctx.signal },
|
|
484
|
-
maxIterations: variants,
|
|
485
|
-
maxConcurrency: Math.min(maxConcurrency, variants)
|
|
486
|
-
});
|
|
487
|
-
const chosen = await pickCoderWinner({
|
|
488
|
-
iterations: result.iterations,
|
|
489
|
-
reviewer: options.reviewer,
|
|
490
|
-
selection: options.winnerSelection ?? "highest-score",
|
|
491
|
-
task,
|
|
492
|
-
signal: ctx.signal
|
|
493
|
-
});
|
|
494
|
-
if (!chosen) throw new Error(noWinnerMessage(options.reviewer));
|
|
495
|
-
ctx.report({ iteration: agentRuns.length, phase: "completed" });
|
|
496
|
-
return chosen;
|
|
497
|
-
};
|
|
498
|
-
}
|
|
499
|
-
async function pickCoderWinner(args) {
|
|
500
|
-
const valid = [];
|
|
501
|
-
for (const iter of args.iterations) {
|
|
502
|
-
if (iter.output === void 0 || iter.error || iter.verdict?.valid !== true) continue;
|
|
503
|
-
valid.push({
|
|
504
|
-
index: iter.index,
|
|
505
|
-
output: iter.output,
|
|
506
|
-
score: iter.verdict.score ?? 0,
|
|
507
|
-
readiness: iter.verdict.score ?? 0
|
|
508
|
-
});
|
|
509
|
-
}
|
|
510
|
-
if (valid.length === 0) return void 0;
|
|
511
|
-
let eligible = valid;
|
|
512
|
-
if (args.reviewer) {
|
|
513
|
-
eligible = [];
|
|
514
|
-
for (const c of valid) {
|
|
515
|
-
const review = await args.reviewer(c.output, args.task, { signal: args.signal });
|
|
516
|
-
if (review.approved) eligible.push({ ...c, readiness: review.readiness });
|
|
517
|
-
}
|
|
518
|
-
if (eligible.length === 0) return void 0;
|
|
519
|
-
}
|
|
520
|
-
return selectCoderCandidate(eligible, args.selection).output;
|
|
521
|
-
}
|
|
522
|
-
function selectCoderCandidate(candidates, selection) {
|
|
523
|
-
const diffLines = (c) => c.output.diffStats.insertions + c.output.diffStats.deletions;
|
|
524
|
-
const sorted = [...candidates].sort((a, b) => {
|
|
525
|
-
switch (selection) {
|
|
526
|
-
case "smallest-diff":
|
|
527
|
-
return diffLines(a) - diffLines(b) || a.index - b.index;
|
|
528
|
-
case "highest-readiness":
|
|
529
|
-
return b.readiness - a.readiness || a.index - b.index;
|
|
530
|
-
case "first-approved":
|
|
531
|
-
return a.index - b.index;
|
|
532
|
-
default:
|
|
533
|
-
return b.score - a.score || a.index - b.index;
|
|
534
|
-
}
|
|
535
|
-
});
|
|
536
|
-
return sorted[0];
|
|
537
|
-
}
|
|
538
|
-
function noWinnerMessage(reviewer) {
|
|
539
|
-
return reviewer ? "coder delegate: no candidate passed validation + review" : "coder delegate: no candidate passed validation";
|
|
540
|
-
}
|
|
541
|
-
function buildCoderGoal(args) {
|
|
542
|
-
if (!args.contextHint) return args.goal;
|
|
543
|
-
return [args.goal, "", "## Context", args.contextHint].join("\n");
|
|
544
|
-
}
|
|
545
|
-
function resolveExecutor(options) {
|
|
546
|
-
if (options.executor && options.sandboxClient) {
|
|
547
|
-
throw new Error("createDefaultCoderDelegate: pass exactly one of `executor` or `sandboxClient`");
|
|
548
|
-
}
|
|
549
|
-
if (options.executor) return options.executor;
|
|
550
|
-
if (options.sandboxClient) {
|
|
551
|
-
return createSiblingSandboxExecutor({ client: options.sandboxClient });
|
|
552
|
-
}
|
|
553
|
-
throw new Error("createDefaultCoderDelegate: `executor` or `sandboxClient` is required");
|
|
554
|
-
}
|
|
555
|
-
var singleShotDriver = {
|
|
556
|
-
name: "mcp-single-shot",
|
|
557
|
-
async plan(task, history) {
|
|
558
|
-
return history.length === 0 ? [task] : [];
|
|
559
|
-
},
|
|
560
|
-
decide(history) {
|
|
561
|
-
return history.length > 0 ? "pick-winner" : "fail";
|
|
562
|
-
}
|
|
563
|
-
};
|
|
564
|
-
|
|
565
362
|
// src/mcp/server.ts
|
|
566
363
|
import { createInterface } from "readline";
|
|
567
364
|
import { Readable, Writable } from "stream";
|
|
@@ -751,15 +548,12 @@ function createInProcessTransport() {
|
|
|
751
548
|
}
|
|
752
549
|
|
|
753
550
|
export {
|
|
754
|
-
createSiblingSandboxExecutor,
|
|
755
|
-
createFleetWorkspaceExecutor,
|
|
756
551
|
createWorktree,
|
|
757
552
|
captureWorktreeDiff,
|
|
758
553
|
removeWorktree,
|
|
759
554
|
createInProcessExecutor,
|
|
760
555
|
detectExecutor,
|
|
761
|
-
createDefaultCoderDelegate,
|
|
762
556
|
createMcpServer,
|
|
763
557
|
createInProcessTransport
|
|
764
558
|
};
|
|
765
|
-
//# sourceMappingURL=chunk-
|
|
559
|
+
//# sourceMappingURL=chunk-M65QJD35.js.map
|