scai 0.1.178 → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +162 -267
- package/dist/__tests__/CommitSuggesterCmd.test.js +112 -0
- package/dist/__tests__/CommitSuggesterCmd.test.js.map +1 -0
- package/dist/__tests__/EvalReportCmd.test.js +645 -0
- package/dist/__tests__/EvalReportCmd.test.js.map +1 -0
- package/dist/__tests__/ModelCmd.test.js +64 -0
- package/dist/__tests__/ModelCmd.test.js.map +1 -0
- package/dist/__tests__/agents/agentActions.test.js +345 -0
- package/dist/__tests__/agents/agentActions.test.js.map +1 -0
- package/dist/__tests__/agents/agentFeedback.test.js +118 -0
- package/dist/__tests__/agents/agentFeedback.test.js.map +1 -0
- package/dist/__tests__/agents/agentGeneralScope.test.js +74 -0
- package/dist/__tests__/agents/agentGeneralScope.test.js.map +1 -0
- package/dist/__tests__/agents/agentLoop.test.js +1723 -0
- package/dist/__tests__/agents/agentLoop.test.js.map +1 -0
- package/dist/__tests__/agents/agentPolicyState.test.js +948 -0
- package/dist/__tests__/agents/agentPolicyState.test.js.map +1 -0
- package/dist/__tests__/agents/agentReadEvidence.test.js +170 -0
- package/dist/__tests__/agents/agentReadEvidence.test.js.map +1 -0
- package/dist/__tests__/agents/agentReadPersistence.test.js +129 -0
- package/dist/__tests__/agents/agentReadPersistence.test.js.map +1 -0
- package/dist/__tests__/agents/agentResumeCheckpoint.test.js +90 -0
- package/dist/__tests__/agents/agentResumeCheckpoint.test.js.map +1 -0
- package/dist/__tests__/agents/agentSearchBatchPlanner.test.js +289 -0
- package/dist/__tests__/agents/agentSearchBatchPlanner.test.js.map +1 -0
- package/dist/__tests__/agents/agentSearchOwnership.test.js +166 -0
- package/dist/__tests__/agents/agentSearchOwnership.test.js.map +1 -0
- package/dist/__tests__/agents/agentSearchRanking.test.js +139 -0
- package/dist/__tests__/agents/agentSearchRanking.test.js.map +1 -0
- package/dist/__tests__/agents/agentSearchRouting.test.js +584 -0
- package/dist/__tests__/agents/agentSearchRouting.test.js.map +1 -0
- package/dist/__tests__/agents/agentSearchScoring.test.js +23 -0
- package/dist/__tests__/agents/agentSearchScoring.test.js.map +1 -0
- package/dist/__tests__/agents/agentSearchShared.test.js +78 -0
- package/dist/__tests__/agents/agentSearchShared.test.js.map +1 -0
- package/dist/__tests__/agents/agentStateMachine.test.js +58 -0
- package/dist/__tests__/agents/agentStateMachine.test.js.map +1 -0
- package/dist/__tests__/agents/agentTaskPersistence.test.js +156 -0
- package/dist/__tests__/agents/agentTaskPersistence.test.js.map +1 -0
- package/dist/__tests__/agents/agentTools.test.js +69 -0
- package/dist/__tests__/agents/agentTools.test.js.map +1 -0
- package/dist/__tests__/agents/agentTransform.test.js +779 -0
- package/dist/__tests__/agents/agentTransform.test.js.map +1 -0
- package/dist/__tests__/agents/analysisPlanGenStep.test.js +157 -0
- package/dist/__tests__/agents/analysisPlanGenStep.test.js.map +1 -0
- package/dist/__tests__/agents/answerOnlyCompletion.test.js +75 -0
- package/dist/__tests__/agents/answerOnlyCompletion.test.js.map +1 -0
- package/dist/__tests__/agents/decideNextAction.test.js +1662 -0
- package/dist/__tests__/agents/decideNextAction.test.js.map +1 -0
- package/dist/__tests__/agents/deriveFocusFromSearchStep.test.js +258 -0
- package/dist/__tests__/agents/deriveFocusFromSearchStep.test.js.map +1 -0
- package/dist/__tests__/agents/evidenceVerifierStep.test.js +113 -0
- package/dist/__tests__/agents/evidenceVerifierStep.test.js.map +1 -0
- package/dist/__tests__/agents/executionPolicyResolver.test.js +208 -0
- package/dist/__tests__/agents/executionPolicyResolver.test.js.map +1 -0
- package/dist/__tests__/agents/fileCheckStep.test.js +299 -0
- package/dist/__tests__/agents/fileCheckStep.test.js.map +1 -0
- package/dist/__tests__/agents/giveUpEvaluatorStep.test.js +35 -0
- package/dist/__tests__/agents/giveUpEvaluatorStep.test.js.map +1 -0
- package/dist/__tests__/agents/guardState.test.js +297 -0
- package/dist/__tests__/agents/guardState.test.js.map +1 -0
- package/dist/__tests__/agents/mainAgentHeuristics.test.js +72 -0
- package/dist/__tests__/agents/mainAgentHeuristics.test.js.map +1 -0
- package/dist/__tests__/agents/objectiveEvaluatorStep.test.js +60 -0
- package/dist/__tests__/agents/objectiveEvaluatorStep.test.js.map +1 -0
- package/dist/__tests__/agents/outerLoopRecoveryEvaluator.test.js +207 -0
- package/dist/__tests__/agents/outerLoopRecoveryEvaluator.test.js.map +1 -0
- package/dist/__tests__/agents/prompting.test.js +363 -0
- package/dist/__tests__/agents/prompting.test.js.map +1 -0
- package/dist/__tests__/agents/readinessGateStep.test.js +180 -0
- package/dist/__tests__/agents/readinessGateStep.test.js.map +1 -0
- package/dist/__tests__/agents/reasonNextStep.test.js +56 -0
- package/dist/__tests__/agents/reasonNextStep.test.js.map +1 -0
- package/dist/__tests__/agents/reasonNextTaskStep.test.js +284 -0
- package/dist/__tests__/agents/reasonNextTaskStep.test.js.map +1 -0
- package/dist/__tests__/agents/resolveAgentTargetClassification.test.js +170 -0
- package/dist/__tests__/agents/resolveAgentTargetClassification.test.js.map +1 -0
- package/dist/__tests__/agents/resolveProgressState.test.js +526 -0
- package/dist/__tests__/agents/resolveProgressState.test.js.map +1 -0
- package/dist/__tests__/agents/resumeCheckpoint.test.js +50 -0
- package/dist/__tests__/agents/resumeCheckpoint.test.js.map +1 -0
- package/dist/__tests__/agents/routingDecisionStep.test.js +134 -0
- package/dist/__tests__/agents/routingDecisionStep.test.js.map +1 -0
- package/dist/__tests__/agents/scopeClassificationStep.test.js +118 -0
- package/dist/__tests__/agents/scopeClassificationStep.test.js.map +1 -0
- package/dist/__tests__/agents/searchContext.test.js +97 -0
- package/dist/__tests__/agents/searchContext.test.js.map +1 -0
- package/dist/__tests__/agents/selectRelevantSourcesStep.test.js +73 -0
- package/dist/__tests__/agents/selectRelevantSourcesStep.test.js.map +1 -0
- package/dist/__tests__/agents/structuredOutput.test.js +45 -0
- package/dist/__tests__/agents/structuredOutput.test.js.map +1 -0
- package/dist/__tests__/agents/transformPlanGenStep.fallback.test.js +59 -0
- package/dist/__tests__/agents/transformPlanGenStep.fallback.test.js.map +1 -0
- package/dist/__tests__/agents/transformPlanGenStep.test.js +92 -0
- package/dist/__tests__/agents/transformPlanGenStep.test.js.map +1 -0
- package/dist/__tests__/agents/understandIntentStep.test.js +237 -0
- package/dist/__tests__/agents/understandIntentStep.test.js.map +1 -0
- package/dist/__tests__/agents/understandResumeContext.test.js +65 -0
- package/dist/__tests__/agents/understandResumeContext.test.js.map +1 -0
- package/dist/__tests__/agents/understandScope.test.js +227 -0
- package/dist/__tests__/agents/understandScope.test.js.map +1 -0
- package/dist/__tests__/agents/validateChangesStep.test.js +52 -0
- package/dist/__tests__/agents/validateChangesStep.test.js.map +1 -0
- package/dist/__tests__/askCommandTaskBinding.test.js +176 -0
- package/dist/__tests__/askCommandTaskBinding.test.js.map +1 -0
- package/dist/__tests__/commandVisibility.test.js +25 -0
- package/dist/__tests__/commandVisibility.test.js.map +1 -0
- package/dist/__tests__/config.devOutput.test.js +82 -0
- package/dist/__tests__/config.devOutput.test.js.map +1 -0
- package/dist/__tests__/currentContext.test.js +43 -0
- package/dist/__tests__/currentContext.test.js.map +1 -0
- package/dist/__tests__/daemonWorker.test.js +51 -0
- package/dist/__tests__/daemonWorker.test.js.map +1 -0
- package/dist/__tests__/dialogState.test.js +113 -0
- package/dist/__tests__/dialogState.test.js.map +1 -0
- package/dist/__tests__/evalCommands.test.js +506 -0
- package/dist/__tests__/evalCommands.test.js.map +1 -0
- package/dist/__tests__/evalCommandsSummary.test.js +68 -0
- package/dist/__tests__/evalCommandsSummary.test.js.map +1 -0
- package/dist/__tests__/example.test.js +1 -0
- package/dist/__tests__/example.test.js.map +1 -0
- package/dist/__tests__/factory.commitCommand.test.js +45 -0
- package/dist/__tests__/factory.commitCommand.test.js.map +1 -0
- package/dist/__tests__/factory.devOutputCommand.test.js +122 -0
- package/dist/__tests__/factory.devOutputCommand.test.js.map +1 -0
- package/dist/__tests__/factory.evalCommands.test.js +38 -0
- package/dist/__tests__/factory.evalCommands.test.js.map +1 -0
- package/dist/__tests__/factory.planCommand.test.js +35 -0
- package/dist/__tests__/factory.planCommand.test.js.map +1 -0
- package/dist/__tests__/factory.setupCommand.test.js +34 -0
- package/dist/__tests__/factory.setupCommand.test.js.map +1 -0
- package/dist/__tests__/factory.statusCommand.test.js +54 -0
- package/dist/__tests__/factory.statusCommand.test.js.map +1 -0
- package/dist/__tests__/fileRules/queryTokenRules.test.js +35 -0
- package/dist/__tests__/fileRules/queryTokenRules.test.js.map +1 -0
- package/dist/__tests__/fileRules/searchPathClassification.test.js +57 -0
- package/dist/__tests__/fileRules/searchPathClassification.test.js.map +1 -0
- package/dist/__tests__/generate.ollamaRecovery.test.js +344 -0
- package/dist/__tests__/generate.ollamaRecovery.test.js.map +1 -0
- package/dist/__tests__/index.modelStartup.test.js +24 -0
- package/dist/__tests__/index.modelStartup.test.js.map +1 -0
- package/dist/__tests__/indexCmd.test.js +85 -0
- package/dist/__tests__/indexCmd.test.js.map +1 -0
- package/dist/__tests__/indexSlashCommand.test.js +50 -0
- package/dist/__tests__/indexSlashCommand.test.js.map +1 -0
- package/dist/__tests__/ollamaService.test.js +103 -0
- package/dist/__tests__/ollamaService.test.js.map +1 -0
- package/dist/__tests__/pipeline/modules/codeTransformModule.small-file.test.js +68 -0
- package/dist/__tests__/pipeline/modules/codeTransformModule.small-file.test.js.map +1 -0
- package/dist/__tests__/pipeline/modules/commitSuggesterModule.test.js +68 -0
- package/dist/__tests__/pipeline/modules/commitSuggesterModule.test.js.map +1 -0
- package/dist/__tests__/pipeline/modules/fileSearchModule.test.js +284 -0
- package/dist/__tests__/pipeline/modules/fileSearchModule.test.js.map +1 -0
- package/dist/__tests__/pipeline/modules/finalAnswerModule.test.js +1139 -0
- package/dist/__tests__/pipeline/modules/finalAnswerModule.test.js.map +1 -0
- package/dist/__tests__/pipeline/modules/readFileModule.test.js +146 -0
- package/dist/__tests__/pipeline/modules/readFileModule.test.js.map +1 -0
- package/dist/__tests__/pipeline/modules/semanticAnalysisModule.test.js +192 -0
- package/dist/__tests__/pipeline/modules/semanticAnalysisModule.test.js.map +1 -0
- package/dist/__tests__/repoIdentity.test.js +31 -0
- package/dist/__tests__/repoIdentity.test.js.map +1 -0
- package/dist/__tests__/resumeContext.test.js +87 -0
- package/dist/__tests__/resumeContext.test.js.map +1 -0
- package/dist/__tests__/resumeState.test.js +239 -0
- package/dist/__tests__/resumeState.test.js.map +1 -0
- package/dist/__tests__/search/SearchOrchestrator.test.js +836 -0
- package/dist/__tests__/search/SearchOrchestrator.test.js.map +1 -0
- package/dist/__tests__/shellDialogUi.test.js +52 -0
- package/dist/__tests__/shellDialogUi.test.js.map +1 -0
- package/dist/__tests__/shellSession.test.js +102 -0
- package/dist/__tests__/shellSession.test.js.map +1 -0
- package/dist/__tests__/statusOwner.test.js +215 -0
- package/dist/__tests__/statusOwner.test.js.map +1 -0
- package/dist/__tests__/testing/contextEval.test.js +244 -0
- package/dist/__tests__/testing/contextEval.test.js.map +1 -0
- package/dist/__tests__/testing/harnessArtifacts.test.js +124 -0
- package/dist/__tests__/testing/harnessArtifacts.test.js.map +1 -0
- package/dist/__tests__/testing/llmTraceSession.test.js +67 -0
- package/dist/__tests__/testing/llmTraceSession.test.js.map +1 -0
- package/dist/__tests__/testing/registerDevCliCommands.test.js +35 -0
- package/dist/__tests__/testing/registerDevCliCommands.test.js.map +1 -0
- package/dist/__tests__/testing/runDiagnosis.test.js +159 -0
- package/dist/__tests__/testing/runDiagnosis.test.js.map +1 -0
- package/dist/__tests__/testing/runtimeLogReader.test.js +66 -0
- package/dist/__tests__/testing/runtimeLogReader.test.js.map +1 -0
- package/dist/__tests__/testing/testCommands.test.js +53 -0
- package/dist/__tests__/testing/testCommands.test.js.map +1 -0
- package/dist/__tests__/utils/compileSearchQuery.test.js +38 -0
- package/dist/__tests__/utils/compileSearchQuery.test.js.map +1 -0
- package/dist/__tests__/utils/consolePresentation.test.js +105 -0
- package/dist/__tests__/utils/consolePresentation.test.js.map +1 -0
- package/dist/__tests__/utils/extractFileReferences.test.js +41 -0
- package/dist/__tests__/utils/extractFileReferences.test.js.map +1 -0
- package/dist/__tests__/utils/log.test.js +34 -0
- package/dist/__tests__/utils/log.test.js.map +1 -0
- package/dist/__tests__/utils/runtimeLogger.test.js +200 -0
- package/dist/__tests__/utils/runtimeLogger.test.js.map +1 -0
- package/dist/__tests__/utils/spinner.test.js +31 -0
- package/dist/__tests__/utils/spinner.test.js.map +1 -0
- package/dist/__tests__/utils/verifyFocusPreference.test.js +41 -0
- package/dist/__tests__/utils/verifyFocusPreference.test.js.map +1 -0
- package/dist/agent/actions/index.js +301 -0
- package/dist/agent/actions/index.js.map +1 -0
- package/dist/agent/actions/normalize.js +360 -0
- package/dist/agent/actions/normalize.js.map +1 -0
- package/dist/agent/actions/schemas.js +129 -0
- package/dist/agent/actions/schemas.js.map +1 -0
- package/dist/agent/evidence/index.js +320 -0
- package/dist/agent/evidence/index.js.map +1 -0
- package/dist/agent/feedback/index.js +187 -0
- package/dist/agent/feedback/index.js.map +1 -0
- package/dist/agent/finalization/index.js +35 -0
- package/dist/agent/finalization/index.js.map +1 -0
- package/dist/agent/index.js +126 -0
- package/dist/agent/index.js.map +1 -0
- package/dist/agent/logging/index.js +350 -0
- package/dist/agent/logging/index.js.map +1 -0
- package/dist/agent/persistence/boot.js +58 -0
- package/dist/agent/persistence/boot.js.map +1 -0
- package/dist/agent/persistence/currentTask.js +36 -0
- package/dist/agent/persistence/currentTask.js.map +1 -0
- package/dist/agent/persistence/hydrate.js +42 -0
- package/dist/agent/persistence/hydrate.js.map +1 -0
- package/dist/agent/persistence/index.js +15 -0
- package/dist/agent/persistence/index.js.map +1 -0
- package/dist/agent/persistence/snapshots.js +97 -0
- package/dist/agent/persistence/snapshots.js.map +1 -0
- package/dist/agent/persistence/steps.js +95 -0
- package/dist/agent/persistence/steps.js.map +1 -0
- package/dist/agent/persistence/tasks.js +195 -0
- package/dist/agent/persistence/tasks.js.map +1 -0
- package/dist/agent/persistence/turns.js +92 -0
- package/dist/agent/persistence/turns.js.map +1 -0
- package/dist/agent/policy/ambiguityResolution.js +226 -0
- package/dist/agent/policy/ambiguityResolution.js.map +1 -0
- package/dist/agent/policy/contracts.js +2 -0
- package/dist/agent/policy/contracts.js.map +1 -0
- package/dist/agent/policy/coveragePolicy.js +309 -0
- package/dist/agent/policy/coveragePolicy.js.map +1 -0
- package/dist/agent/policy/endDecisionPolicy.js +31 -0
- package/dist/agent/policy/endDecisionPolicy.js.map +1 -0
- package/dist/agent/policy/index.js +344 -0
- package/dist/agent/policy/index.js.map +1 -0
- package/dist/agent/policy/loopReview.js +778 -0
- package/dist/agent/policy/loopReview.js.map +1 -0
- package/dist/agent/policy/readinessPolicy.js +108 -0
- package/dist/agent/policy/readinessPolicy.js.map +1 -0
- package/dist/agent/policy/resolutionPipeline.js +356 -0
- package/dist/agent/policy/resolutionPipeline.js.map +1 -0
- package/dist/agent/policy/targetClassification.js +33 -0
- package/dist/agent/policy/targetClassification.js.map +1 -0
- package/dist/agent/prompting/actionChoice.js +90 -0
- package/dist/agent/prompting/actionChoice.js.map +1 -0
- package/dist/agent/prompting/finalAnswer.js +38 -0
- package/dist/agent/prompting/finalAnswer.js.map +1 -0
- package/dist/agent/prompting/index.js +14 -0
- package/dist/agent/prompting/index.js.map +1 -0
- package/dist/agent/prompting/plan.js +59 -0
- package/dist/agent/prompting/plan.js.map +1 -0
- package/dist/agent/prompting/transform.js +175 -0
- package/dist/agent/prompting/transform.js.map +1 -0
- package/dist/agent/prompting/understand.js +70 -0
- package/dist/agent/prompting/understand.js.map +1 -0
- package/dist/agent/read/freshness.js +29 -0
- package/dist/agent/read/freshness.js.map +1 -0
- package/dist/agent/read/fullReadPrompt.js +43 -0
- package/dist/agent/read/fullReadPrompt.js.map +1 -0
- package/dist/agent/read/index.js +140 -0
- package/dist/agent/read/index.js.map +1 -0
- package/dist/agent/read/persistence.js +88 -0
- package/dist/agent/read/persistence.js.map +1 -0
- package/dist/agent/read/summarizeReadEvidence.js +733 -0
- package/dist/agent/read/summarizeReadEvidence.js.map +1 -0
- package/dist/agent/read/targetResolution.js +126 -0
- package/dist/agent/read/targetResolution.js.map +1 -0
- package/dist/agent/resume/checkpoint.js +41 -0
- package/dist/agent/resume/checkpoint.js.map +1 -0
- package/dist/agent/runtime/lifecycle.js +67 -0
- package/dist/agent/runtime/lifecycle.js.map +1 -0
- package/dist/agent/runtime/progress.js +178 -0
- package/dist/agent/runtime/progress.js.map +1 -0
- package/dist/agent/runtime/runAgentLoop.js +402 -0
- package/dist/agent/runtime/runAgentLoop.js.map +1 -0
- package/dist/agent/runtime/runAgentPlanOnly.js +127 -0
- package/dist/agent/runtime/runAgentPlanOnly.js.map +1 -0
- package/dist/agent/runtime/understand.js +336 -0
- package/dist/agent/runtime/understand.js.map +1 -0
- package/dist/agent/search/batchPlanner.js +274 -0
- package/dist/agent/search/batchPlanner.js.map +1 -0
- package/dist/agent/search/candidateRetentionPolicy.js +184 -0
- package/dist/agent/search/candidateRetentionPolicy.js.map +1 -0
- package/dist/agent/search/directory.js +51 -0
- package/dist/agent/search/directory.js.map +1 -0
- package/dist/agent/search/exactTarget.js +151 -0
- package/dist/agent/search/exactTarget.js.map +1 -0
- package/dist/agent/search/fragment.js +110 -0
- package/dist/agent/search/fragment.js.map +1 -0
- package/dist/agent/search/index.js +166 -0
- package/dist/agent/search/index.js.map +1 -0
- package/dist/agent/search/laneClassifier.js +119 -0
- package/dist/agent/search/laneClassifier.js.map +1 -0
- package/dist/agent/search/limits.js +10 -0
- package/dist/agent/search/limits.js.map +1 -0
- package/dist/agent/search/ranking.js +22 -0
- package/dist/agent/search/ranking.js.map +1 -0
- package/dist/agent/search/regex.js +83 -0
- package/dist/agent/search/regex.js.map +1 -0
- package/dist/agent/search/routePolicy.js +11 -0
- package/dist/agent/search/routePolicy.js.map +1 -0
- package/dist/agent/search/searchContext.js +128 -0
- package/dist/agent/search/searchContext.js.map +1 -0
- package/dist/agent/search/semantic.js +113 -0
- package/dist/agent/search/semantic.js.map +1 -0
- package/dist/agent/search/semanticIndexSearch.js +202 -0
- package/dist/agent/search/semanticIndexSearch.js.map +1 -0
- package/dist/agent/search/shared.js +283 -0
- package/dist/agent/search/shared.js.map +1 -0
- package/dist/agent/search/shell.js +202 -0
- package/dist/agent/search/shell.js.map +1 -0
- package/dist/agent/search/snippetEvidence.js +57 -0
- package/dist/agent/search/snippetEvidence.js.map +1 -0
- package/dist/agent/search/types.js +2 -0
- package/dist/agent/search/types.js.map +1 -0
- package/dist/agent/state/index.js +99 -0
- package/dist/agent/state/index.js.map +1 -0
- package/dist/agent/state/memory.js +56 -0
- package/dist/agent/state/memory.js.map +1 -0
- package/dist/agent/structuredOutput/index.js +28 -0
- package/dist/agent/structuredOutput/index.js.map +1 -0
- package/dist/agent/tools/index.js +199 -0
- package/dist/agent/tools/index.js.map +1 -0
- package/dist/agent/transform/index.js +519 -0
- package/dist/agent/transform/index.js.map +1 -0
- package/dist/agent/transform/syntax.js +49 -0
- package/dist/agent/transform/syntax.js.map +1 -0
- package/dist/agent/types.js +20 -0
- package/dist/agent/types.js.map +1 -0
- package/dist/agents/actionRegistry.js +114 -0
- package/dist/agents/actionRegistry.js.map +1 -0
- package/dist/agents/agent.js +5 -0
- package/dist/agents/agent.js.map +1 -0
- package/dist/agents/agentActions.js +5 -0
- package/dist/agents/agentActions.js.map +1 -0
- package/dist/agents/agentEvidence.js +5 -0
- package/dist/agents/agentEvidence.js.map +1 -0
- package/dist/agents/agentFeedback.js +5 -0
- package/dist/agents/agentFeedback.js.map +1 -0
- package/dist/agents/agentLogging.js +5 -0
- package/dist/agents/agentLogging.js.map +1 -0
- package/dist/agents/agentLoop.js +5 -0
- package/dist/agents/agentLoop.js.map +1 -0
- package/dist/agents/agentMemory.js +5 -0
- package/dist/agents/agentMemory.js.map +1 -0
- package/dist/agents/agentPlanMode.js +5 -0
- package/dist/agents/agentPlanMode.js.map +1 -0
- package/dist/agents/agentPolicyState.js +5 -0
- package/dist/agents/agentPolicyState.js.map +1 -0
- package/dist/agents/agentProgress.js +93 -0
- package/dist/agents/agentProgress.js.map +1 -0
- package/dist/agents/agentSchemas.js +5 -0
- package/dist/agents/agentSchemas.js.map +1 -0
- package/dist/agents/agentSearchScoring.js +5 -0
- package/dist/agents/agentSearchScoring.js.map +1 -0
- package/dist/agents/agentStateMachine.js +5 -0
- package/dist/agents/agentStateMachine.js.map +1 -0
- package/dist/agents/agentTools.js +5 -0
- package/dist/agents/agentTools.js.map +1 -0
- package/dist/agents/agentTypes.js +5 -0
- package/dist/agents/agentTypes.js.map +1 -0
- package/dist/agents/agentUnderstand.js +5 -0
- package/dist/agents/agentUnderstand.js.map +1 -0
- package/dist/agents/analysisPlanGenStep.js +194 -17
- package/dist/agents/analysisPlanGenStep.js.map +1 -0
- package/dist/agents/answerOnlyCompletion.js +32 -0
- package/dist/agents/answerOnlyCompletion.js.map +1 -0
- package/dist/agents/collaboratorStep.js +1 -0
- package/dist/agents/collaboratorStep.js.map +1 -0
- package/dist/agents/decideNextAction.js +444 -0
- package/dist/agents/decideNextAction.js.map +1 -0
- package/dist/agents/deriveFocusFromSearchStep.js +83 -0
- package/dist/agents/deriveFocusFromSearchStep.js.map +1 -0
- package/dist/agents/evidenceVerifierStep.js +104 -13
- package/dist/agents/evidenceVerifierStep.js.map +1 -0
- package/dist/agents/fileCheckStep.js +381 -12
- package/dist/agents/fileCheckStep.js.map +1 -0
- package/dist/agents/giveUpEvaluatorStep.js +63 -0
- package/dist/agents/giveUpEvaluatorStep.js.map +1 -0
- package/dist/agents/guardPolicy.js +20 -0
- package/dist/agents/guardPolicy.js.map +1 -0
- package/dist/agents/guards/executionPolicyResolver.js +165 -0
- package/dist/agents/guards/executionPolicyResolver.js.map +1 -0
- package/dist/agents/guards/guardState.js +195 -0
- package/dist/agents/guards/guardState.js.map +1 -0
- package/dist/agents/guards/resolveProgressState.js +403 -0
- package/dist/agents/guards/resolveProgressState.js.map +1 -0
- package/dist/agents/infoPlanGenStep.js +66 -8
- package/dist/agents/infoPlanGenStep.js.map +1 -0
- package/dist/agents/integrateFeedbackStep.js +1 -0
- package/dist/agents/integrateFeedbackStep.js.map +1 -0
- package/dist/agents/iterationFileSelector.js +8 -7
- package/dist/agents/iterationFileSelector.js.map +1 -0
- package/dist/agents/mainAgentActivityLog.js +85 -0
- package/dist/agents/mainAgentActivityLog.js.map +1 -0
- package/dist/agents/mainAgentHeuristics.js +173 -0
- package/dist/agents/mainAgentHeuristics.js.map +1 -0
- package/dist/agents/mainAgentVerify.js +159 -0
- package/dist/agents/mainAgentVerify.js.map +1 -0
- package/dist/agents/objectiveEvaluatorStep.js +103 -0
- package/dist/agents/objectiveEvaluatorStep.js.map +1 -0
- package/dist/agents/outerLoopRecoveryEvaluator.js +108 -0
- package/dist/agents/outerLoopRecoveryEvaluator.js.map +1 -0
- package/dist/agents/readinessGateStep.js +95 -9
- package/dist/agents/readinessGateStep.js.map +1 -0
- package/dist/agents/reasonNextStep.js +9 -8
- package/dist/agents/reasonNextStep.js.map +1 -0
- package/dist/agents/reasonNextTaskStep.js +267 -144
- package/dist/agents/reasonNextTaskStep.js.map +1 -0
- package/dist/agents/researchPlanGenStep.js +61 -25
- package/dist/agents/researchPlanGenStep.js.map +1 -0
- package/dist/agents/resolveAgentTargetClassification.js +5 -0
- package/dist/agents/resolveAgentTargetClassification.js.map +1 -0
- package/dist/agents/resolveExecutionModeStep.js +1 -0
- package/dist/agents/resolveExecutionModeStep.js.map +1 -0
- package/dist/agents/resolveExplicitTargetsStep.js +74 -0
- package/dist/agents/resolveExplicitTargetsStep.js.map +1 -0
- package/dist/agents/routingDecisionStep.js +58 -11
- package/dist/agents/routingDecisionStep.js.map +1 -0
- package/dist/agents/scopeClassificationStep.js +66 -3
- package/dist/agents/scopeClassificationStep.js.map +1 -0
- package/dist/agents/selectRelevantSourcesStep.js +13 -5
- package/dist/agents/selectRelevantSourcesStep.js.map +1 -0
- package/dist/agents/structuralPreloadStep.js +3 -4
- package/dist/agents/structuralPreloadStep.js.map +1 -0
- package/dist/agents/transformPlanGenStep.js +105 -18
- package/dist/agents/transformPlanGenStep.js.map +1 -0
- package/dist/agents/understandIntentStep.js +237 -17
- package/dist/agents/understandIntentStep.js.map +1 -0
- package/dist/agents/validateChangesStep.js +16 -2
- package/dist/agents/validateChangesStep.js.map +1 -0
- package/dist/agents/writeFileStep.js +1 -0
- package/dist/agents/writeFileStep.js.map +1 -0
- package/dist/commands/AskCmd.js +139 -44
- package/dist/commands/AskCmd.js.map +1 -0
- package/dist/commands/BackupCmd.js +1 -0
- package/dist/commands/BackupCmd.js.map +1 -0
- package/dist/commands/ChangeLogUpdateCmd.js +1 -0
- package/dist/commands/ChangeLogUpdateCmd.js.map +1 -0
- package/dist/commands/CommitSuggesterCmd.js +55 -13
- package/dist/commands/CommitSuggesterCmd.js.map +1 -0
- package/dist/commands/DaemonCmd.js +52 -14
- package/dist/commands/DaemonCmd.js.map +1 -0
- package/dist/commands/DeleteIndex.js +1 -0
- package/dist/commands/DeleteIndex.js.map +1 -0
- package/dist/commands/EvalReportCmd.js +374 -0
- package/dist/commands/EvalReportCmd.js.map +1 -0
- package/dist/commands/FindCmd.js +1 -0
- package/dist/commands/FindCmd.js.map +1 -0
- package/dist/commands/GitCmd.js +1 -0
- package/dist/commands/GitCmd.js.map +1 -0
- package/dist/commands/IndexCmd.js +11 -79
- package/dist/commands/IndexCmd.js.map +1 -0
- package/dist/commands/InspectCmd.js +1 -0
- package/dist/commands/InspectCmd.js.map +1 -0
- package/dist/commands/ModelCmd.js +24 -0
- package/dist/commands/ModelCmd.js.map +1 -0
- package/dist/commands/ReadlineSingleton.js +1 -0
- package/dist/commands/ReadlineSingleton.js.map +1 -0
- package/dist/commands/ResetDbCmd.js +18 -1
- package/dist/commands/ResetDbCmd.js.map +1 -0
- package/dist/commands/ReviewCmd.js +1 -0
- package/dist/commands/ReviewCmd.js.map +1 -0
- package/dist/commands/StatusCmd.js +22 -0
- package/dist/commands/StatusCmd.js.map +1 -0
- package/dist/commands/StopDaemonCmd.js +1 -0
- package/dist/commands/StopDaemonCmd.js.map +1 -0
- package/dist/commands/SummaryCmd.js +1 -0
- package/dist/commands/SummaryCmd.js.map +1 -0
- package/dist/commands/SwitchCmd.js +9 -15
- package/dist/commands/SwitchCmd.js.map +1 -0
- package/dist/commands/TasksCmd.js +142 -57
- package/dist/commands/TasksCmd.js.map +1 -0
- package/dist/commands/TestCmd.js +66 -0
- package/dist/commands/TestCmd.js.map +1 -0
- package/dist/commands/WorkflowCmd.js +1 -0
- package/dist/commands/WorkflowCmd.js.map +1 -0
- package/dist/commands/commandVisibility.js +27 -0
- package/dist/commands/commandVisibility.js.map +1 -0
- package/dist/commands/evalCommands.js +1337 -0
- package/dist/commands/evalCommands.js.map +1 -0
- package/dist/commands/factory.js +206 -38
- package/dist/commands/factory.js.map +1 -0
- package/dist/config.js +62 -11
- package/dist/config.js.map +1 -0
- package/dist/constants.js +21 -3
- package/dist/constants.js.map +1 -0
- package/dist/context.js +33 -32
- package/dist/context.js.map +1 -0
- package/dist/daemon/daemonQueues.js +1 -20
- package/dist/daemon/daemonQueues.js.map +1 -0
- package/dist/daemon/daemonWorker.js +26 -37
- package/dist/daemon/daemonWorker.js.map +1 -0
- package/dist/daemon/generateSummaries.js +1 -0
- package/dist/daemon/generateSummaries.js.map +1 -0
- package/dist/daemon/runFolderCapsuleBatch.js +1 -0
- package/dist/daemon/runFolderCapsuleBatch.js.map +1 -0
- package/dist/daemon/runIndexingBatch.js +1 -0
- package/dist/daemon/runIndexingBatch.js.map +1 -0
- package/dist/daemon/runKgBatch.js +9 -1
- package/dist/daemon/runKgBatch.js.map +1 -0
- package/dist/db/backup.js +1 -0
- package/dist/db/backup.js.map +1 -0
- package/dist/db/client.js +18 -3
- package/dist/db/client.js.map +1 -0
- package/dist/db/fileIndex.js +110 -152
- package/dist/db/fileIndex.js.map +1 -0
- package/dist/db/functionExtractors/extractFromJava.js +1 -0
- package/dist/db/functionExtractors/extractFromJava.js.map +1 -0
- package/dist/db/functionExtractors/extractFromJs.js +1 -0
- package/dist/db/functionExtractors/extractFromJs.js.map +1 -0
- package/dist/db/functionExtractors/extractFromTs.js +1 -0
- package/dist/db/functionExtractors/extractFromTs.js.map +1 -0
- package/dist/db/functionExtractors/extractFromXML.js +1 -0
- package/dist/db/functionExtractors/extractFromXML.js.map +1 -0
- package/dist/db/functionExtractors/index.js +1 -0
- package/dist/db/functionExtractors/index.js.map +1 -0
- package/dist/db/functionIndex.js +9 -0
- package/dist/db/functionIndex.js.map +1 -0
- package/dist/db/schema.js +314 -99
- package/dist/db/schema.js.map +1 -0
- package/dist/db/sqlTemplates.js +1 -0
- package/dist/db/sqlTemplates.js.map +1 -0
- package/dist/fileRules/builtins.js +1 -0
- package/dist/fileRules/builtins.js.map +1 -0
- package/dist/fileRules/classifyFile.js +1 -0
- package/dist/fileRules/classifyFile.js.map +1 -0
- package/dist/fileRules/codeAllowedExtensions.js +1 -0
- package/dist/fileRules/codeAllowedExtensions.js.map +1 -0
- package/dist/fileRules/detectFileType.js +1 -0
- package/dist/fileRules/detectFileType.js.map +1 -0
- package/dist/fileRules/fileClassifier.js +1 -0
- package/dist/fileRules/fileClassifier.js.map +1 -0
- package/dist/fileRules/fileExceptions.js +1 -0
- package/dist/fileRules/fileExceptions.js.map +1 -0
- package/dist/fileRules/ignoredExtensions.js +1 -0
- package/dist/fileRules/ignoredExtensions.js.map +1 -0
- package/dist/fileRules/ignoredPaths.js +48 -5
- package/dist/fileRules/ignoredPaths.js.map +1 -0
- package/dist/fileRules/queryTokenRules.js +176 -0
- package/dist/fileRules/queryTokenRules.js.map +1 -0
- package/dist/fileRules/searchPathClassification.js +58 -0
- package/dist/fileRules/searchPathClassification.js.map +1 -0
- package/dist/fileRules/shouldIgnoreFiles.js +1 -0
- package/dist/fileRules/shouldIgnoreFiles.js.map +1 -0
- package/dist/fileRules/stopWords.js +9 -0
- package/dist/fileRules/stopWords.js.map +1 -0
- package/dist/fileRules/wellKnownRepoFiles.js +1 -0
- package/dist/fileRules/wellKnownRepoFiles.js.map +1 -0
- package/dist/git/commitSummary.js +227 -0
- package/dist/git/commitSummary.js.map +1 -0
- package/dist/github/api.js +1 -0
- package/dist/github/api.js.map +1 -0
- package/dist/github/auth.js +1 -0
- package/dist/github/auth.js.map +1 -0
- package/dist/github/github.js +1 -0
- package/dist/github/github.js.map +1 -0
- package/dist/github/githubAuthCheck.js +1 -0
- package/dist/github/githubAuthCheck.js.map +1 -0
- package/dist/github/postComments.js +1 -0
- package/dist/github/postComments.js.map +1 -0
- package/dist/github/repo.js +15 -24
- package/dist/github/repo.js.map +1 -0
- package/dist/github/token.js +1 -0
- package/dist/github/token.js.map +1 -0
- package/dist/github/types.js +1 -0
- package/dist/github/types.js.map +1 -0
- package/dist/index.js +318 -37
- package/dist/index.js.map +1 -0
- package/dist/lib/generate.js +264 -20
- package/dist/lib/generate.js.map +1 -0
- package/dist/lib/generateFolderCapsules.js +1 -0
- package/dist/lib/generateFolderCapsules.js.map +1 -0
- package/dist/lib/ollamaModelPolicy.js +59 -0
- package/dist/lib/ollamaModelPolicy.js.map +1 -0
- package/dist/lib/spinner.js +29 -9
- package/dist/lib/spinner.js.map +1 -0
- package/dist/modelSetup.js +25 -78
- package/dist/modelSetup.js.map +1 -0
- package/dist/pipeline/modules/changeLogModule.js +10 -1
- package/dist/pipeline/modules/changeLogModule.js.map +1 -0
- package/dist/pipeline/modules/cleanupModule.js +1 -0
- package/dist/pipeline/modules/cleanupModule.js.map +1 -0
- package/dist/pipeline/modules/codeTransformModule.js +10 -16
- package/dist/pipeline/modules/codeTransformModule.js.map +1 -0
- package/dist/pipeline/modules/commentModule.js +12 -0
- package/dist/pipeline/modules/commentModule.js.map +1 -0
- package/dist/pipeline/modules/commitSuggesterModule.js +82 -12
- package/dist/pipeline/modules/commitSuggesterModule.js.map +1 -0
- package/dist/pipeline/modules/contextReviewModule.js +12 -1
- package/dist/pipeline/modules/contextReviewModule.js.map +1 -0
- package/dist/pipeline/modules/dialogAnswerModule.js +58 -0
- package/dist/pipeline/modules/dialogAnswerModule.js.map +1 -0
- package/dist/pipeline/modules/fileSearchModule.js +5 -143
- package/dist/pipeline/modules/fileSearchModule.js.map +1 -0
- package/dist/pipeline/modules/finalAnswerModule.js +1176 -151
- package/dist/pipeline/modules/finalAnswerModule.js.map +1 -0
- package/dist/pipeline/modules/kgModule.js +18 -1
- package/dist/pipeline/modules/kgModule.js.map +1 -0
- package/dist/pipeline/modules/planAnswerModule.js +99 -0
- package/dist/pipeline/modules/planAnswerModule.js.map +1 -0
- package/dist/pipeline/modules/readFileModule.js +300 -0
- package/dist/pipeline/modules/readFileModule.js.map +1 -0
- package/dist/pipeline/modules/reviewModule.js +10 -1
- package/dist/pipeline/modules/reviewModule.js.map +1 -0
- package/dist/pipeline/modules/searchDbModule.js +159 -0
- package/dist/pipeline/modules/searchDbModule.js.map +1 -0
- package/dist/pipeline/modules/searchListDirectoryModule.js +62 -0
- package/dist/pipeline/modules/searchListDirectoryModule.js.map +1 -0
- package/dist/pipeline/modules/searchModuleShared.js +71 -0
- package/dist/pipeline/modules/searchModuleShared.js.map +1 -0
- package/dist/pipeline/modules/searchRegexModule.js +59 -0
- package/dist/pipeline/modules/searchRegexModule.js.map +1 -0
- package/dist/pipeline/modules/semanticAnalysisModule.js +185 -28
- package/dist/pipeline/modules/semanticAnalysisModule.js.map +1 -0
- package/dist/pipeline/modules/summaryModule.js +11 -1
- package/dist/pipeline/modules/summaryModule.js.map +1 -0
- package/dist/pipeline/registry/moduleRegistry.js +9 -0
- package/dist/pipeline/registry/moduleRegistry.js.map +1 -0
- package/dist/pipeline/runModulePipeline.js +1 -0
- package/dist/pipeline/runModulePipeline.js.map +1 -0
- package/dist/scripts/dbScriptSupport.js +172 -0
- package/dist/scripts/dbScriptSupport.js.map +1 -0
- package/dist/scripts/dbcheck.js +173 -267
- package/dist/scripts/dbcheck.js.map +1 -0
- package/dist/scripts/dboverview.js +161 -0
- package/dist/scripts/dboverview.js.map +1 -0
- package/dist/scripts/migrateDb.js +1 -0
- package/dist/scripts/migrateDb.js.map +1 -0
- package/dist/search/SearchOrchestrator.js +928 -0
- package/dist/search/SearchOrchestrator.js.map +1 -0
- package/dist/search/sharedRankingPolicy.js +283 -0
- package/dist/search/sharedRankingPolicy.js.map +1 -0
- package/dist/setup/reindexOwner.js +97 -0
- package/dist/setup/reindexOwner.js.map +1 -0
- package/dist/setup/setupOwner.js +100 -0
- package/dist/setup/setupOwner.js.map +1 -0
- package/dist/shell/dialogUi.js +81 -0
- package/dist/shell/dialogUi.js.map +1 -0
- package/dist/shellSession.js +126 -0
- package/dist/shellSession.js.map +1 -0
- package/dist/status/statusOwner.js +239 -0
- package/dist/status/statusOwner.js.map +1 -0
- package/dist/testing/contextEval.js +514 -0
- package/dist/testing/contextEval.js.map +1 -0
- package/dist/testing/fixtures/transform/small-file.input.js +5 -0
- package/dist/testing/fixtures/transform/small-file.input.js.map +1 -0
- package/dist/testing/harnessArtifacts.js +112 -0
- package/dist/testing/harnessArtifacts.js.map +1 -0
- package/dist/testing/llmTraceSession.js +67 -0
- package/dist/testing/llmTraceSession.js.map +1 -0
- package/dist/testing/registerDevCliCommands.js +43 -0
- package/dist/testing/registerDevCliCommands.js.map +1 -0
- package/dist/testing/runDiagnosis.js +248 -0
- package/dist/testing/runDiagnosis.js.map +1 -0
- package/dist/testing/runtimeLogReader.js +144 -0
- package/dist/testing/runtimeLogReader.js.map +1 -0
- package/dist/testing/testCommands.js +35 -303
- package/dist/testing/testCommands.js.map +1 -0
- package/dist/testing/testRegistry.js +233 -0
- package/dist/testing/testRegistry.js.map +1 -0
- package/dist/types.js +1 -0
- package/dist/types.js.map +1 -0
- package/dist/utils/buildContextualPrompt.js +26 -75
- package/dist/utils/buildContextualPrompt.js.map +1 -0
- package/dist/utils/changeLogPrompt.js +1 -0
- package/dist/utils/changeLogPrompt.js.map +1 -0
- package/dist/utils/checkModel.js +17 -92
- package/dist/utils/checkModel.js.map +1 -0
- package/dist/utils/commentMap.js +1 -0
- package/dist/utils/commentMap.js.map +1 -0
- package/dist/utils/compileSearchQuery.js +23 -9
- package/dist/utils/compileSearchQuery.js.map +1 -0
- package/dist/utils/consolePresentation.js +208 -0
- package/dist/utils/consolePresentation.js.map +1 -0
- package/dist/utils/contentUtils.js +17 -2
- package/dist/utils/contentUtils.js.map +1 -0
- package/dist/utils/debugContext.js +1 -0
- package/dist/utils/debugContext.js.map +1 -0
- package/dist/utils/dialogState.js +201 -0
- package/dist/utils/dialogState.js.map +1 -0
- package/dist/utils/editor.js +1 -0
- package/dist/utils/editor.js.map +1 -0
- package/dist/utils/executionEvidence.js +50 -0
- package/dist/utils/executionEvidence.js.map +1 -0
- package/dist/utils/extractFileReferences.js +140 -6
- package/dist/utils/extractFileReferences.js.map +1 -0
- package/dist/utils/fileEvidenceCache.js +50 -0
- package/dist/utils/fileEvidenceCache.js.map +1 -0
- package/dist/utils/fileTree.js +1 -0
- package/dist/utils/fileTree.js.map +1 -0
- package/dist/utils/loadRelevantFolderCapsules.js +35 -5
- package/dist/utils/loadRelevantFolderCapsules.js.map +1 -0
- package/dist/utils/log.js +10 -1
- package/dist/utils/log.js.map +1 -0
- package/dist/utils/normalizeData.js +1 -0
- package/dist/utils/normalizeData.js.map +1 -0
- package/dist/utils/ollamaModelStatus.js +28 -0
- package/dist/utils/ollamaModelStatus.js.map +1 -0
- package/dist/utils/ollamaService.js +294 -0
- package/dist/utils/ollamaService.js.map +1 -0
- package/dist/utils/outputFormatter.js +1 -0
- package/dist/utils/outputFormatter.js.map +1 -0
- package/dist/utils/parseTaggedContent.js +1 -0
- package/dist/utils/parseTaggedContent.js.map +1 -0
- package/dist/utils/planActions.js +27 -46
- package/dist/utils/planActions.js.map +1 -0
- package/dist/utils/promptBuilderHelper.js +1 -0
- package/dist/utils/promptBuilderHelper.js.map +1 -0
- package/dist/utils/promptLogHelper.js +29 -13
- package/dist/utils/promptLogHelper.js.map +1 -0
- package/dist/utils/queryAnchors.js +71 -0
- package/dist/utils/queryAnchors.js.map +1 -0
- package/dist/utils/repoIdentity.js +82 -0
- package/dist/utils/repoIdentity.js.map +1 -0
- package/dist/utils/repoKey.js +1 -0
- package/dist/utils/repoKey.js.map +1 -0
- package/dist/utils/resolveTargetsToFiles.js +1 -0
- package/dist/utils/resolveTargetsToFiles.js.map +1 -0
- package/dist/utils/resumeContext.js +219 -0
- package/dist/utils/resumeContext.js.map +1 -0
- package/dist/utils/resumeState.js +310 -0
- package/dist/utils/resumeState.js.map +1 -0
- package/dist/utils/rollingPlan.js +118 -0
- package/dist/utils/rollingPlan.js.map +1 -0
- package/dist/utils/runQueryWithDaemonControl.js +11 -3
- package/dist/utils/runQueryWithDaemonControl.js.map +1 -0
- package/dist/utils/runtimeLogger.js +252 -0
- package/dist/utils/runtimeLogger.js.map +1 -0
- package/dist/utils/sanitizeQuery.js +1 -0
- package/dist/utils/sanitizeQuery.js.map +1 -0
- package/dist/utils/sharedUtils.js +1 -0
- package/dist/utils/sharedUtils.js.map +1 -0
- package/dist/utils/sleep.js +1 -0
- package/dist/utils/sleep.js.map +1 -0
- package/dist/utils/splitCodeIntoChunk.js +1 -0
- package/dist/utils/splitCodeIntoChunk.js.map +1 -0
- package/dist/utils/time.js +66 -0
- package/dist/utils/time.js.map +1 -0
- package/dist/utils/verifyFocusPreference.js +107 -0
- package/dist/utils/verifyFocusPreference.js.map +1 -0
- package/dist/utils/vscode.js +1 -0
- package/dist/utils/vscode.js.map +1 -0
- package/dist/workflow/workflowResolver.js +1 -0
- package/dist/workflow/workflowResolver.js.map +1 -0
- package/dist/workflow/workflowRunner.js +1 -0
- package/dist/workflow/workflowRunner.js.map +1 -0
- package/package.json +3 -3
- package/dist/agents/MainAgent.js +0 -1886
- package/dist/agents/contextReviewStep.js +0 -101
- package/dist/agents/finalPlanGenStep.js +0 -107
- package/dist/agents/structuralAnalysisStep.js +0 -46
- package/dist/agents/validationAnalysisStep.js +0 -87
- package/dist/pipeline/modules/chunkManagerModule.js +0 -24
- package/dist/pipeline/modules/cleanGeneratedTestsModule.js +0 -33
- package/dist/pipeline/modules/fileReaderModule.js +0 -72
- package/dist/pipeline/modules/gatherInfoModule.js +0 -181
- package/dist/pipeline/modules/generateTestsModule.js +0 -68
- package/dist/pipeline/modules/preserveCodeModule.js +0 -195
- package/dist/pipeline/modules/refactorModule.js +0 -40
- package/dist/pipeline/modules/repairTestsModule.js +0 -48
- package/dist/pipeline/modules/runTestsModule.js +0 -37
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"progress.js","sourceRoot":"","sources":["../../../src/agent/runtime/progress.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Maps new-agent loop phases into transient spinner text and durable milestone lines.\n *\n * Why this file exists:\n * - spinner text should stay human-facing instead of exposing raw event names\n * - durable console messages should stay curated and separate from runtime records\n * - the state machine should validate status, not choose console wording\n * - one formatter keeps `/agent` progress consistent across success and failure paths\n * - stop actions still need readable normal-mode labels\n */\nimport path from \"path\";\nimport chalk from \"chalk\";\nimport type { AgentActionName, AgentFailureDetails, AgentStep, AgentTransformLoopProgress } from \"../types.js\";\n\ntype ProgressContext = {\n turnCount: number;\n maxTurns: number;\n};\n\nfunction withTurnCount(message: string, context: ProgressContext, includeTurn = true): string {\n if (!includeTurn) return message;\n return `${message} (turn ${context.turnCount}/${context.maxTurns})`;\n}\n\nfunction describeAction(action: AgentActionName): string {\n switch (action) {\n case \"plan\":\n return \"Planning next steps\";\n case \"search-db\":\n return \"Searching indexed files\";\n case \"search-regex\":\n return \"Running regex search\";\n case \"search-list-directory\":\n return \"Listing directory\";\n case \"triage-file\":\n return \"Triaging file\";\n case \"read-file\":\n return \"Reading file\";\n case \"codeTransform\":\n return \"Transforming file\";\n case \"cannot-answer\":\n return \"Reporting inability to answer\";\n case \"request-user-input\":\n return \"Requesting user input\";\n case \"final-answer\":\n return \"Producing final answer\";\n }\n}\n\nfunction describeChosenAction(action: AgentActionName): string {\n switch (action) {\n case \"plan\":\n return \"Chose planning.\";\n case \"search-db\":\n return \"Chose indexed search.\";\n case \"search-regex\":\n return \"Chose regex search.\";\n case \"search-list-directory\":\n return \"Chose directory listing.\";\n case \"triage-file\":\n return \"Chose file triage.\";\n case \"read-file\":\n return \"Chose direct file read.\";\n case \"codeTransform\":\n return \"Chose file transform.\";\n case \"cannot-answer\":\n return \"Chose inability report.\";\n case \"request-user-input\":\n return \"Chose user input request.\";\n case \"final-answer\":\n return \"Chose final answer.\";\n }\n}\n\nexport function formatUnderstandProgress(context: ProgressContext): string {\n return withTurnCount(\"Understanding request\", context, false);\n}\n\nexport function formatActionChoiceProgress(context: ProgressContext): string {\n return withTurnCount(\"Choosing next action\", context);\n}\n\nexport function formatStepProgress(step: AgentStep, context: ProgressContext): string {\n return withTurnCount(describeAction(step.action), context);\n}\n\nexport function formatReplanProgress(context: ProgressContext): string {\n return withTurnCount(\"Planning next steps\", context);\n}\n\nexport function formatFinalizingProgress(context: ProgressContext): string {\n return withTurnCount(\"Producing final answer\", context);\n}\n\nexport function formatFailureProgress(details: AgentFailureDetails): string {\n const parts = [\n \"Simple agent failed\",\n details.action ? `action=${details.action}` : \"\",\n details.stepId ? `step=${details.stepId}` : \"\",\n `stage=${details.stage}`,\n ].filter(Boolean);\n return parts.join(\" | \");\n}\n\nexport function formatUnderstandMilestone(): string {\n return \"Understanding request.\";\n}\n\nexport function formatChosenActionMilestone(action: AgentActionName): string {\n return describeChosenAction(action);\n}\n\nexport function formatStepMilestone(step: AgentStep): string {\n return `${describeAction(step.action)}.`;\n}\n\nexport function formatReplanMilestone(): string {\n return \"Planning next steps.\";\n}\n\nexport function formatFinalizingMilestone(): string {\n return \"Producing final answer.\";\n}\n\nfunction formatTransformEditWindow(editIds: string[] | undefined): string {\n if (!Array.isArray(editIds) || editIds.length === 0) {\n return \"edits ?\";\n }\n const numericIds = editIds\n .map((editId) => editId.match(/(\\d+)$/)?.[1])\n .filter((value): value is string => Boolean(value))\n .map((value) => Number(value));\n if (numericIds.length === editIds.length) {\n const sorted = [...numericIds].sort((left, right) => left - right);\n return sorted[0] === sorted[sorted.length - 1]\n ? `edit ${sorted[0]}`\n : `edits ${sorted[0]}-${sorted[sorted.length - 1]}`;\n }\n return editIds.length === 1 ? `edit ${editIds[0]}` : `edits ${editIds.join(\",\")}`;\n}\n\nfunction describeTransformLoopStage(stage: AgentTransformLoopProgress[\"stage\"]): string {\n switch (stage) {\n case \"started\":\n return \"starting\";\n case \"planning\":\n return \"planning\";\n case \"applying\":\n return \"applying\";\n case \"validating\":\n return \"validating\";\n case \"retrying\":\n return \"retrying\";\n case \"failed\":\n return \"failed\";\n case \"completed\":\n return \"completed\";\n }\n}\n\nexport function formatTransformLoopProgress(progress: AgentTransformLoopProgress): string {\n const fileName = path.basename(progress.filePath);\n const batchText = typeof progress.batchNumber === \"number\" && typeof progress.batchCount === \"number\"\n ? `batch ${progress.batchNumber}/${progress.batchCount}`\n : \"batch ?\";\n const retryText = typeof progress.retryCount === \"number\" && progress.retryCount > 0\n ? ` | retry ${progress.retryCount}`\n : \"\";\n return [\n fileName,\n batchText,\n formatTransformEditWindow(progress.editIds),\n describeTransformLoopStage(progress.stage),\n ].join(\" | \") + retryText;\n}\n\nexport function formatTransformStartMilestone(filePath: string): string {\n return `Transform file: ${path.basename(filePath)}`;\n}\n\nexport function formatTransformWarningMilestone(warning: string): string {\n return chalk.yellow(warning);\n}\n\nexport function formatTransformRetryMilestone(progress: AgentTransformLoopProgress): string {\n const fileName = path.basename(progress.filePath);\n const batchText = typeof progress.batchNumber === \"number\" && typeof progress.batchCount === \"number\"\n ? `batch ${progress.batchNumber}/${progress.batchCount}`\n : \"current batch\";\n return `Retry ${batchText} for ${fileName}.`;\n}\n\nexport function formatTransformFailureMilestone(progress: AgentTransformLoopProgress): string {\n const fileName = path.basename(progress.filePath);\n const batchText = typeof progress.batchNumber === \"number\" && typeof progress.batchCount === \"number\"\n ? ` at batch ${progress.batchNumber}/${progress.batchCount}`\n : \"\";\n const reason = progress.reason ? ` Reason: ${progress.reason}` : \"\";\n return `Transform failed for ${fileName}${batchText}.${reason}`;\n}\n\nexport function formatTransformCompletionMilestone(progress: AgentTransformLoopProgress): string {\n return `Transform completed for ${path.basename(progress.filePath)}.`;\n}\n"]}
|
|
@@ -0,0 +1,402 @@
|
|
|
1
|
+
import { generate } from "../../lib/generate.js";
|
|
2
|
+
import { buildActions, sanitizeDecision } from "../actions/index.js";
|
|
3
|
+
import { resolvePolicyState } from "../policy/index.js";
|
|
4
|
+
import { buildTools } from "../tools/index.js";
|
|
5
|
+
import { getErrorMessage, getErrorTrace, logAgentError, logAgentLlmFailure, logAgentLlmInput, logAgentLlmOutput, logAgentStepInput, logAgentStepOutput, logAgentValidationFailure, recordAgentEvent, } from "../logging/index.js";
|
|
6
|
+
import { buildActionChoicePacket, renderActionChoicePrompt } from "../prompting/index.js";
|
|
7
|
+
import { formatActionChoiceProgress, formatChosenActionMilestone, formatFailureProgress, formatReplanProgress, formatReplanMilestone, formatStepProgress, formatStepMilestone, formatUnderstandProgress, formatUnderstandMilestone, } from "./progress.js";
|
|
8
|
+
import { validateActionArgs } from "../actions/schemas.js";
|
|
9
|
+
import { createRuntimeStep, finishStep, finalizeTask, requestReplan, startStep } from "../state/index.js";
|
|
10
|
+
import { runUnderstand } from "./understand.js";
|
|
11
|
+
import { refreshAgentTargetClassification } from "../policy/targetClassification.js";
|
|
12
|
+
import { applyFinalTaskStatus, resolveForcedEndDecision } from "../finalization/index.js";
|
|
13
|
+
import { AgentRuntimeError } from "../types.js";
|
|
14
|
+
import { applyUnderstandResult, recordStepCreated, recordStepFailure, recordStepFinished, recordStepStarted, recordTaskFinalized, } from "./lifecycle.js";
|
|
15
|
+
import { emitAgentLlmTimingMessage, emitAgentStepStateMessage, emitAgentTaskStateMessage, emitConsoleMessage, shouldShowConsoleTiming, } from "../../utils/consolePresentation.js";
|
|
16
|
+
import { nowLocalIso } from "../../utils/time.js";
|
|
17
|
+
import { parseStructuredJson } from "../structuredOutput/index.js";
|
|
18
|
+
function shouldContinue(memory) {
|
|
19
|
+
return memory.task.status === "active" && memory.task.turnCount < memory.task.maxTurns;
|
|
20
|
+
}
|
|
21
|
+
function emitSimpleAgentMilestone(ui, message) {
|
|
22
|
+
if (shouldShowConsoleTiming()) {
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
emitConsoleMessage(ui, message);
|
|
26
|
+
}
|
|
27
|
+
function emitStepCreatedState(ui, step) {
|
|
28
|
+
emitAgentStepStateMessage(ui, {
|
|
29
|
+
stepId: step.id,
|
|
30
|
+
action: step.action,
|
|
31
|
+
from: "created",
|
|
32
|
+
to: step.status,
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
function emitStepTransitionState(ui, step, from, durationMs) {
|
|
36
|
+
emitAgentStepStateMessage(ui, {
|
|
37
|
+
stepId: step.id,
|
|
38
|
+
action: step.action,
|
|
39
|
+
from,
|
|
40
|
+
to: step.status,
|
|
41
|
+
...(typeof durationMs === "number" ? { durationMs } : {}),
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
function emitTaskTransitionState(ui, from, to, reason) {
|
|
45
|
+
emitAgentTaskStateMessage(ui, {
|
|
46
|
+
from,
|
|
47
|
+
to,
|
|
48
|
+
...(reason ? { reason } : {}),
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
function computeStepDurationMs(step) {
|
|
52
|
+
if (!step.startedAt || !step.completedAt) {
|
|
53
|
+
return undefined;
|
|
54
|
+
}
|
|
55
|
+
const startedAtMs = Date.parse(step.startedAt);
|
|
56
|
+
const completedAtMs = Date.parse(step.completedAt);
|
|
57
|
+
if (!Number.isFinite(startedAtMs) || !Number.isFinite(completedAtMs)) {
|
|
58
|
+
return undefined;
|
|
59
|
+
}
|
|
60
|
+
return Math.max(0, completedAtMs - startedAtMs);
|
|
61
|
+
}
|
|
62
|
+
async function chooseNextAction(memory, policy, ui) {
|
|
63
|
+
const legalActions = policy.allowedActions;
|
|
64
|
+
if (legalActions.length === 1) {
|
|
65
|
+
return sanitizeDecision({
|
|
66
|
+
action: legalActions[0],
|
|
67
|
+
args: policy.decision.args ?? {},
|
|
68
|
+
reason: "Only one legal action was available.",
|
|
69
|
+
}, legalActions, memory);
|
|
70
|
+
}
|
|
71
|
+
const packet = buildActionChoicePacket(memory, policy);
|
|
72
|
+
const defaultDecision = policy.decision.stop && legalActions.includes(policy.decision.stop)
|
|
73
|
+
? { action: policy.decision.stop, args: {}, reason: policy.decision.reason }
|
|
74
|
+
: policy.decision.nextAction && legalActions.includes(policy.decision.nextAction)
|
|
75
|
+
? (() => {
|
|
76
|
+
return {
|
|
77
|
+
action: policy.decision.nextAction,
|
|
78
|
+
args: policy.decision.args ?? {},
|
|
79
|
+
reason: policy.decision.reason,
|
|
80
|
+
};
|
|
81
|
+
})()
|
|
82
|
+
: policy.shouldAskUser && legalActions.includes("request-user-input")
|
|
83
|
+
? { action: "request-user-input", args: {}, reason: "The user needs to choose one ambiguous in-repo target before reading further." }
|
|
84
|
+
: { action: legalActions[0], args: {}, reason: "Take the first legal action." };
|
|
85
|
+
logAgentLlmInput(memory, "agent.action-choice", packet, undefined, nowLocalIso());
|
|
86
|
+
try {
|
|
87
|
+
const response = await generate({ query: memory.task.initialQuery, content: renderActionChoicePrompt(packet) }, {
|
|
88
|
+
caller: "agent.action-choice",
|
|
89
|
+
inputContext: packet,
|
|
90
|
+
});
|
|
91
|
+
const parsed = parseStructuredJson(String(response?.data ?? ""), { fallback: defaultDecision });
|
|
92
|
+
const decision = sanitizeDecision(parsed, legalActions, memory);
|
|
93
|
+
const forcedDecision = policy.decision.stop
|
|
94
|
+
? sanitizeDecision({ action: policy.decision.stop, args: {}, reason: policy.decision.reason }, legalActions, memory)
|
|
95
|
+
: policy.decision.nextAction && decision.action !== policy.decision.nextAction
|
|
96
|
+
? sanitizeDecision(defaultDecision, legalActions, memory)
|
|
97
|
+
: null;
|
|
98
|
+
const finalDecision = forcedDecision ?? decision;
|
|
99
|
+
logAgentLlmOutput(memory, "agent.action-choice", {
|
|
100
|
+
decision: finalDecision,
|
|
101
|
+
review: parsed.review,
|
|
102
|
+
legalActions,
|
|
103
|
+
}, undefined, response?.trace);
|
|
104
|
+
if (ui) {
|
|
105
|
+
emitAgentLlmTimingMessage(ui, "agent.action-choice", response?.trace);
|
|
106
|
+
}
|
|
107
|
+
return finalDecision;
|
|
108
|
+
}
|
|
109
|
+
catch (error) {
|
|
110
|
+
const details = {
|
|
111
|
+
stage: "action-choice",
|
|
112
|
+
message: getErrorMessage(error),
|
|
113
|
+
};
|
|
114
|
+
logAgentLlmFailure(memory, "agent.action-choice", details, getErrorTrace(error));
|
|
115
|
+
throw new AgentRuntimeError(details, error);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
function evaluateStep(step, result) {
|
|
119
|
+
if (!result.ok) {
|
|
120
|
+
if (step.action === "codeTransform") {
|
|
121
|
+
return {
|
|
122
|
+
stepStatus: "blocked",
|
|
123
|
+
summary: result.summary,
|
|
124
|
+
needsReplan: false,
|
|
125
|
+
taskStatus: "blocked",
|
|
126
|
+
stopReason: "transform-failed",
|
|
127
|
+
};
|
|
128
|
+
}
|
|
129
|
+
return {
|
|
130
|
+
stepStatus: "failed",
|
|
131
|
+
summary: result.summary,
|
|
132
|
+
needsReplan: false,
|
|
133
|
+
};
|
|
134
|
+
}
|
|
135
|
+
if (step.action === "final-answer") {
|
|
136
|
+
return {
|
|
137
|
+
stepStatus: "done",
|
|
138
|
+
summary: "Task completed with a final answer.",
|
|
139
|
+
needsReplan: false,
|
|
140
|
+
taskStatus: "done",
|
|
141
|
+
stopReason: "completed",
|
|
142
|
+
};
|
|
143
|
+
}
|
|
144
|
+
if (step.action === "plan") {
|
|
145
|
+
return {
|
|
146
|
+
stepStatus: "done",
|
|
147
|
+
summary: result.summary,
|
|
148
|
+
needsReplan: false,
|
|
149
|
+
};
|
|
150
|
+
}
|
|
151
|
+
if (step.action === "request-user-input") {
|
|
152
|
+
return {
|
|
153
|
+
stepStatus: "done",
|
|
154
|
+
summary: result.summary,
|
|
155
|
+
needsReplan: false,
|
|
156
|
+
taskStatus: "waiting",
|
|
157
|
+
stopReason: "need-user-input",
|
|
158
|
+
};
|
|
159
|
+
}
|
|
160
|
+
if (step.action === "codeTransform") {
|
|
161
|
+
return {
|
|
162
|
+
stepStatus: "done",
|
|
163
|
+
summary: result.summary,
|
|
164
|
+
needsReplan: false,
|
|
165
|
+
taskStatus: "done",
|
|
166
|
+
stopReason: "completed",
|
|
167
|
+
};
|
|
168
|
+
}
|
|
169
|
+
return {
|
|
170
|
+
stepStatus: "done",
|
|
171
|
+
summary: result.summary,
|
|
172
|
+
needsReplan: false,
|
|
173
|
+
};
|
|
174
|
+
}
|
|
175
|
+
function runUnderstandPhase(memory, ui) {
|
|
176
|
+
ui.update(formatUnderstandProgress(memory.task));
|
|
177
|
+
emitSimpleAgentMilestone(ui, formatUnderstandMilestone());
|
|
178
|
+
return runUnderstand(memory, ui).then((understand) => {
|
|
179
|
+
applyUnderstandResult(memory, understand);
|
|
180
|
+
refreshAgentTargetClassification(memory);
|
|
181
|
+
});
|
|
182
|
+
}
|
|
183
|
+
async function getOrCreateNextStep(memory, ui) {
|
|
184
|
+
const existingStep = memory.steps.find((candidate) => candidate.status === "pending");
|
|
185
|
+
if (existingStep) {
|
|
186
|
+
return existingStep;
|
|
187
|
+
}
|
|
188
|
+
ui.update(formatActionChoiceProgress(memory.task));
|
|
189
|
+
const policy = resolvePolicyState(memory);
|
|
190
|
+
const decision = await chooseNextAction(memory, policy, ui);
|
|
191
|
+
emitSimpleAgentMilestone(ui, formatChosenActionMilestone(decision.action));
|
|
192
|
+
const step = createRuntimeStep(memory, decision.action, decision.reason, decision.args);
|
|
193
|
+
recordStepCreated(memory, step);
|
|
194
|
+
emitStepCreatedState(ui, step);
|
|
195
|
+
return step;
|
|
196
|
+
}
|
|
197
|
+
function requestReplanIfNeeded(memory, reason, ui) {
|
|
198
|
+
const replanStep = requestReplan(memory);
|
|
199
|
+
if (!replanStep) {
|
|
200
|
+
return false;
|
|
201
|
+
}
|
|
202
|
+
recordAgentEvent(memory, "replan-requested", { reason });
|
|
203
|
+
recordStepCreated(memory, replanStep);
|
|
204
|
+
if (ui) {
|
|
205
|
+
emitStepCreatedState(ui, replanStep);
|
|
206
|
+
}
|
|
207
|
+
if (ui) {
|
|
208
|
+
ui.update(formatReplanProgress(memory.task));
|
|
209
|
+
emitSimpleAgentMilestone(ui, formatReplanMilestone());
|
|
210
|
+
}
|
|
211
|
+
return true;
|
|
212
|
+
}
|
|
213
|
+
function validateOrReplanStep(memory, step, ui, actions) {
|
|
214
|
+
ui.update(formatStepProgress(step, memory.task));
|
|
215
|
+
emitSimpleAgentMilestone(ui, formatStepMilestone(step));
|
|
216
|
+
const spec = actions[step.action];
|
|
217
|
+
logAgentStepInput(memory, step);
|
|
218
|
+
const errors = validateActionArgs(spec, step.args);
|
|
219
|
+
if (errors.length === 0) {
|
|
220
|
+
return { kind: "run-step", spec };
|
|
221
|
+
}
|
|
222
|
+
finishStep(memory, step, "blocked", `Invalid args for ${step.action}: ${errors.join(", ")}`);
|
|
223
|
+
logAgentValidationFailure(memory, step, errors);
|
|
224
|
+
logAgentStepOutput(memory, step, `Validation failed for ${step.action}.`, {
|
|
225
|
+
action: step.action,
|
|
226
|
+
args: step.args,
|
|
227
|
+
errors,
|
|
228
|
+
});
|
|
229
|
+
requestReplanIfNeeded(memory, step.resultSummary ?? `Invalid args for ${step.action}.`, ui);
|
|
230
|
+
return { kind: "continue" };
|
|
231
|
+
}
|
|
232
|
+
async function executeStepWithUi(memory, step, spec, ui) {
|
|
233
|
+
const fromStatus = step.status;
|
|
234
|
+
startStep(memory, step);
|
|
235
|
+
emitStepTransitionState(ui, step, fromStatus);
|
|
236
|
+
recordStepStarted(memory, step);
|
|
237
|
+
const result = await spec.run(memory, step.args);
|
|
238
|
+
memory.artifacts.actionResults[step.id] = result.output ?? null;
|
|
239
|
+
return result;
|
|
240
|
+
}
|
|
241
|
+
function applyEvaluation(memory, step, evaluation) {
|
|
242
|
+
finishStep(memory, step, evaluation.stepStatus, evaluation.summary);
|
|
243
|
+
if (evaluation.taskStatus) {
|
|
244
|
+
return {
|
|
245
|
+
kind: "stop",
|
|
246
|
+
decision: {
|
|
247
|
+
kind: "finalize",
|
|
248
|
+
taskStatus: evaluation.taskStatus,
|
|
249
|
+
stopReason: evaluation.stopReason ?? "completed",
|
|
250
|
+
},
|
|
251
|
+
};
|
|
252
|
+
}
|
|
253
|
+
return { kind: "continue" };
|
|
254
|
+
}
|
|
255
|
+
function applyStepOutcome(memory, step, result, ui) {
|
|
256
|
+
const evaluation = evaluateStep(step, result);
|
|
257
|
+
const fromStatus = step.status;
|
|
258
|
+
const outcome = applyEvaluation(memory, step, evaluation);
|
|
259
|
+
emitStepTransitionState(ui, step, fromStatus, computeStepDurationMs(step));
|
|
260
|
+
recordStepFinished(memory, step, evaluation.summary, {
|
|
261
|
+
action: step.action,
|
|
262
|
+
result: {
|
|
263
|
+
ok: result.ok,
|
|
264
|
+
summary: result.summary,
|
|
265
|
+
output: result.output ?? null,
|
|
266
|
+
},
|
|
267
|
+
evaluation,
|
|
268
|
+
});
|
|
269
|
+
return outcome;
|
|
270
|
+
}
|
|
271
|
+
function resolveEndDecision(memory) {
|
|
272
|
+
return resolveForcedEndDecision(memory);
|
|
273
|
+
}
|
|
274
|
+
function resolvePendingEndStep(memory, decision, ui) {
|
|
275
|
+
if (decision.kind !== "run-action") {
|
|
276
|
+
throw new Error("resolvePendingEndStep only supports run-action decisions.");
|
|
277
|
+
}
|
|
278
|
+
const pendingStep = memory.steps.find((step) => step.status === "pending" && step.action === decision.action);
|
|
279
|
+
if (pendingStep) {
|
|
280
|
+
return pendingStep;
|
|
281
|
+
}
|
|
282
|
+
const step = createRuntimeStep(memory, decision.action, decision.purpose, {}, decision.expectedEvidence);
|
|
283
|
+
recordStepCreated(memory, step);
|
|
284
|
+
emitStepCreatedState(ui, step);
|
|
285
|
+
return step;
|
|
286
|
+
}
|
|
287
|
+
function finalizeAfterEndAction(memory, result, decision) {
|
|
288
|
+
applyFinalTaskStatus(memory, result, decision);
|
|
289
|
+
}
|
|
290
|
+
async function finishRun(memory, ui, actions, decision) {
|
|
291
|
+
if (memory.task.status !== "active") {
|
|
292
|
+
recordTaskFinalized(memory);
|
|
293
|
+
return;
|
|
294
|
+
}
|
|
295
|
+
if (decision.kind === "finalize") {
|
|
296
|
+
const fromStatus = memory.task.status;
|
|
297
|
+
finalizeTask(memory, decision.taskStatus, decision.stopReason);
|
|
298
|
+
emitTaskTransitionState(ui, fromStatus, memory.task.status, decision.stopReason);
|
|
299
|
+
recordTaskFinalized(memory);
|
|
300
|
+
return;
|
|
301
|
+
}
|
|
302
|
+
const step = resolvePendingEndStep(memory, decision, ui);
|
|
303
|
+
const gate = validateOrReplanStep(memory, step, ui, actions);
|
|
304
|
+
if (gate.kind === "continue") {
|
|
305
|
+
const fromStatus = memory.task.status;
|
|
306
|
+
finalizeTask(memory, "blocked", decision.stopReason);
|
|
307
|
+
emitTaskTransitionState(ui, fromStatus, memory.task.status, decision.stopReason);
|
|
308
|
+
}
|
|
309
|
+
else {
|
|
310
|
+
const result = await executeStepWithUi(memory, step, gate.spec, ui);
|
|
311
|
+
const fromStatus = step.status;
|
|
312
|
+
finishStep(memory, step, result.ok ? "done" : "blocked", result.summary);
|
|
313
|
+
emitStepTransitionState(ui, step, fromStatus, computeStepDurationMs(step));
|
|
314
|
+
recordStepFinished(memory, step, result.summary, {
|
|
315
|
+
action: step.action,
|
|
316
|
+
result: {
|
|
317
|
+
ok: result.ok,
|
|
318
|
+
summary: result.summary,
|
|
319
|
+
output: result.output ?? null,
|
|
320
|
+
},
|
|
321
|
+
endDecision: decision,
|
|
322
|
+
});
|
|
323
|
+
const taskStatusBefore = memory.task.status;
|
|
324
|
+
finalizeAfterEndAction(memory, result, decision);
|
|
325
|
+
emitTaskTransitionState(ui, taskStatusBefore, memory.task.status, memory.task.stopReason);
|
|
326
|
+
}
|
|
327
|
+
recordTaskFinalized(memory);
|
|
328
|
+
}
|
|
329
|
+
function buildFailureDetails(memory, activeStep, failureStage, error, ui) {
|
|
330
|
+
const details = error instanceof AgentRuntimeError
|
|
331
|
+
? error.details
|
|
332
|
+
: {
|
|
333
|
+
stage: failureStage,
|
|
334
|
+
message: error instanceof Error ? error.message : String(error),
|
|
335
|
+
stepId: activeStep?.id,
|
|
336
|
+
action: activeStep?.action,
|
|
337
|
+
};
|
|
338
|
+
if (activeStep && activeStep.status === "running") {
|
|
339
|
+
const fromStatus = activeStep.status;
|
|
340
|
+
finishStep(memory, activeStep, "failed", details.message);
|
|
341
|
+
emitStepTransitionState(ui, activeStep, fromStatus, computeStepDurationMs(activeStep));
|
|
342
|
+
recordStepFailure(memory, activeStep, details.message, details.stage);
|
|
343
|
+
}
|
|
344
|
+
if (memory.task.status === "active" || memory.task.status === "waiting") {
|
|
345
|
+
const fromStatus = memory.task.status;
|
|
346
|
+
finalizeTask(memory, "failed", details.stage);
|
|
347
|
+
emitTaskTransitionState(ui, fromStatus, memory.task.status, details.stage);
|
|
348
|
+
}
|
|
349
|
+
recordAgentEvent(memory, "task-failed", {
|
|
350
|
+
stage: details.stage,
|
|
351
|
+
message: details.message,
|
|
352
|
+
action: details.action ?? null,
|
|
353
|
+
stepId: details.stepId ?? null,
|
|
354
|
+
status: "failed",
|
|
355
|
+
}, details.stepId);
|
|
356
|
+
logAgentError(memory, details, {
|
|
357
|
+
currentStepId: memory.task.currentStepId ?? null,
|
|
358
|
+
turnCount: memory.task.turnCount,
|
|
359
|
+
});
|
|
360
|
+
recordTaskFinalized(memory);
|
|
361
|
+
return error instanceof AgentRuntimeError ? error : new AgentRuntimeError(details, error);
|
|
362
|
+
}
|
|
363
|
+
export async function runAgentLoop(memory, ui) {
|
|
364
|
+
const tools = buildTools();
|
|
365
|
+
const actions = buildActions(tools, ui);
|
|
366
|
+
let activeStep;
|
|
367
|
+
let failureStage = "understand";
|
|
368
|
+
try {
|
|
369
|
+
await runUnderstandPhase(memory, ui);
|
|
370
|
+
while (shouldContinue(memory)) {
|
|
371
|
+
memory.task.turnCount += 1;
|
|
372
|
+
failureStage = "action-choice";
|
|
373
|
+
const step = await getOrCreateNextStep(memory, ui);
|
|
374
|
+
activeStep = step;
|
|
375
|
+
const gate = validateOrReplanStep(memory, step, ui, actions);
|
|
376
|
+
if (gate.kind === "continue") {
|
|
377
|
+
activeStep = undefined;
|
|
378
|
+
continue;
|
|
379
|
+
}
|
|
380
|
+
failureStage = "step-execution";
|
|
381
|
+
const result = await executeStepWithUi(memory, step, gate.spec, ui);
|
|
382
|
+
refreshAgentTargetClassification(memory);
|
|
383
|
+
const outcome = applyStepOutcome(memory, step, result, ui);
|
|
384
|
+
activeStep = undefined;
|
|
385
|
+
if (outcome.kind === "stop") {
|
|
386
|
+
await finishRun(memory, ui, actions, outcome.decision);
|
|
387
|
+
return;
|
|
388
|
+
}
|
|
389
|
+
}
|
|
390
|
+
if (memory.task.status === "active") {
|
|
391
|
+
await finishRun(memory, ui, actions, resolveEndDecision(memory));
|
|
392
|
+
return;
|
|
393
|
+
}
|
|
394
|
+
recordTaskFinalized(memory);
|
|
395
|
+
}
|
|
396
|
+
catch (error) {
|
|
397
|
+
const runtimeError = buildFailureDetails(memory, activeStep, failureStage, error, ui);
|
|
398
|
+
ui.update(formatFailureProgress(runtimeError.details));
|
|
399
|
+
throw runtimeError;
|
|
400
|
+
}
|
|
401
|
+
}
|
|
402
|
+
//# sourceMappingURL=runAgentLoop.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runAgentLoop.js","sourceRoot":"","sources":["../../../src/agent/runtime/runAgentLoop.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Runs the new simple agent loop on top of `memory`.\n *\n * Why this file exists:\n * - the new runtime should keep one small explicit loop\n * - loop control and evaluation should stay easy to trace\n * - prompts, tools, and state creation should live elsewhere\n * - live shell progress should stay readable without exposing raw log records\n * - end-of-run work should go through the same explicit state flow as normal steps\n * - dev-mode state lines should describe the real state machine transitions\n * - transform stays one outer runtime action even though the owner batches internally\n */\nimport type { AgentUI } from \"../../types.js\";\nimport { generate } from \"../../lib/generate.js\";\nimport { buildActions, sanitizeDecision } from \"../actions/index.js\";\nimport { resolveNextReadTarget, resolveNextTriageTarget, resolvePolicyState, resolvePreferredReadAction, type AgentPolicyState } from \"../policy/index.js\";\nimport { buildTools } from \"../tools/index.js\";\nimport {\n getErrorMessage,\n getErrorTrace,\n logAgentError,\n logAgentLlmFailure,\n logAgentLlmInput,\n logAgentLlmOutput,\n logAgentStepInput,\n logAgentStepOutput,\n logAgentValidationFailure,\n recordAgentArtifact,\n recordAgentEvent,\n} from \"../logging/index.js\";\nimport { buildActionChoicePacket, renderActionChoicePrompt } from \"../prompting/index.js\";\nimport {\n formatActionChoiceProgress,\n formatChosenActionMilestone,\n formatFailureProgress,\n formatReplanProgress,\n formatReplanMilestone,\n formatStepProgress,\n formatStepMilestone,\n formatUnderstandProgress,\n formatUnderstandMilestone,\n} from \"./progress.js\";\nimport { validateActionArgs } from \"../actions/schemas.js\";\nimport { createRuntimeStep, finishStep, finalizeTask, requestReplan, startStep } from \"../state/index.js\";\nimport { runUnderstand } from \"./understand.js\";\nimport { refreshAgentTargetClassification } from \"../policy/targetClassification.js\";\nimport { applyFinalTaskStatus, resolveForcedEndDecision, type RuntimeEndDecision } from \"../finalization/index.js\";\nimport { AgentRuntimeError, type ActionResult, type AgentActionName, type AgentActionSpec, type AgentDecision, type AgentEvaluation, type AgentMemory, type AgentStep, type AgentTaskStatus } from \"../types.js\";\nimport {\n applyUnderstandResult,\n recordStepCreated,\n recordStepFailure,\n recordStepFinished,\n recordStepStarted,\n recordTaskFinalized,\n} from \"./lifecycle.js\";\nimport {\n emitAgentLlmTimingMessage,\n emitAgentStepStateMessage,\n emitAgentTaskStateMessage,\n emitConsoleMessage,\n shouldShowConsoleTiming,\n} from \"../../utils/consolePresentation.js\";\nimport { nowLocalIso } from \"../../utils/time.js\";\nimport { parseStructuredJson } from \"../structuredOutput/index.js\";\n\ntype AgentActions = Record<AgentActionName, AgentActionSpec>;\n\ntype StepGateDecision =\n | { kind: \"continue\" }\n | { kind: \"run-step\"; spec: AgentActionSpec };\n\ntype EndDecision = RuntimeEndDecision;\n\ntype StepOutcomeDecision =\n | { kind: \"continue\" }\n | { kind: \"stop\"; decision: EndDecision };\n\nfunction shouldContinue(memory: AgentMemory): boolean {\n return memory.task.status === \"active\" && memory.task.turnCount < memory.task.maxTurns;\n}\n\nfunction emitSimpleAgentMilestone(ui: AgentUI, message: string): void {\n if (shouldShowConsoleTiming()) {\n return;\n }\n emitConsoleMessage(ui, message);\n}\n\nfunction emitStepCreatedState(ui: AgentUI, step: AgentStep): void {\n emitAgentStepStateMessage(ui, {\n stepId: step.id,\n action: step.action,\n from: \"created\",\n to: step.status,\n });\n}\n\nfunction emitStepTransitionState(ui: AgentUI, step: AgentStep, from: string, durationMs?: number): void {\n emitAgentStepStateMessage(ui, {\n stepId: step.id,\n action: step.action,\n from,\n to: step.status,\n ...(typeof durationMs === \"number\" ? { durationMs } : {}),\n });\n}\n\nfunction emitTaskTransitionState(\n ui: AgentUI,\n from: AgentTaskStatus,\n to: AgentTaskStatus,\n reason?: string\n): void {\n emitAgentTaskStateMessage(ui, {\n from,\n to,\n ...(reason ? { reason } : {}),\n });\n}\n\nfunction computeStepDurationMs(step: AgentStep): number | undefined {\n if (!step.startedAt || !step.completedAt) {\n return undefined;\n }\n const startedAtMs = Date.parse(step.startedAt);\n const completedAtMs = Date.parse(step.completedAt);\n if (!Number.isFinite(startedAtMs) || !Number.isFinite(completedAtMs)) {\n return undefined;\n }\n return Math.max(0, completedAtMs - startedAtMs);\n}\n\nasync function chooseNextAction(memory: AgentMemory, policy: AgentPolicyState, ui?: AgentUI): Promise<AgentDecision> {\n const legalActions = policy.allowedActions;\n if (legalActions.length === 1) {\n return sanitizeDecision({\n action: legalActions[0],\n args: policy.decision.args ?? {},\n reason: \"Only one legal action was available.\",\n }, legalActions, memory);\n }\n\n const packet = buildActionChoicePacket(memory, policy);\n const defaultDecision: AgentDecision = policy.decision.stop && legalActions.includes(policy.decision.stop)\n ? { action: policy.decision.stop, args: {}, reason: policy.decision.reason }\n : policy.decision.nextAction && legalActions.includes(policy.decision.nextAction)\n ? (() => {\n return {\n action: policy.decision.nextAction,\n args: policy.decision.args ?? {},\n reason: policy.decision.reason,\n };\n })()\n : policy.shouldAskUser && legalActions.includes(\"request-user-input\")\n ? { action: \"request-user-input\", args: {}, reason: \"The user needs to choose one ambiguous in-repo target before reading further.\" }\n : { action: legalActions[0], args: {}, reason: \"Take the first legal action.\" };\n logAgentLlmInput(memory, \"agent.action-choice\", packet, undefined, nowLocalIso());\n try {\n const response = await generate({ query: memory.task.initialQuery, content: renderActionChoicePrompt(packet) }, {\n caller: \"agent.action-choice\",\n inputContext: packet,\n });\n const parsed = parseStructuredJson<Partial<AgentDecision> & { review?: Record<string, unknown> }>(\n String(response?.data ?? \"\"),\n { fallback: defaultDecision }\n );\n const decision = sanitizeDecision(parsed, legalActions, memory);\n const forcedDecision = policy.decision.stop\n ? sanitizeDecision({ action: policy.decision.stop, args: {}, reason: policy.decision.reason }, legalActions, memory)\n : policy.decision.nextAction && decision.action !== policy.decision.nextAction\n ? sanitizeDecision(defaultDecision, legalActions, memory)\n : null;\n const finalDecision = forcedDecision ?? decision;\n logAgentLlmOutput(memory, \"agent.action-choice\", {\n decision: finalDecision,\n review: parsed.review,\n legalActions,\n }, undefined, response?.trace);\n if (ui) {\n emitAgentLlmTimingMessage(ui, \"agent.action-choice\", response?.trace);\n }\n return finalDecision;\n } catch (error) {\n const details = {\n stage: \"action-choice\",\n message: getErrorMessage(error),\n };\n logAgentLlmFailure(memory, \"agent.action-choice\", details, getErrorTrace(error));\n throw new AgentRuntimeError(details, error);\n }\n}\n\nfunction evaluateStep(step: AgentStep, result: ActionResult): AgentEvaluation {\n if (!result.ok) {\n if (step.action === \"codeTransform\") {\n return {\n stepStatus: \"blocked\",\n summary: result.summary,\n needsReplan: false,\n taskStatus: \"blocked\",\n stopReason: \"transform-failed\",\n };\n }\n return {\n stepStatus: \"failed\",\n summary: result.summary,\n needsReplan: false,\n };\n }\n\n if (step.action === \"final-answer\") {\n return {\n stepStatus: \"done\",\n summary: \"Task completed with a final answer.\",\n needsReplan: false,\n taskStatus: \"done\",\n stopReason: \"completed\",\n };\n }\n\n if (step.action === \"plan\") {\n return {\n stepStatus: \"done\",\n summary: result.summary,\n needsReplan: false,\n };\n }\n\n if (step.action === \"request-user-input\") {\n return {\n stepStatus: \"done\",\n summary: result.summary,\n needsReplan: false,\n taskStatus: \"waiting\",\n stopReason: \"need-user-input\",\n };\n }\n\n if (step.action === \"codeTransform\") {\n return {\n stepStatus: \"done\",\n summary: result.summary,\n needsReplan: false,\n taskStatus: \"done\",\n stopReason: \"completed\",\n };\n }\n\n return {\n stepStatus: \"done\",\n summary: result.summary,\n needsReplan: false,\n };\n}\n\nfunction runUnderstandPhase(memory: AgentMemory, ui: AgentUI): Promise<void> {\n ui.update(formatUnderstandProgress(memory.task));\n emitSimpleAgentMilestone(ui, formatUnderstandMilestone());\n return runUnderstand(memory, ui).then((understand) => {\n applyUnderstandResult(memory, understand);\n refreshAgentTargetClassification(memory);\n });\n}\n\nasync function getOrCreateNextStep(memory: AgentMemory, ui: AgentUI): Promise<AgentStep> {\n const existingStep = memory.steps.find((candidate) => candidate.status === \"pending\");\n if (existingStep) {\n return existingStep;\n }\n\n ui.update(formatActionChoiceProgress(memory.task));\n const policy = resolvePolicyState(memory);\n const decision = await chooseNextAction(memory, policy, ui);\n emitSimpleAgentMilestone(ui, formatChosenActionMilestone(decision.action));\n const step = createRuntimeStep(memory, decision.action, decision.reason, decision.args);\n recordStepCreated(memory, step);\n emitStepCreatedState(ui, step);\n return step;\n}\n\nfunction requestReplanIfNeeded(memory: AgentMemory, reason: string, ui?: AgentUI): boolean {\n const replanStep = requestReplan(memory);\n if (!replanStep) {\n return false;\n }\n recordAgentEvent(memory, \"replan-requested\", { reason });\n recordStepCreated(memory, replanStep);\n if (ui) {\n emitStepCreatedState(ui, replanStep);\n }\n if (ui) {\n ui.update(formatReplanProgress(memory.task));\n emitSimpleAgentMilestone(ui, formatReplanMilestone());\n }\n return true;\n}\n\nfunction validateOrReplanStep(\n memory: AgentMemory,\n step: AgentStep,\n ui: AgentUI,\n actions: AgentActions\n): StepGateDecision {\n ui.update(formatStepProgress(step, memory.task));\n emitSimpleAgentMilestone(ui, formatStepMilestone(step));\n\n const spec = actions[step.action];\n logAgentStepInput(memory, step);\n const errors = validateActionArgs(spec, step.args);\n if (errors.length === 0) {\n return { kind: \"run-step\", spec };\n }\n\n finishStep(memory, step, \"blocked\", `Invalid args for ${step.action}: ${errors.join(\", \")}`);\n logAgentValidationFailure(memory, step, errors);\n logAgentStepOutput(memory, step, `Validation failed for ${step.action}.`, {\n action: step.action,\n args: step.args,\n errors,\n });\n requestReplanIfNeeded(memory, step.resultSummary ?? `Invalid args for ${step.action}.`, ui);\n return { kind: \"continue\" };\n}\n\nasync function executeStepWithUi(\n memory: AgentMemory,\n step: AgentStep,\n spec: AgentActionSpec,\n ui: AgentUI\n): Promise<ActionResult> {\n const fromStatus = step.status;\n startStep(memory, step);\n emitStepTransitionState(ui, step, fromStatus);\n recordStepStarted(memory, step);\n\n const result = await spec.run(memory, step.args);\n memory.artifacts.actionResults[step.id] = result.output ?? null;\n return result;\n}\n\nfunction applyEvaluation(memory: AgentMemory, step: AgentStep, evaluation: AgentEvaluation): StepOutcomeDecision {\n finishStep(memory, step, evaluation.stepStatus, evaluation.summary);\n\n if (evaluation.taskStatus) {\n return {\n kind: \"stop\",\n decision: {\n kind: \"finalize\",\n taskStatus: evaluation.taskStatus,\n stopReason: evaluation.stopReason ?? \"completed\",\n },\n };\n }\n\n return { kind: \"continue\" };\n}\n\nfunction applyStepOutcome(memory: AgentMemory, step: AgentStep, result: ActionResult, ui: AgentUI): StepOutcomeDecision {\n const evaluation = evaluateStep(step, result);\n const fromStatus = step.status;\n const outcome = applyEvaluation(memory, step, evaluation);\n emitStepTransitionState(ui, step, fromStatus, computeStepDurationMs(step));\n recordStepFinished(memory, step, evaluation.summary, {\n action: step.action,\n result: {\n ok: result.ok,\n summary: result.summary,\n output: result.output ?? null,\n },\n evaluation,\n });\n return outcome;\n}\n\nfunction resolveEndDecision(memory: AgentMemory): EndDecision {\n return resolveForcedEndDecision(memory);\n}\n\nfunction resolvePendingEndStep(memory: AgentMemory, decision: EndDecision, ui: AgentUI): AgentStep {\n if (decision.kind !== \"run-action\") {\n throw new Error(\"resolvePendingEndStep only supports run-action decisions.\");\n }\n const pendingStep = memory.steps.find((step) => step.status === \"pending\" && step.action === decision.action);\n if (pendingStep) {\n return pendingStep;\n }\n const step = createRuntimeStep(memory, decision.action, decision.purpose, {}, decision.expectedEvidence);\n recordStepCreated(memory, step);\n emitStepCreatedState(ui, step);\n return step;\n}\n\nfunction finalizeAfterEndAction(memory: AgentMemory, result: ActionResult, decision: EndDecision): void {\n applyFinalTaskStatus(memory, result, decision);\n}\n\nasync function finishRun(memory: AgentMemory, ui: AgentUI, actions: AgentActions, decision: EndDecision): Promise<void> {\n if (memory.task.status !== \"active\") {\n recordTaskFinalized(memory);\n return;\n }\n\n if (decision.kind === \"finalize\") {\n const fromStatus = memory.task.status;\n finalizeTask(memory, decision.taskStatus, decision.stopReason);\n emitTaskTransitionState(ui, fromStatus, memory.task.status, decision.stopReason);\n recordTaskFinalized(memory);\n return;\n }\n\n const step = resolvePendingEndStep(memory, decision, ui);\n\n const gate = validateOrReplanStep(memory, step, ui, actions);\n if (gate.kind === \"continue\") {\n const fromStatus = memory.task.status;\n finalizeTask(memory, \"blocked\", decision.stopReason);\n emitTaskTransitionState(ui, fromStatus, memory.task.status, decision.stopReason);\n } else {\n const result = await executeStepWithUi(memory, step, gate.spec, ui);\n const fromStatus = step.status;\n finishStep(memory, step, result.ok ? \"done\" : \"blocked\", result.summary);\n emitStepTransitionState(ui, step, fromStatus, computeStepDurationMs(step));\n recordStepFinished(memory, step, result.summary, {\n action: step.action,\n result: {\n ok: result.ok,\n summary: result.summary,\n output: result.output ?? null,\n },\n endDecision: decision,\n });\n const taskStatusBefore = memory.task.status;\n finalizeAfterEndAction(memory, result, decision);\n emitTaskTransitionState(ui, taskStatusBefore, memory.task.status, memory.task.stopReason);\n }\n\n recordTaskFinalized(memory);\n}\n\nfunction buildFailureDetails(\n memory: AgentMemory,\n activeStep: AgentStep | undefined,\n failureStage: string,\n error: unknown,\n ui: AgentUI\n) {\n const details = error instanceof AgentRuntimeError\n ? error.details\n : {\n stage: failureStage,\n message: error instanceof Error ? error.message : String(error),\n stepId: activeStep?.id,\n action: activeStep?.action,\n };\n\n if (activeStep && activeStep.status === \"running\") {\n const fromStatus = activeStep.status;\n finishStep(memory, activeStep, \"failed\", details.message);\n emitStepTransitionState(ui, activeStep, fromStatus, computeStepDurationMs(activeStep));\n recordStepFailure(memory, activeStep, details.message, details.stage);\n }\n\n if (memory.task.status === \"active\" || memory.task.status === \"waiting\") {\n const fromStatus = memory.task.status;\n finalizeTask(memory, \"failed\", details.stage);\n emitTaskTransitionState(ui, fromStatus, memory.task.status, details.stage);\n }\n recordAgentEvent(memory, \"task-failed\", {\n stage: details.stage,\n message: details.message,\n action: details.action ?? null,\n stepId: details.stepId ?? null,\n status: \"failed\",\n }, details.stepId);\n logAgentError(memory, details, {\n currentStepId: memory.task.currentStepId ?? null,\n turnCount: memory.task.turnCount,\n });\n recordTaskFinalized(memory);\n return error instanceof AgentRuntimeError ? error : new AgentRuntimeError(details, error);\n}\n\nexport async function runAgentLoop(memory: AgentMemory, ui: AgentUI): Promise<void> {\n const tools = buildTools();\n const actions = buildActions(tools, ui);\n let activeStep: AgentStep | undefined;\n let failureStage = \"understand\";\n try {\n await runUnderstandPhase(memory, ui);\n\n while (shouldContinue(memory)) {\n memory.task.turnCount += 1;\n failureStage = \"action-choice\";\n const step = await getOrCreateNextStep(memory, ui);\n\n activeStep = step;\n const gate = validateOrReplanStep(memory, step, ui, actions);\n if (gate.kind === \"continue\") {\n activeStep = undefined;\n continue;\n }\n\n failureStage = \"step-execution\";\n const result = await executeStepWithUi(memory, step, gate.spec, ui);\n refreshAgentTargetClassification(memory);\n const outcome = applyStepOutcome(memory, step, result, ui);\n activeStep = undefined;\n if (outcome.kind === \"stop\") {\n await finishRun(memory, ui, actions, outcome.decision);\n return;\n }\n }\n\n if (memory.task.status === \"active\") {\n await finishRun(memory, ui, actions, resolveEndDecision(memory));\n return;\n }\n\n recordTaskFinalized(memory);\n } catch (error) {\n const runtimeError = buildFailureDetails(memory, activeStep, failureStage, error, ui);\n ui.update(formatFailureProgress(runtimeError.details));\n throw runtimeError;\n }\n}\n"]}
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import { emitAgentStepStateMessage, emitAgentTaskStateMessage, emitConsoleMessage, shouldShowConsoleTiming, } from "../../utils/consolePresentation.js";
|
|
2
|
+
import { buildActions } from "../actions/index.js";
|
|
3
|
+
import { getErrorMessage, getErrorTrace, logAgentError, logAgentStepInput, recordAgentArtifact, recordAgentEvent, } from "../logging/index.js";
|
|
4
|
+
import { formatStepMilestone, formatStepProgress, formatUnderstandMilestone, formatUnderstandProgress, } from "./progress.js";
|
|
5
|
+
import { createRuntimeStep, finalizeTask, finishStep, startStep } from "../state/index.js";
|
|
6
|
+
import { buildTools } from "../tools/index.js";
|
|
7
|
+
import { runUnderstand } from "./understand.js";
|
|
8
|
+
import { AgentRuntimeError } from "../types.js";
|
|
9
|
+
import { applyUnderstandResult, recordStepFailure, recordStepFinished, recordStepStarted, recordTaskFinalized, } from "./lifecycle.js";
|
|
10
|
+
function emitMilestone(ui, message) {
|
|
11
|
+
if (!shouldShowConsoleTiming()) {
|
|
12
|
+
emitConsoleMessage(ui, message);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
function emitStepState(ui, step, from, to) {
|
|
16
|
+
emitAgentStepStateMessage(ui, {
|
|
17
|
+
stepId: step.id,
|
|
18
|
+
action: step.action,
|
|
19
|
+
from,
|
|
20
|
+
to,
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
function renderPlanOnlyAnswer(plan) {
|
|
24
|
+
const lines = [
|
|
25
|
+
`Plan goal: ${plan.goal}`,
|
|
26
|
+
"",
|
|
27
|
+
`Why: ${plan.why}`,
|
|
28
|
+
"",
|
|
29
|
+
"Steps:",
|
|
30
|
+
];
|
|
31
|
+
for (const [index, step] of plan.steps.entries()) {
|
|
32
|
+
lines.push(`${index + 1}. ${step.purpose} (${step.action})`);
|
|
33
|
+
}
|
|
34
|
+
return lines.join("\n");
|
|
35
|
+
}
|
|
36
|
+
export async function runAgentPlanOnly(memory, ui) {
|
|
37
|
+
const tools = buildTools();
|
|
38
|
+
const actions = buildActions(tools, ui);
|
|
39
|
+
let activeStep;
|
|
40
|
+
try {
|
|
41
|
+
ui.update(formatUnderstandProgress(memory.task));
|
|
42
|
+
emitMilestone(ui, formatUnderstandMilestone());
|
|
43
|
+
const understand = await runUnderstand(memory, ui);
|
|
44
|
+
applyUnderstandResult(memory, understand);
|
|
45
|
+
activeStep = createRuntimeStep(memory, "plan", "Create a short implementation plan without entering execution.", {}, ["ordered plan steps"]);
|
|
46
|
+
recordAgentEvent(memory, "step-created", {
|
|
47
|
+
action: activeStep.action,
|
|
48
|
+
args: activeStep.args,
|
|
49
|
+
purpose: activeStep.purpose,
|
|
50
|
+
}, activeStep.id);
|
|
51
|
+
emitStepState(ui, activeStep, "created", activeStep.status);
|
|
52
|
+
ui.update(formatStepProgress(activeStep, memory.task));
|
|
53
|
+
emitMilestone(ui, formatStepMilestone(activeStep));
|
|
54
|
+
logAgentStepInput(memory, activeStep);
|
|
55
|
+
const fromStatus = activeStep.status;
|
|
56
|
+
startStep(memory, activeStep);
|
|
57
|
+
emitStepState(ui, activeStep, fromStatus, activeStep.status);
|
|
58
|
+
recordStepStarted(memory, activeStep);
|
|
59
|
+
const result = await actions.plan.run(memory, {});
|
|
60
|
+
finishStep(memory, activeStep, result.ok ? "done" : "failed", result.summary);
|
|
61
|
+
emitStepState(ui, activeStep, "running", activeStep.status);
|
|
62
|
+
recordStepFinished(memory, activeStep, result.summary, {
|
|
63
|
+
action: activeStep.action,
|
|
64
|
+
result: {
|
|
65
|
+
ok: result.ok,
|
|
66
|
+
summary: result.summary,
|
|
67
|
+
output: result.output ?? null,
|
|
68
|
+
},
|
|
69
|
+
});
|
|
70
|
+
const latestPlan = memory.artifacts.plans[memory.artifacts.plans.length - 1];
|
|
71
|
+
if (!latestPlan) {
|
|
72
|
+
throw new AgentRuntimeError({
|
|
73
|
+
stage: "plan-only",
|
|
74
|
+
message: "Plan-only run finished without a plan artifact.",
|
|
75
|
+
stepId: activeStep.id,
|
|
76
|
+
action: "plan",
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
const answer = renderPlanOnlyAnswer(latestPlan);
|
|
80
|
+
memory.artifacts.finalAnswer = answer;
|
|
81
|
+
recordAgentArtifact(memory.artifacts, "final-answer", answer);
|
|
82
|
+
finalizeTask(memory, "done", "plan-only-completed");
|
|
83
|
+
emitAgentTaskStateMessage(ui, {
|
|
84
|
+
from: "active",
|
|
85
|
+
to: "done",
|
|
86
|
+
reason: "plan-only-completed",
|
|
87
|
+
});
|
|
88
|
+
recordTaskFinalized(memory);
|
|
89
|
+
}
|
|
90
|
+
catch (error) {
|
|
91
|
+
const details = error instanceof AgentRuntimeError
|
|
92
|
+
? error.details
|
|
93
|
+
: {
|
|
94
|
+
stage: "plan-only",
|
|
95
|
+
message: getErrorMessage(error),
|
|
96
|
+
stepId: activeStep?.id,
|
|
97
|
+
action: activeStep?.action,
|
|
98
|
+
};
|
|
99
|
+
if (activeStep?.status === "running") {
|
|
100
|
+
finishStep(memory, activeStep, "failed", details.message);
|
|
101
|
+
emitStepState(ui, activeStep, "running", activeStep.status);
|
|
102
|
+
recordStepFailure(memory, activeStep, details.message, details.stage);
|
|
103
|
+
}
|
|
104
|
+
finalizeTask(memory, "failed", details.stage);
|
|
105
|
+
emitAgentTaskStateMessage(ui, {
|
|
106
|
+
from: "active",
|
|
107
|
+
to: "failed",
|
|
108
|
+
reason: details.stage,
|
|
109
|
+
});
|
|
110
|
+
recordAgentEvent(memory, "task-failed", {
|
|
111
|
+
stage: details.stage,
|
|
112
|
+
message: details.message,
|
|
113
|
+
action: details.action ?? null,
|
|
114
|
+
stepId: details.stepId ?? null,
|
|
115
|
+
status: "failed",
|
|
116
|
+
mode: memory.task.mode,
|
|
117
|
+
}, details.stepId);
|
|
118
|
+
logAgentError(memory, details, {
|
|
119
|
+
currentStepId: memory.task.currentStepId ?? null,
|
|
120
|
+
turnCount: memory.task.turnCount,
|
|
121
|
+
trace: getErrorTrace(error) ?? null,
|
|
122
|
+
});
|
|
123
|
+
recordTaskFinalized(memory);
|
|
124
|
+
throw (error instanceof AgentRuntimeError ? error : new AgentRuntimeError(details, error));
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
//# sourceMappingURL=runAgentPlanOnly.js.map
|