@zhixuan92/multi-model-agent-core 4.7.5 → 4.7.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/dist/bounded-execution/activity-tracker-types.d.ts +0 -2
- package/dist/bounded-execution/activity-tracker-types.d.ts.map +1 -1
- package/dist/bounded-execution/activity-tracker.d.ts +1 -5
- package/dist/bounded-execution/activity-tracker.d.ts.map +1 -1
- package/dist/bounded-execution/activity-tracker.js +1 -27
- package/dist/bounded-execution/activity-tracker.js.map +1 -1
- package/dist/bounded-execution/progress-events-subscriber.d.ts +4 -12
- package/dist/bounded-execution/progress-events-subscriber.d.ts.map +1 -1
- package/dist/bounded-execution/progress-events-subscriber.js +1 -5
- package/dist/bounded-execution/progress-events-subscriber.js.map +1 -1
- package/dist/config/model-profile-registry.d.ts.map +1 -1
- package/dist/config/model-profile-registry.js +9 -6
- package/dist/config/model-profile-registry.js.map +1 -1
- package/dist/error-codes.d.ts +0 -4
- package/dist/error-codes.d.ts.map +1 -1
- package/dist/error-codes.js +1 -5
- package/dist/error-codes.js.map +1 -1
- package/dist/events/task-envelope.d.ts +15 -6
- package/dist/events/task-envelope.d.ts.map +1 -1
- package/dist/events/task-envelope.js +28 -13
- package/dist/events/task-envelope.js.map +1 -1
- package/dist/events/telemetry-uploader.d.ts +6 -2
- package/dist/events/telemetry-uploader.d.ts.map +1 -1
- package/dist/events/telemetry-uploader.js.map +1 -1
- package/dist/events/to-wire-record.d.ts +0 -2
- package/dist/events/to-wire-record.d.ts.map +1 -1
- package/dist/events/to-wire-record.js +34 -8
- package/dist/events/to-wire-record.js.map +1 -1
- package/dist/events/wire-schema.d.ts +37 -108
- package/dist/events/wire-schema.d.ts.map +1 -1
- package/dist/events/wire-schema.js +12 -5
- package/dist/events/wire-schema.js.map +1 -1
- package/dist/index.d.ts +1 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +0 -1
- package/dist/index.js.map +1 -1
- package/dist/lifecycle/build-cancelled-result.d.ts.map +1 -1
- package/dist/lifecycle/build-cancelled-result.js +0 -2
- package/dist/lifecycle/build-cancelled-result.js.map +1 -1
- package/dist/lifecycle/fallback-report.d.ts.map +1 -1
- package/dist/lifecycle/fallback-report.js +0 -1
- package/dist/lifecycle/fallback-report.js.map +1 -1
- package/dist/lifecycle/handlers/annotate-stage.d.ts +0 -5
- package/dist/lifecycle/handlers/annotate-stage.d.ts.map +1 -1
- package/dist/lifecycle/handlers/annotate-stage.js +35 -5
- package/dist/lifecycle/handlers/annotate-stage.js.map +1 -1
- package/dist/lifecycle/handlers/enrich-runtime-result.d.ts.map +1 -1
- package/dist/lifecycle/handlers/enrich-runtime-result.js +22 -2
- package/dist/lifecycle/handlers/enrich-runtime-result.js.map +1 -1
- package/dist/lifecycle/handlers/implement-stage.d.ts.map +1 -1
- package/dist/lifecycle/handlers/implement-stage.js +10 -1
- package/dist/lifecycle/handlers/implement-stage.js.map +1 -1
- package/dist/lifecycle/handlers/read-route-implementer.js +1 -1
- package/dist/lifecycle/handlers/read-route-implementer.js.map +1 -1
- package/dist/lifecycle/handlers/review-stage.d.ts.map +1 -1
- package/dist/lifecycle/handlers/review-stage.js +40 -23
- package/dist/lifecycle/handlers/review-stage.js.map +1 -1
- package/dist/lifecycle/handlers/rework-stage.d.ts.map +1 -1
- package/dist/lifecycle/handlers/rework-stage.js +7 -14
- package/dist/lifecycle/handlers/rework-stage.js.map +1 -1
- package/dist/lifecycle/handlers/terminal-handlers.d.ts.map +1 -1
- package/dist/lifecycle/handlers/terminal-handlers.js +2 -14
- package/dist/lifecycle/handlers/terminal-handlers.js.map +1 -1
- package/dist/lifecycle/lifecycle-context.d.ts +1 -2
- package/dist/lifecycle/lifecycle-context.d.ts.map +1 -1
- package/dist/lifecycle/lifecycle-driver.js +4 -4
- package/dist/lifecycle/lifecycle-driver.js.map +1 -1
- package/dist/lifecycle/merge-stage-stats.d.ts +1 -4
- package/dist/lifecycle/merge-stage-stats.d.ts.map +1 -1
- package/dist/lifecycle/merge-stage-stats.js +1 -6
- package/dist/lifecycle/merge-stage-stats.js.map +1 -1
- package/dist/lifecycle/perform-implementation.d.ts.map +1 -1
- package/dist/lifecycle/perform-implementation.js +2 -16
- package/dist/lifecycle/perform-implementation.js.map +1 -1
- package/dist/lifecycle/stage-plan-types.d.ts +0 -2
- package/dist/lifecycle/stage-plan-types.d.ts.map +1 -1
- package/dist/lifecycle/stage-stats.d.ts +1 -17
- package/dist/lifecycle/stage-stats.d.ts.map +1 -1
- package/dist/lifecycle/stage-stats.js +3 -35
- package/dist/lifecycle/stage-stats.js.map +1 -1
- package/dist/lifecycle/task-completion-summary.d.ts.map +1 -1
- package/dist/lifecycle/task-completion-summary.js +0 -3
- package/dist/lifecycle/task-completion-summary.js.map +1 -1
- package/dist/lifecycle/task-executor.d.ts.map +1 -1
- package/dist/lifecycle/task-executor.js +52 -5
- package/dist/lifecycle/task-executor.js.map +1 -1
- package/dist/lifecycle/task-runner.d.ts +0 -1
- package/dist/lifecycle/task-runner.d.ts.map +1 -1
- package/dist/lifecycle/task-runner.js +7 -4
- package/dist/lifecycle/task-runner.js.map +1 -1
- package/dist/lifecycle/worker-output-contract.d.ts +1 -1
- package/dist/providers/assemble-run-result.d.ts.map +1 -1
- package/dist/providers/assemble-run-result.js +5 -38
- package/dist/providers/assemble-run-result.js.map +1 -1
- package/dist/providers/claude-session.d.ts +2 -0
- package/dist/providers/claude-session.d.ts.map +1 -1
- package/dist/providers/claude-session.js +11 -45
- package/dist/providers/claude-session.js.map +1 -1
- package/dist/providers/claude-tool-categories.d.ts +19 -0
- package/dist/providers/claude-tool-categories.d.ts.map +1 -0
- package/dist/providers/claude-tool-categories.js +37 -0
- package/dist/providers/claude-tool-categories.js.map +1 -0
- package/dist/providers/claude.d.ts.map +1 -1
- package/dist/providers/claude.js +8 -11
- package/dist/providers/claude.js.map +1 -1
- package/dist/providers/codex-cli-event.d.ts +6 -0
- package/dist/providers/codex-cli-event.d.ts.map +1 -1
- package/dist/providers/codex-cli-event.js.map +1 -1
- package/dist/providers/codex-cli-launch.js +2 -2
- package/dist/providers/codex-cli-launch.js.map +1 -1
- package/dist/providers/codex-cli-session.d.ts +1 -7
- package/dist/providers/codex-cli-session.d.ts.map +1 -1
- package/dist/providers/codex-cli-session.js +27 -31
- package/dist/providers/codex-cli-session.js.map +1 -1
- package/dist/providers/normalize-claude.d.ts +0 -3
- package/dist/providers/normalize-claude.d.ts.map +1 -1
- package/dist/providers/normalize-claude.js +9 -20
- package/dist/providers/normalize-claude.js.map +1 -1
- package/dist/providers/provider-factory.d.ts +23 -4
- package/dist/providers/provider-factory.d.ts.map +1 -1
- package/dist/providers/provider-factory.js +102 -24
- package/dist/providers/provider-factory.js.map +1 -1
- package/dist/providers/runner-types.d.ts +2 -4
- package/dist/providers/runner-types.d.ts.map +1 -1
- package/dist/reporting/compose-running-headline.d.ts +1 -2
- package/dist/reporting/compose-running-headline.d.ts.map +1 -1
- package/dist/reporting/compose-running-headline.js +4 -7
- package/dist/reporting/compose-running-headline.js.map +1 -1
- package/dist/reporting/index.d.ts +0 -1
- package/dist/reporting/index.d.ts.map +1 -1
- package/dist/reporting/index.js +0 -1
- package/dist/reporting/index.js.map +1 -1
- package/dist/reporting/structured-report.d.ts +0 -4
- package/dist/reporting/structured-report.d.ts.map +1 -1
- package/dist/reporting/structured-report.js +1 -19
- package/dist/reporting/structured-report.js.map +1 -1
- package/dist/reporting/terminal-status-deriver.d.ts +2 -3
- package/dist/reporting/terminal-status-deriver.d.ts.map +1 -1
- package/dist/reporting/terminal-status-deriver.js +1 -4
- package/dist/reporting/terminal-status-deriver.js.map +1 -1
- package/dist/review/tier-policy.d.ts +11 -0
- package/dist/review/tier-policy.d.ts.map +1 -0
- package/dist/review/tier-policy.js +12 -0
- package/dist/review/tier-policy.js.map +1 -0
- package/dist/stores/batch-registry.d.ts +0 -1
- package/dist/stores/batch-registry.d.ts.map +1 -1
- package/dist/stores/batch-registry.js.map +1 -1
- package/dist/tool-surface/discover.d.ts +1 -1
- package/dist/tool-surface/discover.d.ts.map +1 -1
- package/dist/tool-surface/discover.js +1 -0
- package/dist/tool-surface/discover.js.map +1 -1
- package/dist/tools/delegate/brief-slot.d.ts +0 -1
- package/dist/tools/delegate/brief-slot.d.ts.map +1 -1
- package/dist/tools/delegate/brief-slot.js +0 -1
- package/dist/tools/delegate/brief-slot.js.map +1 -1
- package/dist/tools/delegate/implementer-criteria.d.ts +1 -1
- package/dist/tools/delegate/implementer-criteria.d.ts.map +1 -1
- package/dist/tools/delegate/implementer-criteria.js +2 -4
- package/dist/tools/delegate/implementer-criteria.js.map +1 -1
- package/dist/tools/delegate/schema.d.ts +0 -1
- package/dist/tools/delegate/schema.d.ts.map +1 -1
- package/dist/tools/delegate/schema.js +0 -1
- package/dist/tools/delegate/schema.js.map +1 -1
- package/dist/tools/delegate/tool-config.d.ts.map +1 -1
- package/dist/tools/delegate/tool-config.js +0 -1
- package/dist/tools/delegate/tool-config.js.map +1 -1
- package/dist/tools/execute-plan/brief-slot.d.ts +0 -2
- package/dist/tools/execute-plan/brief-slot.d.ts.map +1 -1
- package/dist/tools/execute-plan/brief-slot.js +0 -1
- package/dist/tools/execute-plan/brief-slot.js.map +1 -1
- package/dist/tools/execute-plan/schema.d.ts +0 -1
- package/dist/tools/execute-plan/schema.d.ts.map +1 -1
- package/dist/tools/execute-plan/schema.js +0 -2
- package/dist/tools/execute-plan/schema.js.map +1 -1
- package/dist/tools/execute-plan/tool-config.d.ts +0 -1
- package/dist/tools/execute-plan/tool-config.d.ts.map +1 -1
- package/dist/tools/execute-plan/tool-config.js +0 -2
- package/dist/tools/execute-plan/tool-config.js.map +1 -1
- package/dist/types/draft-task.d.ts +0 -1
- package/dist/types/draft-task.d.ts.map +1 -1
- package/dist/types/enums.d.ts +1 -17
- package/dist/types/enums.d.ts.map +1 -1
- package/dist/types/enums.js +2 -8
- package/dist/types/enums.js.map +1 -1
- package/dist/types/run-result.d.ts +6 -17
- package/dist/types/run-result.d.ts.map +1 -1
- package/dist/types/stage-stats.d.ts +0 -6
- package/dist/types/stage-stats.d.ts.map +1 -1
- package/dist/types/task-spec.d.ts +0 -1
- package/dist/types/task-spec.d.ts.map +1 -1
- package/dist/types.d.ts +1 -1
- package/dist/types.d.ts.map +1 -1
- package/package.json +1 -1
- package/dist/bounded-execution/cost-rollup.d.ts +0 -17
- package/dist/bounded-execution/cost-rollup.d.ts.map +0 -1
- package/dist/bounded-execution/cost-rollup.js +0 -40
- package/dist/bounded-execution/cost-rollup.js.map +0 -1
- package/dist/config/tier-policy-registry.d.ts +0 -12
- package/dist/config/tier-policy-registry.d.ts.map +0 -1
- package/dist/config/tier-policy-registry.js +0 -13
- package/dist/config/tier-policy-registry.js.map +0 -1
- package/dist/providers/brief-preamble.d.ts +0 -4
- package/dist/providers/brief-preamble.d.ts.map +0 -1
- package/dist/providers/brief-preamble.js +0 -39
- package/dist/providers/brief-preamble.js.map +0 -1
- package/dist/providers/error-classification.d.ts +0 -49
- package/dist/providers/error-classification.d.ts.map +0 -1
- package/dist/providers/error-classification.js +0 -140
- package/dist/providers/error-classification.js.map +0 -1
- package/dist/providers/index.d.ts +0 -5
- package/dist/providers/index.d.ts.map +0 -1
- package/dist/providers/index.js +0 -6
- package/dist/providers/index.js.map +0 -1
- package/dist/providers/run-annotator-turn.d.ts +0 -24
- package/dist/providers/run-annotator-turn.d.ts.map +0 -1
- package/dist/providers/run-annotator-turn.js +0 -44
- package/dist/providers/run-annotator-turn.js.map +0 -1
- package/dist/providers/run-worker-turn.d.ts +0 -26
- package/dist/providers/run-worker-turn.d.ts.map +0 -1
- package/dist/providers/run-worker-turn.js +0 -57
- package/dist/providers/run-worker-turn.js.map +0 -1
- package/dist/providers/runner-adapter.d.ts +0 -49
- package/dist/providers/runner-adapter.d.ts.map +0 -1
- package/dist/providers/runner-adapter.js +0 -8
- package/dist/providers/runner-adapter.js.map +0 -1
- package/dist/providers/stall-detector.d.ts +0 -22
- package/dist/providers/stall-detector.d.ts.map +0 -1
- package/dist/providers/stall-detector.js +0 -43
- package/dist/providers/stall-detector.js.map +0 -1
- package/dist/providers/tool-name-sets.d.ts +0 -29
- package/dist/providers/tool-name-sets.d.ts.map +0 -1
- package/dist/providers/tool-name-sets.js +0 -41
- package/dist/providers/tool-name-sets.js.map +0 -1
- package/dist/reporting/verify-stage-runner.d.ts +0 -21
- package/dist/reporting/verify-stage-runner.d.ts.map +0 -1
- package/dist/reporting/verify-stage-runner.js +0 -102
- package/dist/reporting/verify-stage-runner.js.map +0 -1
- package/dist/review/run-reviewer.d.ts +0 -40
- package/dist/review/run-reviewer.d.ts.map +0 -1
- package/dist/review/run-reviewer.js +0 -55
- package/dist/review/run-reviewer.js.map +0 -1
|
@@ -1,102 +0,0 @@
|
|
|
1
|
-
import { spawn } from 'node:child_process';
|
|
2
|
-
const DEFAULT_TIMEOUT_MS = 300_000; // 5 min
|
|
3
|
-
const MAX_OUTPUT_BYTES = 64 * 1024; // 64 KB
|
|
4
|
-
class RollingTail {
|
|
5
|
-
chunks = [];
|
|
6
|
-
bytes = 0;
|
|
7
|
-
push(s) {
|
|
8
|
-
const buf = Buffer.from(s, 'utf8');
|
|
9
|
-
this.chunks.push(buf);
|
|
10
|
-
this.bytes += buf.length;
|
|
11
|
-
while (this.chunks.length > 0 && this.bytes - this.chunks[0].length >= MAX_OUTPUT_BYTES) {
|
|
12
|
-
this.bytes -= this.chunks.shift().length;
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
toString() {
|
|
16
|
-
if (this.bytes === 0)
|
|
17
|
-
return '';
|
|
18
|
-
const concat = Buffer.concat(this.chunks);
|
|
19
|
-
if (concat.length <= MAX_OUTPUT_BYTES)
|
|
20
|
-
return concat.toString('utf8');
|
|
21
|
-
return concat.subarray(concat.length - MAX_OUTPUT_BYTES).toString('utf8');
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
export class VerifyStageRunner {
|
|
25
|
-
/**
|
|
26
|
-
* Run a post-implementation verify command (e.g. `npm test`).
|
|
27
|
-
*
|
|
28
|
-
* IMPORTANT: `command` is executed via `shell: true` and MUST be trusted input
|
|
29
|
-
* (config-supplied, not user-supplied). Do not pass unsanitized user input here.
|
|
30
|
-
*/
|
|
31
|
-
async run(command, cwd, options = {}) {
|
|
32
|
-
const timeoutMs = options.timeoutMs ?? DEFAULT_TIMEOUT_MS;
|
|
33
|
-
const start = Date.now();
|
|
34
|
-
return new Promise((resolve, reject) => {
|
|
35
|
-
const proc = spawn(command, { shell: true, cwd });
|
|
36
|
-
const stdout = new RollingTail();
|
|
37
|
-
const stderr = new RollingTail();
|
|
38
|
-
let resolved = false;
|
|
39
|
-
const finish = (result) => {
|
|
40
|
-
if (!resolved) {
|
|
41
|
-
resolved = true;
|
|
42
|
-
resolve(result);
|
|
43
|
-
}
|
|
44
|
-
};
|
|
45
|
-
const timer = setTimeout(() => {
|
|
46
|
-
finish({
|
|
47
|
-
exitCode: -1,
|
|
48
|
-
stdout: stdout.toString(),
|
|
49
|
-
stderr: stderr.toString(),
|
|
50
|
-
signal: null,
|
|
51
|
-
durationMs: Date.now() - start,
|
|
52
|
-
errorCode: 'validator_verify_command_failed',
|
|
53
|
-
});
|
|
54
|
-
try {
|
|
55
|
-
proc.kill('SIGKILL');
|
|
56
|
-
}
|
|
57
|
-
catch {
|
|
58
|
-
// best-effort kill
|
|
59
|
-
}
|
|
60
|
-
}, Math.max(1, timeoutMs));
|
|
61
|
-
proc.stdout?.on('data', (d) => stdout.push(d.toString()));
|
|
62
|
-
proc.stderr?.on('data', (d) => stderr.push(d.toString()));
|
|
63
|
-
proc.on('error', (err) => {
|
|
64
|
-
clearTimeout(timer);
|
|
65
|
-
reject(err);
|
|
66
|
-
});
|
|
67
|
-
proc.on('exit', (code, sig) => {
|
|
68
|
-
clearTimeout(timer);
|
|
69
|
-
if (sig) {
|
|
70
|
-
finish({
|
|
71
|
-
exitCode: code ?? -1,
|
|
72
|
-
stdout: stdout.toString(),
|
|
73
|
-
stderr: stderr.toString(),
|
|
74
|
-
signal: sig,
|
|
75
|
-
durationMs: Date.now() - start,
|
|
76
|
-
errorCode: 'validator_verify_command_failed',
|
|
77
|
-
});
|
|
78
|
-
}
|
|
79
|
-
else if (code === 0) {
|
|
80
|
-
finish({
|
|
81
|
-
exitCode: 0,
|
|
82
|
-
stdout: stdout.toString(),
|
|
83
|
-
stderr: stderr.toString(),
|
|
84
|
-
signal: null,
|
|
85
|
-
durationMs: Date.now() - start,
|
|
86
|
-
});
|
|
87
|
-
}
|
|
88
|
-
else {
|
|
89
|
-
finish({
|
|
90
|
-
exitCode: code ?? -1,
|
|
91
|
-
stdout: stdout.toString(),
|
|
92
|
-
stderr: stderr.toString(),
|
|
93
|
-
signal: null,
|
|
94
|
-
durationMs: Date.now() - start,
|
|
95
|
-
errorCode: 'validator_verify_command_failed',
|
|
96
|
-
});
|
|
97
|
-
}
|
|
98
|
-
});
|
|
99
|
-
});
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
//# sourceMappingURL=verify-stage-runner.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"verify-stage-runner.js","sourceRoot":"","sources":["../../src/reporting/verify-stage-runner.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
import type { ExecutionContext } from '../lifecycle/lifecycle-context.js';
|
|
2
|
-
import type { AgentType } from '../types.js';
|
|
3
|
-
export type RunReviewerInput = {
|
|
4
|
-
prompt: string;
|
|
5
|
-
ctx: ExecutionContext;
|
|
6
|
-
reviewer: 'spec' | 'quality';
|
|
7
|
-
/**
|
|
8
|
-
* The implementer's tier. The reviewer runs on the OPPOSITE tier as a
|
|
9
|
-
* "second-opinion needs a different perspective" policy:
|
|
10
|
-
* implementer=standard → reviewer=complex (capable reviewer of cheap work)
|
|
11
|
-
* implementer=complex → reviewer=standard (cheap sanity check of expensive work)
|
|
12
|
-
* If the inverted tier has no provider configured, falls back to the
|
|
13
|
-
* implementer tier and records a `validation_warnings` diagnostic upstream.
|
|
14
|
-
*/
|
|
15
|
-
implementerTier: AgentType;
|
|
16
|
-
};
|
|
17
|
-
/**
|
|
18
|
-
* Cross-tier inversion: reviewer tier is the opposite of the implementer's.
|
|
19
|
-
* Exported so callers can compute the tier independently (e.g. for logging
|
|
20
|
-
* or for the `mergeStageStats` call in review-handler.ts).
|
|
21
|
-
*/
|
|
22
|
-
export declare function invertedReviewerTier(implementerTier: AgentType): AgentType;
|
|
23
|
-
export type RunReviewerResult = {
|
|
24
|
-
kind: 'ok';
|
|
25
|
-
text: string;
|
|
26
|
-
costUSD: number | null;
|
|
27
|
-
turnsUsed: number;
|
|
28
|
-
ms: number;
|
|
29
|
-
model: string | null;
|
|
30
|
-
inputTokens: number;
|
|
31
|
-
outputTokens: number;
|
|
32
|
-
cachedReadTokens: number;
|
|
33
|
-
cachedNonReadTokens: number;
|
|
34
|
-
} | {
|
|
35
|
-
kind: 'transport_error';
|
|
36
|
-
message: string;
|
|
37
|
-
ms: number;
|
|
38
|
-
};
|
|
39
|
-
export declare function runReviewerTurn(input: RunReviewerInput): Promise<RunReviewerResult>;
|
|
40
|
-
//# sourceMappingURL=run-reviewer.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"run-reviewer.d.ts","sourceRoot":"","sources":["../../src/review/run-reviewer.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AAC1E,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAG7C,MAAM,MAAM,gBAAgB,GAAG;IAC7B,MAAM,EAAE,MAAM,CAAC;IACf,GAAG,EAAE,gBAAgB,CAAC;IACtB,QAAQ,EAAE,MAAM,GAAG,SAAS,CAAC;IAC7B;;;;;;;OAOG;IACH,eAAe,EAAE,SAAS,CAAC;CAC5B,CAAC;AAEF;;;;GAIG;AACH,wBAAgB,oBAAoB,CAAC,eAAe,EAAE,SAAS,GAAG,SAAS,CAE1E;AAED,MAAM,MAAM,iBAAiB,GACzB;IACE,IAAI,EAAE,IAAI,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IACvB,SAAS,EAAE,MAAM,CAAC;IAClB,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,MAAM,CAAC;IACrB,gBAAgB,EAAE,MAAM,CAAC;IACzB,mBAAmB,EAAE,MAAM,CAAC;CAC7B,GACD;IAAE,IAAI,EAAE,iBAAiB,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,EAAE,EAAE,MAAM,CAAA;CAAE,CAAC;AAE7D,wBAAsB,eAAe,CAAC,KAAK,EAAE,gBAAgB,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAqCzF"}
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
// Thin wrapper that runs one reviewer-tier LLM turn with 3-attempt transport-retry policy.
|
|
2
|
-
// Spec §4.6: transport failures (network, 5xx, model gateway, timeout) → 3 total attempts
|
|
3
|
-
// with backoff 0s → 1s → 2s. Non-transport caps (turn_cap, sandbox) → no retry.
|
|
4
|
-
import { HUMAN_LABEL } from '../lifecycle/stage-labels.js';
|
|
5
|
-
/**
|
|
6
|
-
* Cross-tier inversion: reviewer tier is the opposite of the implementer's.
|
|
7
|
-
* Exported so callers can compute the tier independently (e.g. for logging
|
|
8
|
-
* or for the `mergeStageStats` call in review-handler.ts).
|
|
9
|
-
*/
|
|
10
|
-
export function invertedReviewerTier(implementerTier) {
|
|
11
|
-
return implementerTier === 'complex' ? 'standard' : 'complex';
|
|
12
|
-
}
|
|
13
|
-
export async function runReviewerTurn(input) {
|
|
14
|
-
const t0 = Date.now();
|
|
15
|
-
const backoffMs = [0, 1000, 2000]; // attempt 1: no backoff; 2: 1s; 3: 2s
|
|
16
|
-
let lastErr = '';
|
|
17
|
-
for (let attempt = 0; attempt < 3; attempt++) {
|
|
18
|
-
if (backoffMs[attempt] > 0)
|
|
19
|
-
await sleep(backoffMs[attempt]);
|
|
20
|
-
try {
|
|
21
|
-
// Cross-tier inversion. If the inverted tier has no provider
|
|
22
|
-
// configured (single-tier deployments), fall back to the implementer
|
|
23
|
-
// tier so the reviewer can still run. The fallback is observable
|
|
24
|
-
// via the resolved `session.model` carried into the wire payload.
|
|
25
|
-
const desired = invertedReviewerTier(input.implementerTier);
|
|
26
|
-
const providers = input.ctx.providers;
|
|
27
|
-
const tierToUse = providers && providers[desired] ? desired : input.implementerTier;
|
|
28
|
-
const session = input.ctx.getSession(tierToUse);
|
|
29
|
-
const r = await session.send(input.prompt, { stageLabel: HUMAN_LABEL.review });
|
|
30
|
-
return {
|
|
31
|
-
kind: 'ok',
|
|
32
|
-
text: r.output ?? '',
|
|
33
|
-
costUSD: r.costUSD ?? null,
|
|
34
|
-
turnsUsed: r.turns ?? 1,
|
|
35
|
-
ms: Date.now() - t0,
|
|
36
|
-
model: typeof r.model === 'string'
|
|
37
|
-
? r.model
|
|
38
|
-
: null,
|
|
39
|
-
inputTokens: r.usage?.inputTokens ?? 0,
|
|
40
|
-
outputTokens: r.usage?.outputTokens ?? 0,
|
|
41
|
-
cachedReadTokens: r.usage?.cachedReadTokens ?? 0,
|
|
42
|
-
cachedNonReadTokens: r.usage?.cachedNonReadTokens ?? 0,
|
|
43
|
-
};
|
|
44
|
-
}
|
|
45
|
-
catch (err) {
|
|
46
|
-
lastErr = err instanceof Error ? err.message : String(err);
|
|
47
|
-
// Only retry on transport-class errors; turn_cap / sandbox are non-retryable.
|
|
48
|
-
if (!/transport|network|5\d\d|timeout/i.test(lastErr))
|
|
49
|
-
break;
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
return { kind: 'transport_error', message: lastErr || 'reviewer failed', ms: Date.now() - t0 };
|
|
53
|
-
}
|
|
54
|
-
function sleep(ms) { return new Promise(r => setTimeout(r, ms)); }
|
|
55
|
-
//# sourceMappingURL=run-reviewer.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"run-reviewer.js","sourceRoot":"","sources":["../../src/review/run-reviewer.ts"],"names":[],"mappings":"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"}
|