substrate-ai 0.20.137 → 0.20.138
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/adapter-registry-Bpa7ESBV.js +4 -0
- package/dist/cli/index.js +29 -16
- package/dist/{decisions-DVuBgwlc.js → decisions-fBdZmqOK.js} +1 -1
- package/dist/{dist-BOooz8sb.js → dist-DnvGvKLu.js} +101 -10
- package/dist/{errors-iQa5SrYw.js → errors-i3s5sshZ.js} +2 -2
- package/dist/{experimenter-B7NPkaQ8.js → experimenter-DU2Cv51N.js} +1 -1
- package/dist/{health-BqCpWu2_.js → health-2Kfa00-H.js} +3 -3
- package/dist/{health-xmLvQgb4.js → health-Caa24SFM.js} +3 -3
- package/dist/{index-DG7r9fNS.d.ts → index-BJEANS9i.d.ts} +88 -2
- package/dist/index.d.ts +9 -1
- package/dist/index.js +2 -2
- package/dist/{interactive-prompt-Czlubg4J.js → interactive-prompt-B91mG5v4.js} +2 -2
- package/dist/{manifest-read-B0XYbIpU.js → manifest-read-DJFbGhSd.js} +2 -2
- package/dist/modules/interactive-prompt/index.js +3 -3
- package/dist/{routing-DkRxOHcc.js → routing-DFIBY9Yk.js} +1 -1
- package/dist/{run-Bb39uB9y.js → run-Dbwlb4Md.js} +6 -6
- package/dist/{run-DBifBbYW.js → run-Ppco-3HT.js} +5 -5
- package/dist/src/modules/recovery-engine/index.d.ts +1 -1
- package/dist/{upgrade-GFHZ2nsS.js → upgrade-CnIsoLpT.js} +2 -2
- package/dist/{upgrade-BwitoFQT.js → upgrade-yULZIAAW.js} +2 -2
- package/dist/{version-manager-impl-CPbTqr0B.js → version-manager-impl-C7ZhqLX3.js} +1 -1
- package/package.json +1 -1
- package/dist/adapter-registry-DxomlVMx.js +0 -4
package/dist/cli/index.js
CHANGED
|
@@ -1,20 +1,20 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import { FileKvStore, SUBSTRATE_OWNED_SETTINGS_KEYS, VALID_PHASES, buildPipelineStatusOutput, createDatabaseAdapter, createDoltOperatorReader, findPackageRoot, formatOutput, formatPipelineStatusHuman, formatPipelineSummary, formatTokenTelemetry, getAllDescendantPids, getAutoHealthData, getSubstrateDefaultSettings, inspectProcessTree, parseDbTimestampAsUtc, registerHealthCommand, resolveBmadMethodSrcPath, resolveBmadMethodVersion } from "../health-
|
|
2
|
+
import { FileKvStore, SUBSTRATE_OWNED_SETTINGS_KEYS, VALID_PHASES, buildPipelineStatusOutput, createDatabaseAdapter, createDoltOperatorReader, findPackageRoot, formatOutput, formatPipelineStatusHuman, formatPipelineSummary, formatTokenTelemetry, getAllDescendantPids, getAutoHealthData, getSubstrateDefaultSettings, inspectProcessTree, parseDbTimestampAsUtc, registerHealthCommand, resolveBmadMethodSrcPath, resolveBmadMethodVersion } from "../health-2Kfa00-H.js";
|
|
3
3
|
import { createLogger } from "../logger-KeHncl-f.js";
|
|
4
4
|
import { createEventBus } from "../helpers-CElYrONe.js";
|
|
5
|
-
import { AdapterRegistry, BudgetConfigSchema, CURRENT_CONFIG_FORMAT_VERSION, CURRENT_TASK_GRAPH_VERSION, ConfigError, CostTrackerConfigSchema, DEFAULT_CONFIG, DoltClient, DoltNotInstalled, GlobalSettingsSchema, InMemoryDatabaseAdapter, IngestionServer, MonitorDatabaseImpl, OPERATIONAL_FINDING, PartialGlobalSettingsSchema, PartialProviderConfigSchema, ProvidersSchema, RoutingRecommender, STORY_METRICS, TelemetryConfigSchema, addTokenUsage, aggregateTokenUsageForRun, checkDoltInstalled, compareRunMetrics, createAmendmentRun, createConfigSystem, createDecision, createPipelineRun, createStderrLogger, getActiveDecisions, getAllCostEntriesFiltered, getBaselineRunMetrics, getDecisionsByCategory, getDecisionsByPhaseForRun, getLatestCompletedRun, getLatestRun, getPipelineRunById, getPlanningCostTotal, getRetryableEscalations, getRunMetrics, getRunningPipelineRuns, getSessionCostSummary, getSessionCostSummaryFiltered, getStoryMetricsForRun, getTokenUsageSummary, incrementRunRestarts, initSchema, initWorkGraphSchema, initializeDolt, listRunMetrics, loadParentRunDecisions, supersedeDecision, swallowDebug, tagRunAsBaseline, updatePipelineRun } from "../dist-
|
|
6
|
-
import { AdapterTelemetryPersistence, AppError, DoltRepoMapMetaRepository, DoltSymbolRepository, ERR_REPO_MAP_STORAGE_WRITE, EpicIngester, GLOBSTAR, GitClient, GrammarLoader, Minimatch, Minipass, RepoMapInjector, RepoMapModule, RepoMapQueryEngine, RepoMapStorage, SymbolParser, createContextCompiler, createDispatcher, createEventEmitter, createGitWorktreeManager, createImplementationOrchestrator, createPackLoader, createPhaseOrchestrator, createStopAfterGate, createTelemetryAdvisor, escape, formatPhaseCompletionSummary, getFactoryRunSummaries, getScenarioResultsForRun, getTwinRunsForRun, listGraphRuns, registerExportCommand, registerFactoryCommand, registerRunCommand, registerScenariosCommand, resolveStoryKeys, runAnalysisPhase, runPlanningPhase, runProbeAuthor, runSolutioningPhase, unescape, validateStopAfterFromConflict } from "../run-
|
|
5
|
+
import { AdapterRegistry, BudgetConfigSchema, CURRENT_CONFIG_FORMAT_VERSION, CURRENT_TASK_GRAPH_VERSION, ConfigError, CostTrackerConfigSchema, DEFAULT_CONFIG, DoltClient, DoltNotInstalled, GlobalSettingsSchema, InMemoryDatabaseAdapter, IngestionServer, MonitorDatabaseImpl, OPERATIONAL_FINDING, PartialGlobalSettingsSchema, PartialProviderConfigSchema, ProvidersSchema, RoutingRecommender, STORY_METRICS, TelemetryConfigSchema, addTokenUsage, aggregateTokenUsageForRun, checkDoltInstalled, compareRunMetrics, createAmendmentRun, createConfigSystem, createDecision, createPipelineRun, createStderrLogger, getActiveDecisions, getAllCostEntriesFiltered, getBaselineRunMetrics, getDecisionsByCategory, getDecisionsByPhaseForRun, getLatestCompletedRun, getLatestRun, getPipelineRunById, getPlanningCostTotal, getRetryableEscalations, getRunMetrics, getRunningPipelineRuns, getSessionCostSummary, getSessionCostSummaryFiltered, getStoryMetricsForRun, getTokenUsageSummary, incrementRunRestarts, initSchema, initWorkGraphSchema, initializeDolt, listRunMetrics, loadParentRunDecisions, supersedeDecision, swallowDebug, tagRunAsBaseline, updatePipelineRun } from "../dist-DnvGvKLu.js";
|
|
6
|
+
import { AdapterTelemetryPersistence, AppError, DoltRepoMapMetaRepository, DoltSymbolRepository, ERR_REPO_MAP_STORAGE_WRITE, EpicIngester, GLOBSTAR, GitClient, GrammarLoader, Minimatch, Minipass, RepoMapInjector, RepoMapModule, RepoMapQueryEngine, RepoMapStorage, SymbolParser, createContextCompiler, createDispatcher, createEventEmitter, createGitWorktreeManager, createImplementationOrchestrator, createPackLoader, createPhaseOrchestrator, createStopAfterGate, createTelemetryAdvisor, escape, formatPhaseCompletionSummary, getFactoryRunSummaries, getScenarioResultsForRun, getTwinRunsForRun, listGraphRuns, registerExportCommand, registerFactoryCommand, registerRunCommand, registerScenariosCommand, resolveStoryKeys, runAnalysisPhase, runPlanningPhase, runProbeAuthor, runSolutioningPhase, unescape, validateStopAfterFromConflict } from "../run-Dbwlb4Md.js";
|
|
7
7
|
import "../adapter-registry-DIcrxjH8.js";
|
|
8
|
-
import { RunManifest, SupervisorLock, ZERO_FINDINGS_BY_AUTHOR, ZERO_FINDING_COUNTS, ZERO_PROBE_AUTHOR_METRICS, aggregateProbeAuthorMetrics, parseRuntimeProbes, readCurrentRunId, resolveMainRepoRoot, resolveRunManifest, rollupFindingCounts, rollupFindingsByAuthor, rollupProbeAuthorByClass, rollupProbeAuthorMetrics, runAcTraceabilityCheck } from "../manifest-read-
|
|
9
|
-
import "../errors-
|
|
8
|
+
import { RunManifest, SupervisorLock, ZERO_FINDINGS_BY_AUTHOR, ZERO_FINDING_COUNTS, ZERO_PROBE_AUTHOR_METRICS, aggregateProbeAuthorMetrics, parseRuntimeProbes, readCurrentRunId, resolveMainRepoRoot, resolveRunManifest, rollupFindingCounts, rollupFindingsByAuthor, rollupProbeAuthorByClass, rollupProbeAuthorMetrics, runAcTraceabilityCheck } from "../manifest-read-DJFbGhSd.js";
|
|
9
|
+
import "../errors-i3s5sshZ.js";
|
|
10
10
|
import "../routing-DFxoKHDt.js";
|
|
11
11
|
import { WorkGraphRepository } from "../work-graph-repository-DZyJv5pV.js";
|
|
12
12
|
import "../decisions-CzSIEeGP.js";
|
|
13
13
|
import "../decision-router-DblHY8se.js";
|
|
14
|
-
import "../interactive-prompt-
|
|
14
|
+
import "../interactive-prompt-B91mG5v4.js";
|
|
15
15
|
import "../recovery-engine-BKGBeBnW.js";
|
|
16
16
|
import "../version-manager-impl-qFBiO4Eh.js";
|
|
17
|
-
import { registerUpgradeCommand } from "../upgrade-
|
|
17
|
+
import { registerUpgradeCommand } from "../upgrade-yULZIAAW.js";
|
|
18
18
|
import { Command } from "commander";
|
|
19
19
|
import { fileURLToPath } from "url";
|
|
20
20
|
import { dirname, join, resolve } from "path";
|
|
@@ -406,7 +406,8 @@ function healthResultToJson(adapterId, displayName, healthResult) {
|
|
|
406
406
|
cliPath: healthResult.cliPath ?? null,
|
|
407
407
|
detectedBillingModes: healthResult.detectedBillingModes ?? [],
|
|
408
408
|
supportsHeadless: healthResult.supportsHeadless,
|
|
409
|
-
error: healthResult.error ?? null
|
|
409
|
+
error: healthResult.error ?? null,
|
|
410
|
+
compatibilityWarning: healthResult.compatibilityWarning ?? null
|
|
410
411
|
};
|
|
411
412
|
}
|
|
412
413
|
|
|
@@ -462,6 +463,18 @@ function registerAdaptersCommand(program, version, registry) {
|
|
|
462
463
|
if (opts.verbose) for (const result of report.results) {
|
|
463
464
|
const health = result.healthResult;
|
|
464
465
|
if (!health.healthy && health.error) process.stdout.write(`\n[${result.adapterId}] Error: ${health.error}\n`);
|
|
466
|
+
if (health.compatibilityWarning !== void 0) process.stdout.write(`\n[${result.adapterId}] Compatibility: ${health.compatibilityWarning}\n`);
|
|
467
|
+
}
|
|
468
|
+
else {
|
|
469
|
+
const drifted = report.results.filter((r) => r.healthResult.compatibilityWarning !== void 0);
|
|
470
|
+
if (drifted.length > 0) {
|
|
471
|
+
process.stdout.write("\nCLI version notes (run with --verbose for full text):\n");
|
|
472
|
+
for (const result of drifted) {
|
|
473
|
+
const w = result.healthResult.compatibilityWarning;
|
|
474
|
+
const oneLine = w.length > 120 ? w.slice(0, 117) + "..." : w;
|
|
475
|
+
process.stdout.write(` ${result.adapterId}: ${oneLine}\n`);
|
|
476
|
+
}
|
|
477
|
+
}
|
|
465
478
|
}
|
|
466
479
|
process.exit(EXIT_CODE_SUCCESS);
|
|
467
480
|
});
|
|
@@ -7023,7 +7036,7 @@ async function runStatusAction(options) {
|
|
|
7023
7036
|
logger$15.debug({ err }, "Work graph query failed, continuing without work graph data");
|
|
7024
7037
|
}
|
|
7025
7038
|
if (run === void 0) {
|
|
7026
|
-
const { inspectProcessTree: inspectProcessTree$1 } = await import("../health-
|
|
7039
|
+
const { inspectProcessTree: inspectProcessTree$1 } = await import("../health-Caa24SFM.js");
|
|
7027
7040
|
const substrateDirPath = join(projectRoot, ".substrate");
|
|
7028
7041
|
const processInfo = inspectProcessTree$1({
|
|
7029
7042
|
projectRoot,
|
|
@@ -7971,7 +7984,7 @@ function defaultSupervisorDeps() {
|
|
|
7971
7984
|
if (cached === null) {
|
|
7972
7985
|
const { AdapterRegistry: AR } = await import(
|
|
7973
7986
|
/* @vite-ignore */
|
|
7974
|
-
"../adapter-registry-
|
|
7987
|
+
"../adapter-registry-Bpa7ESBV.js"
|
|
7975
7988
|
);
|
|
7976
7989
|
cached = new AR();
|
|
7977
7990
|
await cached.discoverAndRegister();
|
|
@@ -8538,11 +8551,11 @@ async function runSupervisorAction(options, deps = {}) {
|
|
|
8538
8551
|
try {
|
|
8539
8552
|
const { createExperimenter } = await import(
|
|
8540
8553
|
/* @vite-ignore */
|
|
8541
|
-
"../experimenter-
|
|
8554
|
+
"../experimenter-DU2Cv51N.js"
|
|
8542
8555
|
);
|
|
8543
8556
|
const { getLatestRun: getLatest } = await import(
|
|
8544
8557
|
/* @vite-ignore */
|
|
8545
|
-
"../decisions-
|
|
8558
|
+
"../decisions-fBdZmqOK.js"
|
|
8546
8559
|
);
|
|
8547
8560
|
const expAdapter = createDatabaseAdapter({
|
|
8548
8561
|
backend: "auto",
|
|
@@ -8552,7 +8565,7 @@ async function runSupervisorAction(options, deps = {}) {
|
|
|
8552
8565
|
await initSchema(expAdapter);
|
|
8553
8566
|
const { runRunAction: runPipeline } = await import(
|
|
8554
8567
|
/* @vite-ignore */
|
|
8555
|
-
"../run-
|
|
8568
|
+
"../run-Ppco-3HT.js"
|
|
8556
8569
|
);
|
|
8557
8570
|
const runStoryFn = async (opts) => {
|
|
8558
8571
|
const exitCode = await runPipeline({
|
|
@@ -9077,7 +9090,7 @@ async function runMetricsAction(options) {
|
|
|
9077
9090
|
const routingConfigPath = join(dbDir, "routing.yml");
|
|
9078
9091
|
let routingConfig = null;
|
|
9079
9092
|
if (existsSync$1(routingConfigPath)) try {
|
|
9080
|
-
const { loadModelRoutingConfig } = await import("../routing-
|
|
9093
|
+
const { loadModelRoutingConfig } = await import("../routing-DFIBY9Yk.js");
|
|
9081
9094
|
routingConfig = loadModelRoutingConfig(routingConfigPath);
|
|
9082
9095
|
} catch {}
|
|
9083
9096
|
if (routingConfig === null) routingConfig = {
|
|
@@ -13387,8 +13400,8 @@ async function createProgram() {
|
|
|
13387
13400
|
/** Fire-and-forget startup version check (story 8.3, AC3/AC5) */
|
|
13388
13401
|
function checkForUpdatesInBackground(currentVersion) {
|
|
13389
13402
|
if (process.env.SUBSTRATE_NO_UPDATE_CHECK === "1") return;
|
|
13390
|
-
import("../upgrade-
|
|
13391
|
-
const { createVersionManager } = await import("../version-manager-impl-
|
|
13403
|
+
import("../upgrade-CnIsoLpT.js").then(async () => {
|
|
13404
|
+
const { createVersionManager } = await import("../version-manager-impl-C7ZhqLX3.js");
|
|
13392
13405
|
const vm = createVersionManager();
|
|
13393
13406
|
const result = await vm.checkForUpdates();
|
|
13394
13407
|
if (result.updateAvailable) {
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { addTokenUsage, createDecision, createPipelineRun, createRequirement, getArtifactByTypeForRun, getArtifactsByRun, getDecisionsByCategory, getDecisionsByPhase, getDecisionsByPhaseForRun, getLatestRun, getPipelineRunById, getRunningPipelineRuns, getTokenUsageSummary, listRequirements, registerArtifact, updateDecision, updatePipelineRun, updatePipelineRunConfig, upsertDecision } from "./dist-
|
|
1
|
+
import { addTokenUsage, createDecision, createPipelineRun, createRequirement, getArtifactByTypeForRun, getArtifactsByRun, getDecisionsByCategory, getDecisionsByPhase, getDecisionsByPhaseForRun, getLatestRun, getPipelineRunById, getRunningPipelineRuns, getTokenUsageSummary, listRequirements, registerArtifact, updateDecision, updatePipelineRun, updatePipelineRunConfig, upsertDecision } from "./dist-DnvGvKLu.js";
|
|
2
2
|
import "./decisions-CzSIEeGP.js";
|
|
3
3
|
|
|
4
4
|
export { getLatestRun };
|
|
@@ -14,11 +14,12 @@ import { homedir } from "os";
|
|
|
14
14
|
import { createServer } from "node:http";
|
|
15
15
|
import { createGunzip, createInflate } from "node:zlib";
|
|
16
16
|
import { promisify } from "node:util";
|
|
17
|
-
import { createRequire } from "node:module";
|
|
18
|
-
import { fileURLToPath } from "node:url";
|
|
19
17
|
import * as semver$2 from "semver";
|
|
20
18
|
import * as semver$1 from "semver";
|
|
21
19
|
import * as semver from "semver";
|
|
20
|
+
import { coerce, compare, valid } from "semver";
|
|
21
|
+
import { createRequire } from "node:module";
|
|
22
|
+
import { fileURLToPath } from "node:url";
|
|
22
23
|
import https from "node:https";
|
|
23
24
|
|
|
24
25
|
//#region packages/core/dist/dispatch/types.js
|
|
@@ -9414,6 +9415,43 @@ var Recommender = class Recommender {
|
|
|
9414
9415
|
}
|
|
9415
9416
|
};
|
|
9416
9417
|
|
|
9418
|
+
//#endregion
|
|
9419
|
+
//#region packages/core/dist/adapters/version-compat.js
|
|
9420
|
+
function normalize(version) {
|
|
9421
|
+
return valid(version) ?? valid(coerce(version) ?? "") ?? null;
|
|
9422
|
+
}
|
|
9423
|
+
/**
|
|
9424
|
+
* Compare a live CLI binary's reported version against the tested range. Pure.
|
|
9425
|
+
*
|
|
9426
|
+
* Three outcomes:
|
|
9427
|
+
* - actual within range → `{ compatible: true }`
|
|
9428
|
+
* - actual outside range → `{ compatible: false, warning }` with a message
|
|
9429
|
+
* naming the adapter + drift + suggested operator action
|
|
9430
|
+
* - actual unparseable → `{ compatible: false, warning }` flagging that
|
|
9431
|
+
* the version couldn't be compared (degrade gracefully; never throw)
|
|
9432
|
+
*/
|
|
9433
|
+
function checkAdapterVersionCompat(adapterName, actualVersion, tested) {
|
|
9434
|
+
const actual = normalize(actualVersion);
|
|
9435
|
+
const min = normalize(tested.min);
|
|
9436
|
+
const max = normalize(tested.max);
|
|
9437
|
+
if (actual === null || min === null || max === null) return {
|
|
9438
|
+
compatible: false,
|
|
9439
|
+
warning: `${adapterName}: CLI version '${actualVersion}' could not be parsed for comparison against substrate's tested range (${tested.min}–${tested.max}). Flag behavior may differ; report any dispatch failures.`
|
|
9440
|
+
};
|
|
9441
|
+
if (compare(actual, min) < 0) return {
|
|
9442
|
+
compatible: false,
|
|
9443
|
+
warning: `${adapterName}: CLI version ${actualVersion} is below substrate's tested range (${tested.min}–${tested.max}). Older flag forms may be required; consider upgrading the CLI to a version within range, or upgrading substrate.` + (tested.note !== void 0 ? ` Range note: ${tested.note}` : "")
|
|
9444
|
+
};
|
|
9445
|
+
if (compare(actual, max) > 0) return {
|
|
9446
|
+
compatible: false,
|
|
9447
|
+
warning: `${adapterName}: CLI version ${actualVersion} is newer than substrate's tested range (${tested.min}–${tested.max}). Flag behavior may have changed since substrate was tested; consider upgrading substrate or reporting any dispatch failures.` + (tested.note !== void 0 ? ` Range note: ${tested.note}` : "")
|
|
9448
|
+
};
|
|
9449
|
+
return tested.note !== void 0 ? {
|
|
9450
|
+
compatible: true,
|
|
9451
|
+
warning: `${adapterName}: ${tested.note}`
|
|
9452
|
+
} : { compatible: true };
|
|
9453
|
+
}
|
|
9454
|
+
|
|
9417
9455
|
//#endregion
|
|
9418
9456
|
//#region packages/core/dist/adapters/claude-adapter.js
|
|
9419
9457
|
const execAsync$2 = promisify(exec);
|
|
@@ -9440,10 +9478,26 @@ function stripCodeFences$2(raw) {
|
|
|
9440
9478
|
* Health check: runs `claude --version` to verify install.
|
|
9441
9479
|
* Billing detection: detects subscription vs API via version output or env.
|
|
9442
9480
|
*/
|
|
9443
|
-
var ClaudeCodeAdapter = class {
|
|
9481
|
+
var ClaudeCodeAdapter = class ClaudeCodeAdapter {
|
|
9444
9482
|
id = "claude-code";
|
|
9445
9483
|
displayName = "Claude Code";
|
|
9446
9484
|
adapterVersion = "1.0.0";
|
|
9485
|
+
/**
|
|
9486
|
+
* Claude Code CLI version range substrate's `buildCommand` has been
|
|
9487
|
+
* empirically verified against (as of substrate v0.20.138 on 2026-05-31).
|
|
9488
|
+
* `healthCheck` compares the live `claude --version` against this range
|
|
9489
|
+
* and surfaces a warning when the operator's CLI is outside it.
|
|
9490
|
+
*
|
|
9491
|
+
* The `note` flags `--max-turns`: the flag is silently accepted by clap
|
|
9492
|
+
* but not honored — substrate's `options.maxTurns` has no effect on
|
|
9493
|
+
* Claude Code 2.x dispatches. Bumping the upper bound requires re-running
|
|
9494
|
+
* the empirical audit (see `feedback_cli_adapter_empirical_version_match`).
|
|
9495
|
+
*/
|
|
9496
|
+
static TESTED_CLI_VERSION_RANGE = {
|
|
9497
|
+
min: "2.1.152",
|
|
9498
|
+
max: "2.1.158",
|
|
9499
|
+
note: "Claude Code 2.x silently accepts but does not honor `--max-turns`; substrate no longer passes that flag."
|
|
9500
|
+
};
|
|
9447
9501
|
_logger;
|
|
9448
9502
|
constructor(logger) {
|
|
9449
9503
|
this._logger = logger ?? createStderrLogger("claude-adapter");
|
|
@@ -9462,12 +9516,14 @@ var ClaudeCodeAdapter = class {
|
|
|
9462
9516
|
const whichResult = await execAsync$2("which claude", { timeout: 5e3 });
|
|
9463
9517
|
cliPath = whichResult.stdout.trim();
|
|
9464
9518
|
} catch {}
|
|
9519
|
+
const compat = checkAdapterVersionCompat("claude-code", output, ClaudeCodeAdapter.TESTED_CLI_VERSION_RANGE);
|
|
9465
9520
|
return {
|
|
9466
9521
|
healthy: true,
|
|
9467
9522
|
version: output,
|
|
9468
9523
|
...cliPath !== void 0 ? { cliPath } : {},
|
|
9469
9524
|
detectedBillingModes,
|
|
9470
|
-
supportsHeadless: true
|
|
9525
|
+
supportsHeadless: true,
|
|
9526
|
+
...compat.warning !== void 0 ? { compatibilityWarning: compat.warning } : {}
|
|
9471
9527
|
};
|
|
9472
9528
|
} catch (err) {
|
|
9473
9529
|
const message = err instanceof Error ? err.message : String(err);
|
|
@@ -9491,7 +9547,6 @@ var ClaudeCodeAdapter = class {
|
|
|
9491
9547
|
model,
|
|
9492
9548
|
"--dangerously-skip-permissions"
|
|
9493
9549
|
];
|
|
9494
|
-
if (options.maxTurns !== void 0) args.push("--max-turns", String(options.maxTurns));
|
|
9495
9550
|
if (options.additionalFlags && options.additionalFlags.length > 0) args.push(...options.additionalFlags);
|
|
9496
9551
|
const systemPromptParts = [BASE_SYSTEM_PROMPT];
|
|
9497
9552
|
if (options.optimizationDirectives) systemPromptParts.push(`\n\n## Optimization Directives\n${options.optimizationDirectives}`);
|
|
@@ -9744,10 +9799,30 @@ function detectCodexSandboxBlock(output) {
|
|
|
9744
9799
|
* Codex CLI uses stdin for the prompt and outputs JSON when --json flag is used.
|
|
9745
9800
|
* Codex supports subscription billing (via `codex login`) and API key billing.
|
|
9746
9801
|
*/
|
|
9747
|
-
var CodexCLIAdapter = class {
|
|
9802
|
+
var CodexCLIAdapter = class CodexCLIAdapter {
|
|
9748
9803
|
id = "codex";
|
|
9749
9804
|
displayName = "Codex CLI";
|
|
9750
9805
|
adapterVersion = "1.0.0";
|
|
9806
|
+
/**
|
|
9807
|
+
* Codex CLI version range substrate's `buildCommand` has been empirically
|
|
9808
|
+
* verified against (as of substrate v0.20.138 on 2026-05-31). The range
|
|
9809
|
+
* is narrow because the v0.20.131→137 arc taught us how much can drift
|
|
9810
|
+
* between minor versions — `--full-auto` changed meaning between 0.111.0
|
|
9811
|
+
* and 0.128.0 (deprecated, semantics shifted) and almost certainly will
|
|
9812
|
+
* drift again.
|
|
9813
|
+
*
|
|
9814
|
+
* The `note` flags the structural truth: `codex exec` hardcodes
|
|
9815
|
+
* `approval_policy=Never` and ignores `-c approval_policy=...` overrides
|
|
9816
|
+
* (codex-rs/exec/src/lib.rs:407). On enterprise managed configs that
|
|
9817
|
+
* disallow `Never`, dispatch will fail at the apply_patch layer regardless
|
|
9818
|
+
* of substrate's flag — see CODEX_SANDBOX_BLOCK_HINT and the policy ask
|
|
9819
|
+
* document in `docs/2026-05-29-codex-managed-config-policy-ask.md`.
|
|
9820
|
+
*/
|
|
9821
|
+
static TESTED_CLI_VERSION_RANGE = {
|
|
9822
|
+
min: "0.135.0",
|
|
9823
|
+
max: "0.135.0",
|
|
9824
|
+
note: "`codex exec` hardcodes approval_policy=Never (cannot be overridden); on enterprise managed configs disallowing Never, dispatch fails at apply_patch."
|
|
9825
|
+
};
|
|
9751
9826
|
_logger;
|
|
9752
9827
|
constructor(logger) {
|
|
9753
9828
|
this._logger = logger ?? createStderrLogger("codex-adapter");
|
|
@@ -9764,12 +9839,14 @@ var CodexCLIAdapter = class {
|
|
|
9764
9839
|
const whichResult = await execAsync$1("which codex", { timeout: 5e3 });
|
|
9765
9840
|
cliPath = whichResult.stdout.trim();
|
|
9766
9841
|
} catch {}
|
|
9842
|
+
const compat = checkAdapterVersionCompat("codex", output, CodexCLIAdapter.TESTED_CLI_VERSION_RANGE);
|
|
9767
9843
|
return {
|
|
9768
9844
|
healthy: true,
|
|
9769
9845
|
version: output,
|
|
9770
9846
|
...cliPath !== void 0 ? { cliPath } : {},
|
|
9771
9847
|
detectedBillingModes: CODEX_BILLING_MODES,
|
|
9772
|
-
supportsHeadless: true
|
|
9848
|
+
supportsHeadless: true,
|
|
9849
|
+
...compat.warning !== void 0 ? { compatibilityWarning: compat.warning } : {}
|
|
9773
9850
|
};
|
|
9774
9851
|
} catch (err) {
|
|
9775
9852
|
const message = err instanceof Error ? err.message : String(err);
|
|
@@ -10005,10 +10082,22 @@ function stripCodeFences(raw) {
|
|
|
10005
10082
|
* Gemini CLI follows similar patterns to Claude Code: prompt via `-p` flag,
|
|
10006
10083
|
* JSON output via `--output-format json`, and model via `--model`.
|
|
10007
10084
|
*/
|
|
10008
|
-
var GeminiCLIAdapter = class {
|
|
10085
|
+
var GeminiCLIAdapter = class GeminiCLIAdapter {
|
|
10009
10086
|
id = "gemini";
|
|
10010
10087
|
displayName = "Gemini CLI";
|
|
10011
10088
|
adapterVersion = "1.0.0";
|
|
10089
|
+
/**
|
|
10090
|
+
* Gemini CLI version range substrate's `buildCommand` has been empirically
|
|
10091
|
+
* verified against (as of substrate v0.20.138 on 2026-05-31). Empirical
|
|
10092
|
+
* audit confirmed `-p`, `-m/--model`, `-o/--output-format` (with choices
|
|
10093
|
+
* `text|json|stream-json`) and the planning command's positional-prompt form
|
|
10094
|
+
* all parse cleanly on both 0.33.0 and 0.44.1 — same flag layer across a
|
|
10095
|
+
* meaningful version span.
|
|
10096
|
+
*/
|
|
10097
|
+
static TESTED_CLI_VERSION_RANGE = {
|
|
10098
|
+
min: "0.33.0",
|
|
10099
|
+
max: "0.44.1"
|
|
10100
|
+
};
|
|
10012
10101
|
_logger;
|
|
10013
10102
|
constructor(logger) {
|
|
10014
10103
|
this._logger = logger ?? createStderrLogger("gemini-adapter");
|
|
@@ -10027,12 +10116,14 @@ var GeminiCLIAdapter = class {
|
|
|
10027
10116
|
const whichResult = await execAsync("which gemini", { timeout: 5e3 });
|
|
10028
10117
|
cliPath = whichResult.stdout.trim();
|
|
10029
10118
|
} catch {}
|
|
10119
|
+
const compat = checkAdapterVersionCompat("gemini", output, GeminiCLIAdapter.TESTED_CLI_VERSION_RANGE);
|
|
10030
10120
|
return {
|
|
10031
10121
|
healthy: true,
|
|
10032
10122
|
version: output,
|
|
10033
10123
|
...cliPath !== void 0 ? { cliPath } : {},
|
|
10034
10124
|
detectedBillingModes,
|
|
10035
|
-
supportsHeadless: true
|
|
10125
|
+
supportsHeadless: true,
|
|
10126
|
+
...compat.warning !== void 0 ? { compatibilityWarning: compat.warning } : {}
|
|
10036
10127
|
};
|
|
10037
10128
|
} catch (err) {
|
|
10038
10129
|
const message = err instanceof Error ? err.message : String(err);
|
|
@@ -11342,4 +11433,4 @@ async function callLLM(params) {
|
|
|
11342
11433
|
|
|
11343
11434
|
//#endregion
|
|
11344
11435
|
export { ADVISORY_NOTES, AdapterRegistry, AdtError, BudgetConfigSchema, CODEX_SANDBOX_BLOCK_HINT, CURRENT_CONFIG_FORMAT_VERSION, CURRENT_TASK_GRAPH_VERSION, Categorizer, ClaudeCodeAdapter, CodexCLIAdapter, ConfigError, ConfigIncompatibleFormatError, ConsumerAnalyzer, CostTrackerConfigSchema, DEFAULT_CONFIG, DEFAULT_GLOBAL_SETTINGS, DispatcherImpl, DoltClient, DoltNotInstalled, DoltQueryError, ESCALATION_DIAGNOSIS, EXPERIMENT_RESULT, EfficiencyScorer, GeminiCLIAdapter, GlobalSettingsSchema, InMemoryDatabaseAdapter, IngestionServer, LEARNING_FINDING, LogTurnAnalyzer, ModelRoutingConfigSchema, MonitorDatabaseImpl, OPERATIONAL_FINDING, PartialGlobalSettingsSchema, PartialProviderConfigSchema, ProviderPolicySchema, ProvidersSchema, Recommender, RoutingConfigError, RoutingRecommender, RoutingResolver, RoutingTelemetry, RoutingTokenAccumulator, RoutingTuner, STORY_METRICS, STORY_OUTCOME, SubstrateConfigSchema, TASK_TYPE_PHASE_MAP, TEST_EXPANSION_FINDING, TEST_PLAN, TelemetryConfigSchema, TelemetryNormalizer, TelemetryPipeline, TurnAnalyzer, VersionManagerImpl, addTokenUsage, aggregateTokenUsageForRun, aggregateTokenUsageForStory, buildAuditLogEntry, buildBranchName, buildModificationDirective, buildPRBody, buildWorktreePath, callLLM, checkDoltInstalled, classifyVersionGap, compareRunMetrics, createAmendmentRun, createConfigSystem, createDatabaseAdapter as createDatabaseAdapter$1, createDecision, createExperimenter, createPipelineRun, createRequirement, createStderrLogger, createVersionManager, detectCodexSandboxBlock, detectInterfaceChanges, determineVerdict, getActiveDecisions, getAllCostEntriesFiltered, getArtifactByTypeForRun, getArtifactsByRun, getBaselineRunMetrics, getDecisionsByCategory, getDecisionsByPhase, getDecisionsByPhaseForRun, getLatestCompletedRun, getLatestRun, getModelTier, getPipelineRunById, getPlanningCostTotal, getRetryableEscalations, getRunMetrics, getRunningPipelineRuns, getSessionCostSummary, getSessionCostSummaryFiltered, getStoryMetricsForRun, getTokenUsageSummary, incrementRunRestarts, initSchema, initWorkGraphSchema, initializeDolt, listRequirements, listRunMetrics, loadModelRoutingConfig, loadParentRunDecisions, registerArtifact, resolvePromptFile, supersedeDecision, swallowDebug, tagRunAsBaseline, updateDecision, updatePipelineRun, updatePipelineRunConfig, upsertDecision, writeRunMetrics, writeStoryMetrics };
|
|
11345
|
-
//# sourceMappingURL=dist-
|
|
11436
|
+
//# sourceMappingURL=dist-DnvGvKLu.js.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { AdtError } from "./dist-
|
|
1
|
+
import { AdtError } from "./dist-DnvGvKLu.js";
|
|
2
2
|
|
|
3
3
|
//#region src/core/errors.ts
|
|
4
4
|
/** Error thrown when task configuration is invalid */
|
|
@@ -71,4 +71,4 @@ var TaskGraphIncompatibleFormatError = class extends AdtError {
|
|
|
71
71
|
|
|
72
72
|
//#endregion
|
|
73
73
|
export { BudgetExceededError, GitError, RecoveryError, TaskConfigError, TaskGraphCycleError, TaskGraphError, TaskGraphIncompatibleFormatError, WorkerError, WorkerNotFoundError };
|
|
74
|
-
//# sourceMappingURL=errors-
|
|
74
|
+
//# sourceMappingURL=errors-i3s5sshZ.js.map
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import { buildAuditLogEntry, buildBranchName, buildModificationDirective, buildPRBody, buildWorktreePath, createExperimenter, determineVerdict, resolvePromptFile } from "./dist-
|
|
1
|
+
import { buildAuditLogEntry, buildBranchName, buildModificationDirective, buildPRBody, buildWorktreePath, createExperimenter, determineVerdict, resolvePromptFile } from "./dist-DnvGvKLu.js";
|
|
2
2
|
|
|
3
3
|
export { createExperimenter };
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { createLogger } from "./logger-KeHncl-f.js";
|
|
2
|
-
import { DoltClient, DoltQueryError, createDatabaseAdapter$1 as createDatabaseAdapter, getLatestRun, getPipelineRunById, initSchema } from "./dist-
|
|
3
|
-
import { resolveMainRepoRoot, resolveRunManifest } from "./manifest-read-
|
|
2
|
+
import { DoltClient, DoltQueryError, createDatabaseAdapter$1 as createDatabaseAdapter, getLatestRun, getPipelineRunById, initSchema } from "./dist-DnvGvKLu.js";
|
|
3
|
+
import { resolveMainRepoRoot, resolveRunManifest } from "./manifest-read-DJFbGhSd.js";
|
|
4
4
|
import { createRequire } from "module";
|
|
5
5
|
import { dirname, join } from "path";
|
|
6
6
|
import { existsSync, readFileSync } from "node:fs";
|
|
@@ -1000,4 +1000,4 @@ function registerHealthCommand(program, _version = "0.0.0", projectRoot = proces
|
|
|
1000
1000
|
|
|
1001
1001
|
//#endregion
|
|
1002
1002
|
export { BMAD_BASELINE_TOKENS_FULL, DEFAULT_STALL_THRESHOLD_SECONDS, FileKvStore, STOP_AFTER_VALID_PHASES, STORY_KEY_PATTERN, SUBSTRATE_OWNED_SETTINGS_KEYS, VALID_PHASES, __commonJS, __require, __toESM, buildPipelineStatusOutput, createDatabaseAdapter$1 as createDatabaseAdapter, createDoltOperatorReader, findPackageRoot, formatOutput, formatPipelineStatusHuman, formatPipelineSummary, formatTokenTelemetry, getAllDescendantPids, getAutoHealthData, getSubstrateDefaultSettings, inspectProcessTree, isOrchestratorProcessLine, parseDbTimestampAsUtc, registerHealthCommand, resolveBmadMethodSrcPath, resolveBmadMethodVersion, runHealthAction, validateStoryKey };
|
|
1003
|
-
//# sourceMappingURL=health-
|
|
1003
|
+
//# sourceMappingURL=health-2Kfa00-H.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { DEFAULT_STALL_THRESHOLD_SECONDS, getAllDescendantPids, getAutoHealthData, inspectProcessTree, isOrchestratorProcessLine, registerHealthCommand, runHealthAction } from "./health-
|
|
1
|
+
import { DEFAULT_STALL_THRESHOLD_SECONDS, getAllDescendantPids, getAutoHealthData, inspectProcessTree, isOrchestratorProcessLine, registerHealthCommand, runHealthAction } from "./health-2Kfa00-H.js";
|
|
2
2
|
import "./logger-KeHncl-f.js";
|
|
3
|
-
import "./dist-
|
|
4
|
-
import "./manifest-read-
|
|
3
|
+
import "./dist-DnvGvKLu.js";
|
|
4
|
+
import "./manifest-read-DJFbGhSd.js";
|
|
5
5
|
import "./work-graph-repository-DZyJv5pV.js";
|
|
6
6
|
import "./decisions-CzSIEeGP.js";
|
|
7
7
|
|
|
@@ -971,6 +971,14 @@ interface AdapterHealthResult {
|
|
|
971
971
|
detectedBillingModes?: BillingMode[];
|
|
972
972
|
/** Whether the CLI supports headless/non-interactive mode */
|
|
973
973
|
supportsHeadless: boolean;
|
|
974
|
+
/**
|
|
975
|
+
* Human-readable note when the live CLI version is OUTSIDE substrate's
|
|
976
|
+
* tested range, OR when the tested range carries an informational caveat
|
|
977
|
+
* even within range. Surfaced by `substrate health` so operators see drift
|
|
978
|
+
* as a noisy first-dispatch signal instead of a multi-ship debugging arc.
|
|
979
|
+
* Pure-helper-computed; see `version-compat.ts`.
|
|
980
|
+
*/
|
|
981
|
+
compatibilityWarning?: string;
|
|
974
982
|
}
|
|
975
983
|
/**
|
|
976
984
|
* Parsed result from a task execution.
|
|
@@ -1260,8 +1268,49 @@ declare class AdapterRegistry {
|
|
|
1260
1268
|
}
|
|
1261
1269
|
|
|
1262
1270
|
//#endregion
|
|
1263
|
-
//#region packages/core/dist/adapters/
|
|
1271
|
+
//#region packages/core/dist/adapters/version-compat.d.ts
|
|
1264
1272
|
//# sourceMappingURL=adapter-registry.d.ts.map
|
|
1273
|
+
/**
|
|
1274
|
+
* Per-adapter CLI version compatibility check.
|
|
1275
|
+
*
|
|
1276
|
+
* Each adapter declares a `TestedVersionRange` — the lowest and highest CLI
|
|
1277
|
+
* binary versions substrate's `buildCommand` has been empirically verified
|
|
1278
|
+
* against. At healthCheck time, the adapter compares the live binary's
|
|
1279
|
+
* reported version to that range and emits a human-readable warning when the
|
|
1280
|
+
* live version sits outside it.
|
|
1281
|
+
*
|
|
1282
|
+
* The lesson this addresses (v0.20.131→137 Codex arc): a string-presence
|
|
1283
|
+
* unit test on the args array proves only that substrate constructs the args
|
|
1284
|
+
* it intends to. It does NOT prove that the live CLI binary still accepts or
|
|
1285
|
+
* honors those args. CLI flag forms drift between versions: deprecations,
|
|
1286
|
+
* renames, silent-acceptance-then-ignore, and harness overrides that beat
|
|
1287
|
+
* `-c` config flags. When substrate's tested version range and the live
|
|
1288
|
+
* version diverge, operators should see a noisy first-dispatch warning
|
|
1289
|
+
* pointing at the right place — not a seven-ship arc of fix-shaped
|
|
1290
|
+
* iteration on substrate when the bug actually lives in Codex (or wherever).
|
|
1291
|
+
*
|
|
1292
|
+
* Pure + exported for unit testing; each adapter's healthCheck is the caller.
|
|
1293
|
+
*/
|
|
1294
|
+
/**
|
|
1295
|
+
* The range of CLI binary versions substrate's adapter has been verified
|
|
1296
|
+
* against. Bumped whenever an adapter author confirms the buildCommand args
|
|
1297
|
+
* still parse and behave correctly on a newer CLI release.
|
|
1298
|
+
*/
|
|
1299
|
+
interface TestedVersionRange {
|
|
1300
|
+
/** Lowest CLI version substrate has verified against. Inclusive. */
|
|
1301
|
+
min: string;
|
|
1302
|
+
/** Highest CLI version substrate has verified against. Inclusive. */
|
|
1303
|
+
max: string;
|
|
1304
|
+
/**
|
|
1305
|
+
* Optional informational note about known caveats *within* the tested range
|
|
1306
|
+
* (e.g. "Claude Code 2.x silently ignores --max-turns; substrate's
|
|
1307
|
+
* options.maxTurns has no effect"). Surfaced even when compatible.
|
|
1308
|
+
*/
|
|
1309
|
+
note?: string;
|
|
1310
|
+
}
|
|
1311
|
+
|
|
1312
|
+
//#endregion
|
|
1313
|
+
//#region packages/core/dist/adapters/claude-adapter.d.ts
|
|
1265
1314
|
/**
|
|
1266
1315
|
* Adapter for the Claude Code CLI agent.
|
|
1267
1316
|
*
|
|
@@ -1273,6 +1322,18 @@ declare class ClaudeCodeAdapter implements WorkerAdapter {
|
|
|
1273
1322
|
readonly id: AgentId;
|
|
1274
1323
|
readonly displayName = "Claude Code";
|
|
1275
1324
|
readonly adapterVersion = "1.0.0";
|
|
1325
|
+
/**
|
|
1326
|
+
* Claude Code CLI version range substrate's `buildCommand` has been
|
|
1327
|
+
* empirically verified against (as of substrate v0.20.138 on 2026-05-31).
|
|
1328
|
+
* `healthCheck` compares the live `claude --version` against this range
|
|
1329
|
+
* and surfaces a warning when the operator's CLI is outside it.
|
|
1330
|
+
*
|
|
1331
|
+
* The `note` flags `--max-turns`: the flag is silently accepted by clap
|
|
1332
|
+
* but not honored — substrate's `options.maxTurns` has no effect on
|
|
1333
|
+
* Claude Code 2.x dispatches. Bumping the upper bound requires re-running
|
|
1334
|
+
* the empirical audit (see `feedback_cli_adapter_empirical_version_match`).
|
|
1335
|
+
*/
|
|
1336
|
+
static readonly TESTED_CLI_VERSION_RANGE: TestedVersionRange;
|
|
1276
1337
|
private readonly _logger;
|
|
1277
1338
|
constructor(logger?: ILogger);
|
|
1278
1339
|
/**
|
|
@@ -1323,6 +1384,22 @@ declare class CodexCLIAdapter implements WorkerAdapter {
|
|
|
1323
1384
|
readonly id: AgentId;
|
|
1324
1385
|
readonly displayName = "Codex CLI";
|
|
1325
1386
|
readonly adapterVersion = "1.0.0";
|
|
1387
|
+
/**
|
|
1388
|
+
* Codex CLI version range substrate's `buildCommand` has been empirically
|
|
1389
|
+
* verified against (as of substrate v0.20.138 on 2026-05-31). The range
|
|
1390
|
+
* is narrow because the v0.20.131→137 arc taught us how much can drift
|
|
1391
|
+
* between minor versions — `--full-auto` changed meaning between 0.111.0
|
|
1392
|
+
* and 0.128.0 (deprecated, semantics shifted) and almost certainly will
|
|
1393
|
+
* drift again.
|
|
1394
|
+
*
|
|
1395
|
+
* The `note` flags the structural truth: `codex exec` hardcodes
|
|
1396
|
+
* `approval_policy=Never` and ignores `-c approval_policy=...` overrides
|
|
1397
|
+
* (codex-rs/exec/src/lib.rs:407). On enterprise managed configs that
|
|
1398
|
+
* disallow `Never`, dispatch will fail at the apply_patch layer regardless
|
|
1399
|
+
* of substrate's flag — see CODEX_SANDBOX_BLOCK_HINT and the policy ask
|
|
1400
|
+
* document in `docs/2026-05-29-codex-managed-config-policy-ask.md`.
|
|
1401
|
+
*/
|
|
1402
|
+
static readonly TESTED_CLI_VERSION_RANGE: TestedVersionRange;
|
|
1326
1403
|
private readonly _logger;
|
|
1327
1404
|
constructor(logger?: ILogger);
|
|
1328
1405
|
/**
|
|
@@ -1413,6 +1490,15 @@ declare class GeminiCLIAdapter implements WorkerAdapter {
|
|
|
1413
1490
|
readonly id: AgentId;
|
|
1414
1491
|
readonly displayName = "Gemini CLI";
|
|
1415
1492
|
readonly adapterVersion = "1.0.0";
|
|
1493
|
+
/**
|
|
1494
|
+
* Gemini CLI version range substrate's `buildCommand` has been empirically
|
|
1495
|
+
* verified against (as of substrate v0.20.138 on 2026-05-31). Empirical
|
|
1496
|
+
* audit confirmed `-p`, `-m/--model`, `-o/--output-format` (with choices
|
|
1497
|
+
* `text|json|stream-json`) and the planning command's positional-prompt form
|
|
1498
|
+
* all parse cleanly on both 0.33.0 and 0.44.1 — same flag layer across a
|
|
1499
|
+
* meaningful version span.
|
|
1500
|
+
*/
|
|
1501
|
+
static readonly TESTED_CLI_VERSION_RANGE: TestedVersionRange;
|
|
1416
1502
|
private readonly _logger;
|
|
1417
1503
|
constructor(logger?: ILogger);
|
|
1418
1504
|
/**
|
|
@@ -1474,4 +1560,4 @@ interface Recommendation {
|
|
|
1474
1560
|
|
|
1475
1561
|
//#endregion
|
|
1476
1562
|
export { AdapterDiscoveryResult, AdapterRegistry as AdapterRegistry$1, AdtError as AdtError$1, ClaudeCodeAdapter as ClaudeCodeAdapter$1, CodexCLIAdapter as CodexCLIAdapter$1, ConfigError as ConfigError$1, ConfigIncompatibleFormatError as ConfigIncompatibleFormatError$1, CoreEvents, DatabaseAdapter, DiscoveryReport, GeminiCLIAdapter as GeminiCLIAdapter$1, Recommendation, TypedEventBus };
|
|
1477
|
-
//# sourceMappingURL=index-
|
|
1563
|
+
//# sourceMappingURL=index-BJEANS9i.d.ts.map
|
package/dist/index.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { AdapterDiscoveryResult, AdapterRegistry$1 as AdapterRegistry, AdtError$1 as AdtError, ClaudeCodeAdapter$1 as ClaudeCodeAdapter, CodexCLIAdapter$1 as CodexCLIAdapter, ConfigError$1 as ConfigError, ConfigIncompatibleFormatError$1 as ConfigIncompatibleFormatError, DiscoveryReport, GeminiCLIAdapter$1 as GeminiCLIAdapter, Recommendation, TypedEventBus } from "./index-
|
|
1
|
+
import { AdapterDiscoveryResult, AdapterRegistry$1 as AdapterRegistry, AdtError$1 as AdtError, ClaudeCodeAdapter$1 as ClaudeCodeAdapter, CodexCLIAdapter$1 as CodexCLIAdapter, ConfigError$1 as ConfigError, ConfigIncompatibleFormatError$1 as ConfigIncompatibleFormatError, DiscoveryReport, GeminiCLIAdapter$1 as GeminiCLIAdapter, Recommendation, TypedEventBus } from "./index-BJEANS9i.js";
|
|
2
2
|
import pino from "pino";
|
|
3
3
|
import { z } from "zod";
|
|
4
4
|
import { Readable, Writable } from "node:stream";
|
|
@@ -2162,6 +2162,14 @@ interface AdapterHealthResult {
|
|
|
2162
2162
|
detectedBillingModes?: BillingMode[];
|
|
2163
2163
|
/** Whether the CLI supports headless/non-interactive mode */
|
|
2164
2164
|
supportsHeadless: boolean;
|
|
2165
|
+
/**
|
|
2166
|
+
* v0.20.138: human-readable note when the live CLI binary version is
|
|
2167
|
+
* outside substrate's tested range, OR when the tested range carries
|
|
2168
|
+
* an informational caveat even within range. Mirrors the field on the
|
|
2169
|
+
* @substrate-ai/core type (separate definition is the same dual-schema
|
|
2170
|
+
* pattern Epic 79's contracts package is designed to consolidate).
|
|
2171
|
+
*/
|
|
2172
|
+
compatibilityWarning?: string;
|
|
2165
2173
|
}
|
|
2166
2174
|
/**
|
|
2167
2175
|
* Parsed result from a task execution.
|
package/dist/index.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { childLogger, createLogger, logger } from "./logger-KeHncl-f.js";
|
|
2
2
|
import { assertDefined, createEventBus, createTuiApp, deepClone, formatDuration, generateId, isPlainObject, isTuiCapable, printNonTtyWarning, sleep, withRetry } from "./helpers-CElYrONe.js";
|
|
3
|
-
import { AdapterRegistry, AdtError, ClaudeCodeAdapter, CodexCLIAdapter, ConfigError, ConfigIncompatibleFormatError, GeminiCLIAdapter } from "./dist-
|
|
3
|
+
import { AdapterRegistry, AdtError, ClaudeCodeAdapter, CodexCLIAdapter, ConfigError, ConfigIncompatibleFormatError, GeminiCLIAdapter } from "./dist-DnvGvKLu.js";
|
|
4
4
|
import "./adapter-registry-DIcrxjH8.js";
|
|
5
|
-
import { BudgetExceededError, GitError, RecoveryError, TaskConfigError, TaskGraphCycleError, TaskGraphError, TaskGraphIncompatibleFormatError, WorkerError, WorkerNotFoundError } from "./errors-
|
|
5
|
+
import { BudgetExceededError, GitError, RecoveryError, TaskConfigError, TaskGraphCycleError, TaskGraphError, TaskGraphIncompatibleFormatError, WorkerError, WorkerNotFoundError } from "./errors-i3s5sshZ.js";
|
|
6
6
|
|
|
7
7
|
//#region src/core/di.ts
|
|
8
8
|
/**
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { createLogger } from "./logger-KeHncl-f.js";
|
|
2
|
-
import { readCurrentRunId, resolveMainRepoRoot } from "./manifest-read-
|
|
2
|
+
import { readCurrentRunId, resolveMainRepoRoot } from "./manifest-read-DJFbGhSd.js";
|
|
3
3
|
import { join } from "node:path";
|
|
4
4
|
import { mkdir, readFile, writeFile } from "node:fs/promises";
|
|
5
5
|
import * as readline from "node:readline";
|
|
@@ -180,4 +180,4 @@ async function runInteractivePrompt(decisionContext) {
|
|
|
180
180
|
|
|
181
181
|
//#endregion
|
|
182
182
|
export { runInteractivePrompt };
|
|
183
|
-
//# sourceMappingURL=interactive-prompt-
|
|
183
|
+
//# sourceMappingURL=interactive-prompt-B91mG5v4.js.map
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { createLogger } from "./logger-KeHncl-f.js";
|
|
2
|
-
import { LEARNING_FINDING, createDecision, getDecisionsByCategory } from "./dist-
|
|
2
|
+
import { LEARNING_FINDING, createDecision, getDecisionsByCategory } from "./dist-DnvGvKLu.js";
|
|
3
3
|
import * as path$1 from "path";
|
|
4
4
|
import { join } from "path";
|
|
5
5
|
import { readFile } from "fs/promises";
|
|
@@ -5851,4 +5851,4 @@ async function resolveRunManifest(dbRoot, runId) {
|
|
|
5851
5851
|
|
|
5852
5852
|
//#endregion
|
|
5853
5853
|
export { FindingsInjector, RunManifest, RuntimeProbeListSchema, SupervisorLock, ZERO_FINDINGS_BY_AUTHOR, ZERO_FINDING_COUNTS, ZERO_PROBE_AUTHOR_METRICS, aggregateProbeAuthorMetrics, applyConfigToGraph, createDefaultVerificationPipeline, createGraphOrchestrator, createSdlcCodeReviewHandler, createSdlcCreateStoryHandler, createSdlcDevStoryHandler, createSdlcPhaseHandler, detectsEventDrivenAC, detectsStateIntegratingAC, extractTargetFilesFromStoryContent, parseRuntimeProbes, readCurrentRunId, renderFindings, resolveGraphPath, resolveMainRepoRoot, resolveRunManifest, rollupFindingCounts, rollupFindingsByAuthor, rollupProbeAuthorByClass, rollupProbeAuthorMetrics, runAcTraceabilityCheck, runStaleVerificationRecovery };
|
|
5854
|
-
//# sourceMappingURL=manifest-read-
|
|
5854
|
+
//# sourceMappingURL=manifest-read-DJFbGhSd.js.map
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import "../../logger-KeHncl-f.js";
|
|
2
|
-
import "../../dist-
|
|
3
|
-
import "../../manifest-read-
|
|
4
|
-
import { runInteractivePrompt } from "../../interactive-prompt-
|
|
2
|
+
import "../../dist-DnvGvKLu.js";
|
|
3
|
+
import "../../manifest-read-DJFbGhSd.js";
|
|
4
|
+
import { runInteractivePrompt } from "../../interactive-prompt-B91mG5v4.js";
|
|
5
5
|
|
|
6
6
|
export { runInteractivePrompt };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ModelRoutingConfigSchema, ProviderPolicySchema, RoutingConfigError, RoutingRecommender, RoutingResolver, RoutingTelemetry, RoutingTokenAccumulator, RoutingTuner, TASK_TYPE_PHASE_MAP, getModelTier, loadModelRoutingConfig } from "./dist-
|
|
1
|
+
import { ModelRoutingConfigSchema, ProviderPolicySchema, RoutingConfigError, RoutingRecommender, RoutingResolver, RoutingTelemetry, RoutingTokenAccumulator, RoutingTuner, TASK_TYPE_PHASE_MAP, getModelTier, loadModelRoutingConfig } from "./dist-DnvGvKLu.js";
|
|
2
2
|
import "./routing-DFxoKHDt.js";
|
|
3
3
|
|
|
4
4
|
export { loadModelRoutingConfig };
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import { BMAD_BASELINE_TOKENS_FULL, FileKvStore, STOP_AFTER_VALID_PHASES, STORY_KEY_PATTERN, VALID_PHASES, __commonJS, __require, __toESM, buildPipelineStatusOutput, createDatabaseAdapter, formatOutput, formatPipelineSummary, formatTokenTelemetry, inspectProcessTree, parseDbTimestampAsUtc, validateStoryKey } from "./health-
|
|
1
|
+
import { BMAD_BASELINE_TOKENS_FULL, FileKvStore, STOP_AFTER_VALID_PHASES, STORY_KEY_PATTERN, VALID_PHASES, __commonJS, __require, __toESM, buildPipelineStatusOutput, createDatabaseAdapter, formatOutput, formatPipelineSummary, formatTokenTelemetry, inspectProcessTree, parseDbTimestampAsUtc, validateStoryKey } from "./health-2Kfa00-H.js";
|
|
2
2
|
import { createLogger } from "./logger-KeHncl-f.js";
|
|
3
3
|
import { TypedEventBusImpl, createEventBus, createTuiApp, isTuiCapable, printNonTtyWarning, sleep } from "./helpers-CElYrONe.js";
|
|
4
|
-
import { ADVISORY_NOTES, CODEX_SANDBOX_BLOCK_HINT, Categorizer, ConsumerAnalyzer, DEFAULT_GLOBAL_SETTINGS, DispatcherImpl, DoltClient, ESCALATION_DIAGNOSIS, EXPERIMENT_RESULT, EfficiencyScorer, IngestionServer, LogTurnAnalyzer, OPERATIONAL_FINDING, Recommender, RoutingRecommender, RoutingResolver, RoutingTelemetry, RoutingTokenAccumulator, RoutingTuner, STORY_METRICS, STORY_OUTCOME, SubstrateConfigSchema, TEST_EXPANSION_FINDING, TEST_PLAN, TelemetryNormalizer, TelemetryPipeline, TurnAnalyzer, addTokenUsage, aggregateTokenUsageForRun, aggregateTokenUsageForStory, callLLM, classifyVersionGap, createConfigSystem, createDatabaseAdapter$1, createDecision, createPipelineRun, createRequirement, createStderrLogger, detectCodexSandboxBlock, detectInterfaceChanges, getArtifactByTypeForRun, getArtifactsByRun, getDecisionsByCategory, getDecisionsByPhase, getDecisionsByPhaseForRun, getLatestRun, getPipelineRunById, getRunMetrics, getRunningPipelineRuns, getStoryMetricsForRun, getTokenUsageSummary, initSchema, listRequirements, loadModelRoutingConfig, registerArtifact, swallowDebug, updatePipelineRun, updatePipelineRunConfig, upsertDecision, writeRunMetrics, writeStoryMetrics } from "./dist-
|
|
5
|
-
import { FindingsInjector, RunManifest, RuntimeProbeListSchema, applyConfigToGraph, createDefaultVerificationPipeline, createGraphOrchestrator, createSdlcCodeReviewHandler, createSdlcCreateStoryHandler, createSdlcDevStoryHandler, createSdlcPhaseHandler, detectsEventDrivenAC, detectsStateIntegratingAC, extractTargetFilesFromStoryContent, parseRuntimeProbes, renderFindings, resolveGraphPath, resolveMainRepoRoot, runAcTraceabilityCheck, runStaleVerificationRecovery } from "./manifest-read-
|
|
4
|
+
import { ADVISORY_NOTES, CODEX_SANDBOX_BLOCK_HINT, Categorizer, ConsumerAnalyzer, DEFAULT_GLOBAL_SETTINGS, DispatcherImpl, DoltClient, ESCALATION_DIAGNOSIS, EXPERIMENT_RESULT, EfficiencyScorer, IngestionServer, LogTurnAnalyzer, OPERATIONAL_FINDING, Recommender, RoutingRecommender, RoutingResolver, RoutingTelemetry, RoutingTokenAccumulator, RoutingTuner, STORY_METRICS, STORY_OUTCOME, SubstrateConfigSchema, TEST_EXPANSION_FINDING, TEST_PLAN, TelemetryNormalizer, TelemetryPipeline, TurnAnalyzer, addTokenUsage, aggregateTokenUsageForRun, aggregateTokenUsageForStory, callLLM, classifyVersionGap, createConfigSystem, createDatabaseAdapter$1, createDecision, createPipelineRun, createRequirement, createStderrLogger, detectCodexSandboxBlock, detectInterfaceChanges, getArtifactByTypeForRun, getArtifactsByRun, getDecisionsByCategory, getDecisionsByPhase, getDecisionsByPhaseForRun, getLatestRun, getPipelineRunById, getRunMetrics, getRunningPipelineRuns, getStoryMetricsForRun, getTokenUsageSummary, initSchema, listRequirements, loadModelRoutingConfig, registerArtifact, swallowDebug, updatePipelineRun, updatePipelineRunConfig, upsertDecision, writeRunMetrics, writeStoryMetrics } from "./dist-DnvGvKLu.js";
|
|
5
|
+
import { FindingsInjector, RunManifest, RuntimeProbeListSchema, applyConfigToGraph, createDefaultVerificationPipeline, createGraphOrchestrator, createSdlcCodeReviewHandler, createSdlcCreateStoryHandler, createSdlcDevStoryHandler, createSdlcPhaseHandler, detectsEventDrivenAC, detectsStateIntegratingAC, extractTargetFilesFromStoryContent, parseRuntimeProbes, renderFindings, resolveGraphPath, resolveMainRepoRoot, runAcTraceabilityCheck, runStaleVerificationRecovery } from "./manifest-read-DJFbGhSd.js";
|
|
6
6
|
import { WorkGraphRepository, detectCycles } from "./work-graph-repository-DZyJv5pV.js";
|
|
7
7
|
import { deriveExitCode, routeDecision } from "./decision-router-DblHY8se.js";
|
|
8
|
-
import { runInteractivePrompt } from "./interactive-prompt-
|
|
8
|
+
import { runInteractivePrompt } from "./interactive-prompt-B91mG5v4.js";
|
|
9
9
|
import { runRecoveryEngine } from "./recovery-engine-BKGBeBnW.js";
|
|
10
10
|
import { basename, dirname, extname, join } from "path";
|
|
11
11
|
import { access, readFile, readdir, stat } from "fs/promises";
|
|
@@ -47442,7 +47442,7 @@ async function runFullPipeline(options) {
|
|
|
47442
47442
|
*/
|
|
47443
47443
|
async function emitPreDispatchVersionAdvisory(currentVersion) {
|
|
47444
47444
|
if (process.env["SUBSTRATE_NO_UPDATE_CHECK"] === "1") return;
|
|
47445
|
-
const { createVersionManager } = await import("./version-manager-impl-
|
|
47445
|
+
const { createVersionManager } = await import("./version-manager-impl-C7ZhqLX3.js");
|
|
47446
47446
|
const vm = createVersionManager();
|
|
47447
47447
|
const result = await vm.checkForUpdates(true);
|
|
47448
47448
|
const gap = classifyVersionGap(currentVersion, result.latestVersion);
|
|
@@ -47539,4 +47539,4 @@ function registerRunCommand(program, version = "0.0.0", projectRoot = process.cw
|
|
|
47539
47539
|
|
|
47540
47540
|
//#endregion
|
|
47541
47541
|
export { AdapterTelemetryPersistence, AppError, DoltRepoMapMetaRepository, DoltSymbolRepository, ERR_REPO_MAP_STORAGE_WRITE, EpicIngester, GLOBSTAR$1 as GLOBSTAR, GitClient, GrammarLoader, Minimatch$1 as Minimatch, Minipass, RepoMapInjector, RepoMapModule, RepoMapQueryEngine, RepoMapStorage, SymbolParser, createContextCompiler, createDispatcher, createEventEmitter, createGitWorktreeManager, createImplementationOrchestrator, createPackLoader, createPhaseOrchestrator, createStopAfterGate, createTelemetryAdvisor, escape$1 as escape, formatPhaseCompletionSummary, getFactoryRunSummaries, getScenarioResultsForRun, getTwinRunsForRun, listGraphRuns, normalizeGraphSummaryToStatus, registerExportCommand, registerFactoryCommand, registerRunCommand, registerScenariosCommand, resolveMaxReviewCycles, resolveProbeAuthorStateIntegrating, resolveStoryKeys, runAnalysisPhase, runPlanningPhase, runProbeAuthor, runRunAction, runSolutioningPhase, unescape$1 as unescape, validateStopAfterFromConflict, wireNdjsonEmitter };
|
|
47542
|
-
//# sourceMappingURL=run-
|
|
47542
|
+
//# sourceMappingURL=run-Dbwlb4Md.js.map
|
|
@@ -1,14 +1,14 @@
|
|
|
1
|
-
import "./health-
|
|
1
|
+
import "./health-2Kfa00-H.js";
|
|
2
2
|
import "./logger-KeHncl-f.js";
|
|
3
3
|
import "./helpers-CElYrONe.js";
|
|
4
|
-
import "./dist-
|
|
5
|
-
import { normalizeGraphSummaryToStatus, registerRunCommand, resolveMaxReviewCycles, resolveProbeAuthorStateIntegrating, runRunAction, wireNdjsonEmitter } from "./run-
|
|
6
|
-
import "./manifest-read-
|
|
4
|
+
import "./dist-DnvGvKLu.js";
|
|
5
|
+
import { normalizeGraphSummaryToStatus, registerRunCommand, resolveMaxReviewCycles, resolveProbeAuthorStateIntegrating, runRunAction, wireNdjsonEmitter } from "./run-Dbwlb4Md.js";
|
|
6
|
+
import "./manifest-read-DJFbGhSd.js";
|
|
7
7
|
import "./routing-DFxoKHDt.js";
|
|
8
8
|
import "./work-graph-repository-DZyJv5pV.js";
|
|
9
9
|
import "./decisions-CzSIEeGP.js";
|
|
10
10
|
import "./decision-router-DblHY8se.js";
|
|
11
|
-
import "./interactive-prompt-
|
|
11
|
+
import "./interactive-prompt-B91mG5v4.js";
|
|
12
12
|
import "./recovery-engine-BKGBeBnW.js";
|
|
13
13
|
|
|
14
14
|
export { runRunAction };
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import "./dist-
|
|
1
|
+
import "./dist-DnvGvKLu.js";
|
|
2
2
|
import "./version-manager-impl-qFBiO4Eh.js";
|
|
3
|
-
import { isGlobalInstall, registerUpgradeCommand, runUpgradeCommand } from "./upgrade-
|
|
3
|
+
import { isGlobalInstall, registerUpgradeCommand, runUpgradeCommand } from "./upgrade-yULZIAAW.js";
|
|
4
4
|
|
|
5
5
|
export { isGlobalInstall, registerUpgradeCommand, runUpgradeCommand };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { createVersionManager } from "./dist-
|
|
1
|
+
import { createVersionManager } from "./dist-DnvGvKLu.js";
|
|
2
2
|
import { execSync, spawn } from "child_process";
|
|
3
3
|
import * as readline from "readline";
|
|
4
4
|
|
|
@@ -123,4 +123,4 @@ function registerUpgradeCommand(program) {
|
|
|
123
123
|
|
|
124
124
|
//#endregion
|
|
125
125
|
export { isGlobalInstall, registerUpgradeCommand, runUpgradeCommand };
|
|
126
|
-
//# sourceMappingURL=upgrade-
|
|
126
|
+
//# sourceMappingURL=upgrade-yULZIAAW.js.map
|
package/package.json
CHANGED