@interf/compiler 0.22.2 → 0.50.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/README.md +119 -282
- package/dist/bin-mcp.d.ts +2 -0
- package/dist/bin-mcp.js +63 -0
- package/dist/bin-runtime.d.ts +2 -0
- package/dist/bin-runtime.js +111 -0
- package/dist/cli/commands/agents.js +4 -35
- package/dist/cli/commands/auth.d.ts +20 -0
- package/dist/cli/commands/auth.js +161 -0
- package/dist/cli/commands/benchmark.d.ts +9 -0
- package/dist/cli/commands/benchmark.js +58 -0
- package/dist/cli/commands/build-plan.js +107 -139
- package/dist/cli/commands/build.d.ts +3 -4
- package/dist/cli/commands/build.js +16 -45
- package/dist/cli/commands/doctor.js +3 -3
- package/dist/cli/commands/graphs.d.ts +2 -0
- package/dist/cli/commands/graphs.js +344 -0
- package/dist/cli/commands/login.js +4 -6
- package/dist/cli/commands/logout.js +1 -1
- package/dist/cli/commands/mcp.d.ts +4 -2
- package/dist/cli/commands/mcp.js +846 -232
- package/dist/cli/commands/project.d.ts +2 -0
- package/dist/cli/commands/project.js +176 -0
- package/dist/cli/commands/reset.d.ts +3 -4
- package/dist/cli/commands/reset.js +10 -31
- package/dist/cli/commands/runs.js +136 -57
- package/dist/cli/commands/runtime.d.ts +24 -0
- package/dist/cli/commands/runtime.js +373 -0
- package/dist/cli/commands/status.d.ts +1 -0
- package/dist/cli/commands/status.js +35 -45
- package/dist/cli/commands/traces.d.ts +2 -0
- package/dist/cli/commands/traces.js +97 -0
- package/dist/cli/commands/wizard.js +171 -178
- package/dist/cli/index.d.ts +7 -4
- package/dist/cli/index.js +13 -7
- package/dist/cli/lib/http-client.d.ts +39 -0
- package/dist/cli/lib/http-client.js +73 -0
- package/dist/index.d.ts +2 -2
- package/dist/index.js +2 -2
- package/dist/packages/build-plans/authoring/brief.d.ts +538 -0
- package/dist/packages/build-plans/authoring/brief.js +89 -0
- package/dist/packages/build-plans/authoring/build-plan-authoring.d.ts +52 -11
- package/dist/packages/build-plans/authoring/build-plan-authoring.js +493 -46
- package/dist/packages/build-plans/authoring/build-plan-edit-session.d.ts +10 -1
- package/dist/packages/build-plans/authoring/build-plan-edit-session.js +27 -4
- package/dist/packages/build-plans/authoring/build-plan-improvement.d.ts +9 -6
- package/dist/packages/build-plans/authoring/build-plan-improvement.js +97 -46
- package/dist/packages/build-plans/authoring/lib/build-plan-edit-utils.d.ts +1 -0
- package/dist/packages/build-plans/authoring/lib/build-plan-edit-utils.js +7 -7
- package/dist/packages/build-plans/build-plan-resolution.d.ts +1 -1
- package/dist/packages/build-plans/build-plan-resolution.js +3 -3
- package/dist/packages/build-plans/index.d.ts +1 -1
- package/dist/packages/build-plans/index.js +1 -1
- package/dist/packages/build-plans/package/build-plan-definitions.d.ts +14 -13
- package/dist/packages/build-plans/package/build-plan-definitions.js +45 -42
- package/dist/packages/build-plans/package/build-plan-helpers.d.ts +3 -2
- package/dist/packages/build-plans/package/build-plan-helpers.js +27 -13
- package/dist/packages/build-plans/package/build-plan-review-paths.d.ts +5 -5
- package/dist/packages/build-plans/package/build-plan-review-paths.js +15 -15
- package/dist/packages/build-plans/package/build-plan-stage-runner.d.ts +5 -4
- package/dist/packages/build-plans/package/build-plan-stage-runner.js +23 -11
- package/dist/packages/build-plans/package/builtin-build-plan.d.ts +7 -8
- package/dist/packages/build-plans/package/builtin-build-plan.js +10 -11
- package/dist/packages/build-plans/package/context-interface.d.ts +14 -9
- package/dist/packages/build-plans/package/context-interface.js +14 -33
- package/dist/packages/build-plans/package/interf-build-plan-package.d.ts +6 -17
- package/dist/packages/build-plans/package/interf-build-plan-package.js +68 -64
- package/dist/packages/build-plans/package/local-build-plans.d.ts +21 -14
- package/dist/packages/build-plans/package/local-build-plans.js +105 -55
- package/dist/packages/build-plans/package/user-build-plans.js +1 -1
- package/dist/packages/contracts/index.d.ts +5 -2
- package/dist/packages/contracts/index.js +3 -1
- package/dist/packages/contracts/lib/context-graph-layer.d.ts +161 -0
- package/dist/packages/contracts/lib/context-graph-layer.js +216 -0
- package/dist/packages/contracts/lib/project-paths.d.ts +144 -0
- package/dist/packages/contracts/lib/project-paths.js +220 -0
- package/dist/packages/contracts/lib/project-schema.d.ts +423 -0
- package/dist/packages/contracts/lib/project-schema.js +138 -0
- package/dist/packages/contracts/lib/schema.d.ts +1273 -81
- package/dist/packages/contracts/lib/schema.js +675 -79
- package/dist/packages/contracts/utils/filesystem.d.ts +1 -0
- package/dist/packages/contracts/utils/filesystem.js +29 -1
- package/dist/packages/contracts/utils/parse.js +67 -0
- package/dist/packages/projects/index.d.ts +6 -0
- package/dist/packages/{project → projects}/index.js +0 -3
- package/dist/packages/{project → projects}/interf-detect.d.ts +12 -12
- package/dist/packages/{project → projects}/interf-detect.js +56 -50
- package/dist/packages/projects/interf.d.ts +2 -0
- package/dist/packages/projects/interf.js +1 -0
- package/dist/packages/projects/lib/schema.d.ts +77 -0
- package/dist/packages/projects/lib/schema.js +91 -0
- package/dist/packages/projects/source-config.d.ts +53 -0
- package/dist/packages/projects/source-config.js +339 -0
- package/dist/packages/projects/source-folders.d.ts +11 -0
- package/dist/packages/{project → projects}/source-folders.js +26 -26
- package/dist/packages/{engine → runtime}/action-planner.d.ts +1 -1
- package/dist/packages/{engine → runtime}/action-planner.js +20 -22
- package/dist/packages/runtime/action-values.d.ts +1 -0
- package/dist/packages/runtime/action-values.js +1 -0
- package/dist/packages/runtime/actions/errors.d.ts +2 -0
- package/dist/packages/runtime/actions/errors.js +12 -0
- package/dist/packages/runtime/actions/fields.d.ts +86 -0
- package/dist/packages/runtime/actions/form-builders.d.ts +14 -0
- package/dist/packages/runtime/actions/form-builders.js +667 -0
- package/dist/packages/runtime/actions/form-validators.d.ts +8 -0
- package/dist/packages/runtime/actions/form-validators.js +134 -0
- package/dist/packages/runtime/actions/helpers.d.ts +11 -0
- package/dist/packages/runtime/actions/helpers.js +80 -0
- package/dist/packages/runtime/actions/index.d.ts +8 -0
- package/dist/packages/runtime/actions/index.js +11 -0
- package/dist/packages/runtime/actions/registry.d.ts +64 -0
- package/dist/packages/runtime/actions/registry.js +62 -0
- package/dist/packages/runtime/actions/requests.d.ts +45 -0
- package/dist/packages/runtime/actions/requests.js +164 -0
- package/dist/packages/runtime/actions/schemas.d.ts +161 -0
- package/dist/packages/runtime/actions/schemas.js +37 -0
- package/dist/packages/runtime/agent-handoff.d.ts +11 -0
- package/dist/packages/runtime/agent-handoff.js +102 -0
- package/dist/packages/{engine → runtime}/agents/index.d.ts +1 -2
- package/dist/packages/{engine → runtime}/agents/index.js +1 -2
- package/dist/packages/runtime/agents/lib/args.d.ts +14 -0
- package/dist/packages/runtime/agents/lib/args.js +24 -0
- package/dist/packages/{engine → runtime}/agents/lib/constants.d.ts +4 -1
- package/dist/packages/runtime/agents/lib/constants.js +13 -0
- package/dist/packages/runtime/agents/lib/context-graph-bootstrap.d.ts +3 -0
- package/dist/packages/{engine/agents/lib/verifiable-context-bootstrap.js → runtime/agents/lib/context-graph-bootstrap.js} +5 -6
- package/dist/packages/{engine → runtime}/agents/lib/detection.d.ts +5 -0
- package/dist/packages/{engine → runtime}/agents/lib/detection.js +16 -7
- package/dist/packages/{engine → runtime}/agents/lib/execution-profile.d.ts +14 -0
- package/dist/packages/{engine → runtime}/agents/lib/execution-profile.js +31 -14
- package/dist/packages/{engine → runtime}/agents/lib/execution.js +22 -6
- package/dist/packages/{engine → runtime}/agents/lib/executors.d.ts +1 -0
- package/dist/packages/{engine → runtime}/agents/lib/executors.js +11 -2
- package/dist/packages/runtime/agents/lib/logs.d.ts +12 -0
- package/dist/packages/runtime/agents/lib/logs.js +41 -0
- package/dist/packages/{engine → runtime}/agents/lib/preflight.js +19 -14
- package/dist/packages/runtime/agents/lib/render.d.ts +26 -0
- package/dist/packages/{engine → runtime}/agents/lib/render.js +48 -22
- package/dist/packages/runtime/agents/lib/shell-fs.d.ts +18 -0
- package/dist/packages/runtime/agents/lib/shell-fs.js +190 -0
- package/dist/packages/runtime/agents/lib/shell-paths.d.ts +16 -0
- package/dist/packages/runtime/agents/lib/shell-paths.js +63 -0
- package/dist/packages/runtime/agents/lib/shell-projection.d.ts +25 -0
- package/dist/packages/runtime/agents/lib/shell-projection.js +314 -0
- package/dist/packages/runtime/agents/lib/shell-templates.d.ts +30 -0
- package/dist/packages/runtime/agents/lib/shell-templates.js +494 -0
- package/dist/packages/runtime/agents/lib/shell-workspace.d.ts +17 -0
- package/dist/packages/runtime/agents/lib/shell-workspace.js +70 -0
- package/dist/packages/runtime/agents/lib/shells.d.ts +92 -0
- package/dist/packages/runtime/agents/lib/shells.js +509 -0
- package/dist/packages/runtime/agents/lib/source-context-scan.d.ts +10 -0
- package/dist/packages/runtime/agents/lib/source-context-scan.js +388 -0
- package/dist/packages/{engine → runtime}/agents/lib/status.js +1 -14
- package/dist/packages/runtime/agents/lib/string-utils.d.ts +16 -0
- package/dist/packages/runtime/agents/lib/string-utils.js +36 -0
- package/dist/packages/{engine → runtime}/agents/lib/types.d.ts +1 -0
- package/dist/packages/{engine → runtime}/agents/lib/user-config.d.ts +8 -2
- package/dist/packages/{engine → runtime}/agents/lib/user-config.js +8 -2
- package/dist/packages/runtime/agents/providers/claude-code.d.ts +13 -0
- package/dist/packages/runtime/agents/providers/claude-code.js +45 -0
- package/dist/packages/runtime/agents/providers/codex.d.ts +17 -0
- package/dist/packages/runtime/agents/providers/codex.js +66 -0
- package/dist/packages/runtime/agents/providers/cursor.d.ts +9 -0
- package/dist/packages/runtime/agents/providers/cursor.js +24 -0
- package/dist/packages/runtime/agents/providers/index.d.ts +9 -0
- package/dist/packages/runtime/agents/providers/index.js +31 -0
- package/dist/packages/runtime/agents/providers/types.d.ts +50 -0
- package/dist/packages/{engine → runtime}/agents/registry.d.ts +13 -2
- package/dist/packages/{engine → runtime}/agents/registry.js +48 -10
- package/dist/packages/{engine → runtime}/agents/role-executors.d.ts +1 -1
- package/dist/packages/{engine → runtime}/agents/role-executors.js +9 -7
- package/dist/packages/{engine → runtime}/agents/role-router.js +7 -5
- package/dist/packages/runtime/auth/account-context.d.ts +52 -0
- package/dist/packages/runtime/auth/account-context.js +68 -0
- package/dist/packages/runtime/auth/auth-flow.d.ts +73 -0
- package/dist/packages/runtime/auth/auth-flow.js +189 -0
- package/dist/packages/runtime/auth/jwt-validator.d.ts +58 -0
- package/dist/packages/runtime/auth/jwt-validator.js +86 -0
- package/dist/packages/runtime/auth/keychain.d.ts +35 -0
- package/dist/packages/runtime/auth/keychain.js +85 -0
- package/dist/packages/runtime/auth/session-store.d.ts +38 -0
- package/dist/packages/runtime/auth/session-store.js +96 -0
- package/dist/packages/runtime/auth/workos-client.d.ts +58 -0
- package/dist/packages/runtime/auth/workos-client.js +87 -0
- package/dist/packages/runtime/benchmark-question-draft.d.ts +23 -0
- package/dist/packages/runtime/benchmark-question-draft.js +153 -0
- package/dist/packages/runtime/build/artifact-counts.d.ts +1 -0
- package/dist/packages/{engine → runtime}/build/artifact-counts.js +5 -9
- package/dist/packages/{engine → runtime}/build/artifact-status.d.ts +6 -6
- package/dist/packages/{engine → runtime}/build/artifact-status.js +26 -24
- package/dist/packages/runtime/build/atomic-fs.d.ts +3 -0
- package/dist/packages/runtime/build/atomic-fs.js +95 -0
- package/dist/packages/runtime/build/billing-events.d.ts +78 -0
- package/dist/packages/{engine → runtime}/build/billing-events.js +17 -19
- package/dist/packages/runtime/build/build-evidence.d.ts +16 -0
- package/dist/packages/runtime/build/build-evidence.js +179 -0
- package/dist/packages/{engine → runtime}/build/build-pipeline.d.ts +12 -8
- package/dist/packages/runtime/build/build-pipeline.js +388 -0
- package/dist/packages/{engine → runtime}/build/build-plan-primitives.d.ts +1 -1
- package/dist/packages/{engine → runtime}/build/build-plan-primitives.js +0 -1
- package/dist/packages/runtime/build/build-plan-runs.d.ts +14 -0
- package/dist/packages/runtime/build/build-plan-runs.js +31 -0
- package/dist/packages/runtime/build/build-stage-plan.d.ts +16 -0
- package/dist/packages/runtime/build/build-stage-plan.js +101 -0
- package/dist/packages/{engine → runtime}/build/build-stage-runner.d.ts +2 -1
- package/dist/packages/runtime/build/build-stage-runner.js +302 -0
- package/dist/packages/{engine → runtime}/build/build-target.d.ts +7 -4
- package/dist/packages/runtime/build/build-target.js +40 -0
- package/dist/packages/{engine → runtime}/build/check-evaluator.d.ts +14 -16
- package/dist/packages/runtime/build/check-evaluator.js +1226 -0
- package/dist/packages/runtime/build/context-graph-paths.d.ts +64 -0
- package/dist/packages/runtime/build/context-graph-paths.js +160 -0
- package/dist/packages/runtime/build/context-graph-schema.d.ts +19 -0
- package/dist/packages/runtime/build/context-graph-schema.js +39 -0
- package/dist/packages/{engine → runtime}/build/discovery.d.ts +2 -2
- package/dist/packages/{engine → runtime}/build/discovery.js +4 -4
- package/dist/packages/{engine → runtime}/build/index.d.ts +7 -5
- package/dist/packages/{engine → runtime}/build/index.js +7 -5
- package/dist/packages/runtime/build/inspect-map.d.ts +10 -0
- package/dist/packages/runtime/build/inspect-map.js +270 -0
- package/dist/packages/{engine → runtime}/build/lib/schema.d.ts +449 -123
- package/dist/packages/runtime/build/lib/schema.js +494 -0
- package/dist/packages/runtime/build/native-entrypoint.d.ts +2 -0
- package/dist/packages/runtime/build/native-entrypoint.js +286 -0
- package/dist/packages/runtime/build/reset.d.ts +2 -0
- package/dist/packages/runtime/build/reset.js +62 -0
- package/dist/packages/{engine → runtime}/build/runtime-contracts.js +13 -7
- package/dist/packages/runtime/build/runtime-inventory.d.ts +7 -0
- package/dist/packages/{engine → runtime}/build/runtime-inventory.js +3 -3
- package/dist/packages/runtime/build/runtime-log-paths.d.ts +3 -0
- package/dist/packages/runtime/build/runtime-log-paths.js +16 -0
- package/dist/packages/{engine → runtime}/build/runtime-prompt.js +12 -9
- package/dist/packages/{engine → runtime}/build/runtime-reconcile.d.ts +1 -1
- package/dist/packages/{engine → runtime}/build/runtime-reconcile.js +25 -21
- package/dist/packages/runtime/build/runtime-runs.d.ts +10 -0
- package/dist/packages/runtime/build/runtime-runs.js +318 -0
- package/dist/packages/{engine → runtime}/build/runtime-types.d.ts +9 -6
- package/dist/packages/runtime/build/runtime-types.js +1 -0
- package/dist/packages/runtime/build/runtime.d.ts +8 -0
- package/dist/packages/runtime/build/runtime.js +7 -0
- package/dist/packages/runtime/build/source-files.d.ts +58 -0
- package/dist/packages/runtime/build/source-files.js +193 -0
- package/dist/packages/runtime/build/source-inventory.d.ts +28 -0
- package/dist/packages/runtime/build/source-inventory.js +512 -0
- package/dist/packages/runtime/build/source-manifest.d.ts +63 -0
- package/dist/packages/runtime/build/source-manifest.js +220 -0
- package/dist/packages/runtime/build/stage-evidence.d.ts +22 -0
- package/dist/packages/runtime/build/stage-evidence.js +386 -0
- package/dist/packages/runtime/build/stage-manifest.d.ts +45 -0
- package/dist/packages/runtime/build/stage-manifest.js +1125 -0
- package/dist/packages/runtime/build/stage-reuse.d.ts +11 -0
- package/dist/packages/runtime/build/stage-reuse.js +154 -0
- package/dist/packages/runtime/build/stage-session.d.ts +81 -0
- package/dist/packages/runtime/build/stage-session.js +308 -0
- package/dist/packages/runtime/build/state-artifacts.d.ts +9 -0
- package/dist/packages/runtime/build/state-artifacts.js +14 -0
- package/dist/packages/runtime/build/state-health.d.ts +4 -0
- package/dist/packages/{engine → runtime}/build/state-health.js +21 -26
- package/dist/packages/runtime/build/state-io.d.ts +12 -0
- package/dist/packages/runtime/build/state-io.js +118 -0
- package/dist/packages/runtime/build/state-view.d.ts +5 -0
- package/dist/packages/runtime/build/state-view.js +121 -0
- package/dist/packages/runtime/build/state.d.ts +7 -0
- package/dist/packages/runtime/build/state.js +12 -0
- package/dist/packages/runtime/build/summary-coverage-index.d.ts +21 -0
- package/dist/packages/runtime/build/summary-coverage-index.js +189 -0
- package/dist/packages/runtime/build/traces.d.ts +30 -0
- package/dist/packages/runtime/build/traces.js +133 -0
- package/dist/packages/{engine/build/validate-verifiable-context.d.ts → runtime/build/validate-context-graph.d.ts} +6 -6
- package/dist/packages/{engine/build/validate-verifiable-context.js → runtime/build/validate-context-graph.js} +49 -36
- package/dist/packages/{engine → runtime}/build/validate.d.ts +5 -5
- package/dist/packages/{engine → runtime}/build/validate.js +26 -26
- package/dist/packages/{engine → runtime}/client.d.ts +18 -18
- package/dist/packages/{engine → runtime}/client.js +48 -36
- package/dist/packages/{engine → runtime}/connection-config.d.ts +3 -2
- package/dist/packages/{engine → runtime}/connection-config.js +9 -8
- package/dist/packages/runtime/context-checks.d.ts +10 -0
- package/dist/packages/runtime/context-checks.js +127 -0
- package/dist/packages/runtime/context-graph-scaffold.d.ts +9 -0
- package/dist/packages/runtime/context-graph-scaffold.js +135 -0
- package/dist/packages/runtime/context-graph-semantic-graph.d.ts +9 -0
- package/dist/packages/runtime/context-graph-semantic-graph.js +416 -0
- package/dist/packages/runtime/entitlement-guard.d.ts +43 -0
- package/dist/packages/runtime/entitlement-guard.js +70 -0
- package/dist/packages/{engine → runtime}/execution/index.d.ts +2 -2
- package/dist/packages/{engine → runtime}/execution/index.js +1 -1
- package/dist/packages/{engine → runtime}/execution/lib/schema.d.ts +272 -191
- package/dist/packages/{engine → runtime}/execution/lib/schema.js +35 -32
- package/dist/packages/runtime/index.d.ts +29 -0
- package/dist/packages/runtime/index.js +21 -0
- package/dist/packages/runtime/instance-paths.d.ts +30 -0
- package/dist/packages/runtime/instance-paths.js +29 -0
- package/dist/packages/runtime/native-run-handlers.d.ts +63 -0
- package/dist/packages/{engine → runtime}/native-run-handlers.js +217 -166
- package/dist/packages/runtime/plan-artifact-contract.d.ts +17 -0
- package/dist/packages/runtime/plan-artifact-contract.js +42 -0
- package/dist/packages/runtime/project-entries.d.ts +11 -0
- package/dist/packages/runtime/project-entries.js +49 -0
- package/dist/packages/runtime/project-source-state.d.ts +26 -0
- package/dist/packages/runtime/project-source-state.js +56 -0
- package/dist/packages/runtime/project-store.d.ts +90 -0
- package/dist/packages/runtime/project-store.js +195 -0
- package/dist/packages/runtime/requested-artifacts.d.ts +7 -0
- package/dist/packages/{engine → runtime}/requested-artifacts.js +23 -1
- package/dist/packages/{engine → runtime}/run-observability.d.ts +2 -1
- package/dist/packages/{engine → runtime}/run-observability.js +174 -87
- package/dist/packages/runtime/runtime-action-proposals.d.ts +7 -0
- package/dist/packages/runtime/runtime-action-proposals.js +542 -0
- package/dist/packages/runtime/runtime-build-plans.d.ts +5 -0
- package/dist/packages/runtime/runtime-build-plans.js +175 -0
- package/dist/packages/runtime/runtime-build-runs.d.ts +47 -0
- package/dist/packages/runtime/runtime-build-runs.js +555 -0
- package/dist/packages/runtime/runtime-caches.d.ts +117 -0
- package/dist/packages/runtime/runtime-caches.js +266 -0
- package/dist/packages/{engine → runtime}/runtime-event-applier.d.ts +3 -1
- package/dist/packages/{engine → runtime}/runtime-event-applier.js +53 -17
- package/dist/packages/runtime/runtime-executor.d.ts +22 -0
- package/dist/packages/runtime/runtime-executor.js +131 -0
- package/dist/packages/runtime/runtime-jobs.d.ts +13 -0
- package/dist/packages/runtime/runtime-jobs.js +463 -0
- package/dist/packages/runtime/runtime-observability.d.ts +11 -0
- package/dist/packages/runtime/runtime-observability.js +39 -0
- package/dist/packages/{engine → runtime}/runtime-persistence.d.ts +9 -18
- package/dist/packages/{engine → runtime}/runtime-persistence.js +25 -25
- package/dist/packages/runtime/runtime-project-mutations.d.ts +7 -0
- package/dist/packages/runtime/runtime-project-mutations.js +65 -0
- package/dist/packages/runtime/runtime-project-reads.d.ts +18 -0
- package/dist/packages/runtime/runtime-project-reads.js +574 -0
- package/dist/packages/runtime/runtime-proposal-helpers.d.ts +22 -0
- package/dist/packages/runtime/runtime-proposal-helpers.js +223 -0
- package/dist/packages/{engine → runtime}/runtime-resource-builders.d.ts +23 -16
- package/dist/packages/{engine → runtime}/runtime-resource-builders.js +58 -46
- package/dist/packages/runtime/runtime-status.d.ts +14 -0
- package/dist/packages/runtime/runtime-status.js +15 -0
- package/dist/packages/runtime/runtime-verify-runs.d.ts +84 -0
- package/dist/packages/runtime/runtime-verify-runs.js +296 -0
- package/dist/packages/runtime/runtime.d.ts +1582 -0
- package/dist/packages/runtime/runtime.js +431 -0
- package/dist/packages/runtime/schemas/actions.d.ts +1206 -0
- package/dist/packages/runtime/schemas/actions.js +117 -0
- package/dist/packages/runtime/schemas/agents.d.ts +104 -0
- package/dist/packages/runtime/schemas/agents.js +74 -0
- package/dist/packages/runtime/schemas/build-plans.d.ts +1132 -0
- package/dist/packages/runtime/schemas/build-plans.js +141 -0
- package/dist/packages/runtime/schemas/context-graphs.d.ts +1522 -0
- package/dist/packages/runtime/schemas/context-graphs.js +110 -0
- package/dist/packages/runtime/schemas/files.d.ts +227 -0
- package/dist/packages/runtime/schemas/files.js +28 -0
- package/dist/packages/runtime/schemas/index.d.ts +9 -0
- package/dist/packages/runtime/schemas/index.js +13 -0
- package/dist/packages/runtime/schemas/instance.d.ts +141 -0
- package/dist/packages/runtime/schemas/instance.js +143 -0
- package/dist/packages/runtime/schemas/jobs.d.ts +339 -0
- package/dist/packages/runtime/schemas/jobs.js +107 -0
- package/dist/packages/runtime/schemas/projects.d.ts +366 -0
- package/dist/packages/runtime/schemas/projects.js +160 -0
- package/dist/packages/runtime/schemas/runs.d.ts +3445 -0
- package/dist/packages/runtime/schemas/runs.js +115 -0
- package/dist/packages/runtime/service/index.d.ts +3 -0
- package/dist/packages/runtime/service/index.js +3 -0
- package/dist/packages/runtime/service/openapi.d.ts +7 -0
- package/dist/packages/runtime/service/openapi.js +118 -0
- package/dist/packages/runtime/service/operations.d.ts +3011 -0
- package/dist/packages/runtime/service/operations.js +375 -0
- package/dist/packages/runtime/service/routes.d.ts +114 -0
- package/dist/packages/runtime/service/routes.js +128 -0
- package/dist/packages/runtime/service/server-api-files.d.ts +10 -0
- package/dist/packages/runtime/service/server-api-files.js +85 -0
- package/dist/packages/runtime/service/server-app-boot.d.ts +4 -0
- package/dist/packages/runtime/service/server-app-boot.js +46 -0
- package/dist/packages/runtime/service/server-guards.d.ts +63 -0
- package/dist/packages/runtime/service/server-guards.js +181 -0
- package/dist/packages/runtime/service/server-helpers.d.ts +38 -0
- package/dist/packages/runtime/service/server-helpers.js +108 -0
- package/dist/packages/runtime/service/server-instance-helpers.d.ts +30 -0
- package/dist/packages/runtime/service/server-instance-helpers.js +114 -0
- package/dist/packages/runtime/service/server-routes-action-proposals.d.ts +3 -0
- package/dist/packages/runtime/service/server-routes-action-proposals.js +45 -0
- package/dist/packages/runtime/service/server-routes-agents.d.ts +4 -0
- package/dist/packages/runtime/service/server-routes-agents.js +132 -0
- package/dist/packages/runtime/service/server-routes-auth.d.ts +33 -0
- package/dist/packages/runtime/service/server-routes-auth.js +138 -0
- package/dist/packages/runtime/service/server-routes-build-plans.d.ts +3 -0
- package/dist/packages/runtime/service/server-routes-build-plans.js +86 -0
- package/dist/packages/runtime/service/server-routes-discovery.d.ts +4 -0
- package/dist/packages/runtime/service/server-routes-discovery.js +196 -0
- package/dist/packages/runtime/service/server-routes-events.d.ts +5 -0
- package/dist/packages/runtime/service/server-routes-events.js +99 -0
- package/dist/packages/runtime/service/server-routes-project-context.d.ts +9 -0
- package/dist/packages/runtime/service/server-routes-project-context.js +287 -0
- package/dist/packages/runtime/service/server-routes-project-jobs.d.ts +9 -0
- package/dist/packages/runtime/service/server-routes-project-jobs.js +137 -0
- package/dist/packages/runtime/service/server-routes-project-runs.d.ts +14 -0
- package/dist/packages/runtime/service/server-routes-project-runs.js +88 -0
- package/dist/packages/runtime/service/server-routes-projects.d.ts +4 -0
- package/dist/packages/runtime/service/server-routes-projects.js +96 -0
- package/dist/packages/runtime/service/server-routes-runs.d.ts +3 -0
- package/dist/packages/runtime/service/server-routes-runs.js +119 -0
- package/dist/packages/runtime/service/server.d.ts +37 -0
- package/dist/packages/runtime/service/server.js +300 -0
- package/dist/packages/{engine → runtime/service}/service-registry.d.ts +5 -5
- package/dist/packages/{engine → runtime/service}/service-registry.js +7 -7
- package/dist/packages/runtime/verify/benchmark-run.d.ts +81 -0
- package/dist/packages/runtime/verify/benchmark-run.js +303 -0
- package/dist/packages/{engine → runtime}/verify/index.d.ts +2 -2
- package/dist/packages/{engine → runtime}/verify/index.js +1 -1
- package/dist/packages/{engine → runtime}/verify/lib/schema.d.ts +83 -16
- package/dist/packages/{engine → runtime}/verify/lib/schema.js +38 -18
- package/dist/packages/runtime/verify/test-file-guard.d.ts +2 -0
- package/dist/packages/runtime/verify/test-file-guard.js +29 -0
- package/dist/packages/{engine → runtime}/verify/verify-execution.d.ts +7 -0
- package/dist/packages/{engine → runtime}/verify/verify-execution.js +119 -45
- package/dist/packages/{engine → runtime}/verify/verify-paths.d.ts +5 -4
- package/dist/packages/runtime/verify/verify-paths.js +65 -0
- package/dist/packages/{engine → runtime}/verify/verify-sandbox.d.ts +1 -1
- package/dist/packages/runtime/verify/verify-sandbox.js +88 -0
- package/dist/packages/{engine → runtime}/verify/verify-specs.d.ts +2 -0
- package/dist/packages/runtime/verify/verify-specs.js +126 -0
- package/dist/packages/runtime/verify/verify-targets.d.ts +5 -0
- package/dist/packages/{engine → runtime}/verify/verify-targets.js +12 -12
- package/dist/packages/runtime/verify/verify-types.js +1 -0
- package/dist/packages/{engine → runtime}/verify/verify.d.ts +1 -1
- package/dist/packages/{engine → runtime}/verify/verify.js +1 -1
- package/dist/packages/runtime/wire-schemas.d.ts +18 -0
- package/dist/packages/runtime/wire-schemas.js +27 -0
- package/package.json +32 -30
- package/public-repo/CONTRIBUTING.md +16 -18
- package/public-repo/README.md +119 -282
- package/public-repo/SECURITY.md +3 -4
- package/public-repo/build-plans/interf-default/README.md +24 -16
- package/public-repo/build-plans/interf-default/build/stages/entrypoint/SKILL.md +74 -0
- package/public-repo/build-plans/interf-default/build/stages/knowledge/SKILL.md +95 -0
- package/public-repo/build-plans/interf-default/build/stages/summarize/SKILL.md +49 -4
- package/public-repo/build-plans/interf-default/build-plan.json +49 -39
- package/public-repo/build-plans/interf-default/build-plan.schema.json +59 -33
- package/public-repo/build-plans/interf-default/improve/SKILL.md +3 -3
- package/public-repo/build-plans/interf-default/use/query/SKILL.md +18 -11
- package/public-repo/openapi/local-service.openapi.json +14227 -0
- package/public-repo/skills/interf/SKILL.md +508 -187
- package/dist/cli/commands/prep.d.ts +0 -2
- package/dist/cli/commands/prep.js +0 -240
- package/dist/cli/commands/test.d.ts +0 -10
- package/dist/cli/commands/test.js +0 -85
- package/dist/cli/commands/web.d.ts +0 -2
- package/dist/cli/commands/web.js +0 -286
- package/dist/interf-ui/404.html +0 -1
- package/dist/interf-ui/__next.__PAGE__.txt +0 -10
- package/dist/interf-ui/__next._full.txt +0 -20
- package/dist/interf-ui/__next._head.txt +0 -5
- package/dist/interf-ui/__next._index.txt +0 -5
- package/dist/interf-ui/__next._tree.txt +0 -5
- package/dist/interf-ui/_next/static/--reS3xBzM5zc6QxNjZd6/_buildManifest.js +0 -11
- package/dist/interf-ui/_next/static/--reS3xBzM5zc6QxNjZd6/_clientMiddlewareManifest.js +0 -1
- package/dist/interf-ui/_next/static/--reS3xBzM5zc6QxNjZd6/_ssgManifest.js +0 -1
- package/dist/interf-ui/_next/static/chunks/0.tjb6f4golw..css +0 -3
- package/dist/interf-ui/_next/static/chunks/03~yq9q893hmn.js +0 -1
- package/dist/interf-ui/_next/static/chunks/085-n_jv2ng_q.css +0 -1
- package/dist/interf-ui/_next/static/chunks/0dn41fa_zvgsl.js +0 -1
- package/dist/interf-ui/_next/static/chunks/0g-ea0zj5d-0k.js +0 -1
- package/dist/interf-ui/_next/static/chunks/0gwqglc4iz583.js +0 -1
- package/dist/interf-ui/_next/static/chunks/0haldgm65ve6l.js +0 -1
- package/dist/interf-ui/_next/static/chunks/0nv3am99vjzn4.js +0 -1
- package/dist/interf-ui/_next/static/chunks/0s77gt_o4jwtx.js +0 -1
- package/dist/interf-ui/_next/static/chunks/0y5z3t-z1c8ks.js.map +0 -5
- package/dist/interf-ui/_next/static/chunks/0~a36ujuzpaz..js +0 -116
- package/dist/interf-ui/_next/static/chunks/10jeodxe4nkgj.js +0 -31
- package/dist/interf-ui/_next/static/chunks/119h2rouych2t.js +0 -1
- package/dist/interf-ui/_next/static/chunks/13c8b~m8knjsf.js +0 -1
- package/dist/interf-ui/_next/static/chunks/14dznb2qpt-ho.js +0 -91
- package/dist/interf-ui/_next/static/chunks/15z_en80lrq-3.js +0 -5
- package/dist/interf-ui/_next/static/chunks/turbopack-0p.pvcjrtq-jh.js +0 -1
- package/dist/interf-ui/_next/static/chunks/turbopack-0usj_75.8frlw.js +0 -1
- package/dist/interf-ui/_next/static/chunks/turbopack-worker-0sjn--fhq~1cg.js +0 -1
- package/dist/interf-ui/_next/static/media/GeistMono_Variable.p.17jn9btb_52pq.woff2 +0 -0
- package/dist/interf-ui/_next/static/media/Geist_Variable-s.p.0-te~ja_gpvcf.woff2 +0 -0
- package/dist/interf-ui/_next/static/media/worker.102zas1s52_pf.js +0 -109
- package/dist/interf-ui/_not-found/__next._full.txt +0 -15
- package/dist/interf-ui/_not-found/__next._head.txt +0 -5
- package/dist/interf-ui/_not-found/__next._index.txt +0 -5
- package/dist/interf-ui/_not-found/__next._not-found.__PAGE__.txt +0 -5
- package/dist/interf-ui/_not-found/__next._not-found.txt +0 -5
- package/dist/interf-ui/_not-found/__next._tree.txt +0 -2
- package/dist/interf-ui/_not-found.html +0 -1
- package/dist/interf-ui/_not-found.txt +0 -15
- package/dist/interf-ui/index.html +0 -1
- package/dist/interf-ui/index.txt +0 -20
- package/dist/packages/contracts/lib/preparation-paths.d.ts +0 -117
- package/dist/packages/contracts/lib/preparation-paths.js +0 -177
- package/dist/packages/engine/action-definitions.d.ts +0 -407
- package/dist/packages/engine/action-definitions.js +0 -1158
- package/dist/packages/engine/action-values.d.ts +0 -1
- package/dist/packages/engine/action-values.js +0 -1
- package/dist/packages/engine/agents/lib/args.d.ts +0 -4
- package/dist/packages/engine/agents/lib/args.js +0 -52
- package/dist/packages/engine/agents/lib/chart-guidance.d.ts +0 -1
- package/dist/packages/engine/agents/lib/chart-guidance.js +0 -8
- package/dist/packages/engine/agents/lib/constants.js +0 -28
- package/dist/packages/engine/agents/lib/logs.d.ts +0 -2
- package/dist/packages/engine/agents/lib/logs.js +0 -17
- package/dist/packages/engine/agents/lib/render.d.ts +0 -8
- package/dist/packages/engine/agents/lib/schema.d.ts +0 -8
- package/dist/packages/engine/agents/lib/schema.js +0 -7
- package/dist/packages/engine/agents/lib/shells.d.ts +0 -74
- package/dist/packages/engine/agents/lib/shells.js +0 -1052
- package/dist/packages/engine/agents/lib/verifiable-context-bootstrap.d.ts +0 -3
- package/dist/packages/engine/build/artifact-counts.d.ts +0 -1
- package/dist/packages/engine/build/billing-events.d.ts +0 -89
- package/dist/packages/engine/build/build-pipeline.js +0 -175
- package/dist/packages/engine/build/build-plan-runs.d.ts +0 -14
- package/dist/packages/engine/build/build-plan-runs.js +0 -31
- package/dist/packages/engine/build/build-stage-plan.d.ts +0 -16
- package/dist/packages/engine/build/build-stage-plan.js +0 -100
- package/dist/packages/engine/build/build-stage-runner.js +0 -94
- package/dist/packages/engine/build/build-target.js +0 -16
- package/dist/packages/engine/build/check-evaluator.js +0 -298
- package/dist/packages/engine/build/lib/schema.js +0 -316
- package/dist/packages/engine/build/reset.d.ts +0 -2
- package/dist/packages/engine/build/reset.js +0 -74
- package/dist/packages/engine/build/runtime-inventory.d.ts +0 -7
- package/dist/packages/engine/build/runtime-paths.d.ts +0 -8
- package/dist/packages/engine/build/runtime-paths.js +0 -26
- package/dist/packages/engine/build/runtime-runs.d.ts +0 -10
- package/dist/packages/engine/build/runtime-runs.js +0 -224
- package/dist/packages/engine/build/runtime.d.ts +0 -5
- package/dist/packages/engine/build/runtime.js +0 -4
- package/dist/packages/engine/build/source-files.d.ts +0 -46
- package/dist/packages/engine/build/source-files.js +0 -149
- package/dist/packages/engine/build/state-artifacts.d.ts +0 -9
- package/dist/packages/engine/build/state-artifacts.js +0 -14
- package/dist/packages/engine/build/state-health.d.ts +0 -4
- package/dist/packages/engine/build/state-io.d.ts +0 -11
- package/dist/packages/engine/build/state-io.js +0 -82
- package/dist/packages/engine/build/state-paths.d.ts +0 -5
- package/dist/packages/engine/build/state-paths.js +0 -16
- package/dist/packages/engine/build/state-view.d.ts +0 -5
- package/dist/packages/engine/build/state-view.js +0 -94
- package/dist/packages/engine/build/state.d.ts +0 -7
- package/dist/packages/engine/build/state.js +0 -12
- package/dist/packages/engine/build/validate-helpers.d.ts +0 -12
- package/dist/packages/engine/build/validate-helpers.js +0 -41
- package/dist/packages/engine/build/verifiable-context-paths.d.ts +0 -47
- package/dist/packages/engine/build/verifiable-context-paths.js +0 -121
- package/dist/packages/engine/build/verifiable-context-schema.d.ts +0 -21
- package/dist/packages/engine/build/verifiable-context-schema.js +0 -126
- package/dist/packages/engine/cloud-seams.d.ts +0 -115
- package/dist/packages/engine/cloud-seams.js +0 -84
- package/dist/packages/engine/index.d.ts +0 -22
- package/dist/packages/engine/index.js +0 -15
- package/dist/packages/engine/instance-paths.d.ts +0 -106
- package/dist/packages/engine/instance-paths.js +0 -171
- package/dist/packages/engine/lib/schema.d.ts +0 -6304
- package/dist/packages/engine/lib/schema.js +0 -730
- package/dist/packages/engine/native-run-handlers.d.ts +0 -25
- package/dist/packages/engine/preparation-store.d.ts +0 -105
- package/dist/packages/engine/preparation-store.js +0 -213
- package/dist/packages/engine/readiness-check-draft.d.ts +0 -20
- package/dist/packages/engine/readiness-check-draft.js +0 -111
- package/dist/packages/engine/requested-artifacts.d.ts +0 -5
- package/dist/packages/engine/routes.d.ts +0 -85
- package/dist/packages/engine/routes.js +0 -99
- package/dist/packages/engine/runtime-caches.d.ts +0 -76
- package/dist/packages/engine/runtime-caches.js +0 -191
- package/dist/packages/engine/runtime-proposal-helpers.d.ts +0 -35
- package/dist/packages/engine/runtime-proposal-helpers.js +0 -247
- package/dist/packages/engine/runtime.d.ts +0 -371
- package/dist/packages/engine/runtime.js +0 -2463
- package/dist/packages/engine/server.d.ts +0 -58
- package/dist/packages/engine/server.js +0 -1399
- package/dist/packages/engine/verify/readiness-check-run.d.ts +0 -82
- package/dist/packages/engine/verify/readiness-check-run.js +0 -265
- package/dist/packages/engine/verify/verify-paths.js +0 -61
- package/dist/packages/engine/verify/verify-sandbox.js +0 -88
- package/dist/packages/engine/verify/verify-specs.js +0 -114
- package/dist/packages/engine/verify/verify-targets.d.ts +0 -5
- package/dist/packages/engine/wire-schemas.d.ts +0 -547
- package/dist/packages/engine/wire-schemas.js +0 -59
- package/dist/packages/project/index.d.ts +0 -9
- package/dist/packages/project/interf-bootstrap.d.ts +0 -1
- package/dist/packages/project/interf-bootstrap.js +0 -1
- package/dist/packages/project/interf-scaffold.d.ts +0 -3
- package/dist/packages/project/interf-scaffold.js +0 -136
- package/dist/packages/project/interf.d.ts +0 -4
- package/dist/packages/project/interf.js +0 -3
- package/dist/packages/project/lib/schema.d.ts +0 -328
- package/dist/packages/project/lib/schema.js +0 -136
- package/dist/packages/project/preparation-entries.d.ts +0 -11
- package/dist/packages/project/preparation-entries.js +0 -49
- package/dist/packages/project/source-config.d.ts +0 -46
- package/dist/packages/project/source-config.js +0 -394
- package/dist/packages/project/source-folders.d.ts +0 -11
- package/public-repo/build-plans/interf-default/build/stages/shape/SKILL.md +0 -27
- package/public-repo/build-plans/interf-default/build/stages/structure/SKILL.md +0 -21
- package/public-repo/plugins/README.md +0 -9
- package/public-repo/plugins/interf/.claude-plugin/plugin.json +0 -21
- package/public-repo/plugins/interf/.mcp.json +0 -12
- package/public-repo/plugins/interf/README.md +0 -32
- package/public-repo/plugins/interf/skills/interf/SKILL.md +0 -376
- /package/dist/packages/{engine/agents/lib/types.js → runtime/actions/fields.js} +0 -0
- /package/dist/packages/{engine → runtime}/agents/lib/agents.d.ts +0 -0
- /package/dist/packages/{engine → runtime}/agents/lib/agents.js +0 -0
- /package/dist/packages/{engine → runtime}/agents/lib/execution.d.ts +0 -0
- /package/dist/packages/{engine → runtime}/agents/lib/preflight.d.ts +0 -0
- /package/dist/packages/{engine → runtime}/agents/lib/status.d.ts +0 -0
- /package/dist/packages/{engine/build/runtime-types.js → runtime/agents/lib/types.js} +0 -0
- /package/dist/packages/{engine/verify/verify-types.js → runtime/agents/providers/types.js} +0 -0
- /package/dist/packages/{engine → runtime}/agents/role-router.d.ts +0 -0
- /package/dist/packages/{engine → runtime}/build/build-execution.d.ts +0 -0
- /package/dist/packages/{engine → runtime}/build/build-execution.js +0 -0
- /package/dist/packages/{engine → runtime}/build/runtime-contracts.d.ts +0 -0
- /package/dist/packages/{engine → runtime}/build/runtime-prompt.d.ts +0 -0
- /package/dist/packages/{engine → runtime}/execution/adapters.d.ts +0 -0
- /package/dist/packages/{engine → runtime}/execution/adapters.js +0 -0
- /package/dist/packages/{engine → runtime}/execution/events.d.ts +0 -0
- /package/dist/packages/{engine → runtime}/execution/events.js +0 -0
- /package/dist/packages/{engine → runtime}/verify/verify-profile-presets.d.ts +0 -0
- /package/dist/packages/{engine → runtime}/verify/verify-profile-presets.js +0 -0
- /package/dist/packages/{engine → runtime}/verify/verify-types.d.ts +0 -0
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { AgentExecutor } from "../../
|
|
1
|
+
import type { AgentExecutor } from "../../runtime/agents/lib/executors.js";
|
|
2
2
|
import type { BuildPlanValidationResult } from "../package/local-build-plans.js";
|
|
3
3
|
import { type BuildPlanEditShellArtifacts } from "./lib/build-plan-edit-utils.js";
|
|
4
4
|
export interface BuildPlanEditSessionResult {
|
|
@@ -7,6 +7,15 @@ export interface BuildPlanEditSessionResult {
|
|
|
7
7
|
validation: BuildPlanValidationResult | null;
|
|
8
8
|
summary: string;
|
|
9
9
|
}
|
|
10
|
+
/**
|
|
11
|
+
* Stable Build Plan editing rules shared verbatim by every prompt that edits a
|
|
12
|
+
* Build Plan package — the from-scratch authoring prompt
|
|
13
|
+
* (`build-plan-authoring.ts`) and the validation-repair prompt below. Defined
|
|
14
|
+
* once so the wording cannot drift between the two prompts. Each entry is the
|
|
15
|
+
* bare rule text; the repair prompt renders it as a `- ` bullet, the authoring
|
|
16
|
+
* prompt renders it as a plain line.
|
|
17
|
+
*/
|
|
18
|
+
export declare const SHARED_BUILD_PLAN_EDIT_RULES: readonly string[];
|
|
10
19
|
export declare function runBuildPlanEditSession(options: {
|
|
11
20
|
executor: AgentExecutor;
|
|
12
21
|
buildPlanPath: string;
|
|
@@ -1,6 +1,19 @@
|
|
|
1
1
|
import { appendFileSync, existsSync, realpathSync, writeFileSync } from "node:fs";
|
|
2
2
|
import { join } from "node:path";
|
|
3
3
|
import { copyDirectory, directoriesMatch, } from "./lib/build-plan-edit-utils.js";
|
|
4
|
+
/**
|
|
5
|
+
* Stable Build Plan editing rules shared verbatim by every prompt that edits a
|
|
6
|
+
* Build Plan package — the from-scratch authoring prompt
|
|
7
|
+
* (`build-plan-authoring.ts`) and the validation-repair prompt below. Defined
|
|
8
|
+
* once so the wording cannot drift between the two prompts. Each entry is the
|
|
9
|
+
* bare rule text; the repair prompt renders it as a `- ` bullet, the authoring
|
|
10
|
+
* prompt renders it as a plain line.
|
|
11
|
+
*/
|
|
12
|
+
export const SHARED_BUILD_PLAN_EDIT_RULES = [
|
|
13
|
+
"Use kebab-case ids everywhere: stage ids, skill_dir values, requested output ids, reads/writes values, and package ids. Never use underscores.",
|
|
14
|
+
"Use `runtime/authoring-context.json.check_param_contracts` as the exact parameter contract for each check kind.",
|
|
15
|
+
"Every deterministic diagnostic must include a human-readable `description` that names the user's assertion; keep `kind` and `params` as the machine evaluator and never as user copy.",
|
|
16
|
+
];
|
|
4
17
|
export async function runBuildPlanEditSession(options) {
|
|
5
18
|
const editableBuildPlanPath = join(options.shell.rootPath, "build-plan");
|
|
6
19
|
copyDirectory(options.buildPlanPath, options.shell.buildPlanBeforePath);
|
|
@@ -17,6 +30,7 @@ export async function runBuildPlanEditSession(options) {
|
|
|
17
30
|
code = await options.executor.execute(options.shell.rootPath, prompt, {
|
|
18
31
|
eventLogPath: options.shell.eventLogPath,
|
|
19
32
|
statusLogPath: options.shell.statusLogPath,
|
|
33
|
+
reasoningLogPath: options.shell.reasoningLogPath,
|
|
20
34
|
completionCheck: () => {
|
|
21
35
|
try {
|
|
22
36
|
if (directoriesMatch(options.shell.buildPlanBeforePath, editableBuildPlanPath))
|
|
@@ -94,12 +108,21 @@ export async function runBuildPlanEditSession(options) {
|
|
|
94
108
|
"",
|
|
95
109
|
"Rules:",
|
|
96
110
|
"- Edit only files under `build-plan/`.",
|
|
97
|
-
|
|
111
|
+
// Stable kebab-case-id rule (shared with the authoring prompt).
|
|
112
|
+
`- ${SHARED_BUILD_PLAN_EDIT_RULES[0]}`,
|
|
113
|
+
"- Stage `reads` may only contain requested output ids declared in `build-plan.schema.json` and produced by an earlier stage. Source files are implicit input; never use `source` or source paths in `reads`.",
|
|
114
|
+
"- Keep coverage expectations, requested outputs, and backed output ids aligned with the Project intent.",
|
|
115
|
+
"- If `runtime/authoring-context.json.artifact_requirements[]` is non-empty, copy every required output `id`, `shape`, and `checks[]` exactly into `build-plan.schema.json`.",
|
|
116
|
+
"- Do not rename, move, merge, split, or reinterpret required outputs while repairing validation errors.",
|
|
98
117
|
"- Keep every stage `skill_dir` matched by `build-plan/build/stages/<skill_dir>/SKILL.md`.",
|
|
99
|
-
"- Keep `build-plan.schema.json`
|
|
100
|
-
"-
|
|
118
|
+
"- Keep `build-plan.schema.json` requested output paths unique. Child outputs may live under the required layer directories `summaries/`, `knowledge/`, and `artifacts/`; unrelated output paths must not overlap.",
|
|
119
|
+
"- Keep deterministic validation on requested output `checks[]` minimal; do not add stage `acceptance` blocks.",
|
|
101
120
|
"- Use only CheckKind values listed in `runtime/authoring-context.json`; replace invented aliases with valid kinds.",
|
|
102
|
-
|
|
121
|
+
// Stable check-param-contract + diagnostic-description rules (shared with
|
|
122
|
+
// the authoring prompt).
|
|
123
|
+
`- ${SHARED_BUILD_PLAN_EDIT_RULES[1]}`,
|
|
124
|
+
`- ${SHARED_BUILD_PLAN_EDIT_RULES[2]}`,
|
|
125
|
+
"- If the Build Plan writes a graph index, keep it declared as a requested output owned by the producing stage.",
|
|
103
126
|
"- Stop as soon as the package should validate.",
|
|
104
127
|
].join("\n");
|
|
105
128
|
appendFileSync(options.shell.promptLogPath, `\n\n---\n\n${prompt}\n`);
|
|
@@ -1,8 +1,7 @@
|
|
|
1
|
-
import type { AgentExecutor } from "../../
|
|
1
|
+
import type { AgentExecutor } from "../../runtime/agents/lib/executors.js";
|
|
2
2
|
import { type BuildPlanValidationResult } from "../package/local-build-plans.js";
|
|
3
|
-
import type {
|
|
4
|
-
|
|
5
|
-
export interface BuildPlanImprovementRunResult {
|
|
3
|
+
import type { BuildPlanImprovementLoopSummary } from "../../runtime/build/lib/schema.js";
|
|
4
|
+
interface BuildPlanImprovementRunResult {
|
|
6
5
|
status: "updated" | "no-change" | "invalid" | "executor-failed";
|
|
7
6
|
changed: boolean;
|
|
8
7
|
validation: BuildPlanValidationResult | null;
|
|
@@ -12,12 +11,16 @@ export interface BuildPlanImprovementRunResult {
|
|
|
12
11
|
}
|
|
13
12
|
export declare function runBuildPlanImprovementLoop(options: {
|
|
14
13
|
executor: AgentExecutor;
|
|
15
|
-
|
|
14
|
+
contextGraphPath: string;
|
|
16
15
|
buildPlanId: string;
|
|
17
|
-
|
|
16
|
+
benchmarkChecks: Array<{
|
|
17
|
+
id: string;
|
|
18
|
+
question: string;
|
|
19
|
+
}>;
|
|
18
20
|
runId: string;
|
|
19
21
|
loopIndex: number;
|
|
20
22
|
maxLoops: number;
|
|
21
23
|
maxAttempts: number;
|
|
22
24
|
previousVariations: BuildPlanImprovementLoopSummary[];
|
|
23
25
|
}): Promise<BuildPlanImprovementRunResult>;
|
|
26
|
+
export {};
|
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
import { appendFileSync, existsSync, mkdirSync, writeFileSync, } from "node:fs";
|
|
2
2
|
import { join, relative } from "node:path";
|
|
3
|
-
import { createBuildPlanImprovementShell, freezeBuildPlanImprovementShell, } from "../../
|
|
4
|
-
import { validateBuildPlanPackage } from "../package/local-build-plans.js";
|
|
3
|
+
import { createBuildPlanImprovementShell, freezeBuildPlanImprovementShell, } from "../../runtime/agents/lib/shells.js";
|
|
5
4
|
import { CONTEXT_INTERFACE_FILE } from "../package/context-interface.js";
|
|
6
5
|
import { readJsonFileWithSchema } from "../../contracts/utils/parse.js";
|
|
7
6
|
import { resolveBuildPlanImprovementReviewPaths } from "../package/build-plan-review-paths.js";
|
|
8
|
-
import {
|
|
9
|
-
import { readInterfConfig } from "../../
|
|
10
|
-
import {
|
|
11
|
-
import {
|
|
7
|
+
import { targetTestRunsRootForContextGraph, targetTestSandboxesRootForContextGraph, buildPlanImprovementRunRoot, buildPlanPackagePathForContextGraph, } from "../../runtime/build/context-graph-paths.js";
|
|
8
|
+
import { readInterfConfig, resolveSourceFolderPath } from "../../projects/interf.js";
|
|
9
|
+
import { scanSourceContext } from "../../runtime/agents/lib/source-context-scan.js";
|
|
10
|
+
import { saveContextGraphInterfConfig } from "../../projects/source-config.js";
|
|
11
|
+
import { BuildPlanImprovementRunLedgerSchema, } from "../../runtime/build/lib/schema.js";
|
|
12
12
|
import { runBuildPlanEditSession } from "./build-plan-edit-session.js";
|
|
13
|
-
import { ensureStageRoles } from "./build-plan-authoring.js";
|
|
13
|
+
import { ensureStageRoles, validateImproveTailoringNonRegression, validateLifecycleBuildPlanPackage, } from "./build-plan-authoring.js";
|
|
14
14
|
function toShellArtifactPath(absolutePath, sourceRoot, shellRoot) {
|
|
15
15
|
if (!absolutePath)
|
|
16
16
|
return null;
|
|
@@ -21,39 +21,61 @@ function toShellArtifactPath(absolutePath, sourceRoot, shellRoot) {
|
|
|
21
21
|
const relativePath = relative(sourceRoot, absolutePath);
|
|
22
22
|
return join(shellRoot, relativePath);
|
|
23
23
|
}
|
|
24
|
-
function mapLoopSummaryForShell(summary,
|
|
24
|
+
function mapLoopSummaryForShell(summary, contextGraphPath) {
|
|
25
25
|
const shellTestRunsRoot = "artifacts/test-runs";
|
|
26
26
|
const shellTestSandboxesRoot = "artifacts/test-sandboxes";
|
|
27
27
|
return {
|
|
28
28
|
...summary,
|
|
29
|
-
test_run_path: toShellArtifactPath(summary.test_run_path,
|
|
30
|
-
test_sandbox_path: toShellArtifactPath(summary.test_sandbox_path,
|
|
29
|
+
test_run_path: toShellArtifactPath(summary.test_run_path, targetTestRunsRootForContextGraph(contextGraphPath), shellTestRunsRoot) ?? summary.test_run_path ?? null,
|
|
30
|
+
test_sandbox_path: toShellArtifactPath(summary.test_sandbox_path, targetTestSandboxesRootForContextGraph(contextGraphPath), shellTestSandboxesRoot) ?? summary.test_sandbox_path ?? null,
|
|
31
31
|
};
|
|
32
32
|
}
|
|
33
33
|
function buildLoopContext(options) {
|
|
34
|
-
const previousVariations = options.previousVariations.map((summary) => mapLoopSummaryForShell(summary, options.
|
|
34
|
+
const previousVariations = options.previousVariations.map((summary) => mapLoopSummaryForShell(summary, options.contextGraphPath));
|
|
35
35
|
const latestFailure = previousVariations.at(-1) ?? null;
|
|
36
36
|
return {
|
|
37
37
|
kind: "interf-build-plan-improvement-loop",
|
|
38
38
|
version: 1,
|
|
39
39
|
generated_at: new Date().toISOString(),
|
|
40
|
-
target_name: readInterfConfig(options.
|
|
40
|
+
target_name: readInterfConfig(options.contextGraphPath)?.name ?? "context-graph",
|
|
41
41
|
build_plan_id: options.buildPlanId,
|
|
42
42
|
loop_index: options.loopIndex,
|
|
43
43
|
max_loops: options.maxLoops,
|
|
44
44
|
max_attempts: options.maxAttempts,
|
|
45
|
-
review_paths: resolveBuildPlanImprovementReviewPaths(options.
|
|
46
|
-
|
|
47
|
-
count: options.
|
|
48
|
-
questions: options.
|
|
49
|
-
id: check.id ?? `check-${index + 1}`,
|
|
50
|
-
question: check.question,
|
|
51
|
-
})),
|
|
45
|
+
review_paths: resolveBuildPlanImprovementReviewPaths(options.contextGraphPath),
|
|
46
|
+
benchmark_questions: {
|
|
47
|
+
count: options.benchmarkChecks.length,
|
|
48
|
+
questions: options.benchmarkChecks,
|
|
52
49
|
},
|
|
53
50
|
previous_variations: previousVariations,
|
|
54
51
|
latest_failure: latestFailure,
|
|
55
52
|
};
|
|
56
53
|
}
|
|
54
|
+
/**
|
|
55
|
+
* Resolve the SAME cheap, contents-free Source inventory the draft path scans,
|
|
56
|
+
* but from the Context Graph the improvement loop is editing. The Context
|
|
57
|
+
* Graph's `interf.json` carries the Project's Source binding, so the improve
|
|
58
|
+
* path CAN reach the Source (`resolveSourceFolderPath` → `scanSourceContext`)
|
|
59
|
+
* exactly like the draft path does — it is not blind to the Source.
|
|
60
|
+
*
|
|
61
|
+
* Returns null (and the tailoring non-regression guard becomes a no-op) only
|
|
62
|
+
* when there is genuinely nothing to scan: no Source binding in the config, or
|
|
63
|
+
* the Source has no readable files. A null here never fabricates an inventory.
|
|
64
|
+
*/
|
|
65
|
+
function resolveImproveSourceContext(contextGraphPath) {
|
|
66
|
+
const config = readInterfConfig(contextGraphPath);
|
|
67
|
+
let sourceFolderPath;
|
|
68
|
+
try {
|
|
69
|
+
sourceFolderPath = resolveSourceFolderPath(contextGraphPath, config);
|
|
70
|
+
}
|
|
71
|
+
catch {
|
|
72
|
+
// No Source binding in the Context Graph config — nothing to tailor
|
|
73
|
+
// against. The draft path always has a Source folder; the improve path may
|
|
74
|
+
// run against a Context Graph whose binding is missing, so degrade quietly.
|
|
75
|
+
return null;
|
|
76
|
+
}
|
|
77
|
+
return scanSourceContext(sourceFolderPath) ?? null;
|
|
78
|
+
}
|
|
57
79
|
function buildBuildPlanImprovementPrompt() {
|
|
58
80
|
return [
|
|
59
81
|
"This is an automated Interf Build Plan improvement run, not an open-ended chat session.",
|
|
@@ -62,12 +84,12 @@ function buildBuildPlanImprovementPrompt() {
|
|
|
62
84
|
`Then read \`build-plan/README.md\`, \`build-plan/build-plan.json\`, \`build-plan/${CONTEXT_INTERFACE_FILE}\`, and \`build-plan/improve/SKILL.md\` if it exists.`,
|
|
63
85
|
"Review preserved evidence from earlier failures under `artifacts/` before you edit the Build Plan.",
|
|
64
86
|
"Treat `build-plan/improve/SKILL.md` as guidance for how to improve the Build Plan, not as the default file to edit.",
|
|
65
|
-
"Treat the Build Plan package as four aligned layers: purpose, inputs,
|
|
66
|
-
"Prefer editing the stage docs, Build Plan contract, input contract, or
|
|
87
|
+
"Treat the Build Plan package as four aligned layers: purpose, inputs, requested output contract, and stages.",
|
|
88
|
+
"Prefer editing the stage docs, Build Plan contract, input contract, or requested output ownership that actually change graph outputs.",
|
|
67
89
|
"Edit only files under `build-plan/`.",
|
|
68
|
-
"Do not edit checks,
|
|
90
|
+
"Do not edit checks, benchmark specs, source files, or generated requested outputs.",
|
|
69
91
|
"Keep the Build Plan package valid for the current build API and `build-plan.schema.json`.",
|
|
70
|
-
"Respect stage boundaries: a stage may only introduce links that resolve within that stage's declared writes or already-existing read
|
|
92
|
+
"Respect stage boundaries: a stage may only introduce links that resolve within that stage's declared writes or already-existing read outputs.",
|
|
71
93
|
"Do not make one stage point at files or notes that are only created later by another stage.",
|
|
72
94
|
"Prefer small, defensible changes to Build Plan docs, stage docs, stage policies, or schema ownership over random churn.",
|
|
73
95
|
"Do not narrate plans or ask follow-up questions.",
|
|
@@ -76,7 +98,7 @@ function buildBuildPlanImprovementPrompt() {
|
|
|
76
98
|
].join("\n");
|
|
77
99
|
}
|
|
78
100
|
function updateBuildPlanOrigin(options) {
|
|
79
|
-
const current = readInterfConfig(options.
|
|
101
|
+
const current = readInterfConfig(options.contextGraphPath);
|
|
80
102
|
if (!current)
|
|
81
103
|
return;
|
|
82
104
|
const nextConfig = {
|
|
@@ -86,27 +108,27 @@ function updateBuildPlanOrigin(options) {
|
|
|
86
108
|
...(options.localDraft ? { local_draft: true } : {}),
|
|
87
109
|
},
|
|
88
110
|
};
|
|
89
|
-
|
|
111
|
+
saveContextGraphInterfConfig(options.contextGraphPath, nextConfig);
|
|
90
112
|
}
|
|
91
|
-
function buildPlanImprovementRunLedgerPath(
|
|
92
|
-
return join(buildPlanImprovementRunRoot(
|
|
113
|
+
function buildPlanImprovementRunLedgerPath(contextGraphPath, runId) {
|
|
114
|
+
return join(buildPlanImprovementRunRoot(contextGraphPath, runId), "run.json");
|
|
93
115
|
}
|
|
94
|
-
function buildPlanImprovementLoopHistoryPath(
|
|
95
|
-
return join(buildPlanImprovementRunRoot(
|
|
116
|
+
function buildPlanImprovementLoopHistoryPath(contextGraphPath, runId) {
|
|
117
|
+
return join(buildPlanImprovementRunRoot(contextGraphPath, runId), "loop-history.jsonl");
|
|
96
118
|
}
|
|
97
119
|
function buildPlanImprovementLoopRecordPath(loopRootPath) {
|
|
98
120
|
return join(loopRootPath, "loop.json");
|
|
99
121
|
}
|
|
100
|
-
function readBuildPlanImprovementRunLedger(
|
|
101
|
-
const ledgerPath = buildPlanImprovementRunLedgerPath(
|
|
122
|
+
function readBuildPlanImprovementRunLedger(contextGraphPath, runId) {
|
|
123
|
+
const ledgerPath = buildPlanImprovementRunLedgerPath(contextGraphPath, runId);
|
|
102
124
|
if (!existsSync(ledgerPath))
|
|
103
125
|
return null;
|
|
104
126
|
return readJsonFileWithSchema(ledgerPath, "Build Plan improvement run ledger", BuildPlanImprovementRunLedgerSchema);
|
|
105
127
|
}
|
|
106
|
-
function writeBuildPlanImprovementRunLedger(
|
|
107
|
-
const runRoot = buildPlanImprovementRunRoot(
|
|
128
|
+
function writeBuildPlanImprovementRunLedger(contextGraphPath, runId, record, options) {
|
|
129
|
+
const runRoot = buildPlanImprovementRunRoot(contextGraphPath, runId);
|
|
108
130
|
mkdirSync(runRoot, { recursive: true });
|
|
109
|
-
const existing = readBuildPlanImprovementRunLedger(
|
|
131
|
+
const existing = readBuildPlanImprovementRunLedger(contextGraphPath, runId);
|
|
110
132
|
const generatedAt = existing?.generated_at ?? new Date().toISOString();
|
|
111
133
|
const ledger = {
|
|
112
134
|
kind: "interf-build-plan-improvement-run",
|
|
@@ -120,9 +142,9 @@ function writeBuildPlanImprovementRunLedger(verifiableContextPath, runId, record
|
|
|
120
142
|
max_attempts: options.maxAttempts,
|
|
121
143
|
loops: [...(existing?.loops ?? []), record],
|
|
122
144
|
};
|
|
123
|
-
writeFileSync(buildPlanImprovementRunLedgerPath(
|
|
145
|
+
writeFileSync(buildPlanImprovementRunLedgerPath(contextGraphPath, runId), `${JSON.stringify(ledger, null, 2)}\n`);
|
|
124
146
|
writeFileSync(buildPlanImprovementLoopRecordPath(record.loop_root_path), `${JSON.stringify(record, null, 2)}\n`);
|
|
125
|
-
appendFileSync(buildPlanImprovementLoopHistoryPath(
|
|
147
|
+
appendFileSync(buildPlanImprovementLoopHistoryPath(contextGraphPath, runId), `${JSON.stringify(record)}\n`);
|
|
126
148
|
}
|
|
127
149
|
function buildBuildPlanImprovementLoopRecord(options) {
|
|
128
150
|
return {
|
|
@@ -145,38 +167,67 @@ function buildBuildPlanImprovementLoopRecord(options) {
|
|
|
145
167
|
prompt_log_path: options.promptLogPath,
|
|
146
168
|
event_log_path: options.eventLogPath,
|
|
147
169
|
status_log_path: options.statusLogPath,
|
|
170
|
+
// Same canonical location the shell teed reasoning to and the freeze
|
|
171
|
+
// preserved (derived from shell_path, like context_path above).
|
|
172
|
+
reasoning_path: join(options.shellPath, "runtime", "agent-reasoning.jsonl"),
|
|
148
173
|
preserved_shell_manifest_path: options.preservedShellManifestPath,
|
|
149
174
|
validation: options.validation,
|
|
150
175
|
};
|
|
151
176
|
}
|
|
152
177
|
export async function runBuildPlanImprovementLoop(options) {
|
|
153
|
-
const
|
|
178
|
+
const contextGraphName = readInterfConfig(options.contextGraphPath)?.name ?? "context-graph";
|
|
154
179
|
const context = buildLoopContext(options);
|
|
155
180
|
const shell = createBuildPlanImprovementShell({
|
|
156
|
-
|
|
157
|
-
|
|
181
|
+
contextGraphPath: options.contextGraphPath,
|
|
182
|
+
contextGraphName,
|
|
158
183
|
buildPlanId: options.buildPlanId,
|
|
159
184
|
runId: options.runId,
|
|
160
185
|
loopIndex: options.loopIndex,
|
|
161
186
|
context,
|
|
162
187
|
});
|
|
163
|
-
const buildPlanRoot =
|
|
188
|
+
const buildPlanRoot = buildPlanPackagePathForContextGraph(options.contextGraphPath);
|
|
189
|
+
// Scan the Source ONCE (from the Context Graph's own binding) so the tailoring
|
|
190
|
+
// non-regression guard below compares before/after against one stable
|
|
191
|
+
// inventory. Null when there is no Source binding or no readable files, which
|
|
192
|
+
// makes that guard a no-op.
|
|
193
|
+
const improveSourceContext = resolveImproveSourceContext(options.contextGraphPath);
|
|
164
194
|
const session = await runBuildPlanEditSession({
|
|
165
195
|
executor: options.executor,
|
|
166
196
|
buildPlanPath: buildPlanRoot,
|
|
167
197
|
shell,
|
|
168
198
|
prompt: buildBuildPlanImprovementPrompt(),
|
|
169
|
-
|
|
199
|
+
// Run the SHARED lifecycle validator (base + product-critical backlink and
|
|
200
|
+
// canonical-top-level-layer invariants), PLUS a tailoring non-regression
|
|
201
|
+
// delta. An improvement edit must not silently strip those invariants, and
|
|
202
|
+
// — closing the original C1 gap — it must not DE-TAILOR a plan that was
|
|
203
|
+
// tailored to the Source back to a generic skeleton. The scaffold-removal,
|
|
204
|
+
// artifact-requirement, and ABSOLUTE tailoring guards stay authoring-only
|
|
205
|
+
// (draft-time concerns); the improve path enforces the non-regression delta
|
|
206
|
+
// so it never false-rejects a faithful improvement to a generic-by-design
|
|
207
|
+
// plan such as `interf-default`.
|
|
208
|
+
validate: (afterBuildPlanPath) => {
|
|
209
|
+
const lifecycle = validateLifecycleBuildPlanPackage(afterBuildPlanPath);
|
|
210
|
+
const tailoringErrors = validateImproveTailoringNonRegression(shell.buildPlanBeforePath, afterBuildPlanPath, improveSourceContext);
|
|
211
|
+
if (tailoringErrors.length === 0)
|
|
212
|
+
return lifecycle;
|
|
213
|
+
const errors = [...lifecycle.errors, ...tailoringErrors];
|
|
214
|
+
return {
|
|
215
|
+
ok: false,
|
|
216
|
+
summary: `Build Plan package has ${errors.length} issue(s).`,
|
|
217
|
+
errors,
|
|
218
|
+
counts: lifecycle.counts,
|
|
219
|
+
};
|
|
220
|
+
},
|
|
170
221
|
maxValidationRepairAttempts: 1,
|
|
171
222
|
});
|
|
172
223
|
if (session.status === "updated") {
|
|
173
|
-
//
|
|
224
|
+
// fill role=general on any stage the improvement run
|
|
174
225
|
// dropped a role from. Idempotent and silent when complete.
|
|
175
226
|
ensureStageRoles(buildPlanRoot);
|
|
176
227
|
}
|
|
177
228
|
const preservedShellManifestPath = freezeBuildPlanImprovementShell(shell.rootPath);
|
|
178
|
-
writeBuildPlanImprovementRunLedger(options.
|
|
179
|
-
targetName:
|
|
229
|
+
writeBuildPlanImprovementRunLedger(options.contextGraphPath, options.runId, buildBuildPlanImprovementLoopRecord({
|
|
230
|
+
targetName: contextGraphName,
|
|
180
231
|
buildPlanId: options.buildPlanId,
|
|
181
232
|
runId: options.runId,
|
|
182
233
|
loopIndex: options.loopIndex,
|
|
@@ -193,14 +244,14 @@ export async function runBuildPlanImprovementLoop(options) {
|
|
|
193
244
|
result: session.status,
|
|
194
245
|
summary: session.summary,
|
|
195
246
|
}), {
|
|
196
|
-
targetName:
|
|
247
|
+
targetName: contextGraphName,
|
|
197
248
|
buildPlanId: options.buildPlanId,
|
|
198
249
|
maxLoops: options.maxLoops,
|
|
199
250
|
maxAttempts: options.maxAttempts,
|
|
200
251
|
});
|
|
201
252
|
if (session.status === "updated") {
|
|
202
253
|
updateBuildPlanOrigin({
|
|
203
|
-
|
|
254
|
+
contextGraphPath: options.contextGraphPath,
|
|
204
255
|
selectedBuildPlanId: options.buildPlanId,
|
|
205
256
|
localDraft: true,
|
|
206
257
|
});
|
|
@@ -5,10 +5,10 @@ export function copyDirectory(sourcePath, targetPath) {
|
|
|
5
5
|
mkdirSync(targetPath, { recursive: true });
|
|
6
6
|
cpSync(sourcePath, targetPath, { recursive: true });
|
|
7
7
|
}
|
|
8
|
-
function
|
|
9
|
-
const
|
|
8
|
+
function listFileState(dirPath) {
|
|
9
|
+
const fileState = new Map();
|
|
10
10
|
if (!existsSync(dirPath))
|
|
11
|
-
return
|
|
11
|
+
return fileState;
|
|
12
12
|
const collect = (currentPath) => {
|
|
13
13
|
for (const entry of readdirSync(currentPath)) {
|
|
14
14
|
const fullPath = join(currentPath, entry);
|
|
@@ -19,15 +19,15 @@ function listFileSnapshot(dirPath) {
|
|
|
19
19
|
}
|
|
20
20
|
if (!stat.isFile())
|
|
21
21
|
continue;
|
|
22
|
-
|
|
22
|
+
fileState.set(relative(dirPath, fullPath), readFileSync(fullPath, "utf8"));
|
|
23
23
|
}
|
|
24
24
|
};
|
|
25
25
|
collect(dirPath);
|
|
26
|
-
return
|
|
26
|
+
return fileState;
|
|
27
27
|
}
|
|
28
28
|
export function directoriesMatch(leftPath, rightPath) {
|
|
29
|
-
const left =
|
|
30
|
-
const right =
|
|
29
|
+
const left = listFileState(leftPath);
|
|
30
|
+
const right = listFileState(rightPath);
|
|
31
31
|
if (left.size !== right.size)
|
|
32
32
|
return false;
|
|
33
33
|
for (const [relativePath, content] of left.entries()) {
|
|
@@ -2,5 +2,5 @@ export declare const DEFAULT_BUILD_PLAN_ID = "interf-default";
|
|
|
2
2
|
export interface BuildPlanSelectionLike {
|
|
3
3
|
build_plan?: string | null;
|
|
4
4
|
}
|
|
5
|
-
export declare function
|
|
5
|
+
export declare function buildPlanIdForProjectConfig(projectConfig: BuildPlanSelectionLike | null | undefined): string | null;
|
|
6
6
|
export declare function resolveBuildPlanId(selection: BuildPlanSelectionLike | null | undefined, fallback?: string): string;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
export const DEFAULT_BUILD_PLAN_ID = "interf-default";
|
|
2
|
-
export function
|
|
3
|
-
return
|
|
2
|
+
export function buildPlanIdForProjectConfig(projectConfig) {
|
|
3
|
+
return projectConfig?.build_plan ?? null;
|
|
4
4
|
}
|
|
5
5
|
export function resolveBuildPlanId(selection, fallback = DEFAULT_BUILD_PLAN_ID) {
|
|
6
|
-
return
|
|
6
|
+
return buildPlanIdForProjectConfig(selection) ?? fallback;
|
|
7
7
|
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export * as buildPlanResolution from "./build-plan-resolution.js";
|
|
2
|
-
export { DEFAULT_BUILD_PLAN_ID,
|
|
2
|
+
export { DEFAULT_BUILD_PLAN_ID, buildPlanIdForProjectConfig, resolveBuildPlanId, } from "./build-plan-resolution.js";
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export * as buildPlanResolution from "./build-plan-resolution.js";
|
|
2
|
-
export { DEFAULT_BUILD_PLAN_ID,
|
|
2
|
+
export { DEFAULT_BUILD_PLAN_ID, buildPlanIdForProjectConfig, resolveBuildPlanId, } from "./build-plan-resolution.js";
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { type LocalBuildPlanDefinition } from "./local-build-plans.js";
|
|
2
|
-
import type {
|
|
2
|
+
import type { BuildPlanRuntimeApi } from "../../runtime/build/lib/schema.js";
|
|
3
3
|
import type { BuildPlanId, RuntimeContractType } from "../../contracts/lib/schema.js";
|
|
4
4
|
import { type ContextInterface, type ContextInterfaceArtifactId, type BuildPlanInputSpec } from "./context-interface.js";
|
|
5
|
+
import type { BuildPlanAuthoringBrief } from "../authoring/brief.js";
|
|
5
6
|
export interface BuildPlanStarterDoc {
|
|
6
7
|
relativePath: string;
|
|
7
8
|
content: string;
|
|
@@ -23,17 +24,17 @@ export interface BuildPlanStageDefinition {
|
|
|
23
24
|
}
|
|
24
25
|
export interface BuildPlanDefinition<TId extends string> {
|
|
25
26
|
id: TId;
|
|
26
|
-
|
|
27
|
+
runtimeApi?: BuildPlanRuntimeApi;
|
|
27
28
|
purpose?: {
|
|
28
29
|
label: string;
|
|
29
30
|
taskHint: string;
|
|
30
31
|
};
|
|
32
|
+
brief?: BuildPlanAuthoringBrief;
|
|
31
33
|
inputs?: BuildPlanInputSpec[];
|
|
32
34
|
label: string;
|
|
33
35
|
hint: string;
|
|
34
36
|
recommended?: boolean;
|
|
35
37
|
contextInterface?: ContextInterface;
|
|
36
|
-
schema?: ContextInterface;
|
|
37
38
|
stages: BuildPlanStageDefinition[];
|
|
38
39
|
stagePolicyNotes?: Record<string, string[]>;
|
|
39
40
|
starterDocs?: BuildPlanStarterDoc[];
|
|
@@ -41,21 +42,21 @@ export interface BuildPlanDefinition<TId extends string> {
|
|
|
41
42
|
}
|
|
42
43
|
export type ResolvedBuildPlanId = string;
|
|
43
44
|
export declare function standaloneBuildPlanDefinitionFromLocalPackage(local: LocalBuildPlanDefinition): BuildPlanDefinition<string>;
|
|
44
|
-
export declare function listBuildPlanChoices(
|
|
45
|
+
export declare function listBuildPlanChoices(projectDataDir?: string): BuildPlanDefinition<string>[];
|
|
45
46
|
export declare function getBuildPlan(buildPlanId: ResolvedBuildPlanId, options?: {
|
|
46
|
-
|
|
47
|
+
projectDataDir?: string;
|
|
47
48
|
}): BuildPlanDefinition<string>;
|
|
48
|
-
export declare function getActiveBuildPlan(
|
|
49
|
-
export declare function
|
|
49
|
+
export declare function getActiveBuildPlan(contextGraphPath: string): BuildPlanDefinition<string>;
|
|
50
|
+
export declare function resolveContextGraphBuildPlanId(value: unknown): ResolvedBuildPlanId | null;
|
|
50
51
|
export declare function resolveBuildPlanFromConfig(config: unknown): ResolvedBuildPlanId | null;
|
|
51
52
|
export declare function resolveRequiredBuildPlanFromConfig(config: unknown, label?: string): ResolvedBuildPlanId;
|
|
52
|
-
export declare function getBuildPlanStageDefinition(buildPlanId: BuildPlanId, stage: string,
|
|
53
|
-
export declare function getBuildPlanStagePosition(buildPlanId: BuildPlanId, stage: string,
|
|
53
|
+
export declare function getBuildPlanStageDefinition(buildPlanId: BuildPlanId, stage: string, projectDataDir?: string): BuildPlanStageDefinition | null;
|
|
54
|
+
export declare function getBuildPlanStagePosition(buildPlanId: BuildPlanId, stage: string, projectDataDir?: string): {
|
|
54
55
|
stageIndex: number;
|
|
55
56
|
stageTotal: number;
|
|
56
57
|
stages: string[];
|
|
57
58
|
} | null;
|
|
58
|
-
export declare function getBuildPlanStages(buildPlanId: BuildPlanId,
|
|
59
|
-
export declare function getActiveBuildPlanStages(
|
|
60
|
-
export declare function getActiveBuildPlanStagePolicyNotes(
|
|
61
|
-
export declare function formatActiveBuildPlanStageLabel(
|
|
59
|
+
export declare function getBuildPlanStages(buildPlanId: BuildPlanId, projectDataDir?: string): string[];
|
|
60
|
+
export declare function getActiveBuildPlanStages(contextGraphPath: string): string[];
|
|
61
|
+
export declare function getActiveBuildPlanStagePolicyNotes(contextGraphPath: string, stage: string): string[];
|
|
62
|
+
export declare function formatActiveBuildPlanStageLabel(contextGraphPath: string, stage: string): string;
|