pulseed 0.3.0 → 0.4.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/base/config/config-metadata.d.ts +1 -1
- package/dist/base/config/config-metadata.d.ts.map +1 -1
- package/dist/base/config/config-metadata.js +1 -1
- package/dist/base/config/config-metadata.js.map +1 -1
- package/dist/base/config/identity-loader.d.ts +1 -1
- package/dist/base/config/identity-loader.d.ts.map +1 -1
- package/dist/base/config/identity-loader.js +4 -3
- package/dist/base/config/identity-loader.js.map +1 -1
- package/dist/base/config/tool-metadata.d.ts +2 -0
- package/dist/base/config/tool-metadata.d.ts.map +1 -1
- package/dist/base/config/tool-metadata.js +30 -6
- package/dist/base/config/tool-metadata.js.map +1 -1
- package/dist/base/llm/llm-client.d.ts +12 -1
- package/dist/base/llm/llm-client.d.ts.map +1 -1
- package/dist/base/llm/llm-client.js +78 -2
- package/dist/base/llm/llm-client.js.map +1 -1
- package/dist/base/llm/ollama-client.d.ts +1 -0
- package/dist/base/llm/ollama-client.d.ts.map +1 -1
- package/dist/base/llm/ollama-client.js +1 -0
- package/dist/base/llm/ollama-client.js.map +1 -1
- package/dist/base/llm/openai-client.d.ts +3 -1
- package/dist/base/llm/openai-client.d.ts.map +1 -1
- package/dist/base/llm/openai-client.js +131 -41
- package/dist/base/llm/openai-client.js.map +1 -1
- package/dist/base/llm/provider-config.d.ts +1 -1
- package/dist/base/llm/provider-config.d.ts.map +1 -1
- package/dist/base/llm/provider-factory.d.ts.map +1 -1
- package/dist/base/llm/provider-factory.js +22 -3
- package/dist/base/llm/provider-factory.js.map +1 -1
- package/dist/base/state/checkpoint-trust-port.d.ts +4 -0
- package/dist/base/state/checkpoint-trust-port.d.ts.map +1 -0
- package/dist/base/state/checkpoint-trust-port.js +2 -0
- package/dist/base/state/checkpoint-trust-port.js.map +1 -0
- package/dist/base/state/state-manager-goal-write.d.ts +22 -0
- package/dist/base/state/state-manager-goal-write.d.ts.map +1 -0
- package/dist/base/state/state-manager-goal-write.js +74 -0
- package/dist/base/state/state-manager-goal-write.js.map +1 -0
- package/dist/base/state/state-manager-wal.d.ts +11 -0
- package/dist/base/state/state-manager-wal.d.ts.map +1 -0
- package/dist/base/state/state-manager-wal.js +89 -0
- package/dist/base/state/state-manager-wal.js.map +1 -0
- package/dist/base/state/state-manager.d.ts +12 -5
- package/dist/base/state/state-manager.d.ts.map +1 -1
- package/dist/base/state/state-manager.js +24 -118
- package/dist/base/state/state-manager.js.map +1 -1
- package/dist/base/utils/errors.d.ts +4 -0
- package/dist/base/utils/errors.d.ts.map +1 -1
- package/dist/base/utils/errors.js +8 -0
- package/dist/base/utils/errors.js.map +1 -1
- package/dist/base/utils/pulseed-meta.d.ts +4 -0
- package/dist/base/utils/pulseed-meta.d.ts.map +1 -0
- package/dist/base/utils/pulseed-meta.js +32 -0
- package/dist/base/utils/pulseed-meta.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/interface/chat/chat-event-state.d.ts +10 -0
- package/dist/interface/chat/chat-event-state.d.ts.map +1 -0
- package/dist/interface/chat/chat-event-state.js +75 -0
- package/dist/interface/chat/chat-event-state.js.map +1 -0
- package/dist/interface/chat/chat-events.d.ts +59 -0
- package/dist/interface/chat/chat-events.d.ts.map +1 -0
- package/dist/interface/chat/chat-events.js +2 -0
- package/dist/interface/chat/chat-events.js.map +1 -0
- package/dist/interface/chat/chat-history.d.ts +4 -4
- package/dist/interface/chat/chat-history.d.ts.map +1 -1
- package/dist/interface/chat/chat-history.js +3 -3
- package/dist/interface/chat/chat-history.js.map +1 -1
- package/dist/interface/chat/chat-runner.d.ts +15 -4
- package/dist/interface/chat/chat-runner.d.ts.map +1 -1
- package/dist/interface/chat/chat-runner.js +241 -27
- package/dist/interface/chat/chat-runner.js.map +1 -1
- package/dist/interface/chat/event-subscriber.d.ts +7 -1
- package/dist/interface/chat/event-subscriber.d.ts.map +1 -1
- package/dist/interface/chat/event-subscriber.js +88 -2
- package/dist/interface/chat/event-subscriber.js.map +1 -1
- package/dist/interface/chat/grounding.d.ts +2 -0
- package/dist/interface/chat/grounding.d.ts.map +1 -1
- package/dist/interface/chat/grounding.js +95 -42
- package/dist/interface/chat/grounding.js.map +1 -1
- package/dist/interface/chat/mutation-tool-defs.js +1 -1
- package/dist/interface/chat/mutation-tool-defs.js.map +1 -1
- package/dist/interface/chat/self-knowledge-mutation-tools.d.ts.map +1 -1
- package/dist/interface/chat/self-knowledge-mutation-tools.js +20 -3
- package/dist/interface/chat/self-knowledge-mutation-tools.js.map +1 -1
- package/dist/interface/chat/self-knowledge-tools.js +2 -2
- package/dist/interface/chat/self-knowledge-tools.js.map +1 -1
- package/dist/interface/chat/tend-command.d.ts +1 -1
- package/dist/interface/cli/cli-command-registry.js +1 -1
- package/dist/interface/cli/cli-command-registry.js.map +1 -1
- package/dist/interface/cli/commands/chat.d.ts.map +1 -1
- package/dist/interface/cli/commands/chat.js +46 -13
- package/dist/interface/cli/commands/chat.js.map +1 -1
- package/dist/interface/cli/commands/config.d.ts.map +1 -1
- package/dist/interface/cli/commands/config.js +37 -6
- package/dist/interface/cli/commands/config.js.map +1 -1
- package/dist/interface/cli/commands/daemon.d.ts.map +1 -1
- package/dist/interface/cli/commands/daemon.js +105 -50
- package/dist/interface/cli/commands/daemon.js.map +1 -1
- package/dist/interface/cli/commands/doctor.d.ts +1 -1
- package/dist/interface/cli/commands/doctor.d.ts.map +1 -1
- package/dist/interface/cli/commands/doctor.js +5 -7
- package/dist/interface/cli/commands/doctor.js.map +1 -1
- package/dist/interface/cli/commands/presets/root-presets.d.ts +3 -3
- package/dist/interface/cli/commands/presets/root-presets.d.ts.map +1 -1
- package/dist/interface/cli/commands/presets/root-presets.js +8 -5
- package/dist/interface/cli/commands/presets/root-presets.js.map +1 -1
- package/dist/interface/cli/commands/schedule.d.ts.map +1 -1
- package/dist/interface/cli/commands/schedule.js +166 -13
- package/dist/interface/cli/commands/schedule.js.map +1 -1
- package/dist/interface/cli/commands/setup/steps-runtime.js +1 -1
- package/dist/interface/cli/ensure-api-key.d.ts +4 -1
- package/dist/interface/cli/ensure-api-key.d.ts.map +1 -1
- package/dist/interface/cli/ensure-api-key.js +52 -15
- package/dist/interface/cli/ensure-api-key.js.map +1 -1
- package/dist/interface/cli/setup.d.ts +9 -0
- package/dist/interface/cli/setup.d.ts.map +1 -1
- package/dist/interface/cli/setup.js +43 -20
- package/dist/interface/cli/setup.js.map +1 -1
- package/dist/interface/cli/utils.d.ts.map +1 -1
- package/dist/interface/cli/utils.js +5 -1
- package/dist/interface/cli/utils.js.map +1 -1
- package/dist/interface/tui/app.d.ts +1 -1
- package/dist/interface/tui/app.d.ts.map +1 -1
- package/dist/interface/tui/app.js +8 -12
- package/dist/interface/tui/app.js.map +1 -1
- package/dist/interface/tui/chat/scroll.d.ts +14 -0
- package/dist/interface/tui/chat/scroll.d.ts.map +1 -0
- package/dist/interface/tui/chat/scroll.js +46 -0
- package/dist/interface/tui/chat/scroll.js.map +1 -0
- package/dist/interface/tui/chat/suggestions.d.ts +8 -0
- package/dist/interface/tui/chat/suggestions.d.ts.map +1 -0
- package/dist/interface/tui/chat/suggestions.js +112 -0
- package/dist/interface/tui/chat/suggestions.js.map +1 -0
- package/dist/interface/tui/chat/types.d.ts +31 -0
- package/dist/interface/tui/chat/types.d.ts.map +1 -0
- package/dist/interface/tui/chat/types.js +2 -0
- package/dist/interface/tui/chat/types.js.map +1 -0
- package/dist/interface/tui/chat/viewport.d.ts +3 -0
- package/dist/interface/tui/chat/viewport.d.ts.map +1 -0
- package/dist/interface/tui/chat/viewport.js +78 -0
- package/dist/interface/tui/chat/viewport.js.map +1 -0
- package/dist/interface/tui/chat.d.ts +5 -49
- package/dist/interface/tui/chat.d.ts.map +1 -1
- package/dist/interface/tui/chat.js +9 -238
- package/dist/interface/tui/chat.js.map +1 -1
- package/dist/interface/tui/checkerboard-spinner.d.ts +3 -0
- package/dist/interface/tui/checkerboard-spinner.d.ts.map +1 -0
- package/dist/interface/tui/checkerboard-spinner.js +20 -0
- package/dist/interface/tui/checkerboard-spinner.js.map +1 -0
- package/dist/interface/tui/dashboard.js +2 -2
- package/dist/interface/tui/dashboard.js.map +1 -1
- package/dist/interface/tui/entry.d.ts.map +1 -1
- package/dist/interface/tui/entry.js +51 -7
- package/dist/interface/tui/entry.js.map +1 -1
- package/dist/interface/tui/use-loop.d.ts +1 -1
- package/dist/orchestrator/ethics-gate.d.ts +3 -0
- package/dist/orchestrator/ethics-gate.d.ts.map +1 -0
- package/dist/orchestrator/ethics-gate.js +2 -0
- package/dist/orchestrator/ethics-gate.js.map +1 -0
- package/dist/orchestrator/execution/context/context-builder.d.ts +8 -0
- package/dist/orchestrator/execution/context/context-builder.d.ts.map +1 -1
- package/dist/orchestrator/execution/context/context-builder.js +38 -0
- package/dist/orchestrator/execution/context/context-builder.js.map +1 -1
- package/dist/orchestrator/execution/parallel-execution-types.d.ts +7 -0
- package/dist/orchestrator/execution/parallel-execution-types.d.ts.map +1 -0
- package/dist/orchestrator/execution/parallel-execution-types.js +2 -0
- package/dist/orchestrator/execution/parallel-execution-types.js.map +1 -0
- package/dist/orchestrator/execution/parallel-executor.d.ts +2 -6
- package/dist/orchestrator/execution/parallel-executor.d.ts.map +1 -1
- package/dist/orchestrator/execution/parallel-executor.js.map +1 -1
- package/dist/orchestrator/execution/result-reconciler.d.ts +1 -1
- package/dist/orchestrator/execution/result-reconciler.d.ts.map +1 -1
- package/dist/orchestrator/execution/task/task-lifecycle.d.ts +8 -10
- package/dist/orchestrator/execution/task/task-lifecycle.d.ts.map +1 -1
- package/dist/orchestrator/execution/task/task-lifecycle.js +28 -1
- package/dist/orchestrator/execution/task/task-lifecycle.js.map +1 -1
- package/dist/orchestrator/execution/task/task-pipeline-cycle.d.ts +5 -35
- package/dist/orchestrator/execution/task/task-pipeline-cycle.d.ts.map +1 -1
- package/dist/orchestrator/execution/task/task-pipeline-cycle.js.map +1 -1
- package/dist/orchestrator/execution/task/task-pipeline-types.d.ts +39 -0
- package/dist/orchestrator/execution/task/task-pipeline-types.d.ts.map +1 -0
- package/dist/orchestrator/execution/task/task-pipeline-types.js +2 -0
- package/dist/orchestrator/execution/task/task-pipeline-types.js.map +1 -0
- package/dist/orchestrator/execution/task/task-verifier-rules.d.ts.map +1 -1
- package/dist/orchestrator/execution/task/task-verifier-rules.js +34 -2
- package/dist/orchestrator/execution/task/task-verifier-rules.js.map +1 -1
- package/dist/orchestrator/execution/task/task-verifier-types.d.ts +2 -0
- package/dist/orchestrator/execution/task/task-verifier-types.d.ts.map +1 -1
- package/dist/orchestrator/goal/goal-negotiator.d.ts.map +1 -1
- package/dist/orchestrator/goal/goal-negotiator.js +2 -1
- package/dist/orchestrator/goal/goal-negotiator.js.map +1 -1
- package/dist/orchestrator/goal/goal-refiner.d.ts.map +1 -1
- package/dist/orchestrator/goal/goal-refiner.js +1 -1
- package/dist/orchestrator/goal/goal-refiner.js.map +1 -1
- package/dist/orchestrator/goal/goal-tree-manager.d.ts +2 -2
- package/dist/orchestrator/goal/goal-tree-manager.d.ts.map +1 -1
- package/dist/orchestrator/goal/goal-tree-manager.js.map +1 -1
- package/dist/orchestrator/goal/negotiator-feasibility.d.ts +10 -0
- package/dist/orchestrator/goal/negotiator-feasibility.d.ts.map +1 -0
- package/dist/orchestrator/goal/negotiator-feasibility.js +55 -0
- package/dist/orchestrator/goal/negotiator-feasibility.js.map +1 -0
- package/dist/orchestrator/goal/negotiator-steps.d.ts +1 -6
- package/dist/orchestrator/goal/negotiator-steps.d.ts.map +1 -1
- package/dist/orchestrator/goal/negotiator-steps.js +4 -56
- package/dist/orchestrator/goal/negotiator-steps.js.map +1 -1
- package/dist/orchestrator/knowledge/knowledge-manager.d.ts +2 -0
- package/dist/orchestrator/knowledge/knowledge-manager.d.ts.map +1 -0
- package/dist/orchestrator/knowledge/knowledge-manager.js +2 -0
- package/dist/orchestrator/knowledge/knowledge-manager.js.map +1 -0
- package/dist/orchestrator/knowledge/memory/memory-lifecycle.d.ts +2 -0
- package/dist/orchestrator/knowledge/memory/memory-lifecycle.d.ts.map +1 -0
- package/dist/orchestrator/knowledge/memory/memory-lifecycle.js +2 -0
- package/dist/orchestrator/knowledge/memory/memory-lifecycle.js.map +1 -0
- package/dist/orchestrator/knowledge/transfer/knowledge-transfer.d.ts +2 -0
- package/dist/orchestrator/knowledge/transfer/knowledge-transfer.d.ts.map +1 -0
- package/dist/orchestrator/knowledge/transfer/knowledge-transfer.js +2 -0
- package/dist/orchestrator/knowledge/transfer/knowledge-transfer.js.map +1 -0
- package/dist/orchestrator/loop/checkpoint-manager-loop.d.ts +1 -1
- package/dist/orchestrator/loop/checkpoint-manager-loop.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop/capability.d.ts +22 -0
- package/dist/orchestrator/loop/core-loop/capability.d.ts.map +1 -0
- package/dist/orchestrator/loop/core-loop/capability.js +151 -0
- package/dist/orchestrator/loop/core-loop/capability.js.map +1 -0
- package/dist/orchestrator/loop/core-loop/contracts.d.ts +245 -0
- package/dist/orchestrator/loop/core-loop/contracts.d.ts.map +1 -0
- package/dist/orchestrator/loop/core-loop/contracts.js +40 -0
- package/dist/orchestrator/loop/core-loop/contracts.js.map +1 -0
- package/dist/orchestrator/loop/core-loop/control.d.ts +27 -0
- package/dist/orchestrator/loop/core-loop/control.d.ts.map +1 -0
- package/dist/orchestrator/loop/core-loop/control.js +72 -0
- package/dist/orchestrator/loop/core-loop/control.js.map +1 -0
- package/dist/orchestrator/loop/core-loop/learning.d.ts +31 -0
- package/dist/orchestrator/loop/core-loop/learning.d.ts.map +1 -0
- package/dist/orchestrator/loop/core-loop/learning.js +92 -0
- package/dist/orchestrator/loop/core-loop/learning.js.map +1 -0
- package/dist/orchestrator/loop/core-loop/preparation.d.ts +63 -0
- package/dist/orchestrator/loop/core-loop/preparation.d.ts.map +1 -0
- package/dist/orchestrator/loop/core-loop/preparation.js +362 -0
- package/dist/orchestrator/loop/core-loop/preparation.js.map +1 -0
- package/dist/orchestrator/loop/core-loop/task-cycle.d.ts +29 -0
- package/dist/orchestrator/loop/core-loop/task-cycle.d.ts.map +1 -0
- package/dist/orchestrator/loop/core-loop/task-cycle.js +674 -0
- package/dist/orchestrator/loop/core-loop/task-cycle.js.map +1 -0
- package/dist/orchestrator/loop/core-loop-capability.d.ts +1 -18
- package/dist/orchestrator/loop/core-loop-capability.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop-capability.js +1 -106
- package/dist/orchestrator/loop/core-loop-capability.js.map +1 -1
- package/dist/orchestrator/loop/core-loop-learning.d.ts +1 -34
- package/dist/orchestrator/loop/core-loop-learning.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop-learning.js +1 -95
- package/dist/orchestrator/loop/core-loop-learning.js.map +1 -1
- package/dist/orchestrator/loop/core-loop-phases-b.d.ts +1 -30
- package/dist/orchestrator/loop/core-loop-phases-b.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop-phases-b.js +1 -590
- package/dist/orchestrator/loop/core-loop-phases-b.js.map +1 -1
- package/dist/orchestrator/loop/core-loop-phases-c.d.ts +1 -26
- package/dist/orchestrator/loop/core-loop-phases-c.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop-phases-c.js +1 -71
- package/dist/orchestrator/loop/core-loop-phases-c.js.map +1 -1
- package/dist/orchestrator/loop/core-loop-phases.d.ts +1 -68
- package/dist/orchestrator/loop/core-loop-phases.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop-phases.js +1 -367
- package/dist/orchestrator/loop/core-loop-phases.js.map +1 -1
- package/dist/orchestrator/loop/core-loop-types.d.ts +1 -307
- package/dist/orchestrator/loop/core-loop-types.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop-types.js +1 -64
- package/dist/orchestrator/loop/core-loop-types.js.map +1 -1
- package/dist/orchestrator/loop/core-loop.d.ts +6 -3
- package/dist/orchestrator/loop/core-loop.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop.js +92 -8
- package/dist/orchestrator/loop/core-loop.js.map +1 -1
- package/dist/orchestrator/loop/loop-report-helper.d.ts +1 -1
- package/dist/orchestrator/loop/loop-report-helper.d.ts.map +1 -1
- package/dist/orchestrator/loop/loop-result-types.d.ts +67 -0
- package/dist/orchestrator/loop/loop-result-types.d.ts.map +1 -0
- package/dist/orchestrator/loop/loop-result-types.js +27 -0
- package/dist/orchestrator/loop/loop-result-types.js.map +1 -0
- package/dist/orchestrator/loop/parallel-dispatch.d.ts +2 -2
- package/dist/orchestrator/loop/parallel-dispatch.d.ts.map +1 -1
- package/dist/orchestrator/loop/post-loop-hooks.d.ts +4 -1
- package/dist/orchestrator/loop/post-loop-hooks.d.ts.map +1 -1
- package/dist/orchestrator/loop/post-loop-hooks.js +19 -1
- package/dist/orchestrator/loop/post-loop-hooks.js.map +1 -1
- package/dist/orchestrator/loop/tree-loop-runner.d.ts +1 -1
- package/dist/orchestrator/loop/tree-loop-runner.d.ts.map +1 -1
- package/dist/orchestrator/loop/tree-loop-runner.js +1 -1
- package/dist/orchestrator/loop/tree-loop-runner.js.map +1 -1
- package/dist/orchestrator/observation/capability-detector.d.ts +2 -0
- package/dist/orchestrator/observation/capability-detector.d.ts.map +1 -0
- package/dist/orchestrator/observation/capability-detector.js +2 -0
- package/dist/orchestrator/observation/capability-detector.js.map +1 -0
- package/dist/orchestrator/strategy/strategy-manager-base.d.ts +1 -0
- package/dist/orchestrator/strategy/strategy-manager-base.d.ts.map +1 -1
- package/dist/orchestrator/strategy/strategy-manager-base.js +48 -4
- package/dist/orchestrator/strategy/strategy-manager-base.js.map +1 -1
- package/dist/orchestrator/strategy-manager.d.ts +2 -0
- package/dist/orchestrator/strategy-manager.d.ts.map +1 -0
- package/dist/orchestrator/strategy-manager.js +2 -0
- package/dist/orchestrator/strategy-manager.js.map +1 -0
- package/dist/platform/dream/dream-activation.d.ts +52 -0
- package/dist/platform/dream/dream-activation.d.ts.map +1 -0
- package/dist/platform/dream/dream-activation.js +199 -0
- package/dist/platform/dream/dream-activation.js.map +1 -0
- package/dist/platform/dream/dream-analyzer.d.ts +53 -0
- package/dist/platform/dream/dream-analyzer.d.ts.map +1 -0
- package/dist/platform/dream/dream-analyzer.js +489 -0
- package/dist/platform/dream/dream-analyzer.js.map +1 -0
- package/dist/platform/dream/dream-config.d.ts +6 -0
- package/dist/platform/dream/dream-config.d.ts.map +1 -0
- package/dist/platform/dream/dream-config.js +20 -0
- package/dist/platform/dream/dream-config.js.map +1 -0
- package/dist/platform/dream/dream-consolidator.d.ts +35 -0
- package/dist/platform/dream/dream-consolidator.d.ts.map +1 -0
- package/dist/platform/dream/dream-consolidator.js +304 -0
- package/dist/platform/dream/dream-consolidator.js.map +1 -0
- package/dist/platform/dream/dream-importance.d.ts +24 -0
- package/dist/platform/dream/dream-importance.d.ts.map +1 -0
- package/dist/platform/dream/dream-importance.js +71 -0
- package/dist/platform/dream/dream-importance.js.map +1 -0
- package/dist/platform/dream/dream-log-collector.d.ts +73 -0
- package/dist/platform/dream/dream-log-collector.d.ts.map +1 -0
- package/dist/platform/dream/dream-log-collector.js +256 -0
- package/dist/platform/dream/dream-log-collector.js.map +1 -0
- package/dist/platform/dream/dream-log-store.d.ts +22 -0
- package/dist/platform/dream/dream-log-store.d.ts.map +1 -0
- package/dist/platform/dream/dream-log-store.js +150 -0
- package/dist/platform/dream/dream-log-store.js.map +1 -0
- package/dist/platform/dream/dream-schedule-suggestions.d.ts +26 -0
- package/dist/platform/dream/dream-schedule-suggestions.d.ts.map +1 -0
- package/dist/platform/dream/dream-schedule-suggestions.js +195 -0
- package/dist/platform/dream/dream-schedule-suggestions.js.map +1 -0
- package/dist/platform/dream/dream-types.d.ts +2587 -0
- package/dist/platform/dream/dream-types.d.ts.map +1 -0
- package/dist/platform/dream/dream-types.js +265 -0
- package/dist/platform/dream/dream-types.js.map +1 -0
- package/dist/platform/dream/index.d.ts +6 -0
- package/dist/platform/dream/index.d.ts.map +1 -0
- package/dist/platform/dream/index.js +6 -0
- package/dist/platform/dream/index.js.map +1 -0
- package/dist/platform/drive/drive-system.d.ts +8 -0
- package/dist/platform/drive/drive-system.d.ts.map +1 -1
- package/dist/platform/drive/drive-system.js +39 -22
- package/dist/platform/drive/drive-system.js.map +1 -1
- package/dist/platform/ethics-gate.d.ts +2 -0
- package/dist/platform/ethics-gate.d.ts.map +1 -0
- package/dist/platform/ethics-gate.js +2 -0
- package/dist/platform/ethics-gate.js.map +1 -0
- package/dist/platform/execution/task/task-lifecycle.d.ts +2 -0
- package/dist/platform/execution/task/task-lifecycle.d.ts.map +1 -0
- package/dist/platform/execution/task/task-lifecycle.js +2 -0
- package/dist/platform/execution/task/task-lifecycle.js.map +1 -0
- package/dist/platform/knowledge/transfer/knowledge-transfer-apply.d.ts.map +1 -1
- package/dist/platform/knowledge/transfer/knowledge-transfer-apply.js +6 -0
- package/dist/platform/knowledge/transfer/knowledge-transfer-apply.js.map +1 -1
- package/dist/platform/knowledge/transfer/knowledge-transfer-detect.d.ts.map +1 -1
- package/dist/platform/knowledge/transfer/knowledge-transfer-detect.js +32 -0
- package/dist/platform/knowledge/transfer/knowledge-transfer-detect.js.map +1 -1
- package/dist/platform/knowledge/transfer/knowledge-transfer.d.ts +18 -1
- package/dist/platform/knowledge/transfer/knowledge-transfer.d.ts.map +1 -1
- package/dist/platform/knowledge/transfer/knowledge-transfer.js +121 -6
- package/dist/platform/knowledge/transfer/knowledge-transfer.js.map +1 -1
- package/dist/platform/observation/capability-detector.d.ts +8 -0
- package/dist/platform/observation/capability-detector.d.ts.map +1 -1
- package/dist/platform/observation/capability-detector.js +71 -4
- package/dist/platform/observation/capability-detector.js.map +1 -1
- package/dist/platform/observation/data-source-adapter.d.ts +19 -0
- package/dist/platform/observation/data-source-adapter.d.ts.map +1 -1
- package/dist/platform/observation/data-source-adapter.js +166 -0
- package/dist/platform/observation/data-source-adapter.js.map +1 -1
- package/dist/platform/observation/engine/observe-context.d.ts +4 -0
- package/dist/platform/observation/engine/observe-context.d.ts.map +1 -0
- package/dist/platform/observation/engine/observe-context.js +26 -0
- package/dist/platform/observation/engine/observe-context.js.map +1 -0
- package/dist/platform/observation/engine/observe-datasource-stage.d.ts +33 -0
- package/dist/platform/observation/engine/observe-datasource-stage.d.ts.map +1 -0
- package/dist/platform/observation/engine/observe-datasource-stage.js +66 -0
- package/dist/platform/observation/engine/observe-datasource-stage.js.map +1 -0
- package/dist/platform/observation/engine/observe-llm-stage.d.ts +25 -0
- package/dist/platform/observation/engine/observe-llm-stage.d.ts.map +1 -0
- package/dist/platform/observation/engine/observe-llm-stage.js +79 -0
- package/dist/platform/observation/engine/observe-llm-stage.js.map +1 -0
- package/dist/platform/observation/engine/observe-precheck.d.ts +21 -0
- package/dist/platform/observation/engine/observe-precheck.d.ts.map +1 -0
- package/dist/platform/observation/engine/observe-precheck.js +51 -0
- package/dist/platform/observation/engine/observe-precheck.js.map +1 -0
- package/dist/platform/observation/engine/observe-self-report.d.ts +18 -0
- package/dist/platform/observation/engine/observe-self-report.d.ts.map +1 -0
- package/dist/platform/observation/engine/observe-self-report.js +26 -0
- package/dist/platform/observation/engine/observe-self-report.js.map +1 -0
- package/dist/platform/observation/engine/observe-tool-stage.d.ts +21 -0
- package/dist/platform/observation/engine/observe-tool-stage.d.ts.map +1 -0
- package/dist/platform/observation/engine/observe-tool-stage.js +49 -0
- package/dist/platform/observation/engine/observe-tool-stage.js.map +1 -0
- package/dist/platform/observation/observation-engine.d.ts.map +1 -1
- package/dist/platform/observation/observation-engine.js +67 -246
- package/dist/platform/observation/observation-engine.js.map +1 -1
- package/dist/platform/observation/observation-helpers.d.ts +6 -0
- package/dist/platform/observation/observation-helpers.d.ts.map +1 -1
- package/dist/platform/observation/observation-helpers.js +2 -0
- package/dist/platform/observation/observation-helpers.js.map +1 -1
- package/dist/platform/observation/types/data-source.d.ts +12 -0
- package/dist/platform/observation/types/data-source.d.ts.map +1 -1
- package/dist/platform/observation/types/data-source.js +1 -0
- package/dist/platform/observation/types/data-source.js.map +1 -1
- package/dist/platform/runtime/plugin-loader.d.ts +2 -0
- package/dist/platform/runtime/plugin-loader.d.ts.map +1 -0
- package/dist/platform/runtime/plugin-loader.js +2 -0
- package/dist/platform/runtime/plugin-loader.js.map +1 -0
- package/dist/platform/tools/executor.d.ts +2 -0
- package/dist/platform/tools/executor.d.ts.map +1 -0
- package/dist/platform/tools/executor.js +2 -0
- package/dist/platform/tools/executor.js.map +1 -0
- package/dist/prompt/context-assembler.d.ts +61 -13
- package/dist/prompt/context-assembler.d.ts.map +1 -1
- package/dist/prompt/context-assembler.js +18 -3
- package/dist/prompt/context-assembler.js.map +1 -1
- package/dist/prompt/purposes/dream.d.ts +9 -0
- package/dist/prompt/purposes/dream.d.ts.map +1 -0
- package/dist/prompt/purposes/dream.js +71 -0
- package/dist/prompt/purposes/dream.js.map +1 -0
- package/dist/prompt/purposes/index.d.ts +1 -0
- package/dist/prompt/purposes/index.d.ts.map +1 -1
- package/dist/prompt/purposes/index.js +1 -0
- package/dist/prompt/purposes/index.js.map +1 -1
- package/dist/reporting/report-formatters.d.ts +1 -1
- package/dist/reporting/report-formatters.d.ts.map +1 -1
- package/dist/reporting/reporting-engine.d.ts +2 -24
- package/dist/reporting/reporting-engine.d.ts.map +1 -1
- package/dist/reporting/reporting-engine.js +0 -1
- package/dist/reporting/reporting-engine.js.map +1 -1
- package/dist/reporting/reporting-types.d.ts +25 -0
- package/dist/reporting/reporting-types.d.ts.map +1 -0
- package/dist/reporting/reporting-types.js +2 -0
- package/dist/reporting/reporting-types.js.map +1 -0
- package/dist/runtime/approval-broker.d.ts +44 -0
- package/dist/runtime/approval-broker.d.ts.map +1 -0
- package/dist/runtime/approval-broker.js +141 -0
- package/dist/runtime/approval-broker.js.map +1 -0
- package/dist/runtime/command-dispatcher.d.ts +35 -0
- package/dist/runtime/command-dispatcher.d.ts.map +1 -0
- package/dist/runtime/command-dispatcher.js +145 -0
- package/dist/runtime/command-dispatcher.js.map +1 -0
- package/dist/runtime/daemon/client.d.ts +67 -0
- package/dist/runtime/daemon/client.d.ts.map +1 -0
- package/dist/runtime/daemon/client.js +330 -0
- package/dist/runtime/daemon/client.js.map +1 -0
- package/dist/runtime/daemon/health.d.ts +31 -0
- package/dist/runtime/daemon/health.d.ts.map +1 -0
- package/dist/runtime/daemon/health.js +113 -0
- package/dist/runtime/daemon/health.js.map +1 -0
- package/dist/runtime/daemon/index.d.ts +9 -0
- package/dist/runtime/daemon/index.d.ts.map +1 -0
- package/dist/runtime/daemon/index.js +8 -0
- package/dist/runtime/daemon/index.js.map +1 -0
- package/dist/runtime/daemon/maintenance.d.ts +47 -0
- package/dist/runtime/daemon/maintenance.d.ts.map +1 -0
- package/dist/runtime/daemon/maintenance.js +230 -0
- package/dist/runtime/daemon/maintenance.js.map +1 -0
- package/dist/runtime/daemon/persistence.d.ts +20 -0
- package/dist/runtime/daemon/persistence.d.ts.map +1 -0
- package/dist/runtime/daemon/persistence.js +112 -0
- package/dist/runtime/daemon/persistence.js.map +1 -0
- package/dist/runtime/daemon/runner-lifecycle.d.ts +29 -0
- package/dist/runtime/daemon/runner-lifecycle.d.ts.map +1 -0
- package/dist/runtime/daemon/runner-lifecycle.js +56 -0
- package/dist/runtime/daemon/runner-lifecycle.js.map +1 -0
- package/dist/runtime/daemon/runner.d.ts +229 -0
- package/dist/runtime/daemon/runner.d.ts.map +1 -0
- package/dist/runtime/daemon/runner.js +875 -0
- package/dist/runtime/daemon/runner.js.map +1 -0
- package/dist/runtime/daemon/runtime-ownership.d.ts +30 -0
- package/dist/runtime/daemon/runtime-ownership.d.ts.map +1 -0
- package/dist/runtime/daemon/runtime-ownership.js +132 -0
- package/dist/runtime/daemon/runtime-ownership.js.map +1 -0
- package/dist/runtime/daemon/signals.d.ts +17 -0
- package/dist/runtime/daemon/signals.d.ts.map +1 -0
- package/dist/runtime/daemon/signals.js +31 -0
- package/dist/runtime/daemon/signals.js.map +1 -0
- package/dist/runtime/daemon/types.d.ts +8 -0
- package/dist/runtime/daemon/types.d.ts.map +1 -0
- package/dist/runtime/daemon/types.js +2 -0
- package/dist/runtime/daemon/types.js.map +1 -0
- package/dist/runtime/daemon-client.d.ts +1 -55
- package/dist/runtime/daemon-client.d.ts.map +1 -1
- package/dist/runtime/daemon-client.js +1 -297
- package/dist/runtime/daemon-client.js.map +1 -1
- package/dist/runtime/daemon-health.d.ts +1 -30
- package/dist/runtime/daemon-health.d.ts.map +1 -1
- package/dist/runtime/daemon-health.js +1 -112
- package/dist/runtime/daemon-health.js.map +1 -1
- package/dist/runtime/daemon-runner-lifecycle.d.ts +2 -0
- package/dist/runtime/daemon-runner-lifecycle.d.ts.map +1 -0
- package/dist/runtime/daemon-runner-lifecycle.js +2 -0
- package/dist/runtime/daemon-runner-lifecycle.js.map +1 -0
- package/dist/runtime/daemon-runner.d.ts +1 -209
- package/dist/runtime/daemon-runner.d.ts.map +1 -1
- package/dist/runtime/daemon-runner.js +1 -874
- package/dist/runtime/daemon-runner.js.map +1 -1
- package/dist/runtime/daemon-runtime-ownership.d.ts +2 -0
- package/dist/runtime/daemon-runtime-ownership.d.ts.map +1 -0
- package/dist/runtime/daemon-runtime-ownership.js +2 -0
- package/dist/runtime/daemon-runtime-ownership.js.map +1 -0
- package/dist/runtime/daemon-signals.d.ts +1 -16
- package/dist/runtime/daemon-signals.d.ts.map +1 -1
- package/dist/runtime/daemon-signals.js +1 -30
- package/dist/runtime/daemon-signals.js.map +1 -1
- package/dist/runtime/event/dispatcher.d.ts +34 -0
- package/dist/runtime/event/dispatcher.d.ts.map +1 -0
- package/dist/runtime/event/dispatcher.js +124 -0
- package/dist/runtime/event/dispatcher.js.map +1 -0
- package/dist/runtime/event/index.d.ts +5 -0
- package/dist/runtime/event/index.d.ts.map +1 -0
- package/dist/runtime/event/index.js +5 -0
- package/dist/runtime/event/index.js.map +1 -0
- package/dist/runtime/event/server-snapshot-reader.d.ts +31 -0
- package/dist/runtime/event/server-snapshot-reader.d.ts.map +1 -0
- package/dist/runtime/event/server-snapshot-reader.js +94 -0
- package/dist/runtime/event/server-snapshot-reader.js.map +1 -0
- package/dist/runtime/event/server-sse.d.ts +25 -0
- package/dist/runtime/event/server-sse.d.ts.map +1 -0
- package/dist/runtime/event/server-sse.js +149 -0
- package/dist/runtime/event/server-sse.js.map +1 -0
- package/dist/runtime/event/server.d.ts +114 -0
- package/dist/runtime/event/server.d.ts.map +1 -0
- package/dist/runtime/event/server.js +651 -0
- package/dist/runtime/event/server.js.map +1 -0
- package/dist/runtime/event-dispatcher.d.ts +2 -0
- package/dist/runtime/event-dispatcher.d.ts.map +1 -0
- package/dist/runtime/event-dispatcher.js +2 -0
- package/dist/runtime/event-dispatcher.js.map +1 -0
- package/dist/runtime/event-server-snapshot-reader.d.ts +2 -0
- package/dist/runtime/event-server-snapshot-reader.d.ts.map +1 -0
- package/dist/runtime/event-server-snapshot-reader.js +2 -0
- package/dist/runtime/event-server-snapshot-reader.js.map +1 -0
- package/dist/runtime/event-server-sse.d.ts +2 -0
- package/dist/runtime/event-server-sse.d.ts.map +1 -0
- package/dist/runtime/event-server-sse.js +2 -0
- package/dist/runtime/event-server-sse.js.map +1 -0
- package/dist/runtime/event-server.d.ts +1 -81
- package/dist/runtime/event-server.d.ts.map +1 -1
- package/dist/runtime/event-server.js +1 -599
- package/dist/runtime/event-server.js.map +1 -1
- package/dist/runtime/executor/loop-supervisor.d.ts +25 -2
- package/dist/runtime/executor/loop-supervisor.d.ts.map +1 -1
- package/dist/runtime/executor/loop-supervisor.js +249 -57
- package/dist/runtime/executor/loop-supervisor.js.map +1 -1
- package/dist/runtime/gateway/http-channel-adapter.d.ts +1 -1
- package/dist/runtime/gateway/http-channel-adapter.js +2 -2
- package/dist/runtime/gateway/http-channel-adapter.js.map +1 -1
- package/dist/runtime/gateway/ingress-gateway.js +1 -1
- package/dist/runtime/gateway/ingress-gateway.js.map +1 -1
- package/dist/runtime/goal-lease-manager.d.ts +35 -0
- package/dist/runtime/goal-lease-manager.d.ts.map +1 -0
- package/dist/runtime/goal-lease-manager.js +191 -0
- package/dist/runtime/goal-lease-manager.js.map +1 -0
- package/dist/runtime/hook-manager.d.ts +4 -0
- package/dist/runtime/hook-manager.d.ts.map +1 -1
- package/dist/runtime/hook-manager.js +33 -0
- package/dist/runtime/hook-manager.js.map +1 -1
- package/dist/runtime/leader-lock-manager.d.ts +30 -0
- package/dist/runtime/leader-lock-manager.d.ts.map +1 -0
- package/dist/runtime/leader-lock-manager.js +160 -0
- package/dist/runtime/leader-lock-manager.js.map +1 -0
- package/dist/runtime/notification-dispatcher.d.ts +2 -0
- package/dist/runtime/notification-dispatcher.d.ts.map +1 -1
- package/dist/runtime/notification-dispatcher.js +12 -0
- package/dist/runtime/notification-dispatcher.js.map +1 -1
- package/dist/runtime/plugin-loader.d.ts +1 -1
- package/dist/runtime/queue/index.d.ts +4 -4
- package/dist/runtime/queue/index.d.ts.map +1 -1
- package/dist/runtime/queue/index.js +2 -2
- package/dist/runtime/queue/index.js.map +1 -1
- package/dist/runtime/queue/journal-backed-queue.d.ts +80 -0
- package/dist/runtime/queue/journal-backed-queue.d.ts.map +1 -0
- package/dist/runtime/queue/journal-backed-queue.js +511 -0
- package/dist/runtime/queue/journal-backed-queue.js.map +1 -0
- package/dist/runtime/queue/queue-claim-sweeper.d.ts +15 -0
- package/dist/runtime/queue/queue-claim-sweeper.d.ts.map +1 -0
- package/dist/runtime/queue/queue-claim-sweeper.js +28 -0
- package/dist/runtime/queue/queue-claim-sweeper.js.map +1 -0
- package/dist/runtime/schedule/engine-layers.d.ts +44 -0
- package/dist/runtime/schedule/engine-layers.d.ts.map +1 -0
- package/dist/runtime/schedule/engine-layers.js +433 -0
- package/dist/runtime/schedule/engine-layers.js.map +1 -0
- package/dist/runtime/schedule/engine.d.ts +82 -0
- package/dist/runtime/schedule/engine.d.ts.map +1 -0
- package/dist/runtime/schedule/engine.js +480 -0
- package/dist/runtime/schedule/engine.js.map +1 -0
- package/dist/runtime/schedule/index.d.ts +5 -0
- package/dist/runtime/schedule/index.d.ts.map +1 -0
- package/dist/runtime/schedule/index.js +5 -0
- package/dist/runtime/schedule/index.js.map +1 -0
- package/dist/runtime/schedule/presets.d.ts +536 -0
- package/dist/runtime/schedule/presets.d.ts.map +1 -0
- package/dist/runtime/schedule/presets.js +166 -0
- package/dist/runtime/schedule/presets.js.map +1 -0
- package/dist/runtime/schedule/source.d.ts +65 -0
- package/dist/runtime/schedule/source.d.ts.map +1 -0
- package/dist/runtime/schedule/source.js +16 -0
- package/dist/runtime/schedule/source.js.map +1 -0
- package/dist/runtime/schedule-engine-layers.d.ts +1 -37
- package/dist/runtime/schedule-engine-layers.d.ts.map +1 -1
- package/dist/runtime/schedule-engine-layers.js +1 -301
- package/dist/runtime/schedule-engine-layers.js.map +1 -1
- package/dist/runtime/schedule-engine.d.ts +1 -61
- package/dist/runtime/schedule-engine.d.ts.map +1 -1
- package/dist/runtime/schedule-engine.js +1 -397
- package/dist/runtime/schedule-engine.js.map +1 -1
- package/dist/runtime/schedule-presets.d.ts +2 -0
- package/dist/runtime/schedule-presets.d.ts.map +1 -0
- package/dist/runtime/schedule-presets.js +2 -0
- package/dist/runtime/schedule-presets.js.map +1 -0
- package/dist/runtime/schedule-source.d.ts +1 -64
- package/dist/runtime/schedule-source.d.ts.map +1 -1
- package/dist/runtime/schedule-source.js +1 -15
- package/dist/runtime/schedule-source.js.map +1 -1
- package/dist/runtime/store/approval-store.d.ts +26 -0
- package/dist/runtime/store/approval-store.d.ts.map +1 -0
- package/dist/runtime/store/approval-store.js +119 -0
- package/dist/runtime/store/approval-store.js.map +1 -0
- package/dist/runtime/store/health-store.d.ts +16 -0
- package/dist/runtime/store/health-store.d.ts.map +1 -0
- package/dist/runtime/store/health-store.js +68 -0
- package/dist/runtime/store/health-store.js.map +1 -0
- package/dist/runtime/store/index.d.ts +10 -0
- package/dist/runtime/store/index.d.ts.map +1 -0
- package/dist/runtime/store/index.js +7 -0
- package/dist/runtime/store/index.js.map +1 -0
- package/dist/runtime/store/outbox-store.d.ts +16 -0
- package/dist/runtime/store/outbox-store.d.ts.map +1 -0
- package/dist/runtime/store/outbox-store.js +92 -0
- package/dist/runtime/store/outbox-store.js.map +1 -0
- package/dist/runtime/store/runtime-journal.d.ts +19 -0
- package/dist/runtime/store/runtime-journal.d.ts.map +1 -0
- package/dist/runtime/store/runtime-journal.js +77 -0
- package/dist/runtime/store/runtime-journal.js.map +1 -0
- package/dist/runtime/store/runtime-paths.d.ts +35 -0
- package/dist/runtime/store/runtime-paths.d.ts.map +1 -0
- package/dist/runtime/store/runtime-paths.js +108 -0
- package/dist/runtime/store/runtime-paths.js.map +1 -0
- package/dist/runtime/store/runtime-schemas.d.ts +218 -0
- package/dist/runtime/store/runtime-schemas.d.ts.map +1 -0
- package/dist/runtime/store/runtime-schemas.js +94 -0
- package/dist/runtime/store/runtime-schemas.js.map +1 -0
- package/dist/runtime/types/daemon.d.ts +6 -0
- package/dist/runtime/types/daemon.d.ts.map +1 -1
- package/dist/runtime/types/daemon.js +3 -0
- package/dist/runtime/types/daemon.js.map +1 -1
- package/dist/runtime/types/hook.d.ts +12 -12
- package/dist/runtime/types/hook.d.ts.map +1 -1
- package/dist/runtime/types/hook.js +1 -0
- package/dist/runtime/types/hook.js.map +1 -1
- package/dist/runtime/types/schedule.d.ts +204 -27
- package/dist/runtime/types/schedule.d.ts.map +1 -1
- package/dist/runtime/types/schedule.js +25 -0
- package/dist/runtime/types/schedule.js.map +1 -1
- package/dist/runtime/watchdog.d.ts +44 -0
- package/dist/runtime/watchdog.d.ts.map +1 -0
- package/dist/runtime/watchdog.js +185 -0
- package/dist/runtime/watchdog.js.map +1 -0
- package/dist/tools/builtin/index.d.ts +15 -0
- package/dist/tools/builtin/index.d.ts.map +1 -1
- package/dist/tools/builtin/index.js +31 -2
- package/dist/tools/builtin/index.js.map +1 -1
- package/dist/tools/execution/MemoryConsolidateTool/MemoryConsolidateTool.d.ts +1 -1
- package/dist/tools/execution/MemoryConsolidateTool/MemoryConsolidateTool.d.ts.map +1 -1
- package/dist/tools/execution/MemoryConsolidateTool/MemoryConsolidateTool.js +6 -5
- package/dist/tools/execution/MemoryConsolidateTool/MemoryConsolidateTool.js.map +1 -1
- package/dist/tools/fs/FileEditTool/FileEditTool.d.ts +1 -1
- package/dist/tools/fs/FileEditTool/FileEditTool.d.ts.map +1 -1
- package/dist/tools/fs/FileEditTool/FileEditTool.js +1 -1
- package/dist/tools/fs/FileEditTool/FileEditTool.js.map +1 -1
- package/dist/tools/fs/FileWriteTool/FileWriteTool.d.ts +1 -1
- package/dist/tools/fs/FileWriteTool/FileWriteTool.d.ts.map +1 -1
- package/dist/tools/fs/FileWriteTool/FileWriteTool.js +1 -1
- package/dist/tools/fs/FileWriteTool/FileWriteTool.js.map +1 -1
- package/dist/tools/fs/GlobTool/GlobTool.d.ts +2 -2
- package/dist/tools/fs/GlobTool/GlobTool.d.ts.map +1 -1
- package/dist/tools/fs/GlobTool/GlobTool.js +2 -2
- package/dist/tools/fs/GlobTool/GlobTool.js.map +1 -1
- package/dist/tools/fs/GrepTool/GrepTool.d.ts +2 -2
- package/dist/tools/fs/GrepTool/GrepTool.d.ts.map +1 -1
- package/dist/tools/fs/GrepTool/GrepTool.js +9 -3
- package/dist/tools/fs/GrepTool/GrepTool.js.map +1 -1
- package/dist/tools/fs/JsonQueryTool/JsonQueryTool.d.ts +2 -2
- package/dist/tools/fs/JsonQueryTool/JsonQueryTool.d.ts.map +1 -1
- package/dist/tools/fs/JsonQueryTool/JsonQueryTool.js +6 -2
- package/dist/tools/fs/JsonQueryTool/JsonQueryTool.js.map +1 -1
- package/dist/tools/fs/ListDirTool/ListDirTool.d.ts +2 -2
- package/dist/tools/fs/ListDirTool/ListDirTool.d.ts.map +1 -1
- package/dist/tools/fs/ListDirTool/ListDirTool.js +2 -2
- package/dist/tools/fs/ListDirTool/ListDirTool.js.map +1 -1
- package/dist/tools/fs/ReadTool/ReadTool.d.ts +1 -1
- package/dist/tools/fs/ReadTool/ReadTool.d.ts.map +1 -1
- package/dist/tools/fs/ReadTool/ReadTool.js +1 -1
- package/dist/tools/fs/ReadTool/ReadTool.js.map +1 -1
- package/dist/tools/mutation/ArchiveGoalTool/ArchiveGoalTool.d.ts +1 -1
- package/dist/tools/mutation/ArchiveGoalTool/ArchiveGoalTool.d.ts.map +1 -1
- package/dist/tools/mutation/ArchiveGoalTool/ArchiveGoalTool.js +1 -1
- package/dist/tools/mutation/ArchiveGoalTool/ArchiveGoalTool.js.map +1 -1
- package/dist/tools/mutation/DeleteGoalTool/DeleteGoalTool.d.ts +1 -1
- package/dist/tools/mutation/DeleteGoalTool/DeleteGoalTool.d.ts.map +1 -1
- package/dist/tools/mutation/DeleteGoalTool/DeleteGoalTool.js +1 -1
- package/dist/tools/mutation/DeleteGoalTool/DeleteGoalTool.js.map +1 -1
- package/dist/tools/mutation/ResetTrustTool/ResetTrustTool.d.ts +1 -1
- package/dist/tools/mutation/ResetTrustTool/ResetTrustTool.d.ts.map +1 -1
- package/dist/tools/mutation/ResetTrustTool/ResetTrustTool.js +1 -1
- package/dist/tools/mutation/ResetTrustTool/ResetTrustTool.js.map +1 -1
- package/dist/tools/mutation/SetGoalTool/SetGoalTool.d.ts +2 -2
- package/dist/tools/mutation/SetGoalTool/SetGoalTool.d.ts.map +1 -1
- package/dist/tools/mutation/SetGoalTool/SetGoalTool.js +2 -2
- package/dist/tools/mutation/SetGoalTool/SetGoalTool.js.map +1 -1
- package/dist/tools/mutation/TaskCreateTool/TaskCreateTool.d.ts +216 -0
- package/dist/tools/mutation/TaskCreateTool/TaskCreateTool.d.ts.map +1 -0
- package/dist/tools/mutation/TaskCreateTool/TaskCreateTool.js +104 -0
- package/dist/tools/mutation/TaskCreateTool/TaskCreateTool.js.map +1 -0
- package/dist/tools/mutation/TaskCreateTool/constants.d.ts +5 -0
- package/dist/tools/mutation/TaskCreateTool/constants.d.ts.map +1 -0
- package/dist/tools/mutation/TaskCreateTool/constants.js +5 -0
- package/dist/tools/mutation/TaskCreateTool/constants.js.map +1 -0
- package/dist/tools/mutation/TaskCreateTool/prompt.d.ts +2 -0
- package/dist/tools/mutation/TaskCreateTool/prompt.d.ts.map +1 -0
- package/dist/tools/mutation/TaskCreateTool/prompt.js +2 -0
- package/dist/tools/mutation/TaskCreateTool/prompt.js.map +1 -0
- package/dist/tools/mutation/TaskOutputTool/TaskOutputTool.d.ts +46 -0
- package/dist/tools/mutation/TaskOutputTool/TaskOutputTool.d.ts.map +1 -0
- package/dist/tools/mutation/TaskOutputTool/TaskOutputTool.js +95 -0
- package/dist/tools/mutation/TaskOutputTool/TaskOutputTool.js.map +1 -0
- package/dist/tools/mutation/TaskOutputTool/constants.d.ts +5 -0
- package/dist/tools/mutation/TaskOutputTool/constants.d.ts.map +1 -0
- package/dist/tools/mutation/TaskOutputTool/constants.js +5 -0
- package/dist/tools/mutation/TaskOutputTool/constants.js.map +1 -0
- package/dist/tools/mutation/TaskOutputTool/prompt.d.ts +2 -0
- package/dist/tools/mutation/TaskOutputTool/prompt.d.ts.map +1 -0
- package/dist/tools/mutation/TaskOutputTool/prompt.js +2 -0
- package/dist/tools/mutation/TaskOutputTool/prompt.js.map +1 -0
- package/dist/tools/mutation/TaskStopTool/TaskStopTool.d.ts +40 -0
- package/dist/tools/mutation/TaskStopTool/TaskStopTool.d.ts.map +1 -0
- package/dist/tools/mutation/TaskStopTool/TaskStopTool.js +95 -0
- package/dist/tools/mutation/TaskStopTool/TaskStopTool.js.map +1 -0
- package/dist/tools/mutation/TaskStopTool/constants.d.ts +5 -0
- package/dist/tools/mutation/TaskStopTool/constants.d.ts.map +1 -0
- package/dist/tools/mutation/TaskStopTool/constants.js +5 -0
- package/dist/tools/mutation/TaskStopTool/constants.js.map +1 -0
- package/dist/tools/mutation/TaskStopTool/prompt.d.ts +2 -0
- package/dist/tools/mutation/TaskStopTool/prompt.d.ts.map +1 -0
- package/dist/tools/mutation/TaskStopTool/prompt.js +2 -0
- package/dist/tools/mutation/TaskStopTool/prompt.js.map +1 -0
- package/dist/tools/mutation/TaskUpdateTool/TaskUpdateTool.d.ts +270 -0
- package/dist/tools/mutation/TaskUpdateTool/TaskUpdateTool.d.ts.map +1 -0
- package/dist/tools/mutation/TaskUpdateTool/TaskUpdateTool.js +137 -0
- package/dist/tools/mutation/TaskUpdateTool/TaskUpdateTool.js.map +1 -0
- package/dist/tools/mutation/TaskUpdateTool/constants.d.ts +5 -0
- package/dist/tools/mutation/TaskUpdateTool/constants.d.ts.map +1 -0
- package/dist/tools/mutation/TaskUpdateTool/constants.js +5 -0
- package/dist/tools/mutation/TaskUpdateTool/constants.js.map +1 -0
- package/dist/tools/mutation/TaskUpdateTool/prompt.d.ts +2 -0
- package/dist/tools/mutation/TaskUpdateTool/prompt.d.ts.map +1 -0
- package/dist/tools/mutation/TaskUpdateTool/prompt.js +2 -0
- package/dist/tools/mutation/TaskUpdateTool/prompt.js.map +1 -0
- package/dist/tools/mutation/TogglePluginTool/TogglePluginTool.d.ts +1 -1
- package/dist/tools/mutation/TogglePluginTool/TogglePluginTool.d.ts.map +1 -1
- package/dist/tools/mutation/TogglePluginTool/TogglePluginTool.js +1 -1
- package/dist/tools/mutation/TogglePluginTool/TogglePluginTool.js.map +1 -1
- package/dist/tools/mutation/UpdateConfigTool/UpdateConfigTool.d.ts +2 -2
- package/dist/tools/mutation/UpdateConfigTool/UpdateConfigTool.d.ts.map +1 -1
- package/dist/tools/mutation/UpdateConfigTool/UpdateConfigTool.js +11 -2
- package/dist/tools/mutation/UpdateConfigTool/UpdateConfigTool.js.map +1 -1
- package/dist/tools/mutation/UpdateGoalTool/UpdateGoalTool.d.ts +2 -2
- package/dist/tools/mutation/UpdateGoalTool/UpdateGoalTool.d.ts.map +1 -1
- package/dist/tools/mutation/UpdateGoalTool/UpdateGoalTool.js +2 -2
- package/dist/tools/mutation/UpdateGoalTool/UpdateGoalTool.js.map +1 -1
- package/dist/tools/mutation/task-history-utils.d.ts +4 -0
- package/dist/tools/mutation/task-history-utils.d.ts.map +1 -0
- package/dist/tools/mutation/task-history-utils.js +30 -0
- package/dist/tools/mutation/task-history-utils.js.map +1 -0
- package/dist/tools/network/HttpFetchTool/HttpFetchTool.d.ts +1 -1
- package/dist/tools/network/HttpFetchTool/HttpFetchTool.d.ts.map +1 -1
- package/dist/tools/network/HttpFetchTool/HttpFetchTool.js +1 -1
- package/dist/tools/network/HttpFetchTool/HttpFetchTool.js.map +1 -1
- package/dist/tools/query/ArchitectureTool/ArchitectureTool.d.ts +2 -2
- package/dist/tools/query/ArchitectureTool/ArchitectureTool.d.ts.map +1 -1
- package/dist/tools/query/ArchitectureTool/ArchitectureTool.js +2 -2
- package/dist/tools/query/ArchitectureTool/ArchitectureTool.js.map +1 -1
- package/dist/tools/query/ConfigTool/ConfigTool.d.ts +2 -2
- package/dist/tools/query/ConfigTool/ConfigTool.d.ts.map +1 -1
- package/dist/tools/query/ConfigTool/ConfigTool.js +2 -2
- package/dist/tools/query/ConfigTool/ConfigTool.js.map +1 -1
- package/dist/tools/query/GoalStateTool/GoalStateTool.d.ts +2 -2
- package/dist/tools/query/GoalStateTool/GoalStateTool.d.ts.map +1 -1
- package/dist/tools/query/GoalStateTool/GoalStateTool.js +2 -2
- package/dist/tools/query/GoalStateTool/GoalStateTool.js.map +1 -1
- package/dist/tools/query/KnowledgeQueryTool/KnowledgeQueryTool.d.ts +2 -2
- package/dist/tools/query/KnowledgeQueryTool/KnowledgeQueryTool.d.ts.map +1 -1
- package/dist/tools/query/KnowledgeQueryTool/KnowledgeQueryTool.js +2 -2
- package/dist/tools/query/KnowledgeQueryTool/KnowledgeQueryTool.js.map +1 -1
- package/dist/tools/query/MemoryRecallTool/MemoryRecallTool.d.ts +7 -7
- package/dist/tools/query/MemoryRecallTool/MemoryRecallTool.d.ts.map +1 -1
- package/dist/tools/query/MemoryRecallTool/MemoryRecallTool.js +11 -10
- package/dist/tools/query/MemoryRecallTool/MemoryRecallTool.js.map +1 -1
- package/dist/tools/query/PluginStateTool/PluginStateTool.d.ts +2 -2
- package/dist/tools/query/PluginStateTool/PluginStateTool.d.ts.map +1 -1
- package/dist/tools/query/PluginStateTool/PluginStateTool.js +2 -2
- package/dist/tools/query/PluginStateTool/PluginStateTool.js.map +1 -1
- package/dist/tools/query/ProgressHistoryTool/ProgressHistoryTool.d.ts +4 -4
- package/dist/tools/query/ProgressHistoryTool/ProgressHistoryTool.d.ts.map +1 -1
- package/dist/tools/query/ProgressHistoryTool/ProgressHistoryTool.js +2 -2
- package/dist/tools/query/ProgressHistoryTool/ProgressHistoryTool.js.map +1 -1
- package/dist/tools/query/SessionHistoryTool/SessionHistoryTool.d.ts +2 -2
- package/dist/tools/query/SessionHistoryTool/SessionHistoryTool.d.ts.map +1 -1
- package/dist/tools/query/SessionHistoryTool/SessionHistoryTool.js +2 -2
- package/dist/tools/query/SessionHistoryTool/SessionHistoryTool.js.map +1 -1
- package/dist/tools/query/TaskGetTool/TaskGetTool.d.ts +34 -0
- package/dist/tools/query/TaskGetTool/TaskGetTool.d.ts.map +1 -0
- package/dist/tools/query/TaskGetTool/TaskGetTool.js +77 -0
- package/dist/tools/query/TaskGetTool/TaskGetTool.js.map +1 -0
- package/dist/tools/query/TaskGetTool/constants.d.ts +6 -0
- package/dist/tools/query/TaskGetTool/constants.d.ts.map +1 -0
- package/dist/tools/query/TaskGetTool/constants.js +6 -0
- package/dist/tools/query/TaskGetTool/constants.js.map +1 -0
- package/dist/tools/query/TaskGetTool/prompt.d.ts +2 -0
- package/dist/tools/query/TaskGetTool/prompt.d.ts.map +1 -0
- package/dist/tools/query/TaskGetTool/prompt.js +2 -0
- package/dist/tools/query/TaskGetTool/prompt.js.map +1 -0
- package/dist/tools/query/TaskListTool/TaskListTool.d.ts +58 -0
- package/dist/tools/query/TaskListTool/TaskListTool.d.ts.map +1 -0
- package/dist/tools/query/TaskListTool/TaskListTool.js +101 -0
- package/dist/tools/query/TaskListTool/TaskListTool.js.map +1 -0
- package/dist/tools/query/TaskListTool/constants.d.ts +6 -0
- package/dist/tools/query/TaskListTool/constants.d.ts.map +1 -0
- package/dist/tools/query/TaskListTool/constants.js +6 -0
- package/dist/tools/query/TaskListTool/constants.js.map +1 -0
- package/dist/tools/query/TaskListTool/prompt.d.ts +2 -0
- package/dist/tools/query/TaskListTool/prompt.d.ts.map +1 -0
- package/dist/tools/query/TaskListTool/prompt.js +2 -0
- package/dist/tools/query/TaskListTool/prompt.js.map +1 -0
- package/dist/tools/query/TrustStateTool/TrustStateTool.d.ts +2 -2
- package/dist/tools/query/TrustStateTool/TrustStateTool.d.ts.map +1 -1
- package/dist/tools/query/TrustStateTool/TrustStateTool.js +2 -2
- package/dist/tools/query/TrustStateTool/TrustStateTool.js.map +1 -1
- package/dist/tools/schedule/CreateScheduleTool/CreateScheduleTool.d.ts +1638 -0
- package/dist/tools/schedule/CreateScheduleTool/CreateScheduleTool.d.ts.map +1 -0
- package/dist/tools/schedule/CreateScheduleTool/CreateScheduleTool.js +86 -0
- package/dist/tools/schedule/CreateScheduleTool/CreateScheduleTool.js.map +1 -0
- package/dist/tools/schedule/CreateScheduleTool/constants.d.ts +5 -0
- package/dist/tools/schedule/CreateScheduleTool/constants.d.ts.map +1 -0
- package/dist/tools/schedule/CreateScheduleTool/constants.js +5 -0
- package/dist/tools/schedule/CreateScheduleTool/constants.js.map +1 -0
- package/dist/tools/schedule/CreateScheduleTool/prompt.d.ts +2 -0
- package/dist/tools/schedule/CreateScheduleTool/prompt.d.ts.map +1 -0
- package/dist/tools/schedule/CreateScheduleTool/prompt.js +2 -0
- package/dist/tools/schedule/CreateScheduleTool/prompt.js.map +1 -0
- package/dist/tools/schedule/GetScheduleTool/GetScheduleTool.d.ts +28 -0
- package/dist/tools/schedule/GetScheduleTool/GetScheduleTool.d.ts.map +1 -0
- package/dist/tools/schedule/GetScheduleTool/GetScheduleTool.js +79 -0
- package/dist/tools/schedule/GetScheduleTool/GetScheduleTool.js.map +1 -0
- package/dist/tools/schedule/GetScheduleTool/constants.d.ts +6 -0
- package/dist/tools/schedule/GetScheduleTool/constants.d.ts.map +1 -0
- package/dist/tools/schedule/GetScheduleTool/constants.js +6 -0
- package/dist/tools/schedule/GetScheduleTool/constants.js.map +1 -0
- package/dist/tools/schedule/GetScheduleTool/prompt.d.ts +2 -0
- package/dist/tools/schedule/GetScheduleTool/prompt.d.ts.map +1 -0
- package/dist/tools/schedule/GetScheduleTool/prompt.js +2 -0
- package/dist/tools/schedule/GetScheduleTool/prompt.js.map +1 -0
- package/dist/tools/schedule/ListSchedulesTool/ListSchedulesTool.d.ts +40 -0
- package/dist/tools/schedule/ListSchedulesTool/ListSchedulesTool.d.ts.map +1 -0
- package/dist/tools/schedule/ListSchedulesTool/ListSchedulesTool.js +83 -0
- package/dist/tools/schedule/ListSchedulesTool/ListSchedulesTool.js.map +1 -0
- package/dist/tools/schedule/ListSchedulesTool/constants.d.ts +6 -0
- package/dist/tools/schedule/ListSchedulesTool/constants.d.ts.map +1 -0
- package/dist/tools/schedule/ListSchedulesTool/constants.js +6 -0
- package/dist/tools/schedule/ListSchedulesTool/constants.js.map +1 -0
- package/dist/tools/schedule/ListSchedulesTool/prompt.d.ts +2 -0
- package/dist/tools/schedule/ListSchedulesTool/prompt.d.ts.map +1 -0
- package/dist/tools/schedule/ListSchedulesTool/prompt.js +2 -0
- package/dist/tools/schedule/ListSchedulesTool/prompt.js.map +1 -0
- package/dist/tools/schedule/PauseScheduleTool/PauseScheduleTool.d.ts +32 -0
- package/dist/tools/schedule/PauseScheduleTool/PauseScheduleTool.d.ts.map +1 -0
- package/dist/tools/schedule/PauseScheduleTool/PauseScheduleTool.js +94 -0
- package/dist/tools/schedule/PauseScheduleTool/PauseScheduleTool.js.map +1 -0
- package/dist/tools/schedule/PauseScheduleTool/constants.d.ts +5 -0
- package/dist/tools/schedule/PauseScheduleTool/constants.d.ts.map +1 -0
- package/dist/tools/schedule/PauseScheduleTool/constants.js +5 -0
- package/dist/tools/schedule/PauseScheduleTool/constants.js.map +1 -0
- package/dist/tools/schedule/PauseScheduleTool/prompt.d.ts +2 -0
- package/dist/tools/schedule/PauseScheduleTool/prompt.d.ts.map +1 -0
- package/dist/tools/schedule/PauseScheduleTool/prompt.js +2 -0
- package/dist/tools/schedule/PauseScheduleTool/prompt.js.map +1 -0
- package/dist/tools/schedule/RemoveScheduleTool/RemoveScheduleTool.d.ts +35 -0
- package/dist/tools/schedule/RemoveScheduleTool/RemoveScheduleTool.d.ts.map +1 -0
- package/dist/tools/schedule/RemoveScheduleTool/RemoveScheduleTool.js +100 -0
- package/dist/tools/schedule/RemoveScheduleTool/RemoveScheduleTool.js.map +1 -0
- package/dist/tools/schedule/RemoveScheduleTool/constants.d.ts +5 -0
- package/dist/tools/schedule/RemoveScheduleTool/constants.d.ts.map +1 -0
- package/dist/tools/schedule/RemoveScheduleTool/constants.js +5 -0
- package/dist/tools/schedule/RemoveScheduleTool/constants.js.map +1 -0
- package/dist/tools/schedule/RemoveScheduleTool/prompt.d.ts +2 -0
- package/dist/tools/schedule/RemoveScheduleTool/prompt.d.ts.map +1 -0
- package/dist/tools/schedule/RemoveScheduleTool/prompt.js +2 -0
- package/dist/tools/schedule/RemoveScheduleTool/prompt.js.map +1 -0
- package/dist/tools/schedule/ResumeScheduleTool/ResumeScheduleTool.d.ts +32 -0
- package/dist/tools/schedule/ResumeScheduleTool/ResumeScheduleTool.d.ts.map +1 -0
- package/dist/tools/schedule/ResumeScheduleTool/ResumeScheduleTool.js +94 -0
- package/dist/tools/schedule/ResumeScheduleTool/ResumeScheduleTool.js.map +1 -0
- package/dist/tools/schedule/ResumeScheduleTool/constants.d.ts +5 -0
- package/dist/tools/schedule/ResumeScheduleTool/constants.d.ts.map +1 -0
- package/dist/tools/schedule/ResumeScheduleTool/constants.js +5 -0
- package/dist/tools/schedule/ResumeScheduleTool/constants.js.map +1 -0
- package/dist/tools/schedule/ResumeScheduleTool/prompt.d.ts +2 -0
- package/dist/tools/schedule/ResumeScheduleTool/prompt.d.ts.map +1 -0
- package/dist/tools/schedule/ResumeScheduleTool/prompt.js +2 -0
- package/dist/tools/schedule/ResumeScheduleTool/prompt.js.map +1 -0
- package/dist/tools/schedule/UpdateScheduleTool/UpdateScheduleTool.d.ts +770 -0
- package/dist/tools/schedule/UpdateScheduleTool/UpdateScheduleTool.d.ts.map +1 -0
- package/dist/tools/schedule/UpdateScheduleTool/UpdateScheduleTool.js +131 -0
- package/dist/tools/schedule/UpdateScheduleTool/UpdateScheduleTool.js.map +1 -0
- package/dist/tools/schedule/UpdateScheduleTool/constants.d.ts +5 -0
- package/dist/tools/schedule/UpdateScheduleTool/constants.d.ts.map +1 -0
- package/dist/tools/schedule/UpdateScheduleTool/constants.js +5 -0
- package/dist/tools/schedule/UpdateScheduleTool/constants.js.map +1 -0
- package/dist/tools/schedule/UpdateScheduleTool/prompt.d.ts +2 -0
- package/dist/tools/schedule/UpdateScheduleTool/prompt.d.ts.map +1 -0
- package/dist/tools/schedule/UpdateScheduleTool/prompt.js +2 -0
- package/dist/tools/schedule/UpdateScheduleTool/prompt.js.map +1 -0
- package/dist/tools/system/EnvTool/EnvTool.d.ts +2 -2
- package/dist/tools/system/EnvTool/EnvTool.d.ts.map +1 -1
- package/dist/tools/system/EnvTool/EnvTool.js +2 -2
- package/dist/tools/system/EnvTool/EnvTool.js.map +1 -1
- package/dist/tools/system/GitDiffTool/GitDiffTool.d.ts +2 -2
- package/dist/tools/system/GitDiffTool/GitDiffTool.d.ts.map +1 -1
- package/dist/tools/system/GitDiffTool/GitDiffTool.js +2 -2
- package/dist/tools/system/GitDiffTool/GitDiffTool.js.map +1 -1
- package/dist/tools/system/GitLogTool/GitLogTool.d.ts +2 -2
- package/dist/tools/system/GitLogTool/GitLogTool.d.ts.map +1 -1
- package/dist/tools/system/GitLogTool/GitLogTool.js +2 -2
- package/dist/tools/system/GitLogTool/GitLogTool.js.map +1 -1
- package/dist/tools/system/SleepTool/SleepTool.d.ts +2 -2
- package/dist/tools/system/SleepTool/SleepTool.d.ts.map +1 -1
- package/dist/tools/system/SleepTool/SleepTool.js +2 -2
- package/dist/tools/system/SleepTool/SleepTool.js.map +1 -1
- package/dist/tools/system/test-runner.d.ts +2 -52
- package/dist/tools/system/test-runner.d.ts.map +1 -1
- package/dist/tools/system/test-runner.js +1 -180
- package/dist/tools/system/test-runner.js.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,674 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Completion checks, stall handling, and task execution for a CoreLoop iteration.
|
|
3
|
+
*/
|
|
4
|
+
import { randomUUID } from "node:crypto";
|
|
5
|
+
import * as path from "node:path";
|
|
6
|
+
import { KnowledgeGraph } from "../../../platform/knowledge/knowledge-graph.js";
|
|
7
|
+
import { loadDreamActivationState, mergeUniqueKnowledgeEntries } from "../../../platform/dream/dream-activation.js";
|
|
8
|
+
import { buildDriveContext, } from "./contracts.js";
|
|
9
|
+
import { getMilestones, evaluatePace, } from "../../goal/milestone-evaluator.js";
|
|
10
|
+
import { gatherStallEvidence } from "../stall-evidence.js";
|
|
11
|
+
import { verifyWithTools } from "../verification-layer1.js";
|
|
12
|
+
import { buildLoopToolContext } from "./preparation.js";
|
|
13
|
+
import { expandKnowledgeEntriesWithGraph, mergeWorkingMemorySelections, } from "../../execution/context/context-builder.js";
|
|
14
|
+
// ─── Phase 5 ───
|
|
15
|
+
/** Completion check + milestone deadline check.
|
|
16
|
+
* Sets result.error on fatal failure, sets result.completionJudgment. */
|
|
17
|
+
export async function checkCompletionAndMilestones(ctx, goalId, goal, result, startTime) {
|
|
18
|
+
// R1-1: record pre-task judgment (do NOT early-return here)
|
|
19
|
+
try {
|
|
20
|
+
const judgment = goal.children_ids.length > 0
|
|
21
|
+
? await ctx.deps.satisficingJudge.judgeTreeCompletion(goalId)
|
|
22
|
+
: ctx.deps.satisficingJudge.isGoalComplete(goal);
|
|
23
|
+
result.completionJudgment = judgment;
|
|
24
|
+
// Wire satisficing callback to MemoryLifecycleManager
|
|
25
|
+
// SatisficingJudge fires (goalId, satisfiedDimensions[]) but MLM expects per-dimension calls
|
|
26
|
+
if (ctx.deps.memoryLifecycleManager) {
|
|
27
|
+
const blockingSet = new Set(judgment.blocking_dimensions);
|
|
28
|
+
for (const dim of goal.dimensions) {
|
|
29
|
+
const isSatisfied = !blockingSet.has(dim.name);
|
|
30
|
+
ctx.deps.memoryLifecycleManager.onSatisficingJudgment(goalId, dim.name, isSatisfied);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
catch (err) {
|
|
35
|
+
result.error = `Completion check failed: ${err instanceof Error ? err.message : String(err)}`;
|
|
36
|
+
ctx.logger?.error(`CoreLoop: ${result.error}`, { goalId });
|
|
37
|
+
result.elapsedMs = Date.now() - startTime;
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
// Milestone deadline check
|
|
41
|
+
try {
|
|
42
|
+
const allGoals = [goal];
|
|
43
|
+
for (const childId of goal.children_ids) {
|
|
44
|
+
const child = await ctx.deps.stateManager.loadGoal(childId);
|
|
45
|
+
if (child)
|
|
46
|
+
allGoals.push(child);
|
|
47
|
+
}
|
|
48
|
+
const milestones = getMilestones(allGoals);
|
|
49
|
+
if (milestones.length > 0) {
|
|
50
|
+
const milestoneAlerts = [];
|
|
51
|
+
for (const milestone of milestones) {
|
|
52
|
+
const currentAchievement = milestone.pace_snapshot?.achievement_ratio ??
|
|
53
|
+
(typeof milestone.dimensions[0]?.current_value === "number"
|
|
54
|
+
? Math.min(milestone.dimensions[0].current_value / 100, 1)
|
|
55
|
+
: 0);
|
|
56
|
+
const snapshot = evaluatePace(milestone, currentAchievement);
|
|
57
|
+
await ctx.deps.stateManager.savePaceSnapshot(milestone.id, snapshot);
|
|
58
|
+
if (snapshot.status === "at_risk" || snapshot.status === "behind") {
|
|
59
|
+
milestoneAlerts.push({
|
|
60
|
+
goalId: milestone.id,
|
|
61
|
+
status: snapshot.status,
|
|
62
|
+
pace_ratio: snapshot.pace_ratio,
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
if (ctx.deps.learningPipeline) {
|
|
67
|
+
try {
|
|
68
|
+
await ctx.deps.learningPipeline.onMilestoneReached(goalId, `Milestone ${milestone.title}: pace ${snapshot.status}`);
|
|
69
|
+
}
|
|
70
|
+
catch {
|
|
71
|
+
// non-fatal
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
if (milestoneAlerts.length > 0) {
|
|
77
|
+
result.milestoneAlerts = milestoneAlerts;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
catch {
|
|
82
|
+
// Milestone check failure is non-fatal
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
// ─── Phase 6 ───
|
|
86
|
+
/** Stall detection per-dimension and globally, plus portfolio rebalance. */
|
|
87
|
+
export async function detectStallsAndRebalance(ctx, goalId, goal, result) {
|
|
88
|
+
try {
|
|
89
|
+
const gapHistory = await ctx.deps.stateManager.loadGapHistory(goalId);
|
|
90
|
+
const gapHistoryByDimension = indexGapHistoryByDimension(goal, gapHistory);
|
|
91
|
+
// Gather tool-based workspace evidence for stall detection (Phase 6)
|
|
92
|
+
if (ctx.toolExecutor) {
|
|
93
|
+
try {
|
|
94
|
+
const toolContext = {
|
|
95
|
+
cwd: process.cwd(),
|
|
96
|
+
goalId,
|
|
97
|
+
trustBalance: 0,
|
|
98
|
+
preApproved: true,
|
|
99
|
+
approvalFn: async () => false,
|
|
100
|
+
};
|
|
101
|
+
const evidence = await gatherStallEvidence(ctx.toolExecutor, toolContext);
|
|
102
|
+
result.toolStallEvidence = evidence;
|
|
103
|
+
if (!evidence.hasWorkspaceChanges) {
|
|
104
|
+
ctx.logger?.info("CoreLoop: stall evidence — no workspace changes detected", { goalId, toolErrors: evidence.toolErrors });
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
catch {
|
|
108
|
+
// Non-fatal: evidence gathering failure does not block stall detection
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
// Gap 3: isSuppressed wiring — suppression is per-dimension only.
|
|
112
|
+
// Collect suppressed dimensions from all active WaitStrategies; skip those dims in stall loop.
|
|
113
|
+
const suppressedDimensions = new Set();
|
|
114
|
+
if (ctx.deps.portfolioManager) {
|
|
115
|
+
try {
|
|
116
|
+
const portfolio = await ctx.deps.strategyManager.getPortfolio(goalId);
|
|
117
|
+
if (portfolio) {
|
|
118
|
+
for (const s of portfolio.strategies) {
|
|
119
|
+
if (s.state !== "active" || !ctx.deps.portfolioManager.isWaitStrategy(s))
|
|
120
|
+
continue;
|
|
121
|
+
const ws = s;
|
|
122
|
+
const waitUntil = typeof ws["wait_until"] === "string" ? ws["wait_until"] : null;
|
|
123
|
+
if (!ctx.deps.stallDetector.isSuppressed(waitUntil))
|
|
124
|
+
continue;
|
|
125
|
+
// Suppress only the primary_dimension of this WaitStrategy
|
|
126
|
+
const primaryDim = typeof ws["primary_dimension"] === "string" ? ws["primary_dimension"] : null;
|
|
127
|
+
if (primaryDim) {
|
|
128
|
+
suppressedDimensions.add(primaryDim);
|
|
129
|
+
ctx.logger?.info("CoreLoop: stall detection suppressed for dimension by active WaitStrategy", {
|
|
130
|
+
goalId,
|
|
131
|
+
dimension: primaryDim,
|
|
132
|
+
waitUntil,
|
|
133
|
+
});
|
|
134
|
+
result.waitSuppressed = true;
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
catch {
|
|
140
|
+
// Non-fatal: suppression check failure does not block stall detection
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
// Per-dimension stall check (skip dimensions suppressed by active WaitStrategies)
|
|
144
|
+
for (const dim of goal.dimensions) {
|
|
145
|
+
if (suppressedDimensions.has(dim.name))
|
|
146
|
+
continue;
|
|
147
|
+
const dimGapHistory = gapHistoryByDimension.get(dim.name) ?? [];
|
|
148
|
+
const stallReport = ctx.deps.stallDetector.checkDimensionStall(goalId, dim.name, dimGapHistory);
|
|
149
|
+
if (stallReport) {
|
|
150
|
+
result.stallDetected = true;
|
|
151
|
+
result.stallReport = stallReport;
|
|
152
|
+
// Predicted stalls are advisory — log but don't pivot/escalate
|
|
153
|
+
if (stallReport.stall_type === "predicted_plateau" ||
|
|
154
|
+
stallReport.stall_type === "predicted_regression") {
|
|
155
|
+
ctx.logger?.info(`CoreLoop: early warning ${stallReport.stall_type} — monitoring, no pivot`, { goalId });
|
|
156
|
+
continue;
|
|
157
|
+
}
|
|
158
|
+
const escalationLevel = await ctx.deps.stallDetector.getEscalationLevel(goalId, dim.name);
|
|
159
|
+
await applyStallAction(ctx, goalId, goal, dimGapHistory, stallReport, escalationLevel, dim.name, result, "");
|
|
160
|
+
break;
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
// Global stall check
|
|
164
|
+
if (!result.stallDetected) {
|
|
165
|
+
await checkGlobalStall(ctx, goalId, goal, result, gapHistoryByDimension);
|
|
166
|
+
}
|
|
167
|
+
// Portfolio: check rebalance after stall detection
|
|
168
|
+
if (ctx.deps.portfolioManager) {
|
|
169
|
+
await rebalancePortfolio(ctx, goalId, goal, result);
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
catch (err) {
|
|
173
|
+
ctx.logger?.warn("CoreLoop: stall detection failed (non-fatal)", { error: err instanceof Error ? err.message : String(err) });
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
function indexGapHistoryByDimension(goal, gapHistory) {
|
|
177
|
+
const indexedHistory = new Map();
|
|
178
|
+
for (const dim of goal.dimensions) {
|
|
179
|
+
indexedHistory.set(dim.name, []);
|
|
180
|
+
}
|
|
181
|
+
for (const entry of gapHistory) {
|
|
182
|
+
const seenDimensions = new Set();
|
|
183
|
+
for (const gap of entry.gap_vector) {
|
|
184
|
+
if (seenDimensions.has(gap.dimension_name))
|
|
185
|
+
continue;
|
|
186
|
+
seenDimensions.add(gap.dimension_name);
|
|
187
|
+
const dimHistory = indexedHistory.get(gap.dimension_name);
|
|
188
|
+
if (!dimHistory) {
|
|
189
|
+
continue;
|
|
190
|
+
}
|
|
191
|
+
const normalizedGap = { normalized_gap: gap.normalized_weighted_gap ?? 1 };
|
|
192
|
+
dimHistory.push(normalizedGap);
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
return indexedHistory;
|
|
196
|
+
}
|
|
197
|
+
// ─── Shared stall-action helper ───
|
|
198
|
+
/** Apply REFINE/PIVOT/ESCALATE logic for a detected stall (per-dimension or global).
|
|
199
|
+
* @param dimHistory Gap history slice used for analysis (single-dim or first-dim for global).
|
|
200
|
+
* @param stallReport The detected StallReport.
|
|
201
|
+
* @param escalationLevel Current escalation level for the stall dimension.
|
|
202
|
+
* @param incrementDimName Dimension name passed to incrementEscalation after handling.
|
|
203
|
+
* @param logPrefix Short prefix for log messages, e.g. "" or "global ".
|
|
204
|
+
*/
|
|
205
|
+
async function applyStallAction(ctx, goalId, goal, dimHistory, stallReport, escalationLevel, incrementDimName, result, logPrefix) {
|
|
206
|
+
if (ctx.deps.learningPipeline) {
|
|
207
|
+
try {
|
|
208
|
+
await ctx.deps.learningPipeline.onStallDetected(goalId, stallReport);
|
|
209
|
+
}
|
|
210
|
+
catch {
|
|
211
|
+
// non-fatal
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
const activeStrategyForRecord = await Promise.resolve(ctx.deps.strategyManager.getActiveStrategy(goalId)).catch(() => null);
|
|
215
|
+
const strategyIdForRecord = activeStrategyForRecord?.id ?? "unknown";
|
|
216
|
+
// M14-S2: analyze stall cause to determine REFINE/PIVOT/ESCALATE
|
|
217
|
+
// Falls back to PIVOT behavior when analyzeStallCause is unavailable
|
|
218
|
+
const analysis = ctx.deps.stallDetector.analyzeStallCause?.(dimHistory);
|
|
219
|
+
result.stallAnalysis = analysis;
|
|
220
|
+
if (analysis?.recommended_action === "refine") {
|
|
221
|
+
// REFINE: keep current strategy, just log and continue
|
|
222
|
+
ctx.logger?.info(`CoreLoop: ${logPrefix}stall REFINE — parameter_issue detected, keeping strategy`, {
|
|
223
|
+
goalId,
|
|
224
|
+
evidence: analysis.evidence,
|
|
225
|
+
});
|
|
226
|
+
}
|
|
227
|
+
else if (stallReport.suggested_cause === "information_deficit" && ctx.deps.goalRefiner) {
|
|
228
|
+
// Observation-failure stall: re-refine the leaf to get better dimensions
|
|
229
|
+
ctx.logger?.info(`CoreLoop: ${logPrefix}observation-failure stall — calling reRefineLeaf`, { goalId });
|
|
230
|
+
try {
|
|
231
|
+
await ctx.deps.goalRefiner.reRefineLeaf(goalId, stallReport.suggested_cause);
|
|
232
|
+
}
|
|
233
|
+
catch (reRefineErr) {
|
|
234
|
+
ctx.logger?.warn(`CoreLoop: ${logPrefix}reRefineLeaf failed (non-fatal)`, {
|
|
235
|
+
goalId,
|
|
236
|
+
err: reRefineErr instanceof Error ? reRefineErr.message : String(reRefineErr),
|
|
237
|
+
});
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
else if (analysis?.recommended_action === "escalate") {
|
|
241
|
+
// ESCALATE: set escalation level to max to trigger loop exit
|
|
242
|
+
ctx.logger?.warn(`CoreLoop: ${logPrefix}stall ESCALATE — goal_unreachable detected`, {
|
|
243
|
+
goalId,
|
|
244
|
+
evidence: analysis.evidence,
|
|
245
|
+
});
|
|
246
|
+
await ctx.deps.strategyManager.onStallDetected(goalId, 3, goal.origin ?? "general");
|
|
247
|
+
result.pivotOccurred = true;
|
|
248
|
+
}
|
|
249
|
+
else {
|
|
250
|
+
// PIVOT: switch strategy, but check pivot count limit first
|
|
251
|
+
const portfolio = await ctx.deps.strategyManager.getPortfolio(goalId);
|
|
252
|
+
const activeStrategy = portfolio?.strategies.find((s) => s.state === "active");
|
|
253
|
+
const pivotCount = activeStrategy?.pivot_count ?? 0;
|
|
254
|
+
const maxPivotCount = activeStrategy?.max_pivot_count ?? 2;
|
|
255
|
+
if (pivotCount >= maxPivotCount) {
|
|
256
|
+
// Auto-escalate when pivot limit reached
|
|
257
|
+
ctx.logger?.warn(`CoreLoop: ${logPrefix}stall auto-ESCALATE — pivot_count limit reached`, {
|
|
258
|
+
goalId,
|
|
259
|
+
pivotCount,
|
|
260
|
+
maxPivotCount,
|
|
261
|
+
});
|
|
262
|
+
await ctx.deps.strategyManager.onStallDetected(goalId, 3, goal.origin ?? "general");
|
|
263
|
+
result.pivotOccurred = true;
|
|
264
|
+
}
|
|
265
|
+
else {
|
|
266
|
+
const newStrategy = await ctx.deps.strategyManager.onStallDetected(goalId, escalationLevel + 1, goal.origin ?? "general");
|
|
267
|
+
if (newStrategy) {
|
|
268
|
+
result.pivotOccurred = true;
|
|
269
|
+
if (activeStrategy?.id) {
|
|
270
|
+
try {
|
|
271
|
+
await ctx.deps.strategyManager.incrementPivotCount(goalId, activeStrategy.id);
|
|
272
|
+
}
|
|
273
|
+
catch {
|
|
274
|
+
// non-fatal
|
|
275
|
+
}
|
|
276
|
+
}
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
// M14-S3: Record decision (non-fatal)
|
|
281
|
+
if (ctx.deps.knowledgeManager) {
|
|
282
|
+
try {
|
|
283
|
+
const latestGap = dimHistory[dimHistory.length - 1]?.normalized_gap ?? 1;
|
|
284
|
+
await ctx.deps.knowledgeManager.recordDecision({
|
|
285
|
+
id: randomUUID(),
|
|
286
|
+
goal_id: goalId,
|
|
287
|
+
goal_type: goal.origin ?? "general",
|
|
288
|
+
strategy_id: strategyIdForRecord,
|
|
289
|
+
hypothesis: activeStrategyForRecord?.hypothesis,
|
|
290
|
+
decision: analysis?.recommended_action ?? "pivot",
|
|
291
|
+
context: {
|
|
292
|
+
gap_value: latestGap,
|
|
293
|
+
stall_count: stallReport.escalation_level,
|
|
294
|
+
cycle_count: dimHistory.length,
|
|
295
|
+
trust_score: 0,
|
|
296
|
+
},
|
|
297
|
+
outcome: "pending",
|
|
298
|
+
timestamp: new Date().toISOString(),
|
|
299
|
+
what_worked: [],
|
|
300
|
+
what_failed: [],
|
|
301
|
+
suggested_next: [],
|
|
302
|
+
});
|
|
303
|
+
}
|
|
304
|
+
catch {
|
|
305
|
+
// non-fatal: never block the loop for decision recording
|
|
306
|
+
}
|
|
307
|
+
}
|
|
308
|
+
if (incrementDimName) {
|
|
309
|
+
await ctx.deps.stallDetector.incrementEscalation(goalId, incrementDimName);
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
/** Global stall detection: check all dimensions together, handle REFINE/PIVOT/ESCALATE. */
|
|
313
|
+
async function checkGlobalStall(ctx, goalId, goal, result, gapHistoryByDimension) {
|
|
314
|
+
const globalStall = ctx.deps.stallDetector.checkGlobalStall(goalId, gapHistoryByDimension);
|
|
315
|
+
if (!globalStall)
|
|
316
|
+
return;
|
|
317
|
+
result.stallDetected = true;
|
|
318
|
+
result.stallReport = globalStall;
|
|
319
|
+
const firstDimHistory = gapHistoryByDimension.get(goal.dimensions[0]?.name ?? "") ?? [];
|
|
320
|
+
const firstDimName = goal.dimensions[0]?.name ?? "";
|
|
321
|
+
// Pass escalationLevel=1 so that escalationLevel+1=2, preserving the original global PIVOT level
|
|
322
|
+
await applyStallAction(ctx, goalId, goal, firstDimHistory, globalStall, 1, firstDimName, result, "global ");
|
|
323
|
+
}
|
|
324
|
+
/** Portfolio rebalance: check for rebalance triggers and handle wait strategy expiry. */
|
|
325
|
+
async function rebalancePortfolio(ctx, goalId, goal, result) {
|
|
326
|
+
if (!ctx.deps.portfolioManager)
|
|
327
|
+
return;
|
|
328
|
+
try {
|
|
329
|
+
const rebalanceTrigger = await ctx.deps.portfolioManager.shouldRebalance(goalId);
|
|
330
|
+
if (rebalanceTrigger) {
|
|
331
|
+
const rebalanceResult = await ctx.deps.portfolioManager.rebalance(goalId, rebalanceTrigger);
|
|
332
|
+
if (rebalanceResult.new_generation_needed) {
|
|
333
|
+
await ctx.deps.strategyManager.onStallDetected(goalId, 3, goal.origin ?? "general");
|
|
334
|
+
}
|
|
335
|
+
}
|
|
336
|
+
}
|
|
337
|
+
catch {
|
|
338
|
+
// Portfolio rebalance errors are non-fatal
|
|
339
|
+
}
|
|
340
|
+
try {
|
|
341
|
+
const portfolio = await ctx.deps.strategyManager.getPortfolio(goalId);
|
|
342
|
+
if (portfolio) {
|
|
343
|
+
for (const strategy of portfolio.strategies) {
|
|
344
|
+
if (ctx.deps.portfolioManager.isWaitStrategy(strategy)) {
|
|
345
|
+
// Gap 1: canAffordWait gate — if TimeHorizonEngine is available, check whether
|
|
346
|
+
// the goal can afford the wait before processing WaitStrategy expiry.
|
|
347
|
+
if (ctx.timeHorizonEngine) {
|
|
348
|
+
try {
|
|
349
|
+
const ws = strategy;
|
|
350
|
+
const waitUntil = typeof ws["wait_until"] === "string" ? ws["wait_until"] : null;
|
|
351
|
+
const startedAt = typeof ws["started_at"] === "string" ? ws["started_at"] : (goal.created_at ?? new Date().toISOString());
|
|
352
|
+
// Remaining wait time (not total): use now as reference so nearly-expired waits pass
|
|
353
|
+
const waitHours = waitUntil
|
|
354
|
+
? Math.max(0, (new Date(waitUntil).getTime() - Date.now()) / 3_600_000)
|
|
355
|
+
: 0;
|
|
356
|
+
const currentGap = result?.gapAggregate ?? 1;
|
|
357
|
+
const initialGap = typeof ws["gap_snapshot_at_start"] === "number" ? ws["gap_snapshot_at_start"] : currentGap;
|
|
358
|
+
// Compute an approximate velocity from gap progress and elapsed time.
|
|
359
|
+
// Fallback to a small positive value (0.01/h) when elapsed is too short to measure.
|
|
360
|
+
const elapsedHours = waitUntil
|
|
361
|
+
? Math.max(0, (Date.now() - new Date(startedAt).getTime()) / 3_600_000)
|
|
362
|
+
: 0;
|
|
363
|
+
const gapDelta = initialGap - currentGap;
|
|
364
|
+
const velocity = elapsedHours > 0.001 && gapDelta > 0
|
|
365
|
+
? gapDelta / elapsedHours
|
|
366
|
+
: 0.01; // conservative positive fallback; replace with real velocity when available
|
|
367
|
+
const budget = ctx.timeHorizonEngine.getTimeBudget(goal.deadline ?? null, startedAt, currentGap, initialGap, velocity);
|
|
368
|
+
if (!budget.canAffordWait(waitHours)) {
|
|
369
|
+
ctx.logger?.info("CoreLoop: canAffordWait=false, skipping WaitStrategy processing", {
|
|
370
|
+
goalId,
|
|
371
|
+
strategyId: strategy.id,
|
|
372
|
+
waitHours,
|
|
373
|
+
});
|
|
374
|
+
continue;
|
|
375
|
+
}
|
|
376
|
+
}
|
|
377
|
+
catch {
|
|
378
|
+
// Non-fatal: if canAffordWait check fails, proceed normally
|
|
379
|
+
}
|
|
380
|
+
}
|
|
381
|
+
const waitTrigger = await ctx.deps.portfolioManager.handleWaitStrategyExpiry(goalId, strategy.id);
|
|
382
|
+
if (waitTrigger) {
|
|
383
|
+
await ctx.deps.portfolioManager.rebalance(goalId, waitTrigger);
|
|
384
|
+
if (result) {
|
|
385
|
+
result.waitExpired = true;
|
|
386
|
+
result.waitStrategyId = strategy.id;
|
|
387
|
+
}
|
|
388
|
+
}
|
|
389
|
+
}
|
|
390
|
+
}
|
|
391
|
+
}
|
|
392
|
+
}
|
|
393
|
+
catch {
|
|
394
|
+
// WaitStrategy expiry errors are non-fatal
|
|
395
|
+
}
|
|
396
|
+
}
|
|
397
|
+
// ─── Phase 6b ───
|
|
398
|
+
/** Check dependency graph block.
|
|
399
|
+
* Returns true if goal is blocked (result.error set, caller should return). */
|
|
400
|
+
export function checkDependencyBlock(ctx, goalId, result) {
|
|
401
|
+
if (ctx.deps.goalDependencyGraph) {
|
|
402
|
+
try {
|
|
403
|
+
if (ctx.deps.goalDependencyGraph.isBlocked(goalId)) {
|
|
404
|
+
const blockingGoals = ctx.deps.goalDependencyGraph.getBlockingGoals(goalId);
|
|
405
|
+
result.error = `Goal ${goalId} is blocked by prerequisites: ${blockingGoals.join(", ")}`;
|
|
406
|
+
return true;
|
|
407
|
+
}
|
|
408
|
+
}
|
|
409
|
+
catch {
|
|
410
|
+
// Dependency graph errors are non-fatal
|
|
411
|
+
}
|
|
412
|
+
}
|
|
413
|
+
return false;
|
|
414
|
+
}
|
|
415
|
+
/** Collect context, run task cycle, handle capability acquisition,
|
|
416
|
+
* transfer detection, and post-task completion re-check.
|
|
417
|
+
* Returns true on success, false if the caller should return result early.
|
|
418
|
+
* `transferCheckCounter` is incremented via the callback to keep mutable state on CoreLoop. */
|
|
419
|
+
export async function runTaskCycleWithContext(ctx, goalId, goal, gapVector, driveScores, highDissatisfactionDimensions, loopIndex, result, startTime, callbacks) {
|
|
420
|
+
const { handleCapabilityAcquisition, incrementTransferCounter, tryGenerateReport } = callbacks;
|
|
421
|
+
try {
|
|
422
|
+
const taskStartTime = Date.now();
|
|
423
|
+
const driveContext = buildDriveContext(goal);
|
|
424
|
+
const adapter = ctx.deps.adapterRegistry.getAdapter(ctx.config.adapterType);
|
|
425
|
+
const baseDir = typeof ctx.deps.stateManager.getBaseDir === "function"
|
|
426
|
+
? ctx.deps.stateManager.getBaseDir()
|
|
427
|
+
: null;
|
|
428
|
+
const dreamActivation = baseDir
|
|
429
|
+
? await loadDreamActivationState(baseDir).catch(() => null)
|
|
430
|
+
: null;
|
|
431
|
+
const activationFlags = dreamActivation?.flags;
|
|
432
|
+
// Portfolio: select strategy for next task
|
|
433
|
+
if (ctx.deps.portfolioManager) {
|
|
434
|
+
try {
|
|
435
|
+
const selectionResult = await ctx.deps.portfolioManager.selectNextStrategyForTask(goalId);
|
|
436
|
+
if (selectionResult) {
|
|
437
|
+
ctx.deps.taskLifecycle.setOnTaskComplete((strategyId) => {
|
|
438
|
+
ctx.deps.portfolioManager?.recordTaskCompletion(strategyId);
|
|
439
|
+
});
|
|
440
|
+
}
|
|
441
|
+
}
|
|
442
|
+
catch {
|
|
443
|
+
// Portfolio strategy selection is non-fatal
|
|
444
|
+
}
|
|
445
|
+
}
|
|
446
|
+
// Collect knowledge context
|
|
447
|
+
let knowledgeContext;
|
|
448
|
+
if (ctx.deps.knowledgeManager) {
|
|
449
|
+
try {
|
|
450
|
+
const topDimension = driveScores[0]?.dimension_name ?? goal.dimensions[0]?.name;
|
|
451
|
+
if (topDimension) {
|
|
452
|
+
let entries = await ctx.deps.knowledgeManager.getRelevantKnowledge(goalId, topDimension);
|
|
453
|
+
if (activationFlags?.semanticContext) {
|
|
454
|
+
const semanticEntries = await ctx.deps.knowledgeManager.searchKnowledge(`${goal.title} ${goal.description} ${topDimension}`, 5).catch(() => []);
|
|
455
|
+
entries = mergeUniqueKnowledgeEntries(entries, semanticEntries, 8);
|
|
456
|
+
}
|
|
457
|
+
let contradictionWarnings = [];
|
|
458
|
+
if (activationFlags?.graphTraversal && entries.length > 0) {
|
|
459
|
+
const graph = baseDir
|
|
460
|
+
? await KnowledgeGraph.create(path.join(baseDir, "knowledge", "graph.json")).catch(() => null)
|
|
461
|
+
: null;
|
|
462
|
+
if (graph) {
|
|
463
|
+
const allEntries = await ctx.deps.knowledgeManager.loadKnowledge(goalId).catch(() => []);
|
|
464
|
+
const expanded = expandKnowledgeEntriesWithGraph(entries, allEntries, graph);
|
|
465
|
+
entries = mergeUniqueKnowledgeEntries(entries, expanded.relatedEntries, 10);
|
|
466
|
+
contradictionWarnings = expanded.contradictionWarnings;
|
|
467
|
+
}
|
|
468
|
+
}
|
|
469
|
+
if (entries.length > 0) {
|
|
470
|
+
knowledgeContext = entries
|
|
471
|
+
.map((e) => `Q: ${e.question}\nA: ${e.answer}`)
|
|
472
|
+
.join("\n\n");
|
|
473
|
+
if (contradictionWarnings.length > 0) {
|
|
474
|
+
knowledgeContext += `\n\nContradiction warnings:\n${contradictionWarnings
|
|
475
|
+
.map((warning) => `- ${warning}`)
|
|
476
|
+
.join("\n")}`;
|
|
477
|
+
}
|
|
478
|
+
}
|
|
479
|
+
}
|
|
480
|
+
}
|
|
481
|
+
catch {
|
|
482
|
+
// Knowledge retrieval failure is non-fatal
|
|
483
|
+
}
|
|
484
|
+
}
|
|
485
|
+
if (activationFlags?.crossGoalLessons && ctx.deps.memoryLifecycleManager) {
|
|
486
|
+
try {
|
|
487
|
+
const topDimension = driveScores[0]?.dimension_name ?? goal.dimensions[0]?.name ?? "";
|
|
488
|
+
const lessons = await ctx.deps.memoryLifecycleManager.searchCrossGoalLessons(`${goal.title} ${goal.description} ${topDimension}`, 3);
|
|
489
|
+
if (lessons.length > 0) {
|
|
490
|
+
const lessonsBlock = [
|
|
491
|
+
"Cross-goal lessons:",
|
|
492
|
+
...lessons.map((lesson, index) => `${index + 1}. ${lesson.lesson}`),
|
|
493
|
+
].join("\n");
|
|
494
|
+
knowledgeContext = knowledgeContext ? `${knowledgeContext}\n\n${lessonsBlock}` : lessonsBlock;
|
|
495
|
+
}
|
|
496
|
+
}
|
|
497
|
+
catch {
|
|
498
|
+
// Non-fatal: proceed without cross-goal lessons.
|
|
499
|
+
}
|
|
500
|
+
}
|
|
501
|
+
// Tier-aware memory selection: use highDissatisfactionDimensions and dynamic budget
|
|
502
|
+
if (ctx.deps.memoryLifecycleManager) {
|
|
503
|
+
try {
|
|
504
|
+
const dimensions = goal.dimensions.map((d) => d.name);
|
|
505
|
+
const maxDissatisfaction = driveScores.length > 0
|
|
506
|
+
? Math.max(...driveScores.map((s) => s.dissatisfaction))
|
|
507
|
+
: 0;
|
|
508
|
+
const satisfiedDimensions = goal.dimensions
|
|
509
|
+
.filter((d) => !result.completionJudgment?.blocking_dimensions.includes(d.name))
|
|
510
|
+
.map((d) => d.name);
|
|
511
|
+
const tierAwareMemory = await ctx.deps.memoryLifecycleManager.selectForWorkingMemoryTierAware(goalId, dimensions, [], 10, [goalId], [], satisfiedDimensions, highDissatisfactionDimensions, maxDissatisfaction);
|
|
512
|
+
if (activationFlags?.semanticWorkingMemory) {
|
|
513
|
+
const topDimension = driveScores[0]?.dimension_name ?? goal.dimensions[0]?.name ?? "";
|
|
514
|
+
const semanticMemory = await ctx.deps.memoryLifecycleManager.selectForWorkingMemorySemantic(goalId, `${goal.title} ${goal.description} ${topDimension}`, dimensions, [], 5, driveScores.map((score) => ({
|
|
515
|
+
dimension: score.dimension_name,
|
|
516
|
+
dissatisfaction: score.dissatisfaction,
|
|
517
|
+
deadline: score.deadline,
|
|
518
|
+
})));
|
|
519
|
+
const mergedEntries = mergeWorkingMemorySelections(tierAwareMemory.shortTerm, semanticMemory.shortTerm, 5);
|
|
520
|
+
if (mergedEntries.length > 0) {
|
|
521
|
+
const memoryBlock = [
|
|
522
|
+
"Working memory:",
|
|
523
|
+
...mergedEntries.map((entry, index) => `${index + 1}. [${entry.data_type}] ${JSON.stringify(entry.data)}`),
|
|
524
|
+
].join("\n");
|
|
525
|
+
knowledgeContext = knowledgeContext ? `${knowledgeContext}\n\n${memoryBlock}` : memoryBlock;
|
|
526
|
+
}
|
|
527
|
+
}
|
|
528
|
+
}
|
|
529
|
+
catch {
|
|
530
|
+
// Memory selection failure is non-fatal
|
|
531
|
+
}
|
|
532
|
+
}
|
|
533
|
+
// Fetch existing tasks for dedup context
|
|
534
|
+
let existingTasks;
|
|
535
|
+
if (adapter.listExistingTasks) {
|
|
536
|
+
try {
|
|
537
|
+
existingTasks = await adapter.listExistingTasks();
|
|
538
|
+
}
|
|
539
|
+
catch {
|
|
540
|
+
// Non-fatal: proceed without existing tasks context
|
|
541
|
+
}
|
|
542
|
+
}
|
|
543
|
+
// Collect workspace context
|
|
544
|
+
let workspaceContext;
|
|
545
|
+
if (ctx.deps.contextProvider) {
|
|
546
|
+
try {
|
|
547
|
+
const topDimension = driveScores[0]?.dimension_name ?? goal.dimensions[0]?.name ?? "";
|
|
548
|
+
workspaceContext = await ctx.deps.contextProvider(goalId, topDimension);
|
|
549
|
+
}
|
|
550
|
+
catch {
|
|
551
|
+
// Non-fatal: proceed without workspace context
|
|
552
|
+
}
|
|
553
|
+
}
|
|
554
|
+
ctx.logger?.debug("CoreLoop: running task cycle", { adapter: adapter.adapterType, goalId });
|
|
555
|
+
ctx.deps.onProgress?.({
|
|
556
|
+
iteration: loopIndex + 1,
|
|
557
|
+
maxIterations: ctx.config.maxIterations,
|
|
558
|
+
phase: "Executing task...",
|
|
559
|
+
gap: result.gapAggregate,
|
|
560
|
+
});
|
|
561
|
+
const taskResult = await ctx.deps.taskLifecycle.runTaskCycle(goalId, gapVector, driveContext, adapter, knowledgeContext, existingTasks, workspaceContext);
|
|
562
|
+
ctx.logger?.info("CoreLoop: task cycle result", { action: taskResult.action, taskId: taskResult.task.id });
|
|
563
|
+
result.taskResult = taskResult;
|
|
564
|
+
result.tokensUsed = (result.tokensUsed ?? 0) + (taskResult.tokensUsed ?? 0);
|
|
565
|
+
ctx.deps.onProgress?.({
|
|
566
|
+
iteration: loopIndex + 1,
|
|
567
|
+
maxIterations: ctx.config.maxIterations,
|
|
568
|
+
phase: "Verifying result...",
|
|
569
|
+
gap: result.gapAggregate,
|
|
570
|
+
taskDescription: taskResult.task.work_description
|
|
571
|
+
? taskResult.task.work_description.split("\n")[0]?.slice(0, 80)
|
|
572
|
+
: undefined,
|
|
573
|
+
});
|
|
574
|
+
// Handle capability_acquiring
|
|
575
|
+
if (taskResult.action === "capability_acquiring" && taskResult.acquisition_task) {
|
|
576
|
+
const acquisitionOutcome = await handleCapabilityAcquisition(taskResult.acquisition_task, goalId, adapter);
|
|
577
|
+
if (acquisitionOutcome?.replanRequired) {
|
|
578
|
+
ctx.logger?.info("CoreLoop: capability acquisition requested replanning", {
|
|
579
|
+
capabilityName: acquisitionOutcome.capabilityName,
|
|
580
|
+
replanRequired: acquisitionOutcome.replanRequired,
|
|
581
|
+
recommendationSource: acquisitionOutcome.recommendationSource,
|
|
582
|
+
recommendedPlugin: acquisitionOutcome.recommendedPlugin,
|
|
583
|
+
});
|
|
584
|
+
ctx.deps.onProgress?.({
|
|
585
|
+
iteration: loopIndex + 1,
|
|
586
|
+
maxIterations: ctx.config.maxIterations,
|
|
587
|
+
phase: "Generating task...",
|
|
588
|
+
gap: result.gapAggregate,
|
|
589
|
+
taskDescription: `Replanning after capability acquisition: ${acquisitionOutcome.capabilityName}`,
|
|
590
|
+
});
|
|
591
|
+
}
|
|
592
|
+
}
|
|
593
|
+
// Portfolio: record task completion
|
|
594
|
+
if (ctx.deps.portfolioManager && taskResult.action === "completed" && taskResult.task.strategy_id) {
|
|
595
|
+
try {
|
|
596
|
+
ctx.deps.portfolioManager.recordTaskCompletion(taskResult.task.strategy_id);
|
|
597
|
+
}
|
|
598
|
+
catch {
|
|
599
|
+
// Non-fatal
|
|
600
|
+
}
|
|
601
|
+
}
|
|
602
|
+
// Phase 7: tool-based verification (Layer 1)
|
|
603
|
+
if (ctx.toolExecutor && taskResult.task.success_criteria.length > 0) {
|
|
604
|
+
try {
|
|
605
|
+
const toolCtx = await buildLoopToolContext(ctx, goalId);
|
|
606
|
+
const verificationResult = await verifyWithTools(taskResult.task.success_criteria, ctx.toolExecutor, toolCtx);
|
|
607
|
+
if (!verificationResult.mechanicalPassed) {
|
|
608
|
+
taskResult.verificationResult = { ...taskResult.verificationResult, verdict: "fail" };
|
|
609
|
+
ctx.logger?.info("CoreLoop Phase 7: tool verification failed", {
|
|
610
|
+
taskId: taskResult.task.id,
|
|
611
|
+
details: verificationResult.details,
|
|
612
|
+
});
|
|
613
|
+
}
|
|
614
|
+
result.toolVerification = verificationResult;
|
|
615
|
+
// Feed execution results back to strategy for scoring
|
|
616
|
+
if (typeof ctx.deps.strategyManager.recordExecutionFeedback === 'function') {
|
|
617
|
+
const activeStrat = await ctx.deps.strategyManager.getActiveStrategy(goalId);
|
|
618
|
+
if (activeStrat) {
|
|
619
|
+
ctx.deps.strategyManager.recordExecutionFeedback({
|
|
620
|
+
strategyId: activeStrat.hypothesis,
|
|
621
|
+
taskId: taskResult.task?.id ?? 'unknown',
|
|
622
|
+
success: taskResult.action === 'completed',
|
|
623
|
+
verificationPassed: verificationResult.mechanicalPassed,
|
|
624
|
+
duration_ms: Date.now() - taskStartTime,
|
|
625
|
+
timestamp: Date.now(),
|
|
626
|
+
});
|
|
627
|
+
}
|
|
628
|
+
}
|
|
629
|
+
}
|
|
630
|
+
catch (err) {
|
|
631
|
+
ctx.logger?.warn("CoreLoop Phase 7: tool verification threw (non-fatal)", {
|
|
632
|
+
error: err instanceof Error ? err.message : String(err),
|
|
633
|
+
});
|
|
634
|
+
}
|
|
635
|
+
}
|
|
636
|
+
// Re-check completion after task execution
|
|
637
|
+
const updatedGoal = await ctx.deps.stateManager.loadGoal(goalId);
|
|
638
|
+
if (updatedGoal) {
|
|
639
|
+
const postTaskJudgment = updatedGoal.children_ids.length > 0
|
|
640
|
+
? await ctx.deps.satisficingJudge.judgeTreeCompletion(updatedGoal.id)
|
|
641
|
+
: ctx.deps.satisficingJudge.isGoalComplete(updatedGoal);
|
|
642
|
+
result.completionJudgment = postTaskJudgment;
|
|
643
|
+
}
|
|
644
|
+
}
|
|
645
|
+
catch (err) {
|
|
646
|
+
result.error = `Task cycle failed: ${err instanceof Error ? err.message : String(err)}`;
|
|
647
|
+
ctx.logger?.error(`CoreLoop: ${result.error}`, { goalId });
|
|
648
|
+
result.elapsedMs = Date.now() - startTime;
|
|
649
|
+
tryGenerateReport(goalId, loopIndex, result, goal);
|
|
650
|
+
return false;
|
|
651
|
+
}
|
|
652
|
+
// Track curiosity goal loop count
|
|
653
|
+
if (ctx.deps.curiosityEngine) {
|
|
654
|
+
const currentGoal = await ctx.deps.stateManager.loadGoal(goalId);
|
|
655
|
+
if (currentGoal?.origin === "curiosity") {
|
|
656
|
+
ctx.deps.curiosityEngine.incrementLoopCount(goalId);
|
|
657
|
+
}
|
|
658
|
+
}
|
|
659
|
+
// Transfer Detection (every 5 iterations, suggestion-only)
|
|
660
|
+
const transferCount = incrementTransferCounter();
|
|
661
|
+
if (ctx.deps.knowledgeTransfer && transferCount % 5 === 0) {
|
|
662
|
+
try {
|
|
663
|
+
const candidates = await ctx.deps.knowledgeTransfer.detectTransferOpportunities(goalId);
|
|
664
|
+
if (candidates.length > 0) {
|
|
665
|
+
result.transfer_candidates = candidates;
|
|
666
|
+
}
|
|
667
|
+
}
|
|
668
|
+
catch {
|
|
669
|
+
// non-fatal
|
|
670
|
+
}
|
|
671
|
+
}
|
|
672
|
+
return true;
|
|
673
|
+
}
|
|
674
|
+
//# sourceMappingURL=task-cycle.js.map
|