@machina.ai/cell-cli-core 1.38.1-rc2 → 1.40.1-rc2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/docs/AFTER_MERGE_PROMPT.md +1 -1
- package/dist/docs/admin/enterprise-controls.md +1 -1
- package/dist/docs/changelogs/index.md +42 -0
- package/dist/docs/changelogs/latest.md +254 -361
- package/dist/docs/changelogs/preview.md +237 -406
- package/dist/docs/cli/acp-mode.md +6 -6
- package/dist/docs/cli/auto-memory.md +143 -0
- package/dist/docs/cli/checkpointing.md +5 -5
- package/dist/docs/cli/cli-reference.md +12 -11
- package/dist/docs/cli/creating-skills.md +2 -2
- package/dist/docs/cli/custom-commands.md +15 -14
- package/dist/docs/cli/enterprise.md +17 -14
- package/dist/docs/cli/gemini-ignore.md +2 -2
- package/dist/docs/cli/generation-settings.md +21 -20
- package/dist/docs/cli/model-routing.md +2 -2
- package/dist/docs/cli/model-steering.md +1 -1
- package/dist/docs/cli/plan-mode.md +11 -6
- package/dist/docs/cli/sandbox.md +7 -5
- package/dist/docs/cli/settings.md +32 -28
- package/dist/docs/cli/system-prompt.md +8 -8
- package/dist/docs/cli/telemetry.md +18 -11
- package/dist/docs/cli/themes.md +2 -2
- package/dist/docs/cli/trusted-folders.md +41 -13
- package/dist/docs/cli/tutorials/mcp-setup.md +1 -1
- package/dist/docs/cli/tutorials/memory-management.md +3 -1
- package/dist/docs/cli/tutorials/plan-mode-steering.md +2 -2
- package/dist/docs/cli/tutorials/session-management.md +1 -1
- package/dist/docs/cli/tutorials/shell-commands.md +1 -1
- package/dist/docs/cli/tutorials/task-planning.md +3 -3
- package/dist/docs/core/index.md +5 -6
- package/dist/docs/core/local-model-routing.md +1 -1
- package/dist/docs/core/remote-agents.md +1 -1
- package/dist/docs/core/subagents.md +38 -8
- package/dist/docs/extensions/best-practices.md +5 -4
- package/dist/docs/extensions/reference.md +6 -5
- package/dist/docs/extensions/releasing.md +6 -5
- package/dist/docs/extensions/writing-extensions.md +11 -11
- package/dist/docs/get-started/{authentication.md → authentication.mdx} +139 -93
- package/dist/docs/get-started/gemini-3.md +1 -1
- package/dist/docs/get-started/index.md +4 -4
- package/dist/docs/get-started/installation.mdx +201 -0
- package/dist/docs/hooks/best-practices.md +18 -17
- package/dist/docs/hooks/index.md +10 -8
- package/dist/docs/hooks/reference.md +10 -10
- package/dist/docs/ide-integration/ide-companion-spec.md +14 -14
- package/dist/docs/ide-integration/index.md +4 -4
- package/dist/docs/index.md +2 -2
- package/dist/docs/integration-tests.md +84 -2
- package/dist/docs/issue-and-pr-automation.md +8 -7
- package/dist/docs/npm.md +2 -2
- package/dist/docs/reference/commands.md +11 -11
- package/dist/docs/reference/configuration.md +150 -47
- package/dist/docs/reference/keyboard-shortcuts.md +79 -2
- package/dist/docs/reference/memport.md +2 -3
- package/dist/docs/reference/policy-engine.md +60 -26
- package/dist/docs/reference/tools.md +38 -4
- package/dist/docs/release-confidence.md +1 -1
- package/dist/docs/releases.md +19 -19
- package/dist/docs/resources/faq.md +5 -5
- package/dist/docs/resources/tos-privacy.md +10 -9
- package/dist/docs/resources/troubleshooting.md +17 -16
- package/dist/docs/resources/uninstall.md +5 -4
- package/dist/docs/sidebar.json +13 -1
- package/dist/docs/tools/ask-user.md +3 -3
- package/dist/docs/tools/file-system.md +7 -7
- package/dist/docs/tools/mcp-resources.md +44 -0
- package/dist/docs/tools/mcp-server.md +42 -39
- package/dist/docs/tools/shell.md +5 -5
- package/dist/docs/tools/tracker.md +61 -0
- package/dist/package.json +5 -4
- package/dist/src/agent/content-utils.d.ts +0 -6
- package/dist/src/agent/content-utils.js +0 -14
- package/dist/src/agent/content-utils.js.map +1 -1
- package/dist/src/agent/content-utils.test.js +1 -18
- package/dist/src/agent/content-utils.test.js.map +1 -1
- package/dist/src/agent/event-translator.js +8 -3
- package/dist/src/agent/event-translator.js.map +1 -1
- package/dist/src/agent/event-translator.test.js +14 -9
- package/dist/src/agent/event-translator.test.js.map +1 -1
- package/dist/src/agent/legacy-agent-session.js +9 -3
- package/dist/src/agent/legacy-agent-session.js.map +1 -1
- package/dist/src/agent/legacy-agent-session.test.js +4 -3
- package/dist/src/agent/legacy-agent-session.test.js.map +1 -1
- package/dist/src/agent/tool-display-utils.d.ts +30 -0
- package/dist/src/agent/tool-display-utils.js +69 -0
- package/dist/src/agent/tool-display-utils.js.map +1 -0
- package/dist/src/agent/tool-display-utils.test.js +101 -0
- package/dist/src/agent/tool-display-utils.test.js.map +1 -0
- package/dist/src/agent/types.d.ts +25 -5
- package/dist/src/agents/a2aUtils.js +28 -15
- package/dist/src/agents/a2aUtils.js.map +1 -1
- package/dist/src/agents/a2aUtils.test.js +43 -0
- package/dist/src/agents/a2aUtils.test.js.map +1 -1
- package/dist/src/agents/agent-tool.d.ts +31 -0
- package/dist/src/agents/agent-tool.js +155 -0
- package/dist/src/agents/agent-tool.js.map +1 -0
- package/dist/src/agents/agent-tool.test.js +110 -0
- package/dist/src/agents/agent-tool.test.js.map +1 -0
- package/dist/src/agents/agentLoader.d.ts +79 -4
- package/dist/src/agents/agentLoader.js +40 -2
- package/dist/src/agents/agentLoader.js.map +1 -1
- package/dist/src/agents/agentLoader.test.js +32 -0
- package/dist/src/agents/agentLoader.test.js.map +1 -1
- package/dist/src/agents/browser/analyzeScreenshot.js +1 -1
- package/dist/src/agents/browser/analyzeScreenshot.js.map +1 -1
- package/dist/src/agents/browser/analyzeScreenshot.test.js +19 -7
- package/dist/src/agents/browser/analyzeScreenshot.test.js.map +1 -1
- package/dist/src/agents/browser/browserAgentInvocation.d.ts +2 -2
- package/dist/src/agents/browser/browserAgentInvocation.js +2 -1
- package/dist/src/agents/browser/browserAgentInvocation.js.map +1 -1
- package/dist/src/agents/browser/browserAgentInvocation.test.js +61 -17
- package/dist/src/agents/browser/browserAgentInvocation.test.js.map +1 -1
- package/dist/src/agents/browser/mcpToolWrapper.js +1 -1
- package/dist/src/agents/browser/mcpToolWrapper.js.map +1 -1
- package/dist/src/agents/browser/mcpToolWrapper.test.js +22 -10
- package/dist/src/agents/browser/mcpToolWrapper.test.js.map +1 -1
- package/dist/src/agents/codebase-investigator.js +2 -2
- package/dist/src/agents/codebase-investigator.js.map +1 -1
- package/dist/src/agents/generalist-agent.js +3 -2
- package/dist/src/agents/generalist-agent.js.map +1 -1
- package/dist/src/agents/generalist-agent.test.js +1 -0
- package/dist/src/agents/generalist-agent.test.js.map +1 -1
- package/dist/src/agents/local-executor.d.ts +1 -1
- package/dist/src/agents/local-executor.js +10 -7
- package/dist/src/agents/local-executor.js.map +1 -1
- package/dist/src/agents/local-executor.test.js +5 -3
- package/dist/src/agents/local-executor.test.js.map +1 -1
- package/dist/src/agents/local-invocation.d.ts +2 -2
- package/dist/src/agents/local-invocation.js +8 -2
- package/dist/src/agents/local-invocation.js.map +1 -1
- package/dist/src/agents/local-invocation.test.js +29 -13
- package/dist/src/agents/local-invocation.test.js.map +1 -1
- package/dist/src/agents/registry.d.ts +2 -0
- package/dist/src/agents/registry.js +20 -19
- package/dist/src/agents/registry.js.map +1 -1
- package/dist/src/agents/registry.test.js +19 -30
- package/dist/src/agents/registry.test.js.map +1 -1
- package/dist/src/agents/remote-invocation.d.ts +3 -4
- package/dist/src/agents/remote-invocation.js +2 -1
- package/dist/src/agents/remote-invocation.js.map +1 -1
- package/dist/src/agents/remote-invocation.test.js +45 -18
- package/dist/src/agents/remote-invocation.test.js.map +1 -1
- package/dist/src/agents/skill-extraction-agent.d.ts +3 -2
- package/dist/src/agents/skill-extraction-agent.js +99 -56
- package/dist/src/agents/skill-extraction-agent.js.map +1 -1
- package/dist/src/agents/skill-extraction-agent.test.js +54 -0
- package/dist/src/agents/skill-extraction-agent.test.js.map +1 -0
- package/dist/src/availability/policyCatalog.js +1 -1
- package/dist/src/availability/policyCatalog.js.map +1 -1
- package/dist/src/availability/policyCatalog.test.js +1 -1
- package/dist/src/availability/policyCatalog.test.js.map +1 -1
- package/dist/src/code_assist/oauth2.js +14 -4
- package/dist/src/code_assist/oauth2.js.map +1 -1
- package/dist/src/commands/memory.d.ts +77 -0
- package/dist/src/commands/memory.js +494 -0
- package/dist/src/commands/memory.js.map +1 -1
- package/dist/src/commands/memory.test.js +720 -1
- package/dist/src/commands/memory.test.js.map +1 -1
- package/dist/src/config/config-agents-reload.test.js +26 -31
- package/dist/src/config/config-agents-reload.test.js.map +1 -1
- package/dist/src/config/config.d.ts +24 -10
- package/dist/src/config/config.js +148 -82
- package/dist/src/config/config.js.map +1 -1
- package/dist/src/config/config.test.js +373 -10
- package/dist/src/config/config.test.js.map +1 -1
- package/dist/src/config/constants.d.ts +1 -0
- package/dist/src/config/constants.js +2 -0
- package/dist/src/config/constants.js.map +1 -1
- package/dist/src/config/defaultModelConfigs.js +7 -7
- package/dist/src/config/defaultModelConfigs.js.map +1 -1
- package/dist/src/config/memory.js +1 -1
- package/dist/src/config/memory.js.map +1 -1
- package/dist/src/config/path-validation.test.js +15 -6
- package/dist/src/config/path-validation.test.js.map +1 -1
- package/dist/src/config/projectRegistry.js +113 -32
- package/dist/src/config/projectRegistry.js.map +1 -1
- package/dist/src/config/projectRegistry.test.js +51 -0
- package/dist/src/config/projectRegistry.test.js.map +1 -1
- package/dist/src/config/storage.d.ts +5 -1
- package/dist/src/config/storage.js +14 -1
- package/dist/src/config/storage.js.map +1 -1
- package/dist/src/config/storage.test.js +12 -0
- package/dist/src/config/storage.test.js.map +1 -1
- package/dist/src/confirmation-bus/message-bus.d.ts +4 -1
- package/dist/src/confirmation-bus/message-bus.js +39 -1
- package/dist/src/confirmation-bus/message-bus.js.map +1 -1
- package/dist/src/confirmation-bus/message-bus.test.js +43 -0
- package/dist/src/confirmation-bus/message-bus.test.js.map +1 -1
- package/dist/src/context/config/configLoader.d.ts +13 -0
- package/dist/src/context/config/configLoader.js +65 -0
- package/dist/src/context/config/configLoader.js.map +1 -0
- package/dist/src/context/config/configLoader.test.d.ts +6 -0
- package/dist/src/context/config/configLoader.test.js +79 -0
- package/dist/src/context/config/configLoader.test.js.map +1 -0
- package/dist/src/context/config/profiles.d.ts +17 -0
- package/dist/src/context/config/profiles.js +93 -0
- package/dist/src/context/config/profiles.js.map +1 -0
- package/dist/src/context/config/registry.d.ts +21 -0
- package/dist/src/context/config/registry.js +32 -0
- package/dist/src/context/config/registry.js.map +1 -0
- package/dist/src/context/config/schema.d.ts +45 -0
- package/dist/src/context/config/schema.js +47 -0
- package/dist/src/context/config/schema.js.map +1 -0
- package/dist/src/context/config/types.d.ts +39 -0
- package/dist/src/context/config/types.js +7 -0
- package/dist/src/context/config/types.js.map +1 -0
- package/dist/src/context/contextManager.barrier.test.d.ts +6 -0
- package/dist/src/context/contextManager.barrier.test.js +56 -0
- package/dist/src/context/contextManager.barrier.test.js.map +1 -0
- package/dist/src/context/contextManager.d.ts +49 -0
- package/dist/src/context/contextManager.js +120 -0
- package/dist/src/context/contextManager.js.map +1 -0
- package/dist/src/context/eventBus.d.ts +28 -0
- package/dist/src/context/eventBus.js +27 -0
- package/dist/src/context/eventBus.js.map +1 -0
- package/dist/src/context/graph/behaviorRegistry.d.ts +28 -0
- package/dist/src/context/graph/behaviorRegistry.js +14 -0
- package/dist/src/context/graph/behaviorRegistry.js.map +1 -0
- package/dist/src/context/graph/builtinBehaviors.d.ts +11 -0
- package/dist/src/context/graph/builtinBehaviors.js +145 -0
- package/dist/src/context/graph/builtinBehaviors.js.map +1 -0
- package/dist/src/context/graph/fromGraph.d.ts +9 -0
- package/dist/src/context/graph/fromGraph.js +34 -0
- package/dist/src/context/graph/fromGraph.js.map +1 -0
- package/dist/src/context/graph/mapper.d.ts +16 -0
- package/dist/src/context/graph/mapper.js +16 -0
- package/dist/src/context/graph/mapper.js.map +1 -0
- package/dist/src/context/graph/render.d.ts +15 -0
- package/dist/src/context/graph/render.js +72 -0
- package/dist/src/context/graph/render.js.map +1 -0
- package/dist/src/context/graph/toGraph.d.ts +10 -0
- package/dist/src/context/graph/toGraph.js +172 -0
- package/dist/src/context/graph/toGraph.js.map +1 -0
- package/dist/src/context/graph/types.d.ts +139 -0
- package/dist/src/context/graph/types.js +36 -0
- package/dist/src/context/graph/types.js.map +1 -0
- package/dist/src/context/historyObserver.d.ts +27 -0
- package/dist/src/context/historyObserver.js +64 -0
- package/dist/src/context/historyObserver.js.map +1 -0
- package/dist/src/context/pipeline/contextWorkingBuffer.d.ts +33 -0
- package/dist/src/context/pipeline/contextWorkingBuffer.js +197 -0
- package/dist/src/context/pipeline/contextWorkingBuffer.js.map +1 -0
- package/dist/src/context/pipeline/contextWorkingBuffer.test.d.ts +6 -0
- package/dist/src/context/pipeline/contextWorkingBuffer.test.js +89 -0
- package/dist/src/context/pipeline/contextWorkingBuffer.test.js.map +1 -0
- package/dist/src/context/pipeline/environment.d.ts +27 -0
- package/dist/src/context/pipeline/environment.js +2 -0
- package/dist/src/context/pipeline/environment.js.map +1 -0
- package/dist/src/context/pipeline/environmentImpl.d.ts +28 -0
- package/dist/src/context/pipeline/environmentImpl.js +40 -0
- package/dist/src/context/pipeline/environmentImpl.js.map +1 -0
- package/dist/src/context/pipeline/environmentImpl.test.d.ts +1 -0
- package/dist/src/context/pipeline/environmentImpl.test.js +32 -0
- package/dist/src/context/pipeline/environmentImpl.test.js.map +1 -0
- package/dist/src/context/pipeline/inbox.d.ts +15 -0
- package/dist/src/context/pipeline/inbox.js +52 -0
- package/dist/src/context/pipeline/inbox.js.map +1 -0
- package/dist/src/context/pipeline/inbox.test.d.ts +1 -0
- package/dist/src/context/pipeline/inbox.test.js +36 -0
- package/dist/src/context/pipeline/inbox.test.js.map +1 -0
- package/dist/src/context/pipeline/orchestrator.d.ts +22 -0
- package/dist/src/context/pipeline/orchestrator.js +126 -0
- package/dist/src/context/pipeline/orchestrator.js.map +1 -0
- package/dist/src/context/pipeline/orchestrator.test.d.ts +6 -0
- package/dist/src/context/pipeline/orchestrator.test.js +154 -0
- package/dist/src/context/pipeline/orchestrator.test.js.map +1 -0
- package/dist/src/context/pipeline.d.ts +52 -0
- package/dist/src/context/pipeline.js +7 -0
- package/dist/src/context/pipeline.js.map +1 -0
- package/dist/src/context/processors/blobDegradationProcessor.d.ts +6 -0
- package/dist/src/context/processors/blobDegradationProcessor.js +127 -0
- package/dist/src/context/processors/blobDegradationProcessor.js.map +1 -0
- package/dist/src/context/processors/blobDegradationProcessor.test.d.ts +6 -0
- package/dist/src/context/processors/blobDegradationProcessor.test.js +72 -0
- package/dist/src/context/processors/blobDegradationProcessor.test.js.map +1 -0
- package/dist/src/context/processors/historyTruncationProcessor.d.ts +11 -0
- package/dist/src/context/processors/historyTruncationProcessor.js +61 -0
- package/dist/src/context/processors/historyTruncationProcessor.js.map +1 -0
- package/dist/src/context/processors/nodeDistillationProcessor.d.ts +8 -0
- package/dist/src/context/processors/nodeDistillationProcessor.js +167 -0
- package/dist/src/context/processors/nodeDistillationProcessor.js.map +1 -0
- package/dist/src/context/processors/nodeDistillationProcessor.test.d.ts +6 -0
- package/dist/src/context/processors/nodeDistillationProcessor.test.js +77 -0
- package/dist/src/context/processors/nodeDistillationProcessor.test.js.map +1 -0
- package/dist/src/context/processors/nodeTruncationProcessor.d.ts +8 -0
- package/dist/src/context/processors/nodeTruncationProcessor.js +109 -0
- package/dist/src/context/processors/nodeTruncationProcessor.js.map +1 -0
- package/dist/src/context/processors/nodeTruncationProcessor.test.d.ts +6 -0
- package/dist/src/context/processors/nodeTruncationProcessor.test.js +71 -0
- package/dist/src/context/processors/nodeTruncationProcessor.test.js.map +1 -0
- package/dist/src/context/processors/rollingSummaryProcessor.d.ts +8 -0
- package/dist/src/context/processors/rollingSummaryProcessor.js +129 -0
- package/dist/src/context/processors/rollingSummaryProcessor.js.map +1 -0
- package/dist/src/context/processors/rollingSummaryProcessor.test.d.ts +1 -0
- package/dist/src/context/processors/rollingSummaryProcessor.test.js +60 -0
- package/dist/src/context/processors/rollingSummaryProcessor.test.js.map +1 -0
- package/dist/src/context/processors/stateSnapshotAsyncProcessor.d.ts +9 -0
- package/dist/src/context/processors/stateSnapshotAsyncProcessor.js +75 -0
- package/dist/src/context/processors/stateSnapshotAsyncProcessor.js.map +1 -0
- package/dist/src/context/processors/stateSnapshotAsyncProcessor.test.d.ts +1 -0
- package/dist/src/context/processors/stateSnapshotAsyncProcessor.test.js +80 -0
- package/dist/src/context/processors/stateSnapshotAsyncProcessor.test.js.map +1 -0
- package/dist/src/context/processors/stateSnapshotProcessor.d.ts +9 -0
- package/dist/src/context/processors/stateSnapshotProcessor.js +130 -0
- package/dist/src/context/processors/stateSnapshotProcessor.js.map +1 -0
- package/dist/src/context/processors/stateSnapshotProcessor.test.d.ts +1 -0
- package/dist/src/context/processors/stateSnapshotProcessor.test.js +91 -0
- package/dist/src/context/processors/stateSnapshotProcessor.test.js.map +1 -0
- package/dist/src/context/processors/toolMaskingProcessor.d.ts +8 -0
- package/dist/src/context/processors/toolMaskingProcessor.js +194 -0
- package/dist/src/context/processors/toolMaskingProcessor.js.map +1 -0
- package/dist/src/context/processors/toolMaskingProcessor.test.d.ts +1 -0
- package/dist/src/context/processors/toolMaskingProcessor.test.js +50 -0
- package/dist/src/context/processors/toolMaskingProcessor.test.js.map +1 -0
- package/dist/src/context/system-tests/lifecycle.golden.test.d.ts +6 -0
- package/dist/src/context/system-tests/lifecycle.golden.test.js +195 -0
- package/dist/src/context/system-tests/lifecycle.golden.test.js.map +1 -0
- package/dist/src/context/system-tests/simulationHarness.d.ts +41 -0
- package/dist/src/context/system-tests/simulationHarness.js +88 -0
- package/dist/src/context/system-tests/simulationHarness.js.map +1 -0
- package/dist/src/context/testing/contextTestUtils.d.ts +44 -0
- package/dist/src/context/testing/contextTestUtils.js +176 -0
- package/dist/src/context/testing/contextTestUtils.js.map +1 -0
- package/dist/src/context/testing/testProfile.d.ts +7 -0
- package/dist/src/context/testing/testProfile.js +20 -0
- package/dist/src/context/testing/testProfile.js.map +1 -0
- package/dist/src/context/tracer.d.ts +19 -0
- package/dist/src/context/tracer.js +79 -0
- package/dist/src/context/tracer.js.map +1 -0
- package/dist/src/context/tracer.test.d.ts +6 -0
- package/dist/src/context/tracer.test.js +71 -0
- package/dist/src/context/tracer.test.js.map +1 -0
- package/dist/src/context/utils/contextTokenCalculator.d.ts +53 -0
- package/dist/src/context/utils/contextTokenCalculator.js +97 -0
- package/dist/src/context/utils/contextTokenCalculator.js.map +1 -0
- package/dist/src/context/utils/snapshotGenerator.d.ts +12 -0
- package/dist/src/context/utils/snapshotGenerator.js +43 -0
- package/dist/src/context/utils/snapshotGenerator.js.map +1 -0
- package/dist/src/core/agentChatHistory.d.ts +26 -0
- package/dist/src/core/agentChatHistory.js +50 -0
- package/dist/src/core/agentChatHistory.js.map +1 -0
- package/dist/src/core/client.js +3 -1
- package/dist/src/core/client.js.map +1 -1
- package/dist/src/core/client.test.js +4 -0
- package/dist/src/core/client.test.js.map +1 -1
- package/dist/src/core/contentGenerator.d.ts +8 -1
- package/dist/src/core/contentGenerator.js +46 -4
- package/dist/src/core/contentGenerator.js.map +1 -1
- package/dist/src/core/contentGenerator.test.js +174 -8
- package/dist/src/core/contentGenerator.test.js.map +1 -1
- package/dist/src/core/coreToolHookTriggers.d.ts +1 -1
- package/dist/src/core/coreToolHookTriggers.js +5 -1
- package/dist/src/core/coreToolHookTriggers.js.map +1 -1
- package/dist/src/core/coreToolHookTriggers.test.js +1 -1
- package/dist/src/core/coreToolHookTriggers.test.js.map +1 -1
- package/dist/src/core/geminiChat.d.ts +2 -1
- package/dist/src/core/geminiChat.js +7 -2
- package/dist/src/core/geminiChat.js.map +1 -1
- package/dist/src/core/geminiChat.test.js +19 -6
- package/dist/src/core/geminiChat.test.js.map +1 -1
- package/dist/src/core/geminiChat_network_retry.test.js +42 -0
- package/dist/src/core/geminiChat_network_retry.test.js.map +1 -1
- package/dist/src/core/localLiteRtLmClient.js +2 -0
- package/dist/src/core/localLiteRtLmClient.js.map +1 -1
- package/dist/src/core/localLiteRtLmClient.test.js +7 -0
- package/dist/src/core/localLiteRtLmClient.test.js.map +1 -1
- package/dist/src/core/loggingContentGenerator.js +19 -6
- package/dist/src/core/loggingContentGenerator.js.map +1 -1
- package/dist/src/core/loggingContentGenerator.test.js +55 -0
- package/dist/src/core/loggingContentGenerator.test.js.map +1 -1
- package/dist/src/core/prompts-substitution.test.js +1 -0
- package/dist/src/core/prompts-substitution.test.js.map +1 -1
- package/dist/src/core/prompts.d.ts +1 -1
- package/dist/src/core/prompts.js +2 -2
- package/dist/src/core/prompts.js.map +1 -1
- package/dist/src/core/prompts.test.js +39 -8
- package/dist/src/core/prompts.test.js.map +1 -1
- package/dist/src/generated/git-commit.d.ts +2 -2
- package/dist/src/generated/git-commit.js +2 -2
- package/dist/src/hooks/hookRunner.js +8 -0
- package/dist/src/hooks/hookRunner.js.map +1 -1
- package/dist/src/hooks/hookRunner.test.js +23 -0
- package/dist/src/hooks/hookRunner.test.js.map +1 -1
- package/dist/src/ide/ide-client.js +3 -4
- package/dist/src/ide/ide-client.js.map +1 -1
- package/dist/src/index.d.ts +7 -3
- package/dist/src/index.js +7 -2
- package/dist/src/index.js.map +1 -1
- package/dist/src/mcp/mcpLauncher.js +1 -1
- package/dist/src/mcp/mcpLauncher.js.map +1 -1
- package/dist/src/mcp/oauth-provider.test.js +24 -17
- package/dist/src/mcp/oauth-provider.test.js.map +1 -1
- package/dist/src/policy/config.d.ts +2 -0
- package/dist/src/policy/config.js +67 -12
- package/dist/src/policy/config.js.map +1 -1
- package/dist/src/policy/core-tools-mapping.test.d.ts +6 -0
- package/dist/src/policy/core-tools-mapping.test.js +44 -0
- package/dist/src/policy/core-tools-mapping.test.js.map +1 -0
- package/dist/src/policy/policies/agents.toml +10 -0
- package/dist/src/policy/policies/plan.toml +17 -43
- package/dist/src/policy/policies/read-only.toml +24 -38
- package/dist/src/policy/policy-engine.d.ts +1 -1
- package/dist/src/policy/policy-engine.js +72 -67
- package/dist/src/policy/policy-engine.js.map +1 -1
- package/dist/src/policy/policy-engine.test.js +71 -4
- package/dist/src/policy/policy-engine.test.js.map +1 -1
- package/dist/src/policy/sandboxPolicyManager.js +4 -4
- package/dist/src/policy/sandboxPolicyManager.js.map +1 -1
- package/dist/src/policy/shell-safety-regression.test.d.ts +6 -0
- package/dist/src/policy/shell-safety-regression.test.js +86 -0
- package/dist/src/policy/shell-safety-regression.test.js.map +1 -0
- package/dist/src/policy/shell-safety.test.js +24 -0
- package/dist/src/policy/shell-safety.test.js.map +1 -1
- package/dist/src/policy/shell-substitution.test.d.ts +6 -0
- package/dist/src/policy/shell-substitution.test.js +75 -0
- package/dist/src/policy/shell-substitution.test.js.map +1 -0
- package/dist/src/policy/toml-loader.test.js +25 -11
- package/dist/src/policy/toml-loader.test.js.map +1 -1
- package/dist/src/policy/types.d.ts +6 -2
- package/dist/src/policy/types.js +4 -2
- package/dist/src/policy/types.js.map +1 -1
- package/dist/src/prompts/promptProvider.d.ts +1 -1
- package/dist/src/prompts/promptProvider.js +41 -24
- package/dist/src/prompts/promptProvider.js.map +1 -1
- package/dist/src/prompts/promptProvider.test.js +36 -2
- package/dist/src/prompts/promptProvider.test.js.map +1 -1
- package/dist/src/prompts/snippets-memory-v2.test.d.ts +6 -0
- package/dist/src/prompts/snippets-memory-v2.test.js +94 -0
- package/dist/src/prompts/snippets-memory-v2.test.js.map +1 -0
- package/dist/src/prompts/snippets.d.ts +19 -1
- package/dist/src/prompts/snippets.js +33 -6
- package/dist/src/prompts/snippets.js.map +1 -1
- package/dist/src/prompts/snippets.legacy.d.ts +6 -1
- package/dist/src/prompts/snippets.legacy.js +14 -7
- package/dist/src/prompts/snippets.legacy.js.map +1 -1
- package/dist/src/prompts/utils.test.js +1 -0
- package/dist/src/prompts/utils.test.js.map +1 -1
- package/dist/src/routing/modelRouterService.js +1 -1
- package/dist/src/routing/modelRouterService.js.map +1 -1
- package/dist/src/sandbox/linux/LinuxSandboxManager.d.ts +2 -0
- package/dist/src/sandbox/linux/LinuxSandboxManager.js +43 -19
- package/dist/src/sandbox/linux/LinuxSandboxManager.js.map +1 -1
- package/dist/src/sandbox/linux/LinuxSandboxManager.test.js +16 -0
- package/dist/src/sandbox/linux/LinuxSandboxManager.test.js.map +1 -1
- package/dist/src/sandbox/linux/bwrapArgsBuilder.d.ts +3 -7
- package/dist/src/sandbox/linux/bwrapArgsBuilder.js +96 -105
- package/dist/src/sandbox/linux/bwrapArgsBuilder.js.map +1 -1
- package/dist/src/sandbox/linux/bwrapArgsBuilder.test.js +144 -41
- package/dist/src/sandbox/linux/bwrapArgsBuilder.test.js.map +1 -1
- package/dist/src/sandbox/macos/MacOsSandboxManager.js +19 -10
- package/dist/src/sandbox/macos/MacOsSandboxManager.js.map +1 -1
- package/dist/src/sandbox/macos/MacOsSandboxManager.test.js +24 -37
- package/dist/src/sandbox/macos/MacOsSandboxManager.test.js.map +1 -1
- package/dist/src/sandbox/macos/seatbeltArgsBuilder.d.ts +3 -9
- package/dist/src/sandbox/macos/seatbeltArgsBuilder.js +129 -96
- package/dist/src/sandbox/macos/seatbeltArgsBuilder.js.map +1 -1
- package/dist/src/sandbox/macos/seatbeltArgsBuilder.test.js +78 -77
- package/dist/src/sandbox/macos/seatbeltArgsBuilder.test.js.map +1 -1
- package/dist/src/sandbox/utils/fsUtils.d.ts +2 -3
- package/dist/src/sandbox/utils/fsUtils.js +12 -27
- package/dist/src/sandbox/utils/fsUtils.js.map +1 -1
- package/dist/src/sandbox/utils/fsUtils.test.js +87 -29
- package/dist/src/sandbox/utils/fsUtils.test.js.map +1 -1
- package/dist/src/sandbox/windows/GeminiSandbox.cs +186 -77
- package/dist/src/sandbox/windows/WindowsSandboxManager.d.ts +4 -16
- package/dist/src/sandbox/windows/WindowsSandboxManager.js +138 -204
- package/dist/src/sandbox/windows/WindowsSandboxManager.js.map +1 -1
- package/dist/src/sandbox/windows/WindowsSandboxManager.test.js +105 -122
- package/dist/src/sandbox/windows/WindowsSandboxManager.test.js.map +1 -1
- package/dist/src/scheduler/policy.js +1 -2
- package/dist/src/scheduler/policy.js.map +1 -1
- package/dist/src/scheduler/policy.test.js +58 -2
- package/dist/src/scheduler/policy.test.js.map +1 -1
- package/dist/src/scheduler/scheduler.d.ts +2 -1
- package/dist/src/scheduler/scheduler.js +13 -14
- package/dist/src/scheduler/scheduler.js.map +1 -1
- package/dist/src/scheduler/scheduler.test.js +66 -0
- package/dist/src/scheduler/scheduler.test.js.map +1 -1
- package/dist/src/scheduler/scheduler_hooks.test.js +1 -0
- package/dist/src/scheduler/scheduler_hooks.test.js.map +1 -1
- package/dist/src/scheduler/scheduler_parallel.test.js +2 -0
- package/dist/src/scheduler/scheduler_parallel.test.js.map +1 -1
- package/dist/src/scheduler/tool-executor.js +2 -0
- package/dist/src/scheduler/tool-executor.js.map +1 -1
- package/dist/src/services/chatRecordingService.d.ts +12 -153
- package/dist/src/services/chatRecordingService.js +444 -350
- package/dist/src/services/chatRecordingService.js.map +1 -1
- package/dist/src/services/chatRecordingService.test.js +174 -128
- package/dist/src/services/chatRecordingService.test.js.map +1 -1
- package/dist/src/services/chatRecordingTypes.d.ts +111 -0
- package/dist/src/services/chatRecordingTypes.js +10 -0
- package/dist/src/services/chatRecordingTypes.js.map +1 -0
- package/dist/src/services/gitService.d.ts +2 -0
- package/dist/src/services/gitService.js +10 -1
- package/dist/src/services/gitService.js.map +1 -1
- package/dist/src/services/gitService.test.js +6 -2
- package/dist/src/services/gitService.test.js.map +1 -1
- package/dist/src/services/keychainService.d.ts +2 -2
- package/dist/src/services/keychainService.js +9 -9
- package/dist/src/services/keychainService.js.map +1 -1
- package/dist/src/services/keychainService.test.js +7 -7
- package/dist/src/services/keychainService.test.js.map +1 -1
- package/dist/src/services/keychainTypes.d.ts +1 -1
- package/dist/src/services/memoryPatchUtils.d.ts +42 -0
- package/dist/src/services/memoryPatchUtils.js +216 -0
- package/dist/src/services/memoryPatchUtils.js.map +1 -0
- package/dist/src/services/memoryService.d.ts +21 -1
- package/dist/src/services/memoryService.js +405 -64
- package/dist/src/services/memoryService.js.map +1 -1
- package/dist/src/services/memoryService.test.js +686 -2
- package/dist/src/services/memoryService.test.js.map +1 -1
- package/dist/src/services/sandboxManager.d.ts +33 -19
- package/dist/src/services/sandboxManager.integration.test.js +728 -266
- package/dist/src/services/sandboxManager.integration.test.js.map +1 -1
- package/dist/src/services/sandboxManager.js +65 -62
- package/dist/src/services/sandboxManager.js.map +1 -1
- package/dist/src/services/sandboxManager.test.js +17 -114
- package/dist/src/services/sandboxManager.test.js.map +1 -1
- package/dist/src/services/sandboxedFileSystemService.js +72 -62
- package/dist/src/services/sandboxedFileSystemService.js.map +1 -1
- package/dist/src/services/sessionSummaryUtils.d.ts +1 -1
- package/dist/src/services/sessionSummaryUtils.js +111 -38
- package/dist/src/services/sessionSummaryUtils.js.map +1 -1
- package/dist/src/services/sessionSummaryUtils.test.js +204 -51
- package/dist/src/services/sessionSummaryUtils.test.js.map +1 -1
- package/dist/src/services/shellExecutionService.d.ts +19 -0
- package/dist/src/services/shellExecutionService.js +88 -34
- package/dist/src/services/shellExecutionService.js.map +1 -1
- package/dist/src/services/shellExecutionService.test.js +38 -4
- package/dist/src/services/shellExecutionService.test.js.map +1 -1
- package/dist/src/telemetry/activity-monitor.js +1 -0
- package/dist/src/telemetry/activity-monitor.js.map +1 -1
- package/dist/src/telemetry/config.js +3 -0
- package/dist/src/telemetry/config.js.map +1 -1
- package/dist/src/telemetry/conseca-logger.js +18 -20
- package/dist/src/telemetry/conseca-logger.js.map +1 -1
- package/dist/src/telemetry/conseca-logger.test.js +100 -0
- package/dist/src/telemetry/conseca-logger.test.js.map +1 -1
- package/dist/src/telemetry/event-loop-monitor.d.ts +17 -0
- package/dist/src/telemetry/event-loop-monitor.js +76 -0
- package/dist/src/telemetry/event-loop-monitor.js.map +1 -0
- package/dist/src/telemetry/index.d.ts +2 -1
- package/dist/src/telemetry/index.js +2 -1
- package/dist/src/telemetry/index.js.map +1 -1
- package/dist/src/telemetry/llmRole.d.ts +2 -1
- package/dist/src/telemetry/llmRole.js +1 -0
- package/dist/src/telemetry/llmRole.js.map +1 -1
- package/dist/src/telemetry/loggers.test.js +184 -8
- package/dist/src/telemetry/loggers.test.js.map +1 -1
- package/dist/src/telemetry/memory-monitor.d.ts +1 -0
- package/dist/src/telemetry/memory-monitor.js +8 -1
- package/dist/src/telemetry/memory-monitor.js.map +1 -1
- package/dist/src/telemetry/memory-monitor.test.js +6 -1
- package/dist/src/telemetry/memory-monitor.test.js.map +1 -1
- package/dist/src/telemetry/metrics.d.ts +12 -0
- package/dist/src/telemetry/metrics.js +19 -0
- package/dist/src/telemetry/metrics.js.map +1 -1
- package/dist/src/telemetry/sdk.js +20 -1
- package/dist/src/telemetry/sdk.js.map +1 -1
- package/dist/src/telemetry/trace.d.ts +23 -6
- package/dist/src/telemetry/trace.js +71 -22
- package/dist/src/telemetry/trace.js.map +1 -1
- package/dist/src/telemetry/trace.test.js +79 -15
- package/dist/src/telemetry/trace.test.js.map +1 -1
- package/dist/src/telemetry/types.js +61 -15
- package/dist/src/telemetry/types.js.map +1 -1
- package/dist/src/test-utils/mock-tool.d.ts +3 -2
- package/dist/src/test-utils/mock-tool.js +4 -3
- package/dist/src/test-utils/mock-tool.js.map +1 -1
- package/dist/src/tools/activate-skill.js +1 -1
- package/dist/src/tools/activate-skill.js.map +1 -1
- package/dist/src/tools/activate-skill.test.js +6 -2
- package/dist/src/tools/activate-skill.test.js.map +1 -1
- package/dist/src/tools/ask-user.d.ts +2 -2
- package/dist/src/tools/ask-user.js +1 -1
- package/dist/src/tools/ask-user.js.map +1 -1
- package/dist/src/tools/ask-user.test.js +9 -3
- package/dist/src/tools/ask-user.test.js.map +1 -1
- package/dist/src/tools/complete-task.d.ts +2 -2
- package/dist/src/tools/complete-task.js +1 -1
- package/dist/src/tools/complete-task.js.map +1 -1
- package/dist/src/tools/complete-task.test.js +9 -3
- package/dist/src/tools/complete-task.test.js.map +1 -1
- package/dist/src/tools/definitions/base-declarations.d.ts +2 -0
- package/dist/src/tools/definitions/base-declarations.js +3 -0
- package/dist/src/tools/definitions/base-declarations.js.map +1 -1
- package/dist/src/tools/definitions/coreTools.d.ts +3 -1
- package/dist/src/tools/definitions/coreTools.js +13 -1
- package/dist/src/tools/definitions/coreTools.js.map +1 -1
- package/dist/src/tools/definitions/model-family-sets/default-legacy.js +29 -1
- package/dist/src/tools/definitions/model-family-sets/default-legacy.js.map +1 -1
- package/dist/src/tools/definitions/model-family-sets/gemini-3.js +29 -1
- package/dist/src/tools/definitions/model-family-sets/gemini-3.js.map +1 -1
- package/dist/src/tools/definitions/types.d.ts +2 -0
- package/dist/src/tools/edit.js +20 -4
- package/dist/src/tools/edit.js.map +1 -1
- package/dist/src/tools/edit.test.js +41 -18
- package/dist/src/tools/edit.test.js.map +1 -1
- package/dist/src/tools/enter-plan-mode.d.ts +2 -2
- package/dist/src/tools/enter-plan-mode.js +1 -1
- package/dist/src/tools/enter-plan-mode.js.map +1 -1
- package/dist/src/tools/enter-plan-mode.test.js +10 -4
- package/dist/src/tools/enter-plan-mode.test.js.map +1 -1
- package/dist/src/tools/exit-plan-mode.d.ts +2 -2
- package/dist/src/tools/exit-plan-mode.js +9 -12
- package/dist/src/tools/exit-plan-mode.js.map +1 -1
- package/dist/src/tools/exit-plan-mode.test.js +44 -17
- package/dist/src/tools/exit-plan-mode.test.js.map +1 -1
- package/dist/src/tools/get-internal-docs.js +6 -3
- package/dist/src/tools/get-internal-docs.js.map +1 -1
- package/dist/src/tools/get-internal-docs.test.js +4 -4
- package/dist/src/tools/get-internal-docs.test.js.map +1 -1
- package/dist/src/tools/glob.js +1 -1
- package/dist/src/tools/glob.js.map +1 -1
- package/dist/src/tools/glob.test.js +16 -16
- package/dist/src/tools/glob.test.js.map +1 -1
- package/dist/src/tools/grep.js +21 -12
- package/dist/src/tools/grep.js.map +1 -1
- package/dist/src/tools/grep.test.js +18 -18
- package/dist/src/tools/grep.test.js.map +1 -1
- package/dist/src/tools/line-endings.test.js +3 -3
- package/dist/src/tools/line-endings.test.js.map +1 -1
- package/dist/src/tools/list-mcp-resources.d.ts +24 -0
- package/dist/src/tools/list-mcp-resources.js +74 -0
- package/dist/src/tools/list-mcp-resources.js.map +1 -0
- package/dist/src/tools/list-mcp-resources.test.d.ts +6 -0
- package/dist/src/tools/list-mcp-resources.test.js +79 -0
- package/dist/src/tools/list-mcp-resources.test.js.map +1 -0
- package/dist/src/tools/ls.js +2 -2
- package/dist/src/tools/ls.js.map +1 -1
- package/dist/src/tools/ls.test.js +21 -21
- package/dist/src/tools/ls.test.js.map +1 -1
- package/dist/src/tools/mcp-client-manager.d.ts +3 -1
- package/dist/src/tools/mcp-client-manager.js +24 -1
- package/dist/src/tools/mcp-client-manager.js.map +1 -1
- package/dist/src/tools/mcp-client-manager.test.js +43 -0
- package/dist/src/tools/mcp-client-manager.test.js.map +1 -1
- package/dist/src/tools/mcp-client.js +10 -12
- package/dist/src/tools/mcp-client.js.map +1 -1
- package/dist/src/tools/mcp-client.test.js +14 -2
- package/dist/src/tools/mcp-client.test.js.map +1 -1
- package/dist/src/tools/mcp-tool.d.ts +2 -2
- package/dist/src/tools/mcp-tool.js +1 -1
- package/dist/src/tools/mcp-tool.js.map +1 -1
- package/dist/src/tools/mcp-tool.test.js +51 -21
- package/dist/src/tools/mcp-tool.test.js.map +1 -1
- package/dist/src/tools/memoryTool.d.ts +4 -3
- package/dist/src/tools/memoryTool.js +43 -14
- package/dist/src/tools/memoryTool.js.map +1 -1
- package/dist/src/tools/memoryTool.test.js +29 -9
- package/dist/src/tools/memoryTool.test.js.map +1 -1
- package/dist/src/tools/read-file.js +1 -1
- package/dist/src/tools/read-file.js.map +1 -1
- package/dist/src/tools/read-file.test.js +17 -17
- package/dist/src/tools/read-file.test.js.map +1 -1
- package/dist/src/tools/read-many-files.js +4 -4
- package/dist/src/tools/read-many-files.js.map +1 -1
- package/dist/src/tools/read-many-files.test.js +70 -24
- package/dist/src/tools/read-many-files.test.js.map +1 -1
- package/dist/src/tools/read-mcp-resource.d.ts +25 -0
- package/dist/src/tools/read-mcp-resource.js +120 -0
- package/dist/src/tools/read-mcp-resource.js.map +1 -0
- package/dist/src/tools/read-mcp-resource.test.d.ts +6 -0
- package/dist/src/tools/read-mcp-resource.test.js +110 -0
- package/dist/src/tools/read-mcp-resource.test.js.map +1 -0
- package/dist/src/tools/ripGrep.d.ts +3 -2
- package/dist/src/tools/ripGrep.js +26 -55
- package/dist/src/tools/ripGrep.js.map +1 -1
- package/dist/src/tools/ripGrep.test.js +113 -167
- package/dist/src/tools/ripGrep.test.js.map +1 -1
- package/dist/src/tools/shell.d.ts +2 -2
- package/dist/src/tools/shell.js +51 -21
- package/dist/src/tools/shell.js.map +1 -1
- package/dist/src/tools/shell.test.js +479 -76
- package/dist/src/tools/shell.test.js.map +1 -1
- package/dist/src/tools/shellBackgroundTools.d.ts +3 -3
- package/dist/src/tools/shellBackgroundTools.integration.test.js +6 -2
- package/dist/src/tools/shellBackgroundTools.integration.test.js.map +1 -1
- package/dist/src/tools/shellBackgroundTools.js +2 -2
- package/dist/src/tools/shellBackgroundTools.js.map +1 -1
- package/dist/src/tools/shellBackgroundTools.test.js +30 -10
- package/dist/src/tools/shellBackgroundTools.test.js.map +1 -1
- package/dist/src/tools/tool-error.d.ts +1 -0
- package/dist/src/tools/tool-error.js +1 -0
- package/dist/src/tools/tool-error.js.map +1 -1
- package/dist/src/tools/tool-names.d.ts +5 -4
- package/dist/src/tools/tool-names.js +8 -2
- package/dist/src/tools/tool-names.js.map +1 -1
- package/dist/src/tools/tool-registry.js +137 -114
- package/dist/src/tools/tool-registry.js.map +1 -1
- package/dist/src/tools/tool-registry.test.js +3 -1
- package/dist/src/tools/tool-registry.test.js.map +1 -1
- package/dist/src/tools/tools.d.ts +6 -6
- package/dist/src/tools/tools.js +6 -2
- package/dist/src/tools/tools.js.map +1 -1
- package/dist/src/tools/topicTool.d.ts +2 -2
- package/dist/src/tools/topicTool.js +1 -1
- package/dist/src/tools/topicTool.js.map +1 -1
- package/dist/src/tools/topicTool.test.js +6 -2
- package/dist/src/tools/topicTool.test.js.map +1 -1
- package/dist/src/tools/trackerTools.d.ts +7 -7
- package/dist/src/tools/trackerTools.js +6 -6
- package/dist/src/tools/trackerTools.js.map +1 -1
- package/dist/src/tools/web-fetch.js +1 -1
- package/dist/src/tools/web-fetch.js.map +1 -1
- package/dist/src/tools/web-fetch.test.js +59 -23
- package/dist/src/tools/web-fetch.test.js.map +1 -1
- package/dist/src/tools/web-search.js +1 -1
- package/dist/src/tools/web-search.js.map +1 -1
- package/dist/src/tools/web-search.test.js +5 -5
- package/dist/src/tools/web-search.test.js.map +1 -1
- package/dist/src/tools/write-file.js +22 -4
- package/dist/src/tools/write-file.js.map +1 -1
- package/dist/src/tools/write-file.test.js +29 -11
- package/dist/src/tools/write-file.test.js.map +1 -1
- package/dist/src/tools/write-todos.js +1 -1
- package/dist/src/tools/write-todos.js.map +1 -1
- package/dist/src/utils/compatibility.js +6 -1
- package/dist/src/utils/compatibility.js.map +1 -1
- package/dist/src/utils/compatibility.test.js +23 -0
- package/dist/src/utils/compatibility.test.js.map +1 -1
- package/dist/src/utils/errors.d.ts +3 -0
- package/dist/src/utils/errors.js +6 -0
- package/dist/src/utils/errors.js.map +1 -1
- package/dist/src/utils/fileUtils.d.ts +1 -2
- package/dist/src/utils/fileUtils.js +80 -40
- package/dist/src/utils/fileUtils.js.map +1 -1
- package/dist/src/utils/fileUtils.test.js +61 -0
- package/dist/src/utils/fileUtils.test.js.map +1 -1
- package/dist/src/utils/filesearch/fileSearch.d.ts +2 -0
- package/dist/src/utils/filesearch/fileSearch.js +97 -6
- package/dist/src/utils/filesearch/fileSearch.js.map +1 -1
- package/dist/src/utils/filesearch/fileSearch.test.js +54 -0
- package/dist/src/utils/filesearch/fileSearch.test.js.map +1 -1
- package/dist/src/utils/filesearch/fileWatcher.d.ts +25 -0
- package/dist/src/utils/filesearch/fileWatcher.js +86 -0
- package/dist/src/utils/filesearch/fileWatcher.js.map +1 -0
- package/dist/src/utils/filesearch/fileWatcher.test.js +142 -0
- package/dist/src/utils/filesearch/fileWatcher.test.js.map +1 -0
- package/dist/src/utils/getFolderStructure.js +4 -2
- package/dist/src/utils/getFolderStructure.js.map +1 -1
- package/dist/src/utils/gitIgnoreParser.js +1 -1
- package/dist/src/utils/gitIgnoreParser.js.map +1 -1
- package/dist/src/utils/googleQuotaErrors.d.ts +2 -1
- package/dist/src/utils/googleQuotaErrors.js +30 -35
- package/dist/src/utils/googleQuotaErrors.js.map +1 -1
- package/dist/src/utils/googleQuotaErrors.test.js +24 -0
- package/dist/src/utils/googleQuotaErrors.test.js.map +1 -1
- package/dist/src/utils/ignoreFileParser.js +1 -1
- package/dist/src/utils/ignoreFileParser.js.map +1 -1
- package/dist/src/utils/memoryDiscovery.js +15 -5
- package/dist/src/utils/memoryDiscovery.js.map +1 -1
- package/dist/src/utils/oauth-flow.js +17 -5
- package/dist/src/utils/oauth-flow.js.map +1 -1
- package/dist/src/utils/oauth-flow.test.js +20 -0
- package/dist/src/utils/oauth-flow.test.js.map +1 -1
- package/dist/src/utils/paths.d.ts +9 -0
- package/dist/src/utils/paths.js +37 -0
- package/dist/src/utils/paths.js.map +1 -1
- package/dist/src/utils/paths.test.js +45 -1
- package/dist/src/utils/paths.test.js.map +1 -1
- package/dist/src/utils/planUtils.d.ts +11 -2
- package/dist/src/utils/planUtils.js +43 -11
- package/dist/src/utils/planUtils.js.map +1 -1
- package/dist/src/utils/planUtils.test.js +10 -9
- package/dist/src/utils/planUtils.test.js.map +1 -1
- package/dist/src/utils/process-utils.d.ts +2 -1
- package/dist/src/utils/process-utils.js +64 -33
- package/dist/src/utils/process-utils.js.map +1 -1
- package/dist/src/utils/process-utils.test.js +9 -0
- package/dist/src/utils/process-utils.test.js.map +1 -1
- package/dist/src/utils/retry.js +18 -6
- package/dist/src/utils/retry.js.map +1 -1
- package/dist/src/utils/retry.test.js +30 -0
- package/dist/src/utils/retry.test.js.map +1 -1
- package/dist/src/utils/sessionOperations.js +3 -2
- package/dist/src/utils/sessionOperations.js.map +1 -1
- package/dist/src/utils/shell-utils.d.ts +2 -0
- package/dist/src/utils/shell-utils.js +237 -107
- package/dist/src/utils/shell-utils.js.map +1 -1
- package/dist/src/utils/tool-utils.d.ts +1 -29
- package/dist/src/utils/tool-utils.js +0 -39
- package/dist/src/utils/tool-utils.js.map +1 -1
- package/dist/src/utils/tool-utils.test.js +2 -76
- package/dist/src/utils/tool-utils.test.js.map +1 -1
- package/dist/src/utils/tool-visibility.d.ts +40 -0
- package/dist/src/utils/tool-visibility.js +111 -0
- package/dist/src/utils/tool-visibility.js.map +1 -0
- package/dist/src/utils/tool-visibility.test.d.ts +6 -0
- package/dist/src/utils/tool-visibility.test.js +96 -0
- package/dist/src/utils/tool-visibility.test.js.map +1 -0
- package/dist/src/utils/trust.d.ts +64 -0
- package/dist/src/utils/trust.js +276 -0
- package/dist/src/utils/trust.js.map +1 -0
- package/dist/src/utils/trust.test.d.ts +6 -0
- package/dist/src/utils/trust.test.js +159 -0
- package/dist/src/utils/trust.test.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +5 -4
- package/dist/docs/get-started/installation.md +0 -181
- package/dist/src/agents/memory-manager-agent.d.ts +0 -25
- package/dist/src/agents/memory-manager-agent.js +0 -138
- package/dist/src/agents/memory-manager-agent.js.map +0 -1
- package/dist/src/agents/memory-manager-agent.test.js +0 -123
- package/dist/src/agents/memory-manager-agent.test.js.map +0 -1
- package/dist/src/agents/subagent-tool-wrapper.d.ts +0 -38
- package/dist/src/agents/subagent-tool-wrapper.js +0 -58
- package/dist/src/agents/subagent-tool-wrapper.js.map +0 -1
- package/dist/src/agents/subagent-tool-wrapper.test.js +0 -123
- package/dist/src/agents/subagent-tool-wrapper.test.js.map +0 -1
- package/dist/src/agents/subagent-tool.d.ts +0 -18
- package/dist/src/agents/subagent-tool.js +0 -134
- package/dist/src/agents/subagent-tool.js.map +0 -1
- package/dist/src/agents/subagent-tool.test.js +0 -287
- package/dist/src/agents/subagent-tool.test.js.map +0 -1
- package/dist/src/policy/policies/tracker.toml +0 -34
- package/dist/src/prompts/snippets-memory-manager.test.js +0 -31
- package/dist/src/prompts/snippets-memory-manager.test.js.map +0 -1
- /package/dist/src/{agents/memory-manager-agent.test.d.ts → agent/tool-display-utils.test.d.ts} +0 -0
- /package/dist/src/agents/{subagent-tool.test.d.ts → agent-tool.test.d.ts} +0 -0
- /package/dist/src/{prompts/snippets-memory-manager.test.d.ts → agents/skill-extraction-agent.test.d.ts} +0 -0
- /package/dist/src/{agents/subagent-tool-wrapper.test.d.ts → utils/filesearch/fileWatcher.test.d.ts} +0 -0
|
@@ -15,6 +15,8 @@ import { ResourceRegistry } from '../resources/resource-registry.js';
|
|
|
15
15
|
import { ToolRegistry } from '../tools/tool-registry.js';
|
|
16
16
|
import { LSTool } from '../tools/ls.js';
|
|
17
17
|
import { ReadFileTool } from '../tools/read-file.js';
|
|
18
|
+
import { ReadMcpResourceTool } from '../tools/read-mcp-resource.js';
|
|
19
|
+
import { ListMcpResourcesTool } from '../tools/list-mcp-resources.js';
|
|
18
20
|
import { GrepTool } from '../tools/grep.js';
|
|
19
21
|
import { canUseRipgrep, RipGrepTool } from '../tools/ripGrep.js';
|
|
20
22
|
import { GlobTool } from '../tools/glob.js';
|
|
@@ -23,11 +25,12 @@ import { EditTool } from '../tools/edit.js';
|
|
|
23
25
|
import { ShellTool } from '../tools/shell.js';
|
|
24
26
|
import { WriteFileTool } from '../tools/write-file.js';
|
|
25
27
|
import { WebFetchTool } from '../tools/web-fetch.js';
|
|
26
|
-
import { MemoryTool, setGeminiMdFilename } from '../tools/memoryTool.js';
|
|
28
|
+
import { MemoryTool, setGeminiMdFilename, getCurrentGeminiMdFilename, } from '../tools/memoryTool.js';
|
|
27
29
|
import { WebSearchTool } from '../tools/web-search.js';
|
|
28
30
|
import { AskUserTool } from '../tools/ask-user.js';
|
|
29
31
|
import { UpdateTopicTool } from '../tools/topicTool.js';
|
|
30
32
|
import { TopicState } from './topicState.js';
|
|
33
|
+
import { AgentTool } from '../agents/agent-tool.js';
|
|
31
34
|
import { ExitPlanModeTool } from '../tools/exit-plan-mode.js';
|
|
32
35
|
import { EnterPlanModeTool } from '../tools/enter-plan-mode.js';
|
|
33
36
|
import { ListBackgroundProcessesTool, ReadBackgroundOutputTool, } from '../tools/shellBackgroundTools.js';
|
|
@@ -70,7 +73,6 @@ import { getExperiments, } from '../code_assist/experiments/experiments.js';
|
|
|
70
73
|
import { AgentRegistry } from '../agents/registry.js';
|
|
71
74
|
import { AcknowledgedAgentsService } from '../agents/acknowledgedAgents.js';
|
|
72
75
|
import { setGlobalProxy, updateGlobalFetchTimeouts } from '../utils/fetch.js';
|
|
73
|
-
import { SubagentTool } from '../agents/subagent-tool.js';
|
|
74
76
|
import { ExperimentFlags } from '../code_assist/experiments/flagNames.js';
|
|
75
77
|
import { debugLogger } from '../utils/debugLogger.js';
|
|
76
78
|
import { SkillManager } from '../skills/skillManager.js';
|
|
@@ -92,7 +94,6 @@ import { SimpleExtensionLoader, } from '../utils/extensionLoader.js';
|
|
|
92
94
|
import { McpClientManager } from '../tools/mcp-client-manager.js';
|
|
93
95
|
import { A2AClientManager } from '../agents/a2a-client-manager.js';
|
|
94
96
|
import {} from '../tools/mcp-client.js';
|
|
95
|
-
import { getErrorMessage } from '../utils/errors.js';
|
|
96
97
|
export { DEFAULT_FILE_FILTERING_OPTIONS, DEFAULT_MEMORY_FILE_FILTERING_OPTIONS, };
|
|
97
98
|
export const DEFAULT_TRUNCATE_TOOL_OUTPUT_THRESHOLD = 40_000;
|
|
98
99
|
export class MCPServerConfig {
|
|
@@ -295,12 +296,14 @@ export class Config {
|
|
|
295
296
|
lastEmittedQuotaRemaining;
|
|
296
297
|
lastEmittedQuotaLimit;
|
|
297
298
|
emitQuotaChangedEvent() {
|
|
298
|
-
const
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
this.lastEmittedQuotaLimit
|
|
303
|
-
|
|
299
|
+
const remaining = this.getQuotaRemaining();
|
|
300
|
+
const limit = this.getQuotaLimit();
|
|
301
|
+
const resetTime = this.getQuotaResetTime();
|
|
302
|
+
if (this.lastEmittedQuotaRemaining !== remaining ||
|
|
303
|
+
this.lastEmittedQuotaLimit !== limit) {
|
|
304
|
+
this.lastEmittedQuotaRemaining = remaining;
|
|
305
|
+
this.lastEmittedQuotaLimit = limit;
|
|
306
|
+
coreEvents.emitQuotaChanged(remaining, limit, resetTime);
|
|
304
307
|
}
|
|
305
308
|
}
|
|
306
309
|
summarizeToolOutput;
|
|
@@ -367,6 +370,7 @@ export class Config {
|
|
|
367
370
|
onModelChange;
|
|
368
371
|
onReload;
|
|
369
372
|
billing;
|
|
373
|
+
vertexAiRouting;
|
|
370
374
|
enableAgents;
|
|
371
375
|
agents;
|
|
372
376
|
enableEventDrivenScheduler;
|
|
@@ -374,7 +378,9 @@ export class Config {
|
|
|
374
378
|
disabledSkills;
|
|
375
379
|
adminSkillsEnabled;
|
|
376
380
|
experimentalJitContext;
|
|
377
|
-
|
|
381
|
+
experimentalMemoryV2;
|
|
382
|
+
experimentalAutoMemory;
|
|
383
|
+
experimentalContextManagementConfig;
|
|
378
384
|
memoryBoundaryMarkers;
|
|
379
385
|
topicUpdateNarration;
|
|
380
386
|
disableLLMCorrection;
|
|
@@ -470,6 +476,7 @@ export class Config {
|
|
|
470
476
|
this.accessibility = params.accessibility ?? {};
|
|
471
477
|
this.telemetrySettings = {
|
|
472
478
|
enabled: params.telemetry?.enabled ?? false,
|
|
479
|
+
traces: params.telemetry?.traces ?? false,
|
|
473
480
|
target: params.telemetry?.target ?? DEFAULT_TELEMETRY_TARGET,
|
|
474
481
|
otlpEndpoint: params.telemetry?.otlpEndpoint ?? DEFAULT_OTLP_ENDPOINT,
|
|
475
482
|
otlpProtocol: params.telemetry?.otlpProtocol,
|
|
@@ -484,6 +491,9 @@ export class Config {
|
|
|
484
491
|
DEFAULT_FILE_FILTERING_OPTIONS.respectGitIgnore,
|
|
485
492
|
respectGeminiIgnore: params.fileFiltering?.respectGeminiIgnore ??
|
|
486
493
|
DEFAULT_FILE_FILTERING_OPTIONS.respectGeminiIgnore,
|
|
494
|
+
enableFileWatcher: params.fileFiltering?.enableFileWatcher ??
|
|
495
|
+
DEFAULT_FILE_FILTERING_OPTIONS.enableFileWatcher ??
|
|
496
|
+
true,
|
|
487
497
|
enableRecursiveFileSearch: params.fileFiltering?.enableRecursiveFileSearch ?? true,
|
|
488
498
|
enableFuzzySearch: params.fileFiltering?.enableFuzzySearch ?? true,
|
|
489
499
|
maxFileCount: params.fileFiltering?.maxFileCount ??
|
|
@@ -558,8 +568,11 @@ export class Config {
|
|
|
558
568
|
};
|
|
559
569
|
}
|
|
560
570
|
this.modelConfigService = new ModelConfigService(modelConfigServiceConfig ?? DEFAULT_MODEL_CONFIGS);
|
|
561
|
-
this.experimentalJitContext = params.experimentalJitContext ??
|
|
562
|
-
this.
|
|
571
|
+
this.experimentalJitContext = params.experimentalJitContext ?? true;
|
|
572
|
+
this.experimentalMemoryV2 = params.experimentalMemoryV2 ?? true;
|
|
573
|
+
this.experimentalAutoMemory = params.experimentalAutoMemory ?? false;
|
|
574
|
+
this.experimentalContextManagementConfig =
|
|
575
|
+
params.experimentalContextManagementConfig;
|
|
563
576
|
this.memoryBoundaryMarkers = params.memoryBoundaryMarkers ?? ['.git'];
|
|
564
577
|
this.contextManagement = {
|
|
565
578
|
enabled: params.contextManagement?.enabled ?? false,
|
|
@@ -591,7 +604,7 @@ export class Config {
|
|
|
591
604
|
},
|
|
592
605
|
},
|
|
593
606
|
};
|
|
594
|
-
this.topicUpdateNarration = params.topicUpdateNarration ??
|
|
607
|
+
this.topicUpdateNarration = params.topicUpdateNarration ?? true;
|
|
595
608
|
this.modelSteering = params.modelSteering ?? false;
|
|
596
609
|
this.injectionService = new InjectionService(() => this.isModelSteeringEnabled());
|
|
597
610
|
ExecutionLifecycleService.setInjectionService(this.injectionService);
|
|
@@ -702,6 +715,8 @@ export class Config {
|
|
|
702
715
|
};
|
|
703
716
|
this.gemmaModelRouter = {
|
|
704
717
|
enabled: params.gemmaModelRouter?.enabled ?? false,
|
|
718
|
+
autoStartServer: params.gemmaModelRouter?.autoStartServer ?? true,
|
|
719
|
+
binaryPath: params.gemmaModelRouter?.binaryPath ?? '',
|
|
705
720
|
classifier: {
|
|
706
721
|
host: params.gemmaModelRouter?.classifier?.host ?? 'http://localhost:9379',
|
|
707
722
|
model: params.gemmaModelRouter?.classifier?.model ?? 'gemma3-1b-gpu-custom',
|
|
@@ -728,6 +743,7 @@ export class Config {
|
|
|
728
743
|
this.billing = {
|
|
729
744
|
overageStrategy: params.billing?.overageStrategy ?? 'ask',
|
|
730
745
|
};
|
|
746
|
+
this.vertexAiRouting = params.vertexAiRouting;
|
|
731
747
|
if (params.contextFileName) {
|
|
732
748
|
setGeminiMdFilename(params.contextFileName);
|
|
733
749
|
}
|
|
@@ -863,11 +879,11 @@ export class Config {
|
|
|
863
879
|
if (this.contentGeneratorConfig) {
|
|
864
880
|
this.contentGeneratorConfig.authType = undefined;
|
|
865
881
|
}
|
|
866
|
-
const newContentGeneratorConfig = await createContentGeneratorConfig(this, authMethod, {
|
|
882
|
+
const newContentGeneratorConfig = await createContentGeneratorConfig(this, authMethod, apiKey, baseUrl, customHeaders, this.vertexAiRouting, {
|
|
867
883
|
clientId: this.keycloakClientId,
|
|
868
884
|
deviceEndpoint: this.keycloakDeviceEndpoint,
|
|
869
885
|
tokenEndpoint: this.keycloakTokenEndpoint,
|
|
870
|
-
}, displayMessage
|
|
886
|
+
}, displayMessage);
|
|
871
887
|
this.contentGenerator = await createContentGenerator(newContentGeneratorConfig, this, this.getSessionId());
|
|
872
888
|
// Only assign to instance properties after successful initialization
|
|
873
889
|
this.contentGeneratorConfig = newContentGeneratorConfig;
|
|
@@ -1032,7 +1048,19 @@ export class Config {
|
|
|
1032
1048
|
return this.clientName;
|
|
1033
1049
|
}
|
|
1034
1050
|
setSessionId(sessionId) {
|
|
1051
|
+
const previousPlansDir = this.storage.isInitialized()
|
|
1052
|
+
? this.storage.getPlansDir()
|
|
1053
|
+
: undefined;
|
|
1035
1054
|
this._sessionId = sessionId;
|
|
1055
|
+
this.storage.setSessionId(sessionId);
|
|
1056
|
+
this.trackerService = undefined;
|
|
1057
|
+
if (previousPlansDir) {
|
|
1058
|
+
this.refreshSessionScopedPlansDirectory(previousPlansDir);
|
|
1059
|
+
}
|
|
1060
|
+
}
|
|
1061
|
+
resetNewSessionState(sessionId) {
|
|
1062
|
+
this.setSessionId(sessionId);
|
|
1063
|
+
this.approvedPlanPath = undefined;
|
|
1036
1064
|
}
|
|
1037
1065
|
setTerminalBackground(terminalBackground) {
|
|
1038
1066
|
this.terminalBackground = terminalBackground;
|
|
@@ -1079,6 +1107,9 @@ export class Config {
|
|
|
1079
1107
|
// When the user explicitly sets a model, that becomes the active model.
|
|
1080
1108
|
this._activeModel = newModel;
|
|
1081
1109
|
coreEvents.emitModelChanged(newModel);
|
|
1110
|
+
this.lastEmittedQuotaRemaining = undefined;
|
|
1111
|
+
this.lastEmittedQuotaLimit = undefined;
|
|
1112
|
+
this.emitQuotaChangedEvent();
|
|
1082
1113
|
}
|
|
1083
1114
|
if (this.onModelChange && !isTemporary) {
|
|
1084
1115
|
this.onModelChange(newModel);
|
|
@@ -1236,6 +1267,34 @@ export class Config {
|
|
|
1236
1267
|
getWorkspaceContext() {
|
|
1237
1268
|
return getWorkspaceContextOverride() ?? this.workspaceContext;
|
|
1238
1269
|
}
|
|
1270
|
+
refreshSessionScopedPlansDirectory(previousPlansDir) {
|
|
1271
|
+
const nextPlansDir = this.storage.getPlansDir();
|
|
1272
|
+
if (previousPlansDir === nextPlansDir) {
|
|
1273
|
+
return;
|
|
1274
|
+
}
|
|
1275
|
+
const pathsToRemove = new Set([previousPlansDir]);
|
|
1276
|
+
try {
|
|
1277
|
+
pathsToRemove.add(resolveToRealPath(previousPlansDir));
|
|
1278
|
+
}
|
|
1279
|
+
catch {
|
|
1280
|
+
// The previous session's plans directory may never have been created.
|
|
1281
|
+
// In that case there is nothing to resolve or remove beyond the raw path.
|
|
1282
|
+
}
|
|
1283
|
+
const currentDirectories = this.workspaceContext
|
|
1284
|
+
.getDirectories()
|
|
1285
|
+
.filter((dir) => !pathsToRemove.has(dir));
|
|
1286
|
+
this.workspaceContext.setDirectories(currentDirectories);
|
|
1287
|
+
try {
|
|
1288
|
+
if (fs.existsSync(nextPlansDir)) {
|
|
1289
|
+
this.workspaceContext.addDirectory(nextPlansDir);
|
|
1290
|
+
}
|
|
1291
|
+
}
|
|
1292
|
+
catch {
|
|
1293
|
+
// Ignore invalid or unreadable plans directories here. This mirrors
|
|
1294
|
+
// initialization behavior, which only adds the plans directory when it
|
|
1295
|
+
// already exists and is readable.
|
|
1296
|
+
}
|
|
1297
|
+
}
|
|
1239
1298
|
getAgentRegistry() {
|
|
1240
1299
|
return this.agentRegistry;
|
|
1241
1300
|
}
|
|
@@ -1293,20 +1352,29 @@ export class Config {
|
|
|
1293
1352
|
this.lastRetrievedQuota = quota;
|
|
1294
1353
|
this.lastQuotaFetchTime = Date.now();
|
|
1295
1354
|
for (const bucket of quota.buckets) {
|
|
1296
|
-
if (bucket.modelId
|
|
1297
|
-
|
|
1298
|
-
|
|
1299
|
-
|
|
1300
|
-
|
|
1301
|
-
|
|
1302
|
-
|
|
1303
|
-
|
|
1304
|
-
|
|
1305
|
-
remaining
|
|
1306
|
-
limit
|
|
1307
|
-
|
|
1308
|
-
|
|
1309
|
-
|
|
1355
|
+
if (!bucket.modelId || bucket.remainingFraction == null) {
|
|
1356
|
+
continue;
|
|
1357
|
+
}
|
|
1358
|
+
let remaining;
|
|
1359
|
+
let limit;
|
|
1360
|
+
if (bucket.remainingAmount) {
|
|
1361
|
+
remaining = parseInt(bucket.remainingAmount, 10);
|
|
1362
|
+
limit =
|
|
1363
|
+
bucket.remainingFraction > 0
|
|
1364
|
+
? Math.round(remaining / bucket.remainingFraction)
|
|
1365
|
+
: (this.modelQuotas.get(bucket.modelId)?.limit ?? 0);
|
|
1366
|
+
}
|
|
1367
|
+
else {
|
|
1368
|
+
// Server only sent remainingFraction — use a normalized scale.
|
|
1369
|
+
limit = 100;
|
|
1370
|
+
remaining = Math.round(bucket.remainingFraction * limit);
|
|
1371
|
+
}
|
|
1372
|
+
if (!isNaN(remaining) && Number.isFinite(limit) && limit > 0) {
|
|
1373
|
+
this.modelQuotas.set(bucket.modelId, {
|
|
1374
|
+
remaining,
|
|
1375
|
+
limit,
|
|
1376
|
+
resetTime: bucket.resetTime,
|
|
1377
|
+
});
|
|
1310
1378
|
}
|
|
1311
1379
|
}
|
|
1312
1380
|
this.emitQuotaChangedEvent();
|
|
@@ -1529,8 +1597,14 @@ export class Config {
|
|
|
1529
1597
|
getMemoryBoundaryMarkers() {
|
|
1530
1598
|
return this.memoryBoundaryMarkers;
|
|
1531
1599
|
}
|
|
1532
|
-
|
|
1533
|
-
return this.
|
|
1600
|
+
isMemoryV2Enabled() {
|
|
1601
|
+
return this.experimentalMemoryV2;
|
|
1602
|
+
}
|
|
1603
|
+
isAutoMemoryEnabled() {
|
|
1604
|
+
return this.experimentalAutoMemory;
|
|
1605
|
+
}
|
|
1606
|
+
getExperimentalContextManagementConfig() {
|
|
1607
|
+
return this.experimentalContextManagementConfig;
|
|
1534
1608
|
}
|
|
1535
1609
|
getContextManagementConfig() {
|
|
1536
1610
|
return this.contextManagement;
|
|
@@ -1695,6 +1769,9 @@ export class Config {
|
|
|
1695
1769
|
getTelemetryEnabled() {
|
|
1696
1770
|
return this.telemetrySettings.enabled ?? false;
|
|
1697
1771
|
}
|
|
1772
|
+
getTelemetryTracesEnabled() {
|
|
1773
|
+
return this.telemetrySettings.traces ?? false;
|
|
1774
|
+
}
|
|
1698
1775
|
getTelemetryLogPromptsEnabled() {
|
|
1699
1776
|
return this.telemetrySettings.logPrompts ?? true;
|
|
1700
1777
|
}
|
|
@@ -1769,6 +1846,7 @@ export class Config {
|
|
|
1769
1846
|
return {
|
|
1770
1847
|
respectGitIgnore: this.fileFiltering.respectGitIgnore,
|
|
1771
1848
|
respectGeminiIgnore: this.fileFiltering.respectGeminiIgnore,
|
|
1849
|
+
enableFileWatcher: this.fileFiltering.enableFileWatcher,
|
|
1772
1850
|
maxFileCount: this.fileFiltering.maxFileCount,
|
|
1773
1851
|
searchTimeout: this.fileFiltering.searchTimeout,
|
|
1774
1852
|
customIgnoreFilePaths: this.fileFiltering.customIgnoreFilePaths,
|
|
@@ -1933,7 +2011,10 @@ export class Config {
|
|
|
1933
2011
|
}
|
|
1934
2012
|
/**
|
|
1935
2013
|
* Checks if a given absolute path is allowed for file system operations.
|
|
1936
|
-
* A path is allowed if it's within the workspace context
|
|
2014
|
+
* A path is allowed if it's within the workspace context, the project's
|
|
2015
|
+
* temporary directory, or is exactly the global personal `~/.cell-cli/GEMINI.md`
|
|
2016
|
+
* file (the latter is the only file under `~/.cell-cli/` that is reachable —
|
|
2017
|
+
* settings, credentials, keybindings, etc. remain disallowed).
|
|
1937
2018
|
*
|
|
1938
2019
|
* @param absolutePath The absolute path to check.
|
|
1939
2020
|
* @returns true if the path is allowed, false otherwise.
|
|
@@ -1946,7 +2027,19 @@ export class Config {
|
|
|
1946
2027
|
}
|
|
1947
2028
|
const projectTempDir = this.storage.getProjectTempDir();
|
|
1948
2029
|
const resolvedTempDir = resolveToRealPath(projectTempDir);
|
|
1949
|
-
|
|
2030
|
+
if (isSubpath(resolvedTempDir, resolvedPath)) {
|
|
2031
|
+
return true;
|
|
2032
|
+
}
|
|
2033
|
+
// Surgical allowlist: the global personal GEMINI.md file (and ONLY that
|
|
2034
|
+
// file) is reachable so the prompt-driven memory flow can persist
|
|
2035
|
+
// cross-project personal preferences. This deliberately does NOT
|
|
2036
|
+
// allowlist the rest of `~/.cell-cli/`.
|
|
2037
|
+
const globalMemoryFilePath = path.join(Storage.getGlobalGeminiDir(), getCurrentGeminiMdFilename());
|
|
2038
|
+
const resolvedGlobalMemoryFilePath = resolveToRealPath(globalMemoryFilePath);
|
|
2039
|
+
if (resolvedPath === resolvedGlobalMemoryFilePath) {
|
|
2040
|
+
return true;
|
|
2041
|
+
}
|
|
2042
|
+
return false;
|
|
1950
2043
|
}
|
|
1951
2044
|
/**
|
|
1952
2045
|
* Validates if a path is allowed and returns a detailed error message if not.
|
|
@@ -2049,7 +2142,8 @@ export class Config {
|
|
|
2049
2142
|
* Note: This method should only be called after startup, once experiments have been loaded.
|
|
2050
2143
|
*/
|
|
2051
2144
|
getProModelNoAccessSync() {
|
|
2052
|
-
if (this.contentGeneratorConfig?.authType !== AuthType.LOGIN_WITH_GOOGLE
|
|
2145
|
+
if (this.contentGeneratorConfig?.authType !== AuthType.LOGIN_WITH_GOOGLE &&
|
|
2146
|
+
this.contentGeneratorConfig?.authType !== AuthType.COMPUTE_ADC) {
|
|
2053
2147
|
return false;
|
|
2054
2148
|
}
|
|
2055
2149
|
return (this.experiments?.flags[ExperimentFlags.PRO_MODEL_NO_ACCESS]?.boolValue ??
|
|
@@ -2245,14 +2339,21 @@ export class Config {
|
|
|
2245
2339
|
return this.shellExecutionConfig;
|
|
2246
2340
|
}
|
|
2247
2341
|
setShellExecutionConfig(config) {
|
|
2342
|
+
const definedConfig = {};
|
|
2343
|
+
for (const [k, v] of Object.entries(config)) {
|
|
2344
|
+
// Only merge properties explicitly provided with a concrete value.
|
|
2345
|
+
// Filtering out `null` and `undefined` ensures existing system defaults
|
|
2346
|
+
// are preserved when an extension doesn't want to override them.
|
|
2347
|
+
if (v != null) {
|
|
2348
|
+
Object.assign(definedConfig, { [k]: v });
|
|
2349
|
+
}
|
|
2350
|
+
}
|
|
2351
|
+
// Note: This performs a shallow merge. If the incoming config provides a nested
|
|
2352
|
+
// object (e.g., sandboxConfig), it will completely overwrite the existing
|
|
2353
|
+
// nested object rather than merging its individual properties.
|
|
2248
2354
|
this.shellExecutionConfig = {
|
|
2249
|
-
|
|
2250
|
-
|
|
2251
|
-
showColor: config.showColor ?? this.shellExecutionConfig.showColor,
|
|
2252
|
-
pager: config.pager ?? this.shellExecutionConfig.pager,
|
|
2253
|
-
sanitizationConfig: config.sanitizationConfig ??
|
|
2254
|
-
this.shellExecutionConfig.sanitizationConfig,
|
|
2255
|
-
sandboxManager: config.sandboxManager ?? this.shellExecutionConfig.sandboxManager,
|
|
2355
|
+
...this.shellExecutionConfig,
|
|
2356
|
+
...definedConfig,
|
|
2256
2357
|
};
|
|
2257
2358
|
}
|
|
2258
2359
|
getScreenReader() {
|
|
@@ -2394,6 +2495,7 @@ export class Config {
|
|
|
2394
2495
|
maybeRegister(RipGrepTool, () => registry.registerTool(new RipGrepTool(this, this.messageBus)));
|
|
2395
2496
|
}
|
|
2396
2497
|
else {
|
|
2498
|
+
debugLogger.warn(`Ripgrep is not available. Falling back to GrepTool.`);
|
|
2397
2499
|
logRipgrepFallback(this, new RipgrepFallbackEvent(errorString));
|
|
2398
2500
|
maybeRegister(GrepTool, () => registry.registerTool(new GrepTool(this, this.messageBus)));
|
|
2399
2501
|
}
|
|
@@ -2406,10 +2508,12 @@ export class Config {
|
|
|
2406
2508
|
maybeRegister(EditTool, () => registry.registerTool(new EditTool(this, this.messageBus)));
|
|
2407
2509
|
maybeRegister(WriteFileTool, () => registry.registerTool(new WriteFileTool(this, this.messageBus)));
|
|
2408
2510
|
maybeRegister(WebFetchTool, () => registry.registerTool(new WebFetchTool(this, this.messageBus)));
|
|
2511
|
+
maybeRegister(ReadMcpResourceTool, () => registry.registerTool(new ReadMcpResourceTool(this, this.messageBus)));
|
|
2512
|
+
maybeRegister(ListMcpResourcesTool, () => registry.registerTool(new ListMcpResourcesTool(this, this.messageBus)));
|
|
2409
2513
|
maybeRegister(ShellTool, () => registry.registerTool(new ShellTool(this, this.messageBus)));
|
|
2410
2514
|
maybeRegister(ListBackgroundProcessesTool, () => registry.registerTool(new ListBackgroundProcessesTool(this, this.messageBus)));
|
|
2411
2515
|
maybeRegister(ReadBackgroundOutputTool, () => registry.registerTool(new ReadBackgroundOutputTool(this, this.messageBus)));
|
|
2412
|
-
if (!this.
|
|
2516
|
+
if (!this.isMemoryV2Enabled()) {
|
|
2413
2517
|
maybeRegister(MemoryTool, () => registry.registerTool(new MemoryTool(this.messageBus, this.storage)));
|
|
2414
2518
|
}
|
|
2415
2519
|
maybeRegister(WebSearchTool, () => registry.registerTool(new WebSearchTool(this, this.messageBus)));
|
|
@@ -2429,47 +2533,12 @@ export class Config {
|
|
|
2429
2533
|
maybeRegister(TrackerAddDependencyTool, () => registry.registerTool(new TrackerAddDependencyTool(this, this.messageBus)));
|
|
2430
2534
|
maybeRegister(TrackerVisualizeTool, () => registry.registerTool(new TrackerVisualizeTool(this, this.messageBus)));
|
|
2431
2535
|
}
|
|
2432
|
-
// Register
|
|
2433
|
-
this.
|
|
2536
|
+
// Register Subagent Tool
|
|
2537
|
+
maybeRegister(AgentTool, () => registry.registerTool(new AgentTool(this, this.messageBus)));
|
|
2434
2538
|
await registry.discoverAllTools();
|
|
2435
2539
|
registry.sortTools();
|
|
2436
2540
|
return registry;
|
|
2437
2541
|
}
|
|
2438
|
-
/**
|
|
2439
|
-
* Registers SubAgentTools for all available agents.
|
|
2440
|
-
*/
|
|
2441
|
-
registerSubAgentTools(registry) {
|
|
2442
|
-
const agentsOverrides = this.getAgentsSettings().overrides ?? {};
|
|
2443
|
-
const discoveredDefinitions = this.agentRegistry.getAllDiscoveredAgentNames();
|
|
2444
|
-
// First, unregister any agents that are now disabled
|
|
2445
|
-
for (const agentName of discoveredDefinitions) {
|
|
2446
|
-
if (!this.isAgentsEnabled() ||
|
|
2447
|
-
agentsOverrides[agentName]?.enabled === false) {
|
|
2448
|
-
const tool = registry.getTool(agentName);
|
|
2449
|
-
if (tool instanceof SubagentTool) {
|
|
2450
|
-
registry.unregisterTool(agentName);
|
|
2451
|
-
}
|
|
2452
|
-
}
|
|
2453
|
-
}
|
|
2454
|
-
const discoveredNames = this.agentRegistry.getAllDiscoveredAgentNames();
|
|
2455
|
-
for (const agentName of discoveredNames) {
|
|
2456
|
-
const definition = this.agentRegistry.getDiscoveredDefinition(agentName);
|
|
2457
|
-
if (!definition) {
|
|
2458
|
-
continue;
|
|
2459
|
-
}
|
|
2460
|
-
try {
|
|
2461
|
-
if (!this.isAgentsEnabled() ||
|
|
2462
|
-
agentsOverrides[definition.name]?.enabled === false) {
|
|
2463
|
-
continue;
|
|
2464
|
-
}
|
|
2465
|
-
const tool = new SubagentTool(definition, this, this.messageBus);
|
|
2466
|
-
registry.registerTool(tool);
|
|
2467
|
-
}
|
|
2468
|
-
catch (e) {
|
|
2469
|
-
debugLogger.warn(`Failed to register tool for agent ${definition.name}: ${getErrorMessage(e)}`);
|
|
2470
|
-
}
|
|
2471
|
-
}
|
|
2472
|
-
}
|
|
2473
2542
|
/**
|
|
2474
2543
|
* Get the hook system instance
|
|
2475
2544
|
*/
|
|
@@ -2553,9 +2622,6 @@ export class Config {
|
|
|
2553
2622
|
debugLogger.debug('Experiments loaded', summaryString);
|
|
2554
2623
|
}
|
|
2555
2624
|
onAgentsRefreshed = async () => {
|
|
2556
|
-
if (this._toolRegistry) {
|
|
2557
|
-
this.registerSubAgentTools(this._toolRegistry);
|
|
2558
|
-
}
|
|
2559
2625
|
// Propagate updates to the active chat session
|
|
2560
2626
|
const client = this.geminiClient;
|
|
2561
2627
|
if (client?.isInitialized()) {
|