onto-mcp 0.3.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/.onto/authority/core-lens-registry.yaml +134 -0
- package/.onto/authority/core-lexicon.yaml +1562 -0
- package/.onto/authority/diagnostic-codes.yaml +94 -0
- package/.onto/domains/accounting/competency_qs.md +384 -0
- package/.onto/domains/accounting/concepts.md +186 -0
- package/.onto/domains/accounting/conciseness_rules.md +160 -0
- package/.onto/domains/accounting/dependency_rules.md +239 -0
- package/.onto/domains/accounting/domain_scope.md +213 -0
- package/.onto/domains/accounting/extension_cases.md +416 -0
- package/.onto/domains/accounting/logic_rules.md +226 -0
- package/.onto/domains/accounting/structure_spec.md +298 -0
- package/.onto/domains/accounting-kr/competency_qs.md +562 -0
- package/.onto/domains/accounting-kr/concepts.md +187 -0
- package/.onto/domains/accounting-kr/conciseness_rules.md +125 -0
- package/.onto/domains/accounting-kr/dependency_rules.md +93 -0
- package/.onto/domains/accounting-kr/domain_scope.md +140 -0
- package/.onto/domains/accounting-kr/extension_cases.md +343 -0
- package/.onto/domains/accounting-kr/logic_rules.md +160 -0
- package/.onto/domains/accounting-kr/structure_spec.md +85 -0
- package/.onto/domains/business/competency_qs.md +263 -0
- package/.onto/domains/business/concepts.md +200 -0
- package/.onto/domains/business/conciseness_rules.md +135 -0
- package/.onto/domains/business/dependency_rules.md +113 -0
- package/.onto/domains/business/domain_scope.md +240 -0
- package/.onto/domains/business/extension_cases.md +249 -0
- package/.onto/domains/business/logic_rules.md +134 -0
- package/.onto/domains/business/structure_spec.md +114 -0
- package/.onto/domains/finance/competency_qs.md +362 -0
- package/.onto/domains/finance/concepts.md +194 -0
- package/.onto/domains/finance/conciseness_rules.md +155 -0
- package/.onto/domains/finance/dependency_rules.md +171 -0
- package/.onto/domains/finance/domain_scope.md +215 -0
- package/.onto/domains/finance/extension_cases.md +350 -0
- package/.onto/domains/finance/logic_rules.md +191 -0
- package/.onto/domains/finance/structure_spec.md +182 -0
- package/.onto/domains/llm-native-development/competency_qs.md +430 -0
- package/.onto/domains/llm-native-development/concepts.md +242 -0
- package/.onto/domains/llm-native-development/conciseness_rules.md +163 -0
- package/.onto/domains/llm-native-development/dependency_rules.md +216 -0
- package/.onto/domains/llm-native-development/domain_scope.md +197 -0
- package/.onto/domains/llm-native-development/extension_cases.md +474 -0
- package/.onto/domains/llm-native-development/logic_rules.md +123 -0
- package/.onto/domains/llm-native-development/prompt_interface.md +49 -0
- package/.onto/domains/llm-native-development/structure_spec.md +245 -0
- package/.onto/domains/market-intelligence/competency_qs.md +274 -0
- package/.onto/domains/market-intelligence/concepts.md +233 -0
- package/.onto/domains/market-intelligence/conciseness_rules.md +165 -0
- package/.onto/domains/market-intelligence/dependency_rules.md +197 -0
- package/.onto/domains/market-intelligence/domain_scope.md +231 -0
- package/.onto/domains/market-intelligence/extension_cases.md +425 -0
- package/.onto/domains/market-intelligence/logic_rules.md +247 -0
- package/.onto/domains/market-intelligence/structure_spec.md +209 -0
- package/.onto/domains/ontology/competency_qs.md +394 -0
- package/.onto/domains/ontology/concepts.md +172 -0
- package/.onto/domains/ontology/conciseness_rules.md +134 -0
- package/.onto/domains/ontology/dependency_rules.md +125 -0
- package/.onto/domains/ontology/domain_scope.md +114 -0
- package/.onto/domains/ontology/extension_cases.md +501 -0
- package/.onto/domains/ontology/logic_rules.md +114 -0
- package/.onto/domains/ontology/problem_framing_profile.md +67 -0
- package/.onto/domains/ontology/structure_spec.md +115 -0
- package/.onto/domains/palantir-foundry/RESEARCH_NOTES.md +911 -0
- package/.onto/domains/palantir-foundry/competency_qs.md +191 -0
- package/.onto/domains/palantir-foundry/competitive_comparison.md +329 -0
- package/.onto/domains/palantir-foundry/concepts.md +197 -0
- package/.onto/domains/palantir-foundry/conciseness_rules.md +245 -0
- package/.onto/domains/palantir-foundry/dependency_rules.md +135 -0
- package/.onto/domains/palantir-foundry/domain_scope.md +395 -0
- package/.onto/domains/palantir-foundry/extension_cases.md +210 -0
- package/.onto/domains/palantir-foundry/logic_rules.md +172 -0
- package/.onto/domains/palantir-foundry/structure_spec.md +291 -0
- package/.onto/domains/software-engineering/competency_qs.md +538 -0
- package/.onto/domains/software-engineering/concepts.md +238 -0
- package/.onto/domains/software-engineering/conciseness_rules.md +167 -0
- package/.onto/domains/software-engineering/dependency_rules.md +216 -0
- package/.onto/domains/software-engineering/domain_scope.md +183 -0
- package/.onto/domains/software-engineering/extension_cases.md +551 -0
- package/.onto/domains/software-engineering/logic_rules.md +240 -0
- package/.onto/domains/software-engineering/problem_framing_profile.md +68 -0
- package/.onto/domains/software-engineering/structure_spec.md +185 -0
- package/.onto/domains/ui-design/competency_qs.md +567 -0
- package/.onto/domains/ui-design/concepts.md +194 -0
- package/.onto/domains/ui-design/conciseness_rules.md +190 -0
- package/.onto/domains/ui-design/dependency_rules.md +323 -0
- package/.onto/domains/ui-design/domain_scope.md +340 -0
- package/.onto/domains/ui-design/extension_cases.md +563 -0
- package/.onto/domains/ui-design/logic_rules.md +349 -0
- package/.onto/domains/ui-design/structure_spec.md +252 -0
- package/.onto/domains/visual-design/competency_qs.md +472 -0
- package/.onto/domains/visual-design/concepts.md +147 -0
- package/.onto/domains/visual-design/conciseness_rules.md +186 -0
- package/.onto/domains/visual-design/dependency_rules.md +282 -0
- package/.onto/domains/visual-design/domain_scope.md +290 -0
- package/.onto/domains/visual-design/extension_cases.md +480 -0
- package/.onto/domains/visual-design/logic_rules.md +232 -0
- package/.onto/domains/visual-design/structure_spec.md +213 -0
- package/.onto/principles/llm-native-development-guideline.md +401 -0
- package/.onto/principles/llm-runtime-interface-principles.md +665 -0
- package/.onto/principles/non-specialist-communication-guideline.md +74 -0
- package/.onto/principles/ontology-as-code-guideline.md +243 -0
- package/.onto/principles/ontology-as-code-naming-charter.md +130 -0
- package/.onto/principles/product-locality-principle.md +129 -0
- package/.onto/principles/productization-charter.md +569 -0
- package/.onto/processes/evolve/material-kind-adapter-contract.md +113 -0
- package/.onto/processes/reconstruct/reconstruct-boundary-contract.md +366 -0
- package/.onto/processes/reconstruct/source-profile-contract.md +107 -0
- package/.onto/processes/reconstruct/source-profiles/code.md +72 -0
- package/.onto/processes/reconstruct/source-profiles/database.md +74 -0
- package/.onto/processes/reconstruct/source-profiles/document.md +71 -0
- package/.onto/processes/reconstruct/source-profiles/spreadsheet.md +79 -0
- package/.onto/processes/review/binding-contract.md +270 -0
- package/.onto/processes/review/execution-preparation-artifacts.md +281 -0
- package/.onto/processes/review/interpretation-contract.md +245 -0
- package/.onto/processes/review/issue-stance-deliberation-contract.md +761 -0
- package/.onto/processes/review/lens-prompt-contract.md +402 -0
- package/.onto/processes/review/lens-registry.md +127 -0
- package/.onto/processes/review/pre-dispatch-contracts.md +428 -0
- package/.onto/processes/review/productized-live-path.md +398 -0
- package/.onto/processes/review/prompt-execution-runner-contract.md +187 -0
- package/.onto/processes/review/record-contract.md +427 -0
- package/.onto/processes/review/record-field-mapping.md +337 -0
- package/.onto/processes/review/review-context-manifest-contract.md +356 -0
- package/.onto/processes/review/review-execution-ux-contract.md +809 -0
- package/.onto/processes/review/review-target-profile-contract.md +259 -0
- package/.onto/processes/review/shared-phenomenon-contract.md +129 -0
- package/.onto/processes/review/synthesize-prompt-contract.md +343 -0
- package/.onto/processes/shared/target-material-kind-contract.md +198 -0
- package/.onto/roles/axiology.md +81 -0
- package/.onto/roles/conciseness.md +36 -0
- package/.onto/roles/coverage.md +34 -0
- package/.onto/roles/dependency.md +37 -0
- package/.onto/roles/evolution.md +35 -0
- package/.onto/roles/logic.md +104 -0
- package/.onto/roles/pragmatics.md +32 -0
- package/.onto/roles/semantics.md +36 -0
- package/.onto/roles/structure.md +33 -0
- package/.onto/roles/synthesize.md +92 -0
- package/AGENTS.md +240 -0
- package/CLAUDE.md +39 -0
- package/README.md +287 -0
- package/bin/onto +92 -0
- package/dist/cli.js +101 -0
- package/dist/core-api/reconstruct-api.js +222 -0
- package/dist/core-api/review-api.js +1271 -0
- package/dist/core-runtime/cli/assemble-review-record.js +431 -0
- package/dist/core-runtime/cli/bootstrap-review-binding.js +186 -0
- package/dist/core-runtime/cli/codex-nested-dispatch.js +226 -0
- package/dist/core-runtime/cli/codex-nested-dispatch.test.js +390 -0
- package/dist/core-runtime/cli/codex-nested-teamlead-executor.js +464 -0
- package/dist/core-runtime/cli/codex-nested-teamlead-executor.test.js +335 -0
- package/dist/core-runtime/cli/codex-review-unit-executor.js +228 -0
- package/dist/core-runtime/cli/complete-review-session.js +64 -0
- package/dist/core-runtime/cli/complexity-assessment.js +153 -0
- package/dist/core-runtime/cli/coordinator-helpers.js +583 -0
- package/dist/core-runtime/cli/coordinator-state-machine-deliberation.test.js +167 -0
- package/dist/core-runtime/cli/coordinator-state-machine.js +794 -0
- package/dist/core-runtime/cli/e2e-codex-multi-agent-fixes.test.js +615 -0
- package/dist/core-runtime/cli/e2e-start-review-session.test.js +312 -0
- package/dist/core-runtime/cli/health.js +44 -0
- package/dist/core-runtime/cli/inline-http-review-unit-executor.js +656 -0
- package/dist/core-runtime/cli/inline-http-review-unit-executor.test.js +567 -0
- package/dist/core-runtime/cli/materialize-review-execution-preparation.js +104 -0
- package/dist/core-runtime/cli/materialize-review-prompt-packets.js +952 -0
- package/dist/core-runtime/cli/migrate-session-roots.js +118 -0
- package/dist/core-runtime/cli/mock-review-unit-executor.js +285 -0
- package/dist/core-runtime/cli/onto-tools.js +369 -0
- package/dist/core-runtime/cli/prepare-review-session.js +272 -0
- package/dist/core-runtime/cli/render-review-final-output.js +350 -0
- package/dist/core-runtime/cli/repo-layout-migration-replace.smoke.test.js +106 -0
- package/dist/core-runtime/cli/review-invoke-auto-resolution.test.js +268 -0
- package/dist/core-runtime/cli/review-invoke-coordinator-topology.test.js +136 -0
- package/dist/core-runtime/cli/review-invoke-resolver-caching.test.js +201 -0
- package/dist/core-runtime/cli/review-invoke-topology-dispatch.test.js +192 -0
- package/dist/core-runtime/cli/review-invoke.js +2030 -0
- package/dist/core-runtime/cli/run-review-prompt-execution.js +2152 -0
- package/dist/core-runtime/cli/session-root-guard.js +168 -0
- package/dist/core-runtime/cli/spawn-watcher.js +173 -0
- package/dist/core-runtime/cli/spawn-watcher.test.js +457 -0
- package/dist/core-runtime/cli/start-review-session.js +68 -0
- package/dist/core-runtime/cli/strip-wrapping-code-fence.js +56 -0
- package/dist/core-runtime/cli/strip-wrapping-code-fence.test.js +79 -0
- package/dist/core-runtime/cli/teamcreate-lens-deliberation-executor.js +412 -0
- package/dist/core-runtime/cli/teamcreate-lens-deliberation-executor.test.js +351 -0
- package/dist/core-runtime/cli/topology-executor-mapping.js +139 -0
- package/dist/core-runtime/cli/topology-executor-mapping.test.js +173 -0
- package/dist/core-runtime/cli/write-review-interpretation.js +81 -0
- package/dist/core-runtime/config/onto-config-cli.js +278 -0
- package/dist/core-runtime/config/onto-config-key-path.js +288 -0
- package/dist/core-runtime/config/onto-config-key-path.test.js +195 -0
- package/dist/core-runtime/config/onto-config-preview.js +108 -0
- package/dist/core-runtime/config/onto-config-preview.test.js +132 -0
- package/dist/core-runtime/discovery/config-chain.js +118 -0
- package/dist/core-runtime/discovery/config-chain.test.js +103 -0
- package/dist/core-runtime/discovery/config-profile.js +199 -0
- package/dist/core-runtime/discovery/config-profile.test.js +233 -0
- package/dist/core-runtime/discovery/host-detection.js +33 -0
- package/dist/core-runtime/discovery/host-detection.test.js +186 -0
- package/dist/core-runtime/discovery/installation-paths.js +21 -0
- package/dist/core-runtime/discovery/installation-paths.test.js +65 -0
- package/dist/core-runtime/discovery/lens-registry.js +60 -0
- package/dist/core-runtime/discovery/lens-registry.test.js +81 -0
- package/dist/core-runtime/discovery/onto-home.js +71 -0
- package/dist/core-runtime/discovery/path-normalization.js +28 -0
- package/dist/core-runtime/discovery/path-normalization.test.js +22 -0
- package/dist/core-runtime/discovery/plugin-path.js +72 -0
- package/dist/core-runtime/discovery/plugin-path.test.js +95 -0
- package/dist/core-runtime/discovery/project-root.js +47 -0
- package/dist/core-runtime/discovery/settings-chain.js +353 -0
- package/dist/core-runtime/discovery/walk-up.js +17 -0
- package/dist/core-runtime/evolve/adapters/code-product/compile/compile-defense.js +344 -0
- package/dist/core-runtime/evolve/adapters/code-product/compile/compile-defense.test.js +915 -0
- package/dist/core-runtime/evolve/adapters/code-product/compile/compile.js +564 -0
- package/dist/core-runtime/evolve/adapters/code-product/compile/compile.test.js +708 -0
- package/dist/core-runtime/evolve/adapters/code-product/parsers/brief-parser.js +165 -0
- package/dist/core-runtime/evolve/adapters/code-product/parsers/brief-parser.test.js +227 -0
- package/dist/core-runtime/evolve/adapters/code-product/validators/validate.js +59 -0
- package/dist/core-runtime/evolve/adapters/code-product/validators/validate.test.js +205 -0
- package/dist/core-runtime/evolve/adapters/methodology/adapter.js +16 -0
- package/dist/core-runtime/evolve/adapters/methodology/adapter.test.js +9 -0
- package/dist/core-runtime/evolve/adapters/methodology/perspectives/authority-consistency.js +298 -0
- package/dist/core-runtime/evolve/adapters/methodology/perspectives/authority-consistency.test.js +70 -0
- package/dist/core-runtime/evolve/adapters/methodology/scope-types/process.js +46 -0
- package/dist/core-runtime/evolve/adapters/methodology/scope-types/process.test.js +73 -0
- package/dist/core-runtime/evolve/adapters/registry.js +47 -0
- package/dist/core-runtime/evolve/adapters/registry.test.js +67 -0
- package/dist/core-runtime/evolve/cli.js +256 -0
- package/dist/core-runtime/evolve/commands/align.js +194 -0
- package/dist/core-runtime/evolve/commands/align.test.js +82 -0
- package/dist/core-runtime/evolve/commands/apply.js +161 -0
- package/dist/core-runtime/evolve/commands/apply.test.js +138 -0
- package/dist/core-runtime/evolve/commands/close.js +39 -0
- package/dist/core-runtime/evolve/commands/close.test.js +99 -0
- package/dist/core-runtime/evolve/commands/defer.js +40 -0
- package/dist/core-runtime/evolve/commands/defer.test.js +134 -0
- package/dist/core-runtime/evolve/commands/draft.js +323 -0
- package/dist/core-runtime/evolve/commands/draft.test.js +178 -0
- package/dist/core-runtime/evolve/commands/e2e-evolve-full-cycle.test.js +208 -0
- package/dist/core-runtime/evolve/commands/error-messages.js +125 -0
- package/dist/core-runtime/evolve/commands/error-messages.test.js +167 -0
- package/dist/core-runtime/evolve/commands/propose-align.js +222 -0
- package/dist/core-runtime/evolve/commands/propose-align.test.js +136 -0
- package/dist/core-runtime/evolve/commands/reconstruct.js +330 -0
- package/dist/core-runtime/evolve/commands/reconstruct.test.js +278 -0
- package/dist/core-runtime/evolve/commands/shared.js +22 -0
- package/dist/core-runtime/evolve/commands/stale-check.js +103 -0
- package/dist/core-runtime/evolve/commands/stale-check.test.js +84 -0
- package/dist/core-runtime/evolve/commands/start.js +887 -0
- package/dist/core-runtime/evolve/commands/start.test.js +396 -0
- package/dist/core-runtime/evolve/config/project-config.js +99 -0
- package/dist/core-runtime/evolve/config/project-config.test.js +170 -0
- package/dist/core-runtime/evolve/renderers/align-packet.js +280 -0
- package/dist/core-runtime/evolve/renderers/align-packet.test.js +332 -0
- package/dist/core-runtime/evolve/renderers/draft-packet.js +303 -0
- package/dist/core-runtime/evolve/renderers/draft-packet.test.js +377 -0
- package/dist/core-runtime/evolve/renderers/format.js +5 -0
- package/dist/core-runtime/evolve/renderers/scope-md.js +237 -0
- package/dist/core-runtime/evolve/renderers/scope-md.test.js +306 -0
- package/dist/core-runtime/govern/cli.js +369 -0
- package/dist/core-runtime/govern/cli.test.js +314 -0
- package/dist/core-runtime/govern/drift-engine.js +103 -0
- package/dist/core-runtime/govern/drift-engine.test.js +319 -0
- package/dist/core-runtime/govern/promote-principle.js +206 -0
- package/dist/core-runtime/govern/promote-principle.test.js +368 -0
- package/dist/core-runtime/govern/queue.js +81 -0
- package/dist/core-runtime/govern/types.js +16 -0
- package/dist/core-runtime/install/cli.js +530 -0
- package/dist/core-runtime/install/detect.js +128 -0
- package/dist/core-runtime/install/detect.test.js +155 -0
- package/dist/core-runtime/install/gitignore-update.js +74 -0
- package/dist/core-runtime/install/gitignore-update.test.js +64 -0
- package/dist/core-runtime/install/install-integration.test.js +373 -0
- package/dist/core-runtime/install/prompts.js +389 -0
- package/dist/core-runtime/install/prompts.test.js +293 -0
- package/dist/core-runtime/install/types.js +26 -0
- package/dist/core-runtime/install/validation.js +295 -0
- package/dist/core-runtime/install/validation.test.js +313 -0
- package/dist/core-runtime/install/writer.js +254 -0
- package/dist/core-runtime/install/writer.test.js +218 -0
- package/dist/core-runtime/learning/extractor.js +461 -0
- package/dist/core-runtime/learning/feedback.js +179 -0
- package/dist/core-runtime/learning/health-report.js +165 -0
- package/dist/core-runtime/learning/health-report.test.js +169 -0
- package/dist/core-runtime/learning/loader.js +388 -0
- package/dist/core-runtime/learning/loader.test.js +102 -0
- package/dist/core-runtime/learning/promote/apply-state.js +240 -0
- package/dist/core-runtime/learning/promote/audit-obligation.js +195 -0
- package/dist/core-runtime/learning/promote/collector.js +432 -0
- package/dist/core-runtime/learning/promote/degraded-state.js +125 -0
- package/dist/core-runtime/learning/promote/domain-doc-proposer.js +166 -0
- package/dist/core-runtime/learning/promote/e2e-promote.test.js +6385 -0
- package/dist/core-runtime/learning/promote/health-snapshot.js +150 -0
- package/dist/core-runtime/learning/promote/insight-reclassifier.js +544 -0
- package/dist/core-runtime/learning/promote/judgment-auditor.js +517 -0
- package/dist/core-runtime/learning/promote/panel-reviewer.js +1158 -0
- package/dist/core-runtime/learning/promote/promote-executor.js +1675 -0
- package/dist/core-runtime/learning/promote/promoter.js +307 -0
- package/dist/core-runtime/learning/promote/retirement.js +122 -0
- package/dist/core-runtime/learning/promote/types.js +23 -0
- package/dist/core-runtime/learning/prompt-sections.js +51 -0
- package/dist/core-runtime/learning/shared/artifact-registry-init.js +45 -0
- package/dist/core-runtime/learning/shared/artifact-registry.js +254 -0
- package/dist/core-runtime/learning/shared/audit-obligation-kernel.js +73 -0
- package/dist/core-runtime/learning/shared/audit-state.js +99 -0
- package/dist/core-runtime/learning/shared/duplicate-check.js +28 -0
- package/dist/core-runtime/learning/shared/llm-caller.js +831 -0
- package/dist/core-runtime/learning/shared/llm-caller.test.js +601 -0
- package/dist/core-runtime/learning/shared/llm-tool-loop.js +393 -0
- package/dist/core-runtime/learning/shared/mode.js +25 -0
- package/dist/core-runtime/learning/shared/paths.js +84 -0
- package/dist/core-runtime/learning/shared/paths.test.js +79 -0
- package/dist/core-runtime/learning/shared/patterns.js +37 -0
- package/dist/core-runtime/learning/shared/recoverability.js +355 -0
- package/dist/core-runtime/learning/shared/recovery-context.js +374 -0
- package/dist/core-runtime/learning/shared/scope.js +1 -0
- package/dist/core-runtime/learning/shared/semantic-classifier.js +94 -0
- package/dist/core-runtime/learning/shared/specs/apply-execution-state-spec.js +42 -0
- package/dist/core-runtime/learning/shared/specs/audit-state-spec.js +37 -0
- package/dist/core-runtime/learning/shared/specs/backup-metadata-spec.js +39 -0
- package/dist/core-runtime/learning/shared/specs/emergency-log-spec.js +41 -0
- package/dist/core-runtime/learning/shared/specs/layout-version-spec.js +38 -0
- package/dist/core-runtime/learning/shared/specs/promote-decisions-spec.js +43 -0
- package/dist/core-runtime/learning/shared/specs/promote-report-spec.js +113 -0
- package/dist/core-runtime/learning/shared/specs/prune-log-spec.js +36 -0
- package/dist/core-runtime/learning/shared/specs/recovery-resolution-spec.js +48 -0
- package/dist/core-runtime/learning/shared/specs/restore-manifest-spec.js +43 -0
- package/dist/core-runtime/learning/shared/specs/spec-helpers.js +64 -0
- package/dist/core-runtime/learning/usage-tracker.js +190 -0
- package/dist/core-runtime/learning/usage-tracker.test.js +176 -0
- package/dist/core-runtime/llm/llm-caller.js +649 -0
- package/dist/core-runtime/llm/llm-tool-loop.js +401 -0
- package/dist/core-runtime/llm/model-switcher.js +62 -0
- package/dist/core-runtime/logger.js +22 -0
- package/dist/core-runtime/onboard/detect-review-axes.js +122 -0
- package/dist/core-runtime/onboard/detect-review-axes.test.js +127 -0
- package/dist/core-runtime/onboard/write-review-block.js +188 -0
- package/dist/core-runtime/onboard/write-review-block.test.js +240 -0
- package/dist/core-runtime/readers/brownfield-builder.js +150 -0
- package/dist/core-runtime/readers/brownfield-builder.test.js +136 -0
- package/dist/core-runtime/readers/code-chunk-collector.js +53 -0
- package/dist/core-runtime/readers/code-chunk-collector.test.js +136 -0
- package/dist/core-runtime/readers/file-utils.js +240 -0
- package/dist/core-runtime/readers/file-utils.test.js +146 -0
- package/dist/core-runtime/readers/lexicon-citation-check.js +93 -0
- package/dist/core-runtime/readers/lexicon-citation-check.test.js +77 -0
- package/dist/core-runtime/readers/mcp-figma.js +30 -0
- package/dist/core-runtime/readers/mcp-figma.test.js +82 -0
- package/dist/core-runtime/readers/mcp-generic.js +31 -0
- package/dist/core-runtime/readers/mcp-generic.test.js +76 -0
- package/dist/core-runtime/readers/ontology-index.js +148 -0
- package/dist/core-runtime/readers/ontology-index.test.js +245 -0
- package/dist/core-runtime/readers/ontology-query.js +168 -0
- package/dist/core-runtime/readers/ontology-query.test.js +311 -0
- package/dist/core-runtime/readers/ontology-resolve.js +48 -0
- package/dist/core-runtime/readers/ontology-resolve.test.js +48 -0
- package/dist/core-runtime/readers/patterns/index.js +7 -0
- package/dist/core-runtime/readers/review-log.js +213 -0
- package/dist/core-runtime/readers/review-log.test.js +313 -0
- package/dist/core-runtime/readers/scan-local.js +102 -0
- package/dist/core-runtime/readers/scan-local.test.js +102 -0
- package/dist/core-runtime/readers/scan-tarball.js +121 -0
- package/dist/core-runtime/readers/scan-tarball.test.js +283 -0
- package/dist/core-runtime/readers/scan-vault.js +34 -0
- package/dist/core-runtime/readers/scan-vault.test.js +81 -0
- package/dist/core-runtime/readers/types.js +42 -0
- package/dist/core-runtime/readers/types.test.js +94 -0
- package/dist/core-runtime/readers/viewpoint-collectors.js +229 -0
- package/dist/core-runtime/reconstruct/artifact-types.js +1 -0
- package/dist/core-runtime/reconstruct/directive-validation.js +123 -0
- package/dist/core-runtime/reconstruct/materialize-preparation.js +251 -0
- package/dist/core-runtime/reconstruct/record.js +198 -0
- package/dist/core-runtime/reconstruct/run.js +578 -0
- package/dist/core-runtime/reconstruct/seed-candidate-validation.js +356 -0
- package/dist/core-runtime/reconstruct/source-observations.js +62 -0
- package/dist/core-runtime/reconstruct/source-profiles.js +73 -0
- package/dist/core-runtime/release-channel/release-channel.js +90 -0
- package/dist/core-runtime/review/artifact-types.js +13 -0
- package/dist/core-runtime/review/citation-audit.js +204 -0
- package/dist/core-runtime/review/citation-audit.test.js +165 -0
- package/dist/core-runtime/review/controlled-lens-deliberation.js +125 -0
- package/dist/core-runtime/review/execution-plan-resolver.js +247 -0
- package/dist/core-runtime/review/execution-plan-resolver.test.js +243 -0
- package/dist/core-runtime/review/execution-topology-resolver-axis-first.test.js +246 -0
- package/dist/core-runtime/review/execution-topology-resolver.js +401 -0
- package/dist/core-runtime/review/execution-topology-resolver.test.js +315 -0
- package/dist/core-runtime/review/failure-records.js +57 -0
- package/dist/core-runtime/review/inline-context-embedder.js +141 -0
- package/dist/core-runtime/review/inline-context-embedder.test.js +154 -0
- package/dist/core-runtime/review/issue-artifact-runtime.js +859 -0
- package/dist/core-runtime/review/legacy-mode-policy.js +88 -0
- package/dist/core-runtime/review/lens-completion-policy.js +17 -0
- package/dist/core-runtime/review/materializers-effort-persist.test.js +79 -0
- package/dist/core-runtime/review/materializers.js +963 -0
- package/dist/core-runtime/review/ontology-path-classifier.js +179 -0
- package/dist/core-runtime/review/ontology-path-classifier.test.js +216 -0
- package/dist/core-runtime/review/packet-boundary-policy.js +215 -0
- package/dist/core-runtime/review/packet-boundary-policy.test.js +107 -0
- package/dist/core-runtime/review/participating-lens-paths.js +61 -0
- package/dist/core-runtime/review/participating-lens-paths.test.js +73 -0
- package/dist/core-runtime/review/review-artifact-utils.js +287 -0
- package/dist/core-runtime/review/review-config-legacy-translate.js +244 -0
- package/dist/core-runtime/review/review-config-legacy-translate.test.js +161 -0
- package/dist/core-runtime/review/review-config-validator.js +289 -0
- package/dist/core-runtime/review/review-config-validator.test.js +236 -0
- package/dist/core-runtime/review/review-execution-profile.js +193 -0
- package/dist/core-runtime/review/review-execution-route.js +52 -0
- package/dist/core-runtime/review/review-progress-contract.js +123 -0
- package/dist/core-runtime/review/review-record-validation.js +251 -0
- package/dist/core-runtime/review/review-result-classification.js +379 -0
- package/dist/core-runtime/review/review-state-machine.js +39 -0
- package/dist/core-runtime/review/route-visibility.js +125 -0
- package/dist/core-runtime/review/shape-pipeline-audit.test.js +311 -0
- package/dist/core-runtime/review/shape-to-topology-id.js +117 -0
- package/dist/core-runtime/review/shape-to-topology-id.test.js +132 -0
- package/dist/core-runtime/review/topology-shape-derivation.js +155 -0
- package/dist/core-runtime/review/topology-shape-derivation.test.js +195 -0
- package/dist/core-runtime/scope-runtime/constants.js +12 -0
- package/dist/core-runtime/scope-runtime/constraint-pool.js +166 -0
- package/dist/core-runtime/scope-runtime/constraint-pool.test.js +674 -0
- package/dist/core-runtime/scope-runtime/domain-validation-log.js +135 -0
- package/dist/core-runtime/scope-runtime/domain-validation-log.test.js +156 -0
- package/dist/core-runtime/scope-runtime/eval-persistence.js +65 -0
- package/dist/core-runtime/scope-runtime/eval-persistence.test.js +84 -0
- package/dist/core-runtime/scope-runtime/event-pipeline.js +64 -0
- package/dist/core-runtime/scope-runtime/event-pipeline.test.js +450 -0
- package/dist/core-runtime/scope-runtime/event-store.js +39 -0
- package/dist/core-runtime/scope-runtime/event-store.test.js +95 -0
- package/dist/core-runtime/scope-runtime/gate-guard.js +348 -0
- package/dist/core-runtime/scope-runtime/gate-guard.test.js +1047 -0
- package/dist/core-runtime/scope-runtime/hash.js +4 -0
- package/dist/core-runtime/scope-runtime/hash.test.js +33 -0
- package/dist/core-runtime/scope-runtime/id.js +4 -0
- package/dist/core-runtime/scope-runtime/id.test.js +17 -0
- package/dist/core-runtime/scope-runtime/reducer.js +297 -0
- package/dist/core-runtime/scope-runtime/reducer.test.js +759 -0
- package/dist/core-runtime/scope-runtime/scope-manager.js +161 -0
- package/dist/core-runtime/scope-runtime/state-machine.js +309 -0
- package/dist/core-runtime/scope-runtime/state-machine.test.js +704 -0
- package/dist/core-runtime/scope-runtime/types.js +116 -0
- package/dist/core-runtime/scope-runtime/types.test.js +69 -0
- package/dist/core-runtime/target-material-kind.js +256 -0
- package/dist/core-runtime/translate/render-for-user.js +169 -0
- package/dist/core-runtime/translate/render-for-user.test.js +122 -0
- package/dist/mcp/server.js +1011 -0
- package/dist/mcp/tool-schemas.js +93 -0
- package/dist/providers/capability-contract.js +1 -0
- package/package.json +68 -0
- package/settings.example.json +33 -0
|
@@ -0,0 +1,794 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
/**
|
|
3
|
+
* Coordinator State Machine — Deterministic State Enforcer for review process.
|
|
4
|
+
*
|
|
5
|
+
* 9 states (auto 3, await 3, terminal 3), 12 edges.
|
|
6
|
+
* Auto state transitions are recorded in two phases:
|
|
7
|
+
* 1. Entry transition recorded in memory (not flushed to disk)
|
|
8
|
+
* 2. Exit transition recorded and flushed after auto state completes
|
|
9
|
+
* On crash, the on-disk state file points to the previous await state.
|
|
10
|
+
*
|
|
11
|
+
* Design authority: .onto/temp/coordinator-state-machine-v3.md
|
|
12
|
+
*/
|
|
13
|
+
import path from "node:path";
|
|
14
|
+
import { parseArgs } from "node:util";
|
|
15
|
+
import { pathToFileURL } from "node:url";
|
|
16
|
+
import { ALLOWED_TRANSITIONS } from "../review/artifact-types.js";
|
|
17
|
+
import fs from "node:fs/promises";
|
|
18
|
+
import { isoNow, readYamlDocument, requireString, writeYamlDocument, fileExists, appendMarkdownLogEntry, parseMarkdownFrontmatter, } from "../review/review-artifact-utils.js";
|
|
19
|
+
import { readExtractMode } from "../learning/shared/mode.js";
|
|
20
|
+
import { initCoordinatorLog, buildSynthesizeRuntimePacket, writeExecutionResult, } from "./coordinator-helpers.js";
|
|
21
|
+
import { buildLensControlledDeliberationPrompt, buildTeamleadControlledDeliberationPrompt, } from "../review/controlled-lens-deliberation.js";
|
|
22
|
+
import { resolveRequiredParticipatingLensCount } from "../review/lens-completion-policy.js";
|
|
23
|
+
import { PRE_DELIBERATION_ISSUE_ARTIFACT_IDS, renderIssueArtifactContext, resolveProblemFramingProfileRef, validateIssueArtifactOnDisk, writeIssueArtifactPromptPacket, } from "../review/issue-artifact-runtime.js";
|
|
24
|
+
// ─────────────────────────────────────────────
|
|
25
|
+
// Derived constants
|
|
26
|
+
// ─────────────────────────────────────────────
|
|
27
|
+
/** Derived from ALLOWED_TRANSITIONS: states with no outgoing edges. */
|
|
28
|
+
const TERMINAL_STATES = Object.entries(ALLOWED_TRANSITIONS)
|
|
29
|
+
.filter(([key, targets]) => key !== "(init)" && targets.length === 0)
|
|
30
|
+
.map(([key]) => key);
|
|
31
|
+
const AGENT_PROMPT_TEMPLATE = `You are a single bounded review unit executing as an Agent Teams-style ContextIsolatedReasoningUnit.
|
|
32
|
+
|
|
33
|
+
Unit id: {unit_id}
|
|
34
|
+
Unit kind: {unit_kind}
|
|
35
|
+
Authoritative prompt packet path: {packet_path}
|
|
36
|
+
Canonical output path: {output_path}
|
|
37
|
+
|
|
38
|
+
Rules:
|
|
39
|
+
- Read the prompt packet file at {packet_path}. Treat it as the authoritative contract.
|
|
40
|
+
- Treat the Boundary Policy and Effective Boundary State in the packet as hard constraints.
|
|
41
|
+
- Read the files referenced by the prompt packet when needed.
|
|
42
|
+
- Stay within the smallest sufficient file set implied by the packet.
|
|
43
|
+
- Do not recursively follow reference chains beyond the files explicitly listed in the packet unless the packet requires it.
|
|
44
|
+
- Do not use web research when the packet says web research is denied.
|
|
45
|
+
- Do not read outside the allowed filesystem scope described in the packet.
|
|
46
|
+
- Produce only the final content for the canonical output path.
|
|
47
|
+
- Do not wrap the answer in code fences.
|
|
48
|
+
- Do not add commentary before or after the markdown.
|
|
49
|
+
- Do not modify repository files yourself.
|
|
50
|
+
- Do not change the required output structure from the packet.
|
|
51
|
+
- Preserve disagreement and uncertainty explicitly when present.
|
|
52
|
+
- If you cannot complete the task within the declared boundary, preserve that limitation explicitly as insufficient access or insufficient evidence within boundary instead of broadening the search.
|
|
53
|
+
|
|
54
|
+
Read the prompt packet, execute the review, then write the complete output to {output_path}.`;
|
|
55
|
+
function buildAgentPrompt(unitId, unitKind, packetPath, outputPath) {
|
|
56
|
+
return AGENT_PROMPT_TEMPLATE.replace(/\{unit_id\}/g, unitId)
|
|
57
|
+
.replace(/\{unit_kind\}/g, unitKind)
|
|
58
|
+
.replace(/\{packet_path\}/g, packetPath)
|
|
59
|
+
.replace(/\{output_path\}/g, outputPath);
|
|
60
|
+
}
|
|
61
|
+
// ─────────────────────────────────────────────
|
|
62
|
+
// State file I/O
|
|
63
|
+
// ─────────────────────────────────────────────
|
|
64
|
+
function stateFilePath(sessionRoot) {
|
|
65
|
+
return path.join(sessionRoot, "coordinator-state.yaml");
|
|
66
|
+
}
|
|
67
|
+
async function readStateFile(sessionRoot) {
|
|
68
|
+
return readYamlDocument(stateFilePath(sessionRoot));
|
|
69
|
+
}
|
|
70
|
+
async function writeStateFile(sessionRoot, state) {
|
|
71
|
+
await writeYamlDocument(stateFilePath(sessionRoot), state);
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Validates transition legality, updates current_state, and appends to
|
|
75
|
+
* the transitions log. Does NOT flush to disk — caller decides when to write.
|
|
76
|
+
*
|
|
77
|
+
* Validates both:
|
|
78
|
+
* - State-position: `from` must match `state.current_state` (except "(init)")
|
|
79
|
+
* - Edge-existence: `from → to` must be in ALLOWED_TRANSITIONS
|
|
80
|
+
*/
|
|
81
|
+
function applyTransition(state, from, to) {
|
|
82
|
+
// State-position validation
|
|
83
|
+
if (from !== "(init)" && state.current_state !== from) {
|
|
84
|
+
throw new Error(`State position mismatch: current_state is "${state.current_state}" but transition starts from "${from}"`);
|
|
85
|
+
}
|
|
86
|
+
// Edge-existence validation
|
|
87
|
+
const allowed = ALLOWED_TRANSITIONS[from];
|
|
88
|
+
if (!allowed || !allowed.includes(to)) {
|
|
89
|
+
throw new Error(`Invalid state transition: ${from} → ${to}. Allowed: ${(allowed ?? []).join(", ")}`);
|
|
90
|
+
}
|
|
91
|
+
state.current_state = to;
|
|
92
|
+
state.transitions.push({ from, to, at: isoNow() });
|
|
93
|
+
}
|
|
94
|
+
// ─────────────────────────────────────────────
|
|
95
|
+
// Build agent instructions from execution plan
|
|
96
|
+
// ─────────────────────────────────────────────
|
|
97
|
+
function buildLensAgentInstructions(executionPlan) {
|
|
98
|
+
return executionPlan.lens_prompt_packet_seats.map((seat) => ({
|
|
99
|
+
lens_id: seat.lens_id,
|
|
100
|
+
description: `Review lens: ${seat.lens_id}`,
|
|
101
|
+
prompt: buildAgentPrompt(seat.lens_id, "lens", seat.packet_path, seat.output_path),
|
|
102
|
+
output_path: seat.output_path,
|
|
103
|
+
packet_path: seat.packet_path,
|
|
104
|
+
}));
|
|
105
|
+
}
|
|
106
|
+
function buildSynthesizeAgentInstruction(executionPlan, runtimePacketPath) {
|
|
107
|
+
return {
|
|
108
|
+
lens_id: "synthesize",
|
|
109
|
+
description: "Synthesize lens findings",
|
|
110
|
+
prompt: buildAgentPrompt("synthesize", "synthesize", runtimePacketPath, executionPlan.synthesis_output_path),
|
|
111
|
+
output_path: executionPlan.synthesis_output_path,
|
|
112
|
+
packet_path: runtimePacketPath,
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
async function readLensOutputsForDeliberation(executionPlan) {
|
|
116
|
+
const lensOutputs = [];
|
|
117
|
+
for (const seat of executionPlan.lens_prompt_packet_seats) {
|
|
118
|
+
if (!(await fileExists(seat.output_path))) {
|
|
119
|
+
continue;
|
|
120
|
+
}
|
|
121
|
+
const content = await fs.readFile(seat.output_path, "utf8");
|
|
122
|
+
if (content.trim().length === 0) {
|
|
123
|
+
continue;
|
|
124
|
+
}
|
|
125
|
+
lensOutputs.push({
|
|
126
|
+
lens_id: seat.lens_id,
|
|
127
|
+
output_path: seat.output_path,
|
|
128
|
+
content,
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
const minimumParticipating = resolveRequiredParticipatingLensCount(executionPlan);
|
|
132
|
+
if (lensOutputs.length < minimumParticipating) {
|
|
133
|
+
throw new Error(`Fewer than ${minimumParticipating} participating lens outputs are available for deliberation.`);
|
|
134
|
+
}
|
|
135
|
+
return lensOutputs;
|
|
136
|
+
}
|
|
137
|
+
function requireDeliberationSeat(executionPlan, lensId) {
|
|
138
|
+
const seat = executionPlan.lens_deliberation_prompt_packet_seats.find((candidate) => candidate.lens_id === lensId);
|
|
139
|
+
if (!seat) {
|
|
140
|
+
throw new Error(`Missing deliberation prompt seat for lens: ${lensId}`);
|
|
141
|
+
}
|
|
142
|
+
return seat;
|
|
143
|
+
}
|
|
144
|
+
async function buildLensDeliberationAgentInstructions(executionPlan, projectRoot) {
|
|
145
|
+
if (executionPlan.deliberation_mode !== "controlled-lens-deliberation") {
|
|
146
|
+
throw new Error(`Unsupported review deliberation mode: ${executionPlan.deliberation_mode}`);
|
|
147
|
+
}
|
|
148
|
+
const lensOutputs = await readLensOutputsForDeliberation(executionPlan);
|
|
149
|
+
const issueArtifactContext = await renderIssueArtifactContext({
|
|
150
|
+
projectRoot,
|
|
151
|
+
executionPlan,
|
|
152
|
+
});
|
|
153
|
+
const lensOutputById = new Map(lensOutputs.map((lensOutput) => [lensOutput.lens_id, lensOutput]));
|
|
154
|
+
const instructions = [];
|
|
155
|
+
for (const lensOutput of lensOutputs) {
|
|
156
|
+
const seat = requireDeliberationSeat(executionPlan, lensOutput.lens_id);
|
|
157
|
+
const packetText = buildLensControlledDeliberationPrompt({
|
|
158
|
+
session_id: executionPlan.session_id,
|
|
159
|
+
lens_id: lensOutput.lens_id,
|
|
160
|
+
output_path: seat.output_path,
|
|
161
|
+
own_output: lensOutput,
|
|
162
|
+
other_outputs: lensOutputs.filter((candidate) => candidate.lens_id !== lensOutput.lens_id),
|
|
163
|
+
issue_artifact_context: issueArtifactContext,
|
|
164
|
+
});
|
|
165
|
+
await fs.mkdir(path.dirname(seat.packet_path), { recursive: true });
|
|
166
|
+
await fs.writeFile(seat.packet_path, `${packetText.trimEnd()}\n`, "utf8");
|
|
167
|
+
instructions.push({
|
|
168
|
+
lens_id: `deliberation-${lensOutput.lens_id}`,
|
|
169
|
+
description: `Controlled deliberation response: ${lensOutput.lens_id}`,
|
|
170
|
+
prompt: buildAgentPrompt(`deliberation-${lensOutput.lens_id}`, "deliberation", seat.packet_path, seat.output_path),
|
|
171
|
+
output_path: seat.output_path,
|
|
172
|
+
packet_path: seat.packet_path,
|
|
173
|
+
});
|
|
174
|
+
if (!lensOutputById.has(lensOutput.lens_id)) {
|
|
175
|
+
throw new Error(`Missing deliberation lens output: ${lensOutput.lens_id}`);
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
return instructions;
|
|
179
|
+
}
|
|
180
|
+
async function buildTeamleadDeliberationAgentInstruction(executionPlan, projectRoot) {
|
|
181
|
+
const lensOutputs = await readLensOutputsForDeliberation(executionPlan);
|
|
182
|
+
const issueArtifactContext = await renderIssueArtifactContext({
|
|
183
|
+
projectRoot,
|
|
184
|
+
executionPlan,
|
|
185
|
+
});
|
|
186
|
+
const responses = [];
|
|
187
|
+
for (const lensOutput of lensOutputs) {
|
|
188
|
+
const seat = requireDeliberationSeat(executionPlan, lensOutput.lens_id);
|
|
189
|
+
if (!(await fileExists(seat.output_path))) {
|
|
190
|
+
throw new Error(`Missing lens deliberation response for teamlead result: ${seat.output_path}`);
|
|
191
|
+
}
|
|
192
|
+
const content = await fs.readFile(seat.output_path, "utf8");
|
|
193
|
+
if (content.trim().length === 0) {
|
|
194
|
+
throw new Error(`Empty lens deliberation response for teamlead result: ${seat.output_path}`);
|
|
195
|
+
}
|
|
196
|
+
responses.push({
|
|
197
|
+
lens_id: lensOutput.lens_id,
|
|
198
|
+
response_path: seat.output_path,
|
|
199
|
+
content,
|
|
200
|
+
});
|
|
201
|
+
}
|
|
202
|
+
const packetText = buildTeamleadControlledDeliberationPrompt({
|
|
203
|
+
session_id: executionPlan.session_id,
|
|
204
|
+
output_path: executionPlan.deliberation_output_path,
|
|
205
|
+
lens_outputs: lensOutputs,
|
|
206
|
+
lens_deliberation_responses: responses,
|
|
207
|
+
issue_artifact_context: issueArtifactContext,
|
|
208
|
+
});
|
|
209
|
+
await fs.writeFile(executionPlan.teamlead_deliberation_prompt_packet_path, `${packetText.trimEnd()}\n`, "utf8");
|
|
210
|
+
return {
|
|
211
|
+
lens_id: "controlled-deliberation",
|
|
212
|
+
description: "Teamlead controlled lens deliberation result",
|
|
213
|
+
prompt: buildAgentPrompt("controlled-deliberation", "deliberation", executionPlan.teamlead_deliberation_prompt_packet_path, executionPlan.deliberation_output_path),
|
|
214
|
+
output_path: executionPlan.deliberation_output_path,
|
|
215
|
+
packet_path: executionPlan.teamlead_deliberation_prompt_packet_path,
|
|
216
|
+
};
|
|
217
|
+
}
|
|
218
|
+
async function hasNonEmptyFile(filePath) {
|
|
219
|
+
if (!(await fileExists(filePath)))
|
|
220
|
+
return false;
|
|
221
|
+
const text = await fs.readFile(filePath, "utf8");
|
|
222
|
+
return text.trim().length > 0;
|
|
223
|
+
}
|
|
224
|
+
async function getParticipatingLensRefs(executionPlan) {
|
|
225
|
+
const lensOutputs = await readLensOutputsForDeliberation(executionPlan);
|
|
226
|
+
return {
|
|
227
|
+
lensIds: lensOutputs.map((lensOutput) => lensOutput.lens_id),
|
|
228
|
+
outputPaths: lensOutputs.map((lensOutput) => lensOutput.output_path),
|
|
229
|
+
};
|
|
230
|
+
}
|
|
231
|
+
async function validatePreDeliberationIssueArtifacts(args) {
|
|
232
|
+
for (const artifactId of PRE_DELIBERATION_ISSUE_ARTIFACT_IDS) {
|
|
233
|
+
await validateIssueArtifactOnDisk({
|
|
234
|
+
executionPlan: args.executionPlan,
|
|
235
|
+
artifactId,
|
|
236
|
+
participatingLensIds: args.participatingLensIds,
|
|
237
|
+
});
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
async function buildIssueArtifactAgentInstruction(args) {
|
|
241
|
+
const seat = await writeIssueArtifactPromptPacket({
|
|
242
|
+
artifactId: args.artifactId,
|
|
243
|
+
sessionId: args.executionPlan.session_id,
|
|
244
|
+
projectRoot: args.projectRoot,
|
|
245
|
+
executionPlan: args.executionPlan,
|
|
246
|
+
lensOutputPaths: args.lensOutputPaths,
|
|
247
|
+
...(args.deliberationResponsePaths
|
|
248
|
+
? { deliberationResponsePaths: args.deliberationResponsePaths }
|
|
249
|
+
: {}),
|
|
250
|
+
...(args.deliberationOutputPath
|
|
251
|
+
? { deliberationOutputPath: args.deliberationOutputPath }
|
|
252
|
+
: {}),
|
|
253
|
+
...(args.problemFramingProfileRef !== undefined
|
|
254
|
+
? { problemFramingProfileRef: args.problemFramingProfileRef }
|
|
255
|
+
: {}),
|
|
256
|
+
});
|
|
257
|
+
return {
|
|
258
|
+
lens_id: args.artifactId,
|
|
259
|
+
description: `Issue closure artifact: ${args.artifactId}`,
|
|
260
|
+
prompt: buildAgentPrompt(args.artifactId, "issue_artifact", seat.packet_path, seat.output_path),
|
|
261
|
+
output_path: seat.output_path,
|
|
262
|
+
packet_path: seat.packet_path,
|
|
263
|
+
};
|
|
264
|
+
}
|
|
265
|
+
async function buildNextPreDeliberationIssueArtifactAgent(args) {
|
|
266
|
+
const { lensIds, outputPaths } = await getParticipatingLensRefs(args.executionPlan);
|
|
267
|
+
for (const artifactId of PRE_DELIBERATION_ISSUE_ARTIFACT_IDS) {
|
|
268
|
+
const seat = args.executionPlan.issue_artifact_prompt_packet_seats.find((candidate) => candidate.artifact_id === artifactId);
|
|
269
|
+
if (!seat) {
|
|
270
|
+
throw new Error(`Missing issue artifact prompt seat: ${artifactId}`);
|
|
271
|
+
}
|
|
272
|
+
if (!(await hasNonEmptyFile(seat.output_path))) {
|
|
273
|
+
return buildIssueArtifactAgentInstruction({
|
|
274
|
+
executionPlan: args.executionPlan,
|
|
275
|
+
projectRoot: args.projectRoot,
|
|
276
|
+
artifactId,
|
|
277
|
+
lensOutputPaths: outputPaths,
|
|
278
|
+
});
|
|
279
|
+
}
|
|
280
|
+
await validateIssueArtifactOnDisk({
|
|
281
|
+
executionPlan: args.executionPlan,
|
|
282
|
+
artifactId,
|
|
283
|
+
participatingLensIds: lensIds,
|
|
284
|
+
});
|
|
285
|
+
}
|
|
286
|
+
return null;
|
|
287
|
+
}
|
|
288
|
+
async function readLensDeliberationResponsePaths(executionPlan) {
|
|
289
|
+
const lensOutputs = await readLensOutputsForDeliberation(executionPlan);
|
|
290
|
+
const paths = [];
|
|
291
|
+
for (const lensOutput of lensOutputs) {
|
|
292
|
+
const seat = requireDeliberationSeat(executionPlan, lensOutput.lens_id);
|
|
293
|
+
if (!(await hasNonEmptyFile(seat.output_path))) {
|
|
294
|
+
throw new Error(`Missing lens deliberation response: ${seat.output_path}`);
|
|
295
|
+
}
|
|
296
|
+
paths.push(seat.output_path);
|
|
297
|
+
}
|
|
298
|
+
return paths;
|
|
299
|
+
}
|
|
300
|
+
async function buildProblemFramingAgentIfNeeded(args) {
|
|
301
|
+
const { lensIds, outputPaths } = await getParticipatingLensRefs(args.executionPlan);
|
|
302
|
+
await validatePreDeliberationIssueArtifacts({
|
|
303
|
+
executionPlan: args.executionPlan,
|
|
304
|
+
participatingLensIds: lensIds,
|
|
305
|
+
});
|
|
306
|
+
const problemFramingSeat = args.executionPlan.issue_artifact_prompt_packet_seats.find((candidate) => candidate.artifact_id === "problem-framing");
|
|
307
|
+
if (!problemFramingSeat) {
|
|
308
|
+
throw new Error("Missing issue artifact prompt seat: problem-framing");
|
|
309
|
+
}
|
|
310
|
+
if (await hasNonEmptyFile(problemFramingSeat.output_path)) {
|
|
311
|
+
await validateIssueArtifactOnDisk({
|
|
312
|
+
executionPlan: args.executionPlan,
|
|
313
|
+
artifactId: "problem-framing",
|
|
314
|
+
participatingLensIds: lensIds,
|
|
315
|
+
});
|
|
316
|
+
return null;
|
|
317
|
+
}
|
|
318
|
+
return buildIssueArtifactAgentInstruction({
|
|
319
|
+
executionPlan: args.executionPlan,
|
|
320
|
+
projectRoot: args.projectRoot,
|
|
321
|
+
artifactId: "problem-framing",
|
|
322
|
+
lensOutputPaths: outputPaths,
|
|
323
|
+
deliberationResponsePaths: await readLensDeliberationResponsePaths(args.executionPlan),
|
|
324
|
+
deliberationOutputPath: args.executionPlan.deliberation_output_path,
|
|
325
|
+
problemFramingProfileRef: await resolveProblemFramingProfileRef({
|
|
326
|
+
projectRoot: args.projectRoot,
|
|
327
|
+
executionPlan: args.executionPlan,
|
|
328
|
+
}),
|
|
329
|
+
});
|
|
330
|
+
}
|
|
331
|
+
// ─────────────────────────────────────────────
|
|
332
|
+
// coordinator start
|
|
333
|
+
// ─────────────────────────────────────────────
|
|
334
|
+
export async function coordinatorStart(argv) {
|
|
335
|
+
let sessionRoot;
|
|
336
|
+
let requestText = "";
|
|
337
|
+
try {
|
|
338
|
+
// Phase 1: Create session via reviewPrepareOnly
|
|
339
|
+
const { reviewPrepareOnly } = await import("./review-invoke.js");
|
|
340
|
+
const enrichedArgv = [...argv];
|
|
341
|
+
if (!enrichedArgv.includes("--prepare-only")) {
|
|
342
|
+
enrichedArgv.push("--prepare-only");
|
|
343
|
+
}
|
|
344
|
+
const prepareResult = await reviewPrepareOnly(enrichedArgv);
|
|
345
|
+
sessionRoot = path.resolve(prepareResult.session_root);
|
|
346
|
+
requestText = prepareResult.request_text;
|
|
347
|
+
// State file created immediately after session directory exists (CCON-1).
|
|
348
|
+
// current_state="preparing" — auto state is still running (initCoordinatorLog pending).
|
|
349
|
+
const stateFile = {
|
|
350
|
+
schema_version: "1",
|
|
351
|
+
current_state: "preparing",
|
|
352
|
+
session_root: sessionRoot,
|
|
353
|
+
request_text: requestText,
|
|
354
|
+
started_at: isoNow(),
|
|
355
|
+
halt_reason: null,
|
|
356
|
+
error_message: null,
|
|
357
|
+
transitions: [{ from: "(init)", to: "preparing", at: isoNow() }],
|
|
358
|
+
};
|
|
359
|
+
await writeStateFile(sessionRoot, stateFile);
|
|
360
|
+
// Phase 2: Initialize coordinator log (still within "preparing" auto state)
|
|
361
|
+
await initCoordinatorLog(["--session-root", sessionRoot]);
|
|
362
|
+
// Read execution plan
|
|
363
|
+
const executionPlan = await readYamlDocument(path.join(sessionRoot, "execution-plan.yaml"));
|
|
364
|
+
// preparing complete → transition to awaiting_lens_dispatch
|
|
365
|
+
applyTransition(stateFile, "preparing", "awaiting_lens_dispatch");
|
|
366
|
+
await writeStateFile(sessionRoot, stateFile);
|
|
367
|
+
return {
|
|
368
|
+
state: "awaiting_lens_dispatch",
|
|
369
|
+
session_root: sessionRoot,
|
|
370
|
+
request_text: requestText,
|
|
371
|
+
agents: buildLensAgentInstructions(executionPlan),
|
|
372
|
+
max_concurrent_lenses: executionPlan.max_concurrent_lenses ??
|
|
373
|
+
executionPlan.lens_prompt_packet_seats.length,
|
|
374
|
+
};
|
|
375
|
+
}
|
|
376
|
+
catch (error) {
|
|
377
|
+
if (sessionRoot) {
|
|
378
|
+
try {
|
|
379
|
+
// State file may exist (created after Phase 1) — update it
|
|
380
|
+
const existing = await readStateFile(sessionRoot);
|
|
381
|
+
existing.error_message =
|
|
382
|
+
error instanceof Error ? error.message : String(error);
|
|
383
|
+
applyTransition(existing, "preparing", "failed");
|
|
384
|
+
await writeStateFile(sessionRoot, existing);
|
|
385
|
+
}
|
|
386
|
+
catch {
|
|
387
|
+
// State file doesn't exist (Phase 1 failed) — create one
|
|
388
|
+
const failedState = {
|
|
389
|
+
schema_version: "1",
|
|
390
|
+
current_state: "failed",
|
|
391
|
+
session_root: sessionRoot,
|
|
392
|
+
request_text: requestText,
|
|
393
|
+
started_at: isoNow(),
|
|
394
|
+
halt_reason: null,
|
|
395
|
+
error_message: error instanceof Error ? error.message : String(error),
|
|
396
|
+
transitions: [
|
|
397
|
+
{ from: "(init)", to: "preparing", at: isoNow() },
|
|
398
|
+
{ from: "preparing", to: "failed", at: isoNow() },
|
|
399
|
+
],
|
|
400
|
+
};
|
|
401
|
+
await writeStateFile(sessionRoot, failedState);
|
|
402
|
+
}
|
|
403
|
+
}
|
|
404
|
+
throw error;
|
|
405
|
+
}
|
|
406
|
+
}
|
|
407
|
+
// ─────────────────────────────────────────────
|
|
408
|
+
// coordinator next
|
|
409
|
+
// ─────────────────────────────────────────────
|
|
410
|
+
export async function coordinatorNext(sessionRoot, projectRoot, orchestratorReportedRealization) {
|
|
411
|
+
const stateFile = await readStateFile(sessionRoot);
|
|
412
|
+
// Orchestrator self-reporting: record on first provided value (idempotent).
|
|
413
|
+
// Closes the gap between binding.yaml's plan-time resolved_execution_realization
|
|
414
|
+
// and the caller's actual dispatch mechanism. Contract §18.
|
|
415
|
+
if (orchestratorReportedRealization &&
|
|
416
|
+
!stateFile.orchestrator_reported_realization) {
|
|
417
|
+
stateFile.orchestrator_reported_realization = orchestratorReportedRealization;
|
|
418
|
+
await writeStateFile(sessionRoot, stateFile);
|
|
419
|
+
}
|
|
420
|
+
const currentState = stateFile.current_state;
|
|
421
|
+
if (TERMINAL_STATES.includes(currentState)) {
|
|
422
|
+
throw new Error(`Session already terminated (state: ${currentState})`);
|
|
423
|
+
}
|
|
424
|
+
switch (currentState) {
|
|
425
|
+
case "awaiting_lens_dispatch": {
|
|
426
|
+
try {
|
|
427
|
+
// Record auto state entry in memory (not flushed — crash-safe)
|
|
428
|
+
applyTransition(stateFile, "awaiting_lens_dispatch", "validating_lenses");
|
|
429
|
+
// Run validating_lenses auto state
|
|
430
|
+
const result = await buildSynthesizeRuntimePacket([
|
|
431
|
+
"--session-root",
|
|
432
|
+
sessionRoot,
|
|
433
|
+
"--project-root",
|
|
434
|
+
projectRoot,
|
|
435
|
+
"--validate-lenses-only",
|
|
436
|
+
]);
|
|
437
|
+
if (result.halt) {
|
|
438
|
+
stateFile.halt_reason = result.halt_reason ?? null;
|
|
439
|
+
applyTransition(stateFile, "validating_lenses", "halted_partial");
|
|
440
|
+
await writeStateFile(sessionRoot, stateFile);
|
|
441
|
+
return {
|
|
442
|
+
state: "halted_partial",
|
|
443
|
+
session_root: sessionRoot,
|
|
444
|
+
halt_reason: result.halt_reason,
|
|
445
|
+
participating_lens_ids: result.participating_lens_ids,
|
|
446
|
+
degraded_lens_ids: result.degraded_lens_ids,
|
|
447
|
+
};
|
|
448
|
+
}
|
|
449
|
+
const executionPlan = await readYamlDocument(path.join(sessionRoot, "execution-plan.yaml"));
|
|
450
|
+
const issueArtifactAgent = await buildNextPreDeliberationIssueArtifactAgent({
|
|
451
|
+
executionPlan,
|
|
452
|
+
projectRoot,
|
|
453
|
+
});
|
|
454
|
+
applyTransition(stateFile, "validating_lenses", "awaiting_adjudication");
|
|
455
|
+
if (!issueArtifactAgent) {
|
|
456
|
+
const deliberationAgents = await buildLensDeliberationAgentInstructions(executionPlan, projectRoot);
|
|
457
|
+
applyTransition(stateFile, "awaiting_adjudication", "awaiting_deliberation");
|
|
458
|
+
await writeStateFile(sessionRoot, stateFile);
|
|
459
|
+
return {
|
|
460
|
+
state: "awaiting_deliberation",
|
|
461
|
+
session_root: sessionRoot,
|
|
462
|
+
agents: deliberationAgents,
|
|
463
|
+
participating_lens_ids: result.participating_lens_ids,
|
|
464
|
+
degraded_lens_ids: result.degraded_lens_ids,
|
|
465
|
+
};
|
|
466
|
+
}
|
|
467
|
+
await writeStateFile(sessionRoot, stateFile);
|
|
468
|
+
return {
|
|
469
|
+
state: "awaiting_adjudication",
|
|
470
|
+
session_root: sessionRoot,
|
|
471
|
+
...(issueArtifactAgent ? { agent: issueArtifactAgent } : {}),
|
|
472
|
+
participating_lens_ids: result.participating_lens_ids,
|
|
473
|
+
degraded_lens_ids: result.degraded_lens_ids,
|
|
474
|
+
};
|
|
475
|
+
}
|
|
476
|
+
catch (error) {
|
|
477
|
+
// Reload from disk — in-memory state may have partial transitions
|
|
478
|
+
const diskState = await readStateFile(sessionRoot);
|
|
479
|
+
diskState.error_message =
|
|
480
|
+
error instanceof Error ? error.message : String(error);
|
|
481
|
+
// If still at awaiting_lens_dispatch on disk, record the full path
|
|
482
|
+
if (diskState.current_state === "awaiting_lens_dispatch") {
|
|
483
|
+
applyTransition(diskState, "awaiting_lens_dispatch", "validating_lenses");
|
|
484
|
+
}
|
|
485
|
+
applyTransition(diskState, "validating_lenses", "failed");
|
|
486
|
+
await writeStateFile(sessionRoot, diskState);
|
|
487
|
+
return {
|
|
488
|
+
state: "failed",
|
|
489
|
+
session_root: sessionRoot,
|
|
490
|
+
error_message: diskState.error_message,
|
|
491
|
+
};
|
|
492
|
+
}
|
|
493
|
+
}
|
|
494
|
+
case "awaiting_synthesize_dispatch": {
|
|
495
|
+
// Controlled lens deliberation is a required pre-synthesize stage.
|
|
496
|
+
// Completing may proceed only when both artifacts agree that the
|
|
497
|
+
// deliberation stage ran and synthesize consumed it.
|
|
498
|
+
try {
|
|
499
|
+
// Record auto state entry in memory (not flushed — crash-safe)
|
|
500
|
+
applyTransition(stateFile, "awaiting_synthesize_dispatch", "completing");
|
|
501
|
+
// Run completing auto state
|
|
502
|
+
// Step 1: Check synthesis output
|
|
503
|
+
const executionPlan = await readYamlDocument(path.join(sessionRoot, "execution-plan.yaml"));
|
|
504
|
+
if (!(await fileExists(executionPlan.synthesis_output_path))) {
|
|
505
|
+
throw new Error("completing step 1: synthesis output missing");
|
|
506
|
+
}
|
|
507
|
+
// Step 2: Deliberation-status guard. Completed review requires the
|
|
508
|
+
// synthesize stage to acknowledge the pre-synthesize controlled
|
|
509
|
+
// deliberation artifact.
|
|
510
|
+
const synthesisText = await fs.readFile(executionPlan.synthesis_output_path, "utf8");
|
|
511
|
+
const synthesisFrontmatter = parseMarkdownFrontmatter(synthesisText).metadata;
|
|
512
|
+
const synthesisDeliberationStatus = synthesisFrontmatter?.deliberation_status;
|
|
513
|
+
if (synthesisDeliberationStatus !== "performed") {
|
|
514
|
+
throw new Error("completing step 2: synthesis output must declare " +
|
|
515
|
+
"`deliberation_status: performed` because controlled lens " +
|
|
516
|
+
"deliberation is a required pre-synthesize stage.");
|
|
517
|
+
}
|
|
518
|
+
if (!(await fileExists(executionPlan.deliberation_output_path))) {
|
|
519
|
+
throw new Error(`completing step 2: controlled deliberation output missing: ${executionPlan.deliberation_output_path}`);
|
|
520
|
+
}
|
|
521
|
+
// Step 2.5: Learning extraction (Phase 2)
|
|
522
|
+
const sessionMetadata = await readYamlDocument(path.join(sessionRoot, "session-metadata.yaml"));
|
|
523
|
+
const extractMode = readExtractMode(sessionMetadata);
|
|
524
|
+
if (extractMode !== "disabled") {
|
|
525
|
+
try {
|
|
526
|
+
const { runLearningExtraction } = await import("../learning/extractor.js");
|
|
527
|
+
const extractionManifest = await runLearningExtraction({
|
|
528
|
+
sessionRoot,
|
|
529
|
+
projectRoot,
|
|
530
|
+
executionPlan,
|
|
531
|
+
mode: extractMode,
|
|
532
|
+
sessionId: executionPlan.session_id,
|
|
533
|
+
sessionDomain: sessionMetadata.requested_domain_token || null,
|
|
534
|
+
});
|
|
535
|
+
// Persist manifest (shadow and production both)
|
|
536
|
+
await writeYamlDocument(path.join(sessionRoot, "execution-preparation", "learning-extraction-manifest.yaml"), extractionManifest);
|
|
537
|
+
}
|
|
538
|
+
catch (error) {
|
|
539
|
+
// Non-blocking: extraction failure must not prevent review completion
|
|
540
|
+
await appendMarkdownLogEntry(path.join(sessionRoot, "error-log.md"), "learning extraction failed (non-blocking)", error instanceof Error ? error.message : String(error));
|
|
541
|
+
}
|
|
542
|
+
}
|
|
543
|
+
// Step 3: write-execution-result
|
|
544
|
+
const startedAt = stateFile.transitions.find((t) => t.to === "preparing")?.at ??
|
|
545
|
+
stateFile.started_at;
|
|
546
|
+
const writeOutput = await writeExecutionResult([
|
|
547
|
+
"--session-root",
|
|
548
|
+
sessionRoot,
|
|
549
|
+
"--started-at",
|
|
550
|
+
startedAt,
|
|
551
|
+
]);
|
|
552
|
+
// Step 4: complete-session
|
|
553
|
+
const { completeReviewSession } = await import("./complete-review-session.js");
|
|
554
|
+
const stateForRequest = await readStateFile(sessionRoot);
|
|
555
|
+
await completeReviewSession([
|
|
556
|
+
"--project-root",
|
|
557
|
+
projectRoot,
|
|
558
|
+
"--session-root",
|
|
559
|
+
sessionRoot,
|
|
560
|
+
"--request-text",
|
|
561
|
+
stateForRequest.request_text,
|
|
562
|
+
]);
|
|
563
|
+
applyTransition(stateFile, "completing", "completed");
|
|
564
|
+
await writeStateFile(sessionRoot, stateFile);
|
|
565
|
+
// Read review record status
|
|
566
|
+
const reviewRecordPath = executionPlan.review_record_path ??
|
|
567
|
+
path.join(sessionRoot, "review-record.yaml");
|
|
568
|
+
let recordStatus;
|
|
569
|
+
if (await fileExists(reviewRecordPath)) {
|
|
570
|
+
const record = await readYamlDocument(reviewRecordPath);
|
|
571
|
+
recordStatus = record.record_status;
|
|
572
|
+
}
|
|
573
|
+
return {
|
|
574
|
+
state: "completed",
|
|
575
|
+
session_root: sessionRoot,
|
|
576
|
+
final_output_path: executionPlan.final_output_path ??
|
|
577
|
+
path.join(sessionRoot, "final-output.md"),
|
|
578
|
+
review_record_path: reviewRecordPath,
|
|
579
|
+
record_status: recordStatus,
|
|
580
|
+
};
|
|
581
|
+
}
|
|
582
|
+
catch (error) {
|
|
583
|
+
// Reload from disk — in-memory state may have partial transitions
|
|
584
|
+
const diskState = await readStateFile(sessionRoot);
|
|
585
|
+
diskState.error_message =
|
|
586
|
+
error instanceof Error ? error.message : String(error);
|
|
587
|
+
if (diskState.current_state === "awaiting_synthesize_dispatch") {
|
|
588
|
+
applyTransition(diskState, "awaiting_synthesize_dispatch", "completing");
|
|
589
|
+
}
|
|
590
|
+
applyTransition(diskState, "completing", "failed");
|
|
591
|
+
await writeStateFile(sessionRoot, diskState);
|
|
592
|
+
return {
|
|
593
|
+
state: "failed",
|
|
594
|
+
session_root: sessionRoot,
|
|
595
|
+
error_message: diskState.error_message,
|
|
596
|
+
};
|
|
597
|
+
}
|
|
598
|
+
}
|
|
599
|
+
case "awaiting_adjudication": {
|
|
600
|
+
try {
|
|
601
|
+
const executionPlan = await readYamlDocument(path.join(sessionRoot, "execution-plan.yaml"));
|
|
602
|
+
const issueArtifactAgent = await buildNextPreDeliberationIssueArtifactAgent({
|
|
603
|
+
executionPlan,
|
|
604
|
+
projectRoot,
|
|
605
|
+
});
|
|
606
|
+
if (issueArtifactAgent) {
|
|
607
|
+
return {
|
|
608
|
+
state: "awaiting_adjudication",
|
|
609
|
+
session_root: sessionRoot,
|
|
610
|
+
agent: issueArtifactAgent,
|
|
611
|
+
};
|
|
612
|
+
}
|
|
613
|
+
const deliberationAgents = await buildLensDeliberationAgentInstructions(executionPlan, projectRoot);
|
|
614
|
+
applyTransition(stateFile, "awaiting_adjudication", "awaiting_deliberation");
|
|
615
|
+
await writeStateFile(sessionRoot, stateFile);
|
|
616
|
+
return {
|
|
617
|
+
state: "awaiting_deliberation",
|
|
618
|
+
session_root: sessionRoot,
|
|
619
|
+
agents: deliberationAgents,
|
|
620
|
+
};
|
|
621
|
+
}
|
|
622
|
+
catch (error) {
|
|
623
|
+
const diskState = await readStateFile(sessionRoot);
|
|
624
|
+
diskState.error_message =
|
|
625
|
+
error instanceof Error ? error.message : String(error);
|
|
626
|
+
if (diskState.current_state === "awaiting_adjudication") {
|
|
627
|
+
applyTransition(diskState, "awaiting_adjudication", "failed");
|
|
628
|
+
}
|
|
629
|
+
await writeStateFile(sessionRoot, diskState);
|
|
630
|
+
return {
|
|
631
|
+
state: "failed",
|
|
632
|
+
session_root: sessionRoot,
|
|
633
|
+
error_message: diskState.error_message,
|
|
634
|
+
};
|
|
635
|
+
}
|
|
636
|
+
}
|
|
637
|
+
case "awaiting_deliberation": {
|
|
638
|
+
try {
|
|
639
|
+
const executionPlan = await readYamlDocument(path.join(sessionRoot, "execution-plan.yaml"));
|
|
640
|
+
if (!(await fileExists(executionPlan.deliberation_output_path))) {
|
|
641
|
+
return {
|
|
642
|
+
state: "awaiting_deliberation",
|
|
643
|
+
session_root: sessionRoot,
|
|
644
|
+
agent: await buildTeamleadDeliberationAgentInstruction(executionPlan, projectRoot),
|
|
645
|
+
};
|
|
646
|
+
}
|
|
647
|
+
const problemFramingAgent = await buildProblemFramingAgentIfNeeded({
|
|
648
|
+
executionPlan,
|
|
649
|
+
projectRoot,
|
|
650
|
+
});
|
|
651
|
+
if (problemFramingAgent) {
|
|
652
|
+
return {
|
|
653
|
+
state: "awaiting_deliberation",
|
|
654
|
+
session_root: sessionRoot,
|
|
655
|
+
agent: problemFramingAgent,
|
|
656
|
+
};
|
|
657
|
+
}
|
|
658
|
+
const result = await buildSynthesizeRuntimePacket([
|
|
659
|
+
"--session-root",
|
|
660
|
+
sessionRoot,
|
|
661
|
+
"--project-root",
|
|
662
|
+
projectRoot,
|
|
663
|
+
"--require-deliberation",
|
|
664
|
+
]);
|
|
665
|
+
if (result.halt) {
|
|
666
|
+
stateFile.halt_reason = result.halt_reason ?? null;
|
|
667
|
+
applyTransition(stateFile, "awaiting_deliberation", "failed");
|
|
668
|
+
await writeStateFile(sessionRoot, stateFile);
|
|
669
|
+
return {
|
|
670
|
+
state: "failed",
|
|
671
|
+
session_root: sessionRoot,
|
|
672
|
+
halt_reason: result.halt_reason,
|
|
673
|
+
};
|
|
674
|
+
}
|
|
675
|
+
const runtimePacketPath = result.runtime_packet_path ??
|
|
676
|
+
path.join(executionPlan.prompt_packets_root ??
|
|
677
|
+
path.join(sessionRoot, "prompt-packets"), "synthesize.runtime.prompt.md");
|
|
678
|
+
applyTransition(stateFile, "awaiting_deliberation", "awaiting_synthesize_dispatch");
|
|
679
|
+
await writeStateFile(sessionRoot, stateFile);
|
|
680
|
+
return {
|
|
681
|
+
state: "awaiting_synthesize_dispatch",
|
|
682
|
+
session_root: sessionRoot,
|
|
683
|
+
agent: buildSynthesizeAgentInstruction(executionPlan, runtimePacketPath),
|
|
684
|
+
};
|
|
685
|
+
}
|
|
686
|
+
catch (error) {
|
|
687
|
+
const diskState = await readStateFile(sessionRoot);
|
|
688
|
+
diskState.error_message =
|
|
689
|
+
error instanceof Error ? error.message : String(error);
|
|
690
|
+
if (diskState.current_state === "awaiting_deliberation") {
|
|
691
|
+
applyTransition(diskState, "awaiting_deliberation", "failed");
|
|
692
|
+
}
|
|
693
|
+
await writeStateFile(sessionRoot, diskState);
|
|
694
|
+
return {
|
|
695
|
+
state: "failed",
|
|
696
|
+
session_root: sessionRoot,
|
|
697
|
+
error_message: diskState.error_message,
|
|
698
|
+
};
|
|
699
|
+
}
|
|
700
|
+
}
|
|
701
|
+
default:
|
|
702
|
+
throw new Error(`Unexpected state for next: ${currentState}`);
|
|
703
|
+
}
|
|
704
|
+
}
|
|
705
|
+
// ─────────────────────────────────────────────
|
|
706
|
+
// coordinator status
|
|
707
|
+
// ─────────────────────────────────────────────
|
|
708
|
+
export async function coordinatorStatus(sessionRoot) {
|
|
709
|
+
return readStateFile(sessionRoot);
|
|
710
|
+
}
|
|
711
|
+
// ─────────────────────────────────────────────
|
|
712
|
+
// Runtime dispatch entrypoints
|
|
713
|
+
// ─────────────────────────────────────────────
|
|
714
|
+
async function cliStart(argv) {
|
|
715
|
+
try {
|
|
716
|
+
const result = await coordinatorStart(argv);
|
|
717
|
+
console.log(JSON.stringify(result, null, 2));
|
|
718
|
+
return 0;
|
|
719
|
+
}
|
|
720
|
+
catch (error) {
|
|
721
|
+
console.error(`[coordinator] start failed: ${error instanceof Error ? error.message : String(error)}`);
|
|
722
|
+
return 1;
|
|
723
|
+
}
|
|
724
|
+
}
|
|
725
|
+
async function cliNext(argv) {
|
|
726
|
+
const { values } = parseArgs({
|
|
727
|
+
options: {
|
|
728
|
+
"session-root": { type: "string" },
|
|
729
|
+
"project-root": { type: "string", default: "." },
|
|
730
|
+
"orchestrator-reported-realization": { type: "string" },
|
|
731
|
+
},
|
|
732
|
+
strict: true,
|
|
733
|
+
allowPositionals: false,
|
|
734
|
+
args: argv,
|
|
735
|
+
});
|
|
736
|
+
const sessionRoot = path.resolve(requireString(values["session-root"], "session-root"));
|
|
737
|
+
const projectRoot = path.resolve(requireString(values["project-root"], "project-root"));
|
|
738
|
+
const orchestratorReportedRealization = values["orchestrator-reported-realization"];
|
|
739
|
+
try {
|
|
740
|
+
const result = await coordinatorNext(sessionRoot, projectRoot, orchestratorReportedRealization);
|
|
741
|
+
console.log(JSON.stringify(result, null, 2));
|
|
742
|
+
return 0;
|
|
743
|
+
}
|
|
744
|
+
catch (error) {
|
|
745
|
+
console.error(`[coordinator] next failed: ${error instanceof Error ? error.message : String(error)}`);
|
|
746
|
+
return 1;
|
|
747
|
+
}
|
|
748
|
+
}
|
|
749
|
+
async function cliStatus(argv) {
|
|
750
|
+
const { values } = parseArgs({
|
|
751
|
+
options: {
|
|
752
|
+
"session-root": { type: "string" },
|
|
753
|
+
},
|
|
754
|
+
strict: true,
|
|
755
|
+
allowPositionals: false,
|
|
756
|
+
args: argv,
|
|
757
|
+
});
|
|
758
|
+
const sessionRoot = path.resolve(requireString(values["session-root"], "session-root"));
|
|
759
|
+
try {
|
|
760
|
+
const state = await coordinatorStatus(sessionRoot);
|
|
761
|
+
console.log(JSON.stringify(state, null, 2));
|
|
762
|
+
return 0;
|
|
763
|
+
}
|
|
764
|
+
catch (error) {
|
|
765
|
+
console.error(`[coordinator] status failed: ${error instanceof Error ? error.message : String(error)}`);
|
|
766
|
+
return 1;
|
|
767
|
+
}
|
|
768
|
+
}
|
|
769
|
+
// ─────────────────────────────────────────────
|
|
770
|
+
// Runtime dispatch
|
|
771
|
+
// ─────────────────────────────────────────────
|
|
772
|
+
async function main() {
|
|
773
|
+
const subcommand = process.argv[2];
|
|
774
|
+
const subArgv = process.argv.slice(3);
|
|
775
|
+
switch (subcommand) {
|
|
776
|
+
case "start":
|
|
777
|
+
return cliStart(subArgv);
|
|
778
|
+
case "next":
|
|
779
|
+
return cliNext(subArgv);
|
|
780
|
+
case "status":
|
|
781
|
+
return cliStatus(subArgv);
|
|
782
|
+
default:
|
|
783
|
+
console.error(`Unknown coordinator subcommand: ${subcommand}`);
|
|
784
|
+
console.error("Available: start, next, status");
|
|
785
|
+
return 1;
|
|
786
|
+
}
|
|
787
|
+
}
|
|
788
|
+
if (process.argv[1] &&
|
|
789
|
+
import.meta.url === pathToFileURL(process.argv[1]).href) {
|
|
790
|
+
main().then((exitCode) => process.exit(exitCode), (error) => {
|
|
791
|
+
console.error(error instanceof Error ? error.message : String(error));
|
|
792
|
+
process.exit(1);
|
|
793
|
+
});
|
|
794
|
+
}
|