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,274 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Plans grouped semantic search batches from understand-owned term hints.
|
|
3
|
+
*
|
|
4
|
+
* Why this file exists:
|
|
5
|
+
* - grouped search expansion should have one owner in the search area
|
|
6
|
+
* - search should decide batch order and stop conditions without leaking that logic into lanes
|
|
7
|
+
* - semantic search should stay broad enough to recover, but still stop early on strong evidence
|
|
8
|
+
*/
|
|
9
|
+
import { finalizeLanePacket } from "./candidateRetentionPolicy.js";
|
|
10
|
+
const WEAK_SEMANTIC_TERMS = new Set([
|
|
11
|
+
"agent",
|
|
12
|
+
"code",
|
|
13
|
+
"config",
|
|
14
|
+
"configuration",
|
|
15
|
+
"file",
|
|
16
|
+
"files",
|
|
17
|
+
"project",
|
|
18
|
+
"repo",
|
|
19
|
+
"repository",
|
|
20
|
+
"script",
|
|
21
|
+
"scripts",
|
|
22
|
+
"setting",
|
|
23
|
+
"source",
|
|
24
|
+
"test",
|
|
25
|
+
"tests",
|
|
26
|
+
]);
|
|
27
|
+
const SEARCH_TERM_GROUP_ORDER = [
|
|
28
|
+
"repo-anchor",
|
|
29
|
+
"command-path",
|
|
30
|
+
"generic",
|
|
31
|
+
];
|
|
32
|
+
function dedupeStrings(values) {
|
|
33
|
+
const seen = new Set();
|
|
34
|
+
const out = [];
|
|
35
|
+
for (const value of values) {
|
|
36
|
+
const trimmed = String(value ?? "").trim();
|
|
37
|
+
if (!trimmed) {
|
|
38
|
+
continue;
|
|
39
|
+
}
|
|
40
|
+
const key = trimmed.toLowerCase();
|
|
41
|
+
if (seen.has(key)) {
|
|
42
|
+
continue;
|
|
43
|
+
}
|
|
44
|
+
seen.add(key);
|
|
45
|
+
out.push(trimmed);
|
|
46
|
+
}
|
|
47
|
+
return out;
|
|
48
|
+
}
|
|
49
|
+
function dedupeMatches(matches) {
|
|
50
|
+
const seen = new Set();
|
|
51
|
+
const out = [];
|
|
52
|
+
for (const match of matches) {
|
|
53
|
+
const key = [match.filePath, match.line ?? "", match.column ?? "", match.matchKind, match.snippet].join("|");
|
|
54
|
+
if (seen.has(key)) {
|
|
55
|
+
continue;
|
|
56
|
+
}
|
|
57
|
+
seen.add(key);
|
|
58
|
+
out.push(match);
|
|
59
|
+
}
|
|
60
|
+
return out;
|
|
61
|
+
}
|
|
62
|
+
function buildTermGroupQuery(terms) {
|
|
63
|
+
return dedupeStrings(terms).join(" ");
|
|
64
|
+
}
|
|
65
|
+
function isWeakSemanticTerm(term) {
|
|
66
|
+
return WEAK_SEMANTIC_TERMS.has(String(term ?? "").trim().toLowerCase());
|
|
67
|
+
}
|
|
68
|
+
function looksLikeConfigurationIntent(context) {
|
|
69
|
+
const lowered = String(context.query ?? "").toLowerCase();
|
|
70
|
+
return /\b(where|which|what)\b/.test(lowered)
|
|
71
|
+
&& /\b(set|setting|configured|configuration|register|registered|entry|entrypoint|command|commands|limit|count|max)\b/.test(lowered);
|
|
72
|
+
}
|
|
73
|
+
export function buildSemanticSearchBatchPlan(context) {
|
|
74
|
+
const batches = [{
|
|
75
|
+
query: context.query,
|
|
76
|
+
source: "base-query",
|
|
77
|
+
}];
|
|
78
|
+
const seenQueries = new Set([String(context.query ?? "").trim().toLowerCase()]);
|
|
79
|
+
const prioritizedGroups = SEARCH_TERM_GROUP_ORDER.flatMap((kind) => context.searchTermGroups
|
|
80
|
+
.map((group, index) => ({ group, index }))
|
|
81
|
+
.filter((entry) => entry.group.kind === kind));
|
|
82
|
+
for (const { group, index } of prioritizedGroups) {
|
|
83
|
+
const terms = dedupeStrings(group.terms);
|
|
84
|
+
if (terms.length === 0) {
|
|
85
|
+
continue;
|
|
86
|
+
}
|
|
87
|
+
const query = buildTermGroupQuery(terms);
|
|
88
|
+
const key = query.toLowerCase();
|
|
89
|
+
if (!query || seenQueries.has(key)) {
|
|
90
|
+
continue;
|
|
91
|
+
}
|
|
92
|
+
seenQueries.add(key);
|
|
93
|
+
batches.push({
|
|
94
|
+
query,
|
|
95
|
+
source: "search-term-group",
|
|
96
|
+
termGroupIndex: index,
|
|
97
|
+
kind: group.kind,
|
|
98
|
+
terms,
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
return batches;
|
|
102
|
+
}
|
|
103
|
+
function mergeRelatedFileScores(left = {}, right = {}) {
|
|
104
|
+
const merged = { ...left };
|
|
105
|
+
for (const [filePath, score] of Object.entries(right)) {
|
|
106
|
+
const current = merged[filePath];
|
|
107
|
+
merged[filePath] = typeof current === "number" ? Math.min(current, score) : score;
|
|
108
|
+
}
|
|
109
|
+
return merged;
|
|
110
|
+
}
|
|
111
|
+
function mergeSearchPackets(baseQuery, packets) {
|
|
112
|
+
const first = packets[0];
|
|
113
|
+
const mergedDebug = {
|
|
114
|
+
queriesRun: dedupeStrings(packets.flatMap((packet) => packet.debug?.queriesRun ?? [])),
|
|
115
|
+
recoveryUsed: packets.some((packet) => packet.debug?.recoveryUsed === true),
|
|
116
|
+
matchTerms: dedupeStrings(packets.flatMap((packet) => packet.debug?.matchTerms ?? [])),
|
|
117
|
+
};
|
|
118
|
+
const recoveryReasons = dedupeStrings(packets.flatMap((packet) => packet.debug?.recoveryReason ? [packet.debug.recoveryReason] : []));
|
|
119
|
+
return {
|
|
120
|
+
lane: first.lane,
|
|
121
|
+
query: baseQuery,
|
|
122
|
+
filePaths: dedupeStrings(packets.flatMap((packet) => packet.filePaths)),
|
|
123
|
+
matches: dedupeMatches(packets.flatMap((packet) => packet.matches ?? [])),
|
|
124
|
+
relatedFileScores: packets.reduce((acc, packet) => mergeRelatedFileScores(acc, packet.relatedFileScores), {}),
|
|
125
|
+
debug: {
|
|
126
|
+
queriesRun: mergedDebug.queriesRun,
|
|
127
|
+
recoveryUsed: mergedDebug.recoveryUsed,
|
|
128
|
+
matchTerms: mergedDebug.matchTerms,
|
|
129
|
+
...(recoveryReasons.length > 0 ? { recoveryReason: recoveryReasons.join(",") } : {}),
|
|
130
|
+
},
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
function extractMatchedTerms(packet) {
|
|
134
|
+
return dedupeStrings((packet.matches ?? [])
|
|
135
|
+
.flatMap((match) => match.reasons ?? [])
|
|
136
|
+
.map((reason) => reason.match(/^term:(.+)$/i)?.[1] ?? "")
|
|
137
|
+
.filter(Boolean));
|
|
138
|
+
}
|
|
139
|
+
function extractTopHitConfirmations(packet) {
|
|
140
|
+
const confirmations = new Set();
|
|
141
|
+
for (const hit of packet.topHits ?? []) {
|
|
142
|
+
for (const reason of hit.reasons) {
|
|
143
|
+
if (!reason.startsWith("match-confirmation:")) {
|
|
144
|
+
continue;
|
|
145
|
+
}
|
|
146
|
+
for (const term of reason.slice("match-confirmation:".length).split(",")) {
|
|
147
|
+
const normalized = term.trim().toLowerCase();
|
|
148
|
+
if (!normalized || isWeakSemanticTerm(normalized)) {
|
|
149
|
+
continue;
|
|
150
|
+
}
|
|
151
|
+
confirmations.add(normalized);
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
return Array.from(confirmations);
|
|
156
|
+
}
|
|
157
|
+
function hasConcreteSnippetEvidence(packet) {
|
|
158
|
+
const perFileConcreteTerms = new Map();
|
|
159
|
+
for (const match of packet.matches ?? []) {
|
|
160
|
+
const concreteTerms = (match.reasons ?? [])
|
|
161
|
+
.map((reason) => reason.match(/^term:(.+)$/i)?.[1]?.toLowerCase())
|
|
162
|
+
.filter((term) => Boolean(term))
|
|
163
|
+
.filter((term) => !isWeakSemanticTerm(term));
|
|
164
|
+
if (concreteTerms.length === 0) {
|
|
165
|
+
continue;
|
|
166
|
+
}
|
|
167
|
+
const current = perFileConcreteTerms.get(match.filePath) ?? new Set();
|
|
168
|
+
for (const term of concreteTerms) {
|
|
169
|
+
current.add(term);
|
|
170
|
+
}
|
|
171
|
+
perFileConcreteTerms.set(match.filePath, current);
|
|
172
|
+
}
|
|
173
|
+
return Array.from(perFileConcreteTerms.values()).some((terms) => terms.size >= 2);
|
|
174
|
+
}
|
|
175
|
+
function hasStrongMatchConfirmation(packet) {
|
|
176
|
+
const perFileStrongTerms = new Map();
|
|
177
|
+
for (const match of packet.matches ?? []) {
|
|
178
|
+
const terms = (match.reasons ?? [])
|
|
179
|
+
.map((reason) => reason.match(/^term:(.+)$/i)?.[1]?.toLowerCase())
|
|
180
|
+
.filter((term) => Boolean(term))
|
|
181
|
+
.filter((term) => !isWeakSemanticTerm(term));
|
|
182
|
+
if (terms.length === 0) {
|
|
183
|
+
continue;
|
|
184
|
+
}
|
|
185
|
+
const current = perFileStrongTerms.get(match.filePath) ?? new Set();
|
|
186
|
+
for (const term of terms) {
|
|
187
|
+
current.add(term);
|
|
188
|
+
}
|
|
189
|
+
perFileStrongTerms.set(match.filePath, current);
|
|
190
|
+
}
|
|
191
|
+
return Array.from(perFileStrongTerms.values()).some((terms) => terms.size >= 2);
|
|
192
|
+
}
|
|
193
|
+
function hasStrongTopHitAnchor(packet) {
|
|
194
|
+
return (packet.topHits ?? []).slice(0, 3).some((hit) => hit.reasons.some((reason) => reason === "path-anchor"
|
|
195
|
+
|| reason.startsWith("exact-basename:")
|
|
196
|
+
|| (reason.startsWith("symbol:")
|
|
197
|
+
&& !isWeakSemanticTerm(String(reason.split(":")[1] ?? "").toLowerCase()))
|
|
198
|
+
|| ((/^match-confirmation:/).test(reason)
|
|
199
|
+
&& reason
|
|
200
|
+
.split(":")[1]
|
|
201
|
+
?.split(",")
|
|
202
|
+
.map((term) => term.trim().toLowerCase())
|
|
203
|
+
.filter((term) => term && !isWeakSemanticTerm(term))
|
|
204
|
+
.length >= 2)));
|
|
205
|
+
}
|
|
206
|
+
function resolveStrongEnough(packet, context) {
|
|
207
|
+
const matchedTerms = extractMatchedTerms(packet).filter((term) => !isWeakSemanticTerm(term));
|
|
208
|
+
const topHitConfirmations = extractTopHitConfirmations(packet);
|
|
209
|
+
const configIntent = looksLikeConfigurationIntent(context);
|
|
210
|
+
const concreteSnippetEvidence = hasConcreteSnippetEvidence(packet);
|
|
211
|
+
const strongMatchConfirmation = hasStrongMatchConfirmation(packet);
|
|
212
|
+
if (hasStrongTopHitAnchor(packet)) {
|
|
213
|
+
if (!strongMatchConfirmation && !concreteSnippetEvidence && topHitConfirmations.length === 0) {
|
|
214
|
+
return { strongEnough: false, reason: "top hits are anchored but still too generic to stop" };
|
|
215
|
+
}
|
|
216
|
+
if (configIntent && topHitConfirmations.length < 2 && !concreteSnippetEvidence) {
|
|
217
|
+
return { strongEnough: false, reason: "top hits are anchored but still too generic for config intent" };
|
|
218
|
+
}
|
|
219
|
+
return { strongEnough: true, reason: "top hits include strong anchors" };
|
|
220
|
+
}
|
|
221
|
+
if (strongMatchConfirmation) {
|
|
222
|
+
return { strongEnough: true, reason: "one file has multiple concrete matched terms" };
|
|
223
|
+
}
|
|
224
|
+
if (concreteSnippetEvidence) {
|
|
225
|
+
return { strongEnough: true, reason: "snippets contain concrete multi-term evidence" };
|
|
226
|
+
}
|
|
227
|
+
if (matchedTerms.length >= 4 && topHitConfirmations.length >= 2 && !configIntent) {
|
|
228
|
+
return { strongEnough: true, reason: "matched terms are concrete and broad enough to stop" };
|
|
229
|
+
}
|
|
230
|
+
return { strongEnough: false, reason: "evidence is still driven by weak semantic terms" };
|
|
231
|
+
}
|
|
232
|
+
export async function runSemanticSearchBatches(memory, context, visibleLimit, runBatch) {
|
|
233
|
+
const batches = buildSemanticSearchBatchPlan(context);
|
|
234
|
+
const rawPackets = [];
|
|
235
|
+
const batchDebug = [];
|
|
236
|
+
for (let index = 0; index < batches.length; index += 1) {
|
|
237
|
+
const batch = batches[index];
|
|
238
|
+
const packet = await runBatch(batch.query);
|
|
239
|
+
rawPackets.push(packet);
|
|
240
|
+
const merged = mergeSearchPackets(context.query, rawPackets);
|
|
241
|
+
const scored = finalizeLanePacket("semantic", memory, merged, visibleLimit);
|
|
242
|
+
const confidence = resolveStrongEnough(scored, context);
|
|
243
|
+
const strongEnough = confidence.strongEnough;
|
|
244
|
+
const continued = index < batches.length - 1 && !strongEnough;
|
|
245
|
+
batchDebug.push({
|
|
246
|
+
query: batch.query,
|
|
247
|
+
source: batch.source,
|
|
248
|
+
...(typeof batch.termGroupIndex === "number" ? { termGroupIndex: batch.termGroupIndex } : {}),
|
|
249
|
+
...(batch.kind ? { kind: batch.kind } : {}),
|
|
250
|
+
...(batch.terms ? { terms: batch.terms } : {}),
|
|
251
|
+
continued,
|
|
252
|
+
strongEnough,
|
|
253
|
+
strongReason: confidence.reason,
|
|
254
|
+
});
|
|
255
|
+
if (!continued) {
|
|
256
|
+
return {
|
|
257
|
+
...merged,
|
|
258
|
+
debug: {
|
|
259
|
+
...(merged.debug ?? {}),
|
|
260
|
+
batchDebug,
|
|
261
|
+
},
|
|
262
|
+
};
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
const merged = mergeSearchPackets(context.query, rawPackets);
|
|
266
|
+
return {
|
|
267
|
+
...merged,
|
|
268
|
+
debug: {
|
|
269
|
+
...(merged.debug ?? {}),
|
|
270
|
+
batchDebug,
|
|
271
|
+
},
|
|
272
|
+
};
|
|
273
|
+
}
|
|
274
|
+
//# sourceMappingURL=batchPlanner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"batchPlanner.js","sourceRoot":"","sources":["../../../src/agent/search/batchPlanner.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Plans grouped semantic search batches from understand-owned term hints.\n *\n * Why this file exists:\n * - grouped search expansion should have one owner in the search area\n * - search should decide batch order and stop conditions without leaking that logic into lanes\n * - semantic search should stay broad enough to recover, but still stop early on strong evidence\n */\nimport { finalizeLanePacket } from \"./candidateRetentionPolicy.js\";\nimport type { AgentSearchContext } from \"./searchContext.js\";\nimport type { AgentSearchPacket } from \"./types.js\";\nimport type { AgentMemory, AgentSearchTermGroup, AgentSearchTermGroupKind } from \"../types.js\";\n\nconst WEAK_SEMANTIC_TERMS = new Set([\n \"agent\",\n \"code\",\n \"config\",\n \"configuration\",\n \"file\",\n \"files\",\n \"project\",\n \"repo\",\n \"repository\",\n \"script\",\n \"scripts\",\n \"setting\",\n \"source\",\n \"test\",\n \"tests\",\n]);\n\nexport interface SearchBatchPlanEntry {\n query: string;\n source: \"base-query\" | \"search-term-group\";\n termGroupIndex?: number;\n kind?: AgentSearchTermGroupKind;\n terms?: string[];\n}\n\ntype SearchBatchDebugEntry = {\n query: string;\n source: \"base-query\" | \"search-term-group\";\n termGroupIndex?: number;\n kind?: AgentSearchTermGroupKind;\n terms?: string[];\n continued: boolean;\n strongEnough: boolean;\n strongReason?: string;\n};\n\nconst SEARCH_TERM_GROUP_ORDER: AgentSearchTermGroupKind[] = [\n \"repo-anchor\",\n \"command-path\",\n \"generic\",\n];\n\nfunction dedupeStrings(values: string[]): string[] {\n const seen = new Set<string>();\n const out: string[] = [];\n for (const value of values) {\n const trimmed = String(value ?? \"\").trim();\n if (!trimmed) {\n continue;\n }\n const key = trimmed.toLowerCase();\n if (seen.has(key)) {\n continue;\n }\n seen.add(key);\n out.push(trimmed);\n }\n return out;\n}\n\nfunction dedupeMatches(matches: NonNullable<AgentSearchPacket[\"matches\"]>): NonNullable<AgentSearchPacket[\"matches\"]> {\n const seen = new Set<string>();\n const out: NonNullable<AgentSearchPacket[\"matches\"]> = [];\n for (const match of matches) {\n const key = [match.filePath, match.line ?? \"\", match.column ?? \"\", match.matchKind, match.snippet].join(\"|\");\n if (seen.has(key)) {\n continue;\n }\n seen.add(key);\n out.push(match);\n }\n return out;\n}\n\nfunction buildTermGroupQuery(terms: string[]): string {\n return dedupeStrings(terms).join(\" \");\n}\n\nfunction isWeakSemanticTerm(term: string): boolean {\n return WEAK_SEMANTIC_TERMS.has(String(term ?? \"\").trim().toLowerCase());\n}\n\nfunction looksLikeConfigurationIntent(context: AgentSearchContext): boolean {\n const lowered = String(context.query ?? \"\").toLowerCase();\n return /\\b(where|which|what)\\b/.test(lowered)\n && /\\b(set|setting|configured|configuration|register|registered|entry|entrypoint|command|commands|limit|count|max)\\b/.test(lowered);\n}\n\nexport function buildSemanticSearchBatchPlan(context: AgentSearchContext): SearchBatchPlanEntry[] {\n const batches: SearchBatchPlanEntry[] = [{\n query: context.query,\n source: \"base-query\",\n }];\n const seenQueries = new Set([String(context.query ?? \"\").trim().toLowerCase()]);\n\n const prioritizedGroups = SEARCH_TERM_GROUP_ORDER.flatMap((kind) =>\n context.searchTermGroups\n .map((group, index) => ({ group, index }))\n .filter((entry) => entry.group.kind === kind)\n );\n\n for (const { group, index } of prioritizedGroups) {\n const terms = dedupeStrings(group.terms);\n if (terms.length === 0) {\n continue;\n }\n const query = buildTermGroupQuery(terms);\n const key = query.toLowerCase();\n if (!query || seenQueries.has(key)) {\n continue;\n }\n seenQueries.add(key);\n batches.push({\n query,\n source: \"search-term-group\",\n termGroupIndex: index,\n kind: group.kind,\n terms,\n });\n }\n\n return batches;\n}\n\nfunction mergeRelatedFileScores(\n left: Record<string, number> = {},\n right: Record<string, number> = {}\n): Record<string, number> {\n const merged = { ...left };\n for (const [filePath, score] of Object.entries(right)) {\n const current = merged[filePath];\n merged[filePath] = typeof current === \"number\" ? Math.min(current, score) : score;\n }\n return merged;\n}\n\nfunction mergeSearchPackets(baseQuery: string, packets: AgentSearchPacket[]): AgentSearchPacket {\n const first = packets[0];\n const mergedDebug = {\n queriesRun: dedupeStrings(packets.flatMap((packet) => packet.debug?.queriesRun ?? [])),\n recoveryUsed: packets.some((packet) => packet.debug?.recoveryUsed === true),\n matchTerms: dedupeStrings(packets.flatMap((packet) => packet.debug?.matchTerms ?? [])),\n };\n const recoveryReasons = dedupeStrings(\n packets.flatMap((packet) => packet.debug?.recoveryReason ? [packet.debug.recoveryReason] : [])\n );\n\n return {\n lane: first.lane,\n query: baseQuery,\n filePaths: dedupeStrings(packets.flatMap((packet) => packet.filePaths)),\n matches: dedupeMatches(packets.flatMap((packet) => packet.matches ?? [])),\n relatedFileScores: packets.reduce(\n (acc, packet) => mergeRelatedFileScores(acc, packet.relatedFileScores),\n {} as Record<string, number>\n ),\n debug: {\n queriesRun: mergedDebug.queriesRun,\n recoveryUsed: mergedDebug.recoveryUsed,\n matchTerms: mergedDebug.matchTerms,\n ...(recoveryReasons.length > 0 ? { recoveryReason: recoveryReasons.join(\",\") } : {}),\n },\n };\n}\n\nfunction extractMatchedTerms(packet: AgentSearchPacket): string[] {\n return dedupeStrings(\n (packet.matches ?? [])\n .flatMap((match) => match.reasons ?? [])\n .map((reason) => reason.match(/^term:(.+)$/i)?.[1] ?? \"\")\n .filter(Boolean)\n );\n}\n\nfunction extractTopHitConfirmations(packet: AgentSearchPacket): string[] {\n const confirmations = new Set<string>();\n for (const hit of packet.topHits ?? []) {\n for (const reason of hit.reasons) {\n if (!reason.startsWith(\"match-confirmation:\")) {\n continue;\n }\n for (const term of reason.slice(\"match-confirmation:\".length).split(\",\")) {\n const normalized = term.trim().toLowerCase();\n if (!normalized || isWeakSemanticTerm(normalized)) {\n continue;\n }\n confirmations.add(normalized);\n }\n }\n }\n return Array.from(confirmations);\n}\n\nfunction hasConcreteSnippetEvidence(packet: AgentSearchPacket): boolean {\n const perFileConcreteTerms = new Map<string, Set<string>>();\n for (const match of packet.matches ?? []) {\n const concreteTerms = (match.reasons ?? [])\n .map((reason) => reason.match(/^term:(.+)$/i)?.[1]?.toLowerCase())\n .filter((term): term is string => Boolean(term))\n .filter((term) => !isWeakSemanticTerm(term));\n if (concreteTerms.length === 0) {\n continue;\n }\n const current = perFileConcreteTerms.get(match.filePath) ?? new Set<string>();\n for (const term of concreteTerms) {\n current.add(term);\n }\n perFileConcreteTerms.set(match.filePath, current);\n }\n\n return Array.from(perFileConcreteTerms.values()).some((terms) => terms.size >= 2);\n}\n\nfunction hasStrongMatchConfirmation(packet: AgentSearchPacket): boolean {\n const perFileStrongTerms = new Map<string, Set<string>>();\n for (const match of packet.matches ?? []) {\n const terms = (match.reasons ?? [])\n .map((reason) => reason.match(/^term:(.+)$/i)?.[1]?.toLowerCase())\n .filter((term): term is string => Boolean(term))\n .filter((term) => !isWeakSemanticTerm(term));\n if (terms.length === 0) {\n continue;\n }\n const current = perFileStrongTerms.get(match.filePath) ?? new Set<string>();\n for (const term of terms) {\n current.add(term);\n }\n perFileStrongTerms.set(match.filePath, current);\n }\n\n return Array.from(perFileStrongTerms.values()).some((terms) => terms.size >= 2);\n}\n\nfunction hasStrongTopHitAnchor(packet: AgentSearchPacket): boolean {\n return (packet.topHits ?? []).slice(0, 3).some((hit) =>\n hit.reasons.some((reason) =>\n reason === \"path-anchor\"\n || reason.startsWith(\"exact-basename:\")\n || (reason.startsWith(\"symbol:\")\n && !isWeakSemanticTerm(String(reason.split(\":\")[1] ?? \"\").toLowerCase()))\n || ((/^match-confirmation:/).test(reason)\n && reason\n .split(\":\")[1]\n ?.split(\",\")\n .map((term) => term.trim().toLowerCase())\n .filter((term) => term && !isWeakSemanticTerm(term))\n .length >= 2)\n )\n );\n}\n\nfunction resolveStrongEnough(packet: AgentSearchPacket, context: AgentSearchContext): {\n strongEnough: boolean;\n reason: string;\n} {\n const matchedTerms = extractMatchedTerms(packet).filter((term) => !isWeakSemanticTerm(term));\n const topHitConfirmations = extractTopHitConfirmations(packet);\n const configIntent = looksLikeConfigurationIntent(context);\n const concreteSnippetEvidence = hasConcreteSnippetEvidence(packet);\n const strongMatchConfirmation = hasStrongMatchConfirmation(packet);\n if (hasStrongTopHitAnchor(packet)) {\n if (!strongMatchConfirmation && !concreteSnippetEvidence && topHitConfirmations.length === 0) {\n return { strongEnough: false, reason: \"top hits are anchored but still too generic to stop\" };\n }\n if (configIntent && topHitConfirmations.length < 2 && !concreteSnippetEvidence) {\n return { strongEnough: false, reason: \"top hits are anchored but still too generic for config intent\" };\n }\n return { strongEnough: true, reason: \"top hits include strong anchors\" };\n }\n if (strongMatchConfirmation) {\n return { strongEnough: true, reason: \"one file has multiple concrete matched terms\" };\n }\n if (concreteSnippetEvidence) {\n return { strongEnough: true, reason: \"snippets contain concrete multi-term evidence\" };\n }\n if (matchedTerms.length >= 4 && topHitConfirmations.length >= 2 && !configIntent) {\n return { strongEnough: true, reason: \"matched terms are concrete and broad enough to stop\" };\n }\n return { strongEnough: false, reason: \"evidence is still driven by weak semantic terms\" };\n}\n\nexport async function runSemanticSearchBatches(\n memory: AgentMemory,\n context: AgentSearchContext,\n visibleLimit: number,\n runBatch: (query: string) => Promise<AgentSearchPacket>\n): Promise<AgentSearchPacket> {\n const batches = buildSemanticSearchBatchPlan(context);\n const rawPackets: AgentSearchPacket[] = [];\n const batchDebug: SearchBatchDebugEntry[] = [];\n\n for (let index = 0; index < batches.length; index += 1) {\n const batch = batches[index];\n const packet = await runBatch(batch.query);\n rawPackets.push(packet);\n const merged = mergeSearchPackets(context.query, rawPackets);\n const scored = finalizeLanePacket(\"semantic\", memory, merged, visibleLimit);\n const confidence = resolveStrongEnough(scored, context);\n const strongEnough = confidence.strongEnough;\n const continued = index < batches.length - 1 && !strongEnough;\n batchDebug.push({\n query: batch.query,\n source: batch.source,\n ...(typeof batch.termGroupIndex === \"number\" ? { termGroupIndex: batch.termGroupIndex } : {}),\n ...(batch.kind ? { kind: batch.kind } : {}),\n ...(batch.terms ? { terms: batch.terms } : {}),\n continued,\n strongEnough,\n strongReason: confidence.reason,\n });\n if (!continued) {\n return {\n ...merged,\n debug: {\n ...(merged.debug ?? {}),\n batchDebug,\n },\n };\n }\n }\n\n const merged = mergeSearchPackets(context.query, rawPackets);\n return {\n ...merged,\n debug: {\n ...(merged.debug ?? {}),\n batchDebug,\n },\n };\n}\n"]}
|
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Shapes lane results into the candidate set that policy will consume.
|
|
3
|
+
*
|
|
4
|
+
* Why this file exists:
|
|
5
|
+
* - lane execution and candidate shaping are different search concerns
|
|
6
|
+
* - fallback rules should be lane-aware instead of one-size-fits-all
|
|
7
|
+
* - read policy should receive a smaller, cleaner candidate frontier
|
|
8
|
+
*/
|
|
9
|
+
import fs from "fs";
|
|
10
|
+
import path from "path";
|
|
11
|
+
import { classifyFileRulePath } from "../../fileRules/searchPathClassification.js";
|
|
12
|
+
import { MAX_WELL_KNOWN_REPO_FILES, WELL_KNOWN_REPO_FILE_BASENAMES } from "../../fileRules/wellKnownRepoFiles.js";
|
|
13
|
+
import { rankAgentSearchHits } from "./ranking.js";
|
|
14
|
+
const SPARSE_RESULT_THRESHOLD = 3;
|
|
15
|
+
function dedupePaths(paths) {
|
|
16
|
+
const seen = new Set();
|
|
17
|
+
const out = [];
|
|
18
|
+
for (const filePath of paths) {
|
|
19
|
+
const normalized = path.normalize(String(filePath ?? "").trim());
|
|
20
|
+
if (!normalized || seen.has(normalized)) {
|
|
21
|
+
continue;
|
|
22
|
+
}
|
|
23
|
+
seen.add(normalized);
|
|
24
|
+
out.push(normalized);
|
|
25
|
+
}
|
|
26
|
+
return out;
|
|
27
|
+
}
|
|
28
|
+
function getLiteralSearchPenalty(filePath) {
|
|
29
|
+
const classification = classifyFileRulePath(filePath);
|
|
30
|
+
let penalty = 0;
|
|
31
|
+
if (classification.isDocumentation) {
|
|
32
|
+
penalty += 1;
|
|
33
|
+
}
|
|
34
|
+
if (classification.isGeneratedBuild || classification.isArtifact || classification.isLogLike || classification.isSourceMap || classification.isHarnessLike) {
|
|
35
|
+
penalty += 3;
|
|
36
|
+
}
|
|
37
|
+
return penalty;
|
|
38
|
+
}
|
|
39
|
+
function resolveRetrievalScope(memory) {
|
|
40
|
+
if (memory.task.hardFileTargets.length > 0) {
|
|
41
|
+
return "single-file";
|
|
42
|
+
}
|
|
43
|
+
const explicitTargetCount = memory.task.explicitTargets.filter((target) => {
|
|
44
|
+
const trimmed = String(target ?? "").trim();
|
|
45
|
+
return trimmed.includes("/") || /\.[A-Za-z0-9_]{1,10}$/.test(trimmed);
|
|
46
|
+
}).length;
|
|
47
|
+
return explicitTargetCount > 0 ? "single-file" : "repo-wide";
|
|
48
|
+
}
|
|
49
|
+
function preferCodeLikeMatches(route, rankedHits) {
|
|
50
|
+
if (route !== "fragment" && route !== "regex") {
|
|
51
|
+
return rankedHits;
|
|
52
|
+
}
|
|
53
|
+
const hasCodeLikeHit = rankedHits.some((hit) => getLiteralSearchPenalty(hit.filePath) === 0);
|
|
54
|
+
if (!hasCodeLikeHit) {
|
|
55
|
+
return rankedHits;
|
|
56
|
+
}
|
|
57
|
+
return [...rankedHits].sort((left, right) => {
|
|
58
|
+
const leftPenalty = getLiteralSearchPenalty(left.filePath);
|
|
59
|
+
const rightPenalty = getLiteralSearchPenalty(right.filePath);
|
|
60
|
+
if (leftPenalty !== rightPenalty) {
|
|
61
|
+
return leftPenalty - rightPenalty;
|
|
62
|
+
}
|
|
63
|
+
if (right.score !== left.score) {
|
|
64
|
+
return right.score - left.score;
|
|
65
|
+
}
|
|
66
|
+
return left.filePath.localeCompare(right.filePath);
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
function applyDeterministicPrefilter(args) {
|
|
70
|
+
const dedupedPaths = dedupePaths(args.filePaths);
|
|
71
|
+
if (dedupedPaths.length === 0) {
|
|
72
|
+
return [];
|
|
73
|
+
}
|
|
74
|
+
const scored = rankAgentSearchHits(dedupedPaths, args.relatedFileScores, args.query, args.matches ?? [], args.hintTerms ?? []);
|
|
75
|
+
if (scored.length === 0) {
|
|
76
|
+
return dedupedPaths.slice(0, args.limit);
|
|
77
|
+
}
|
|
78
|
+
const scope = resolveRetrievalScope(args.memory);
|
|
79
|
+
const baseKeepCount = scope === "single-file" ? Math.max(args.limit, 6) : Math.max(args.limit, 10);
|
|
80
|
+
const keepCount = Math.min(Math.max(3, baseKeepCount), scored.length);
|
|
81
|
+
const selected = new Set(scored.slice(0, keepCount).map(item => item.filePath));
|
|
82
|
+
for (const item of scored) {
|
|
83
|
+
if (item.reasons.includes("path-anchor") || item.reasons.some(reason => reason.startsWith("exact-basename:"))) {
|
|
84
|
+
selected.add(item.filePath);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
return scored.filter(item => selected.has(item.filePath)).map(item => item.filePath);
|
|
88
|
+
}
|
|
89
|
+
function filterMatchesToVisibleFiles(packet, visibleFiles) {
|
|
90
|
+
if (!packet.matches || packet.matches.length === 0) {
|
|
91
|
+
return [];
|
|
92
|
+
}
|
|
93
|
+
const visible = new Set(visibleFiles);
|
|
94
|
+
const perFileCounts = new Map();
|
|
95
|
+
const filtered = packet.matches.filter((match) => visible.has(match.filePath));
|
|
96
|
+
const limited = [];
|
|
97
|
+
for (const match of filtered) {
|
|
98
|
+
const count = perFileCounts.get(match.filePath) ?? 0;
|
|
99
|
+
if (count >= 2) {
|
|
100
|
+
continue;
|
|
101
|
+
}
|
|
102
|
+
limited.push(match);
|
|
103
|
+
perFileCounts.set(match.filePath, count + 1);
|
|
104
|
+
if (limited.length >= 6) {
|
|
105
|
+
break;
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
return limited;
|
|
109
|
+
}
|
|
110
|
+
function shouldInjectRepoDefaults(route, memory, filePaths) {
|
|
111
|
+
if (route !== "semantic") {
|
|
112
|
+
return false;
|
|
113
|
+
}
|
|
114
|
+
if (memory.task.hardFileTargets.length > 0) {
|
|
115
|
+
return false;
|
|
116
|
+
}
|
|
117
|
+
if (memory.task.explicitTargets.some((target) => {
|
|
118
|
+
const trimmed = String(target ?? "").trim();
|
|
119
|
+
return trimmed.includes("/") || /\.[A-Za-z0-9_]{1,10}$/.test(trimmed);
|
|
120
|
+
})) {
|
|
121
|
+
return false;
|
|
122
|
+
}
|
|
123
|
+
const scope = resolveRetrievalScope(memory);
|
|
124
|
+
return scope === "repo-wide" && filePaths.length < SPARSE_RESULT_THRESHOLD;
|
|
125
|
+
}
|
|
126
|
+
function injectWellKnownRepoFiles(memory, filePaths) {
|
|
127
|
+
const dedupedPaths = dedupePaths(filePaths);
|
|
128
|
+
const candidates = WELL_KNOWN_REPO_FILE_BASENAMES
|
|
129
|
+
.map(fileName => path.join(memory.session.executionPath, fileName))
|
|
130
|
+
.filter(filePath => fs.existsSync(filePath))
|
|
131
|
+
.slice(0, MAX_WELL_KNOWN_REPO_FILES);
|
|
132
|
+
if (candidates.length === 0) {
|
|
133
|
+
return dedupedPaths;
|
|
134
|
+
}
|
|
135
|
+
const existing = new Set(dedupedPaths);
|
|
136
|
+
for (const filePath of candidates) {
|
|
137
|
+
existing.add(filePath);
|
|
138
|
+
}
|
|
139
|
+
return Array.from(existing);
|
|
140
|
+
}
|
|
141
|
+
/**
|
|
142
|
+
* Applies lane-aware prefiltering and fallback before candidates hit read policy.
|
|
143
|
+
* Example: semantic repo-wide search may add `README.md`, but exact-target search never should.
|
|
144
|
+
*/
|
|
145
|
+
export function finalizeLanePacket(route, memory, packet, limit) {
|
|
146
|
+
if (packet.filePaths.length === 0) {
|
|
147
|
+
return packet;
|
|
148
|
+
}
|
|
149
|
+
if (route === "exact-target") {
|
|
150
|
+
const exactPaths = dedupePaths(packet.filePaths);
|
|
151
|
+
const rankedHits = rankAgentSearchHits(exactPaths, packet.relatedFileScores ?? {}, packet.query, packet.matches, packet.debug?.matchTerms ?? []);
|
|
152
|
+
return {
|
|
153
|
+
...packet,
|
|
154
|
+
filePaths: exactPaths,
|
|
155
|
+
matches: filterMatchesToVisibleFiles(packet, exactPaths),
|
|
156
|
+
topHits: rankedHits.slice(0, limit),
|
|
157
|
+
};
|
|
158
|
+
}
|
|
159
|
+
const relatedFileScores = packet.relatedFileScores ?? {};
|
|
160
|
+
const filteredPaths = route === "directory"
|
|
161
|
+
? []
|
|
162
|
+
: applyDeterministicPrefilter({
|
|
163
|
+
memory,
|
|
164
|
+
filePaths: packet.filePaths,
|
|
165
|
+
query: packet.query,
|
|
166
|
+
relatedFileScores,
|
|
167
|
+
matches: packet.matches,
|
|
168
|
+
hintTerms: packet.debug?.matchTerms,
|
|
169
|
+
limit,
|
|
170
|
+
});
|
|
171
|
+
const expandedPaths = shouldInjectRepoDefaults(route, memory, filteredPaths)
|
|
172
|
+
? injectWellKnownRepoFiles(memory, filteredPaths)
|
|
173
|
+
: filteredPaths;
|
|
174
|
+
const rankedHits = preferCodeLikeMatches(route, rankAgentSearchHits(expandedPaths, relatedFileScores, packet.query, packet.matches, packet.debug?.matchTerms ?? []));
|
|
175
|
+
const visibleHits = rankedHits.slice(0, limit);
|
|
176
|
+
const visibleFiles = visibleHits.map((hit) => hit.filePath);
|
|
177
|
+
return {
|
|
178
|
+
...packet,
|
|
179
|
+
filePaths: visibleFiles,
|
|
180
|
+
matches: filterMatchesToVisibleFiles(packet, visibleFiles),
|
|
181
|
+
topHits: visibleHits,
|
|
182
|
+
};
|
|
183
|
+
}
|
|
184
|
+
//# sourceMappingURL=candidateRetentionPolicy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"candidateRetentionPolicy.js","sourceRoot":"","sources":["../../../src/agent/search/candidateRetentionPolicy.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Shapes lane results into the candidate set that policy will consume.\n *\n * Why this file exists:\n * - lane execution and candidate shaping are different search concerns\n * - fallback rules should be lane-aware instead of one-size-fits-all\n * - read policy should receive a smaller, cleaner candidate frontier\n */\nimport fs from \"fs\";\nimport path from \"path\";\nimport { classifyFileRulePath } from \"../../fileRules/searchPathClassification.js\";\nimport { MAX_WELL_KNOWN_REPO_FILES, WELL_KNOWN_REPO_FILE_BASENAMES } from \"../../fileRules/wellKnownRepoFiles.js\";\nimport type { AgentMemory } from \"../types.js\";\nimport { rankAgentSearchHits, type AgentScoredSearchHit } from \"./ranking.js\";\nimport type { AgentSearchLane, AgentSearchPacket } from \"./types.js\";\n\nconst SPARSE_RESULT_THRESHOLD = 3;\n\ntype RetrievalScope = \"single-file\" | \"repo-wide\";\n\nfunction dedupePaths(paths: string[]): string[] {\n const seen = new Set<string>();\n const out: string[] = [];\n for (const filePath of paths) {\n const normalized = path.normalize(String(filePath ?? \"\").trim());\n if (!normalized || seen.has(normalized)) {\n continue;\n }\n seen.add(normalized);\n out.push(normalized);\n }\n return out;\n}\n\nfunction getLiteralSearchPenalty(filePath: string): number {\n const classification = classifyFileRulePath(filePath);\n let penalty = 0;\n if (classification.isDocumentation) {\n penalty += 1;\n }\n if (classification.isGeneratedBuild || classification.isArtifact || classification.isLogLike || classification.isSourceMap || classification.isHarnessLike) {\n penalty += 3;\n }\n return penalty;\n}\n\nfunction resolveRetrievalScope(memory: AgentMemory): RetrievalScope {\n if (memory.task.hardFileTargets.length > 0) {\n return \"single-file\";\n }\n\n const explicitTargetCount = memory.task.explicitTargets.filter((target) => {\n const trimmed = String(target ?? \"\").trim();\n return trimmed.includes(\"/\") || /\\.[A-Za-z0-9_]{1,10}$/.test(trimmed);\n }).length;\n\n return explicitTargetCount > 0 ? \"single-file\" : \"repo-wide\";\n}\n\nfunction preferCodeLikeMatches(route: AgentSearchLane, rankedHits: AgentScoredSearchHit[]): AgentScoredSearchHit[] {\n if (route !== \"fragment\" && route !== \"regex\") {\n return rankedHits;\n }\n\n const hasCodeLikeHit = rankedHits.some((hit) => getLiteralSearchPenalty(hit.filePath) === 0);\n if (!hasCodeLikeHit) {\n return rankedHits;\n }\n\n return [...rankedHits].sort((left, right) => {\n const leftPenalty = getLiteralSearchPenalty(left.filePath);\n const rightPenalty = getLiteralSearchPenalty(right.filePath);\n if (leftPenalty !== rightPenalty) {\n return leftPenalty - rightPenalty;\n }\n if (right.score !== left.score) {\n return right.score - left.score;\n }\n return left.filePath.localeCompare(right.filePath);\n });\n}\n\nfunction applyDeterministicPrefilter(args: {\n memory: AgentMemory;\n filePaths: string[];\n query: string;\n relatedFileScores: Record<string, number>;\n matches?: AgentSearchPacket[\"matches\"];\n hintTerms?: string[];\n limit: number;\n}): string[] {\n const dedupedPaths = dedupePaths(args.filePaths);\n if (dedupedPaths.length === 0) {\n return [];\n }\n\n const scored = rankAgentSearchHits(\n dedupedPaths,\n args.relatedFileScores,\n args.query,\n args.matches ?? [],\n args.hintTerms ?? []\n );\n if (scored.length === 0) {\n return dedupedPaths.slice(0, args.limit);\n }\n\n const scope = resolveRetrievalScope(args.memory);\n const baseKeepCount = scope === \"single-file\" ? Math.max(args.limit, 6) : Math.max(args.limit, 10);\n const keepCount = Math.min(Math.max(3, baseKeepCount), scored.length);\n const selected = new Set<string>(scored.slice(0, keepCount).map(item => item.filePath));\n\n for (const item of scored) {\n if (item.reasons.includes(\"path-anchor\") || item.reasons.some(reason => reason.startsWith(\"exact-basename:\"))) {\n selected.add(item.filePath);\n }\n }\n\n return scored.filter(item => selected.has(item.filePath)).map(item => item.filePath);\n}\n\nfunction filterMatchesToVisibleFiles(packet: AgentSearchPacket, visibleFiles: string[]): NonNullable<AgentSearchPacket[\"matches\"]> {\n if (!packet.matches || packet.matches.length === 0) {\n return [];\n }\n\n const visible = new Set(visibleFiles);\n const perFileCounts = new Map<string, number>();\n const filtered = packet.matches.filter((match) => visible.has(match.filePath));\n const limited: NonNullable<AgentSearchPacket[\"matches\"]> = [];\n for (const match of filtered) {\n const count = perFileCounts.get(match.filePath) ?? 0;\n if (count >= 2) {\n continue;\n }\n limited.push(match);\n perFileCounts.set(match.filePath, count + 1);\n if (limited.length >= 6) {\n break;\n }\n }\n return limited;\n}\n\nfunction shouldInjectRepoDefaults(route: AgentSearchLane, memory: AgentMemory, filePaths: string[]): boolean {\n if (route !== \"semantic\") {\n return false;\n }\n if (memory.task.hardFileTargets.length > 0) {\n return false;\n }\n if (memory.task.explicitTargets.some((target) => {\n const trimmed = String(target ?? \"\").trim();\n return trimmed.includes(\"/\") || /\\.[A-Za-z0-9_]{1,10}$/.test(trimmed);\n })) {\n return false;\n }\n\n const scope = resolveRetrievalScope(memory);\n return scope === \"repo-wide\" && filePaths.length < SPARSE_RESULT_THRESHOLD;\n}\n\nfunction injectWellKnownRepoFiles(memory: AgentMemory, filePaths: string[]): string[] {\n const dedupedPaths = dedupePaths(filePaths);\n const candidates = WELL_KNOWN_REPO_FILE_BASENAMES\n .map(fileName => path.join(memory.session.executionPath, fileName))\n .filter(filePath => fs.existsSync(filePath))\n .slice(0, MAX_WELL_KNOWN_REPO_FILES);\n\n if (candidates.length === 0) {\n return dedupedPaths;\n }\n\n const existing = new Set(dedupedPaths);\n for (const filePath of candidates) {\n existing.add(filePath);\n }\n return Array.from(existing);\n}\n\n/**\n * Applies lane-aware prefiltering and fallback before candidates hit read policy.\n * Example: semantic repo-wide search may add `README.md`, but exact-target search never should.\n */\nexport function finalizeLanePacket(\n route: AgentSearchLane,\n memory: AgentMemory,\n packet: AgentSearchPacket,\n limit: number\n): AgentSearchPacket {\n if (packet.filePaths.length === 0) {\n return packet;\n }\n\n if (route === \"exact-target\") {\n const exactPaths = dedupePaths(packet.filePaths);\n const rankedHits = rankAgentSearchHits(\n exactPaths,\n packet.relatedFileScores ?? {},\n packet.query,\n packet.matches,\n packet.debug?.matchTerms ?? []\n );\n return {\n ...packet,\n filePaths: exactPaths,\n matches: filterMatchesToVisibleFiles(packet, exactPaths),\n topHits: rankedHits.slice(0, limit),\n };\n }\n\n const relatedFileScores = packet.relatedFileScores ?? {};\n const filteredPaths = route === \"directory\"\n ? []\n : applyDeterministicPrefilter({\n memory,\n filePaths: packet.filePaths,\n query: packet.query,\n relatedFileScores,\n matches: packet.matches,\n hintTerms: packet.debug?.matchTerms,\n limit,\n });\n\n const expandedPaths = shouldInjectRepoDefaults(route, memory, filteredPaths)\n ? injectWellKnownRepoFiles(memory, filteredPaths)\n : filteredPaths;\n\n const rankedHits = preferCodeLikeMatches(\n route,\n rankAgentSearchHits(\n expandedPaths,\n relatedFileScores,\n packet.query,\n packet.matches,\n packet.debug?.matchTerms ?? []\n )\n );\n const visibleHits = rankedHits.slice(0, limit);\n const visibleFiles = visibleHits.map((hit) => hit.filePath);\n\n return {\n ...packet,\n filePaths: visibleFiles,\n matches: filterMatchesToVisibleFiles(packet, visibleFiles),\n topHits: visibleHits,\n };\n}\n"]}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Lists direct directory children for modular-agent search.
|
|
3
|
+
*
|
|
4
|
+
* Why this file exists:
|
|
5
|
+
* - direct folder listing is its own search lane
|
|
6
|
+
* - folder summary shaping belongs with the directory lane, not generic retention
|
|
7
|
+
*/
|
|
8
|
+
import fs from "fs";
|
|
9
|
+
import path from "path";
|
|
10
|
+
import { collectDirectDirectoryEntries } from "./shared.js";
|
|
11
|
+
/**
|
|
12
|
+
* Formats one compact folder listing summary for answers and follow-up prompts.
|
|
13
|
+
* Example: `Contents of /repo/cli: [dir] src`.
|
|
14
|
+
*/
|
|
15
|
+
export function renderDirectoryListingSummary(folderPath, entries) {
|
|
16
|
+
const header = folderPath ? `Contents of ${folderPath}:` : "Directory contents:";
|
|
17
|
+
if (entries.length === 0) {
|
|
18
|
+
return `${header}\n[empty]`;
|
|
19
|
+
}
|
|
20
|
+
return [
|
|
21
|
+
header,
|
|
22
|
+
...entries.map(entry => `${entry.kind === "folder" ? "[dir]" : "[file]"} ${entry.name}`),
|
|
23
|
+
].join("\n");
|
|
24
|
+
}
|
|
25
|
+
export function runDirectorySearch(rootDir, rawTarget) {
|
|
26
|
+
const folderPath = rawTarget && rawTarget.trim().length > 0
|
|
27
|
+
? (path.isAbsolute(rawTarget) ? rawTarget : path.join(rootDir, rawTarget))
|
|
28
|
+
: rootDir;
|
|
29
|
+
if (!fs.existsSync(folderPath) || !fs.statSync(folderPath).isDirectory()) {
|
|
30
|
+
return {
|
|
31
|
+
lane: "directory",
|
|
32
|
+
query: rawTarget,
|
|
33
|
+
filePaths: [],
|
|
34
|
+
failure: {
|
|
35
|
+
status: "failed",
|
|
36
|
+
failureClass: "scope-missing",
|
|
37
|
+
message: "Could not resolve a folder to list.",
|
|
38
|
+
},
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
const entries = collectDirectDirectoryEntries(folderPath);
|
|
42
|
+
return {
|
|
43
|
+
lane: "directory",
|
|
44
|
+
query: rawTarget,
|
|
45
|
+
filePaths: [],
|
|
46
|
+
directoryPath: folderPath,
|
|
47
|
+
directoryEntries: entries,
|
|
48
|
+
summary: renderDirectoryListingSummary(folderPath, entries),
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=directory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"directory.js","sourceRoot":"","sources":["../../../src/agent/search/directory.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AACH,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,IAAI,MAAM,MAAM,CAAC;AAExB,OAAO,EAAE,6BAA6B,EAAE,MAAM,aAAa,CAAC;AAE5D;;;GAGG;AACH,MAAM,UAAU,6BAA6B,CAC3C,UAA8B,EAC9B,OAAyD;IAEzD,MAAM,MAAM,GAAG,UAAU,CAAC,CAAC,CAAC,eAAe,UAAU,GAAG,CAAC,CAAC,CAAC,qBAAqB,CAAC;IACjF,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACzB,OAAO,GAAG,MAAM,WAAW,CAAC;IAC9B,CAAC;IACD,OAAO;QACL,MAAM;QACN,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;KACzF,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACf,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,OAAe,EAAE,SAAiB;IACnE,MAAM,UAAU,GAAG,SAAS,IAAI,SAAS,CAAC,IAAI,EAAE,CAAC,MAAM,GAAG,CAAC;QACzD,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QAC1E,CAAC,CAAC,OAAO,CAAC;IAEZ,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC;QACzE,OAAO;YACL,IAAI,EAAE,WAAW;YACjB,KAAK,EAAE,SAAS;YAChB,SAAS,EAAE,EAAE;YACb,OAAO,EAAE;gBACP,MAAM,EAAE,QAAQ;gBAChB,YAAY,EAAE,eAAe;gBAC7B,OAAO,EAAE,qCAAqC;aAC/C;SACF,CAAC;IACJ,CAAC;IAED,MAAM,OAAO,GAAG,6BAA6B,CAAC,UAAU,CAAC,CAAC;IAC1D,OAAO;QACL,IAAI,EAAE,WAAW;QACjB,KAAK,EAAE,SAAS;QAChB,SAAS,EAAE,EAAE;QACb,aAAa,EAAE,UAAU;QACzB,gBAAgB,EAAE,OAAO;QACzB,OAAO,EAAE,6BAA6B,CAAC,UAAU,EAAE,OAAO,CAAC;KAC5D,CAAC;AACJ,CAAC","sourcesContent":["/**\n * Lists direct directory children for modular-agent search.\n *\n * Why this file exists:\n * - direct folder listing is its own search lane\n * - folder summary shaping belongs with the directory lane, not generic retention\n */\nimport fs from \"fs\";\nimport path from \"path\";\nimport type { AgentSearchPacket } from \"./types.js\";\nimport { collectDirectDirectoryEntries } from \"./shared.js\";\n\n/**\n * Formats one compact folder listing summary for answers and follow-up prompts.\n * Example: `Contents of /repo/cli: [dir] src`.\n */\nexport function renderDirectoryListingSummary(\n folderPath: string | undefined,\n entries: Array<{ name: string; kind: \"file\" | \"folder\" }>\n): string {\n const header = folderPath ? `Contents of ${folderPath}:` : \"Directory contents:\";\n if (entries.length === 0) {\n return `${header}\\n[empty]`;\n }\n return [\n header,\n ...entries.map(entry => `${entry.kind === \"folder\" ? \"[dir]\" : \"[file]\"} ${entry.name}`),\n ].join(\"\\n\");\n}\n\nexport function runDirectorySearch(rootDir: string, rawTarget: string): AgentSearchPacket {\n const folderPath = rawTarget && rawTarget.trim().length > 0\n ? (path.isAbsolute(rawTarget) ? rawTarget : path.join(rootDir, rawTarget))\n : rootDir;\n\n if (!fs.existsSync(folderPath) || !fs.statSync(folderPath).isDirectory()) {\n return {\n lane: \"directory\",\n query: rawTarget,\n filePaths: [],\n failure: {\n status: \"failed\",\n failureClass: \"scope-missing\",\n message: \"Could not resolve a folder to list.\",\n },\n };\n }\n\n const entries = collectDirectDirectoryEntries(folderPath);\n return {\n lane: \"directory\",\n query: rawTarget,\n filePaths: [],\n directoryPath: folderPath,\n directoryEntries: entries,\n summary: renderDirectoryListingSummary(folderPath, entries),\n };\n}\n"]}
|