@machina.ai/cell-cli-core 1.36.0-rc1 → 1.38.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 +3 -10
- package/dist/docs/assets/theme-tokyonight-dark.png +0 -0
- package/dist/docs/changelogs/index.md +49 -0
- package/dist/docs/changelogs/latest.md +355 -458
- package/dist/docs/changelogs/preview.md +402 -363
- package/dist/docs/cli/acp-mode.md +126 -0
- package/dist/docs/cli/cli-reference.md +1 -1
- package/dist/docs/cli/notifications.md +5 -5
- package/dist/docs/cli/plan-mode.md +26 -10
- package/dist/docs/cli/sandbox.md +53 -1
- package/dist/docs/cli/settings.md +52 -48
- package/dist/docs/cli/themes.md +5 -0
- package/dist/docs/core/index.md +2 -2
- package/dist/docs/core/remote-agents.md +14 -18
- package/dist/docs/core/subagents.md +194 -47
- package/dist/docs/get-started/authentication.md +2 -2
- package/dist/docs/get-started/gemini-3.md +1 -1
- package/dist/docs/get-started/index.md +127 -1
- package/dist/docs/get-started/installation.md +7 -0
- package/dist/docs/hooks/index.md +6 -6
- package/dist/docs/ide-integration/index.md +99 -24
- package/dist/docs/index.md +0 -2
- package/dist/docs/redirects.json +1 -0
- package/dist/docs/reference/commands.md +1 -3
- package/dist/docs/reference/configuration.md +220 -99
- package/dist/docs/reference/keyboard-shortcuts.md +21 -8
- package/dist/docs/reference/policy-engine.md +36 -31
- package/dist/docs/reference/tools.md +56 -23
- package/dist/docs/release-confidence.md +0 -6
- package/dist/docs/releases.md +4 -0
- package/dist/docs/resources/quota-and-pricing.md +23 -9
- package/dist/docs/sidebar.json +11 -4
- package/dist/docs/tools/mcp-server.md +3 -3
- package/dist/docs/tools/planning.md +6 -4
- package/dist/docs/tools/web-fetch.md +3 -0
- package/dist/package.json +2 -1
- package/dist/src/agent/agent-session.test.js +14 -6
- package/dist/src/agent/agent-session.test.js.map +1 -1
- package/dist/src/agent/event-translator.js +2 -1
- package/dist/src/agent/event-translator.js.map +1 -1
- package/dist/src/agent/event-translator.test.js +1 -0
- package/dist/src/agent/event-translator.test.js.map +1 -1
- package/dist/src/agent/legacy-agent-session.d.ts +47 -4
- package/dist/src/agent/legacy-agent-session.js +38 -15
- package/dist/src/agent/legacy-agent-session.js.map +1 -1
- package/dist/src/agent/legacy-agent-session.test.js +60 -73
- package/dist/src/agent/legacy-agent-session.test.js.map +1 -1
- package/dist/src/agent/mock.js +7 -1
- package/dist/src/agent/mock.js.map +1 -1
- package/dist/src/agent/mock.test.js +1 -1
- package/dist/src/agent/mock.test.js.map +1 -1
- package/dist/src/agent/types.d.ts +34 -1
- package/dist/src/agents/a2a-client-manager.js +3 -3
- package/dist/src/agents/a2a-client-manager.js.map +1 -1
- package/dist/src/agents/agent-scheduler.js +6 -1
- package/dist/src/agents/agent-scheduler.js.map +1 -1
- package/dist/src/agents/agent-scheduler.test.js +38 -0
- package/dist/src/agents/agent-scheduler.test.js.map +1 -1
- package/dist/src/agents/agentLoader.d.ts +12 -12
- package/dist/src/agents/agentLoader.js +1 -0
- package/dist/src/agents/agentLoader.js.map +1 -1
- package/dist/src/agents/auth-provider/api-key-provider.test.js +18 -2
- package/dist/src/agents/auth-provider/api-key-provider.test.js.map +1 -1
- package/dist/src/agents/auth-provider/value-resolver.test.js +30 -0
- package/dist/src/agents/auth-provider/value-resolver.test.js.map +1 -1
- package/dist/src/agents/browser/analyzeScreenshot.js +36 -6
- package/dist/src/agents/browser/analyzeScreenshot.js.map +1 -1
- package/dist/src/agents/browser/analyzeScreenshot.test.js +35 -3
- package/dist/src/agents/browser/analyzeScreenshot.test.js.map +1 -1
- package/dist/src/agents/browser/automationOverlay.js +2 -10
- package/dist/src/agents/browser/automationOverlay.js.map +1 -1
- package/dist/src/agents/browser/browserAgentDefinition.js +10 -3
- package/dist/src/agents/browser/browserAgentDefinition.js.map +1 -1
- package/dist/src/agents/browser/browserAgentFactory.d.ts +11 -3
- package/dist/src/agents/browser/browserAgentFactory.js +171 -129
- package/dist/src/agents/browser/browserAgentFactory.js.map +1 -1
- package/dist/src/agents/browser/browserAgentFactory.test.js +99 -13
- package/dist/src/agents/browser/browserAgentFactory.test.js.map +1 -1
- package/dist/src/agents/browser/browserAgentInvocation.d.ts +1 -0
- package/dist/src/agents/browser/browserAgentInvocation.js +87 -27
- package/dist/src/agents/browser/browserAgentInvocation.js.map +1 -1
- package/dist/src/agents/browser/browserAgentInvocation.test.js +107 -7
- package/dist/src/agents/browser/browserAgentInvocation.test.js.map +1 -1
- package/dist/src/agents/browser/browserManager.d.ts +89 -8
- package/dist/src/agents/browser/browserManager.js +357 -74
- package/dist/src/agents/browser/browserManager.js.map +1 -1
- package/dist/src/agents/browser/browserManager.test.js +540 -19
- package/dist/src/agents/browser/browserManager.test.js.map +1 -1
- package/dist/src/agents/browser/inputBlocker.d.ts +4 -4
- package/dist/src/agents/browser/inputBlocker.js +8 -18
- package/dist/src/agents/browser/inputBlocker.js.map +1 -1
- package/dist/src/agents/browser/inputBlocker.test.js +31 -3
- package/dist/src/agents/browser/inputBlocker.test.js.map +1 -1
- package/dist/src/agents/browser/mcpToolWrapper.d.ts +1 -1
- package/dist/src/agents/browser/mcpToolWrapper.js +9 -6
- package/dist/src/agents/browser/mcpToolWrapper.js.map +1 -1
- package/dist/src/agents/browser/mcpToolWrapper.test.js +2 -2
- package/dist/src/agents/browser/mcpToolWrapper.test.js.map +1 -1
- package/dist/src/agents/browser/modelAvailability.d.ts +5 -0
- package/dist/src/agents/browser/modelAvailability.js +12 -0
- package/dist/src/agents/browser/modelAvailability.js.map +1 -1
- package/dist/src/agents/browser/snapshotSuperseder.d.ts +31 -0
- package/dist/src/agents/browser/snapshotSuperseder.js +101 -0
- package/dist/src/agents/browser/snapshotSuperseder.js.map +1 -0
- package/dist/src/agents/browser/snapshotSuperseder.test.js +158 -0
- package/dist/src/agents/browser/snapshotSuperseder.test.js.map +1 -0
- package/dist/src/agents/local-executor.d.ts +9 -0
- package/dist/src/agents/local-executor.js +144 -200
- package/dist/src/agents/local-executor.js.map +1 -1
- package/dist/src/agents/local-executor.test.js +500 -115
- package/dist/src/agents/local-executor.test.js.map +1 -1
- package/dist/src/agents/local-invocation.d.ts +1 -0
- package/dist/src/agents/local-invocation.js +19 -9
- package/dist/src/agents/local-invocation.js.map +1 -1
- package/dist/src/agents/local-invocation.test.js +24 -0
- package/dist/src/agents/local-invocation.test.js.map +1 -1
- package/dist/src/agents/memory-manager-agent.js +1 -0
- package/dist/src/agents/memory-manager-agent.js.map +1 -1
- package/dist/src/agents/memory-manager-agent.test.js +6 -0
- package/dist/src/agents/memory-manager-agent.test.js.map +1 -1
- package/dist/src/agents/registry.js +19 -11
- package/dist/src/agents/registry.js.map +1 -1
- package/dist/src/agents/registry.test.js +67 -0
- package/dist/src/agents/registry.test.js.map +1 -1
- package/dist/src/agents/skill-extraction-agent.d.ts +24 -0
- package/dist/src/agents/skill-extraction-agent.js +269 -0
- package/dist/src/agents/skill-extraction-agent.js.map +1 -0
- package/dist/src/agents/types.d.ts +20 -0
- package/dist/src/agents/types.js.map +1 -1
- package/dist/src/availability/policyCatalog.d.ts +2 -1
- package/dist/src/availability/policyCatalog.js +1 -1
- package/dist/src/availability/policyCatalog.js.map +1 -1
- package/dist/src/availability/policyHelpers.js +43 -32
- package/dist/src/availability/policyHelpers.js.map +1 -1
- package/dist/src/availability/policyHelpers.test.js +12 -1
- package/dist/src/availability/policyHelpers.test.js.map +1 -1
- package/dist/src/code_assist/admin/admin_controls.js +1 -1
- package/dist/src/code_assist/admin/admin_controls.js.map +1 -1
- package/dist/src/code_assist/experiments/flagNames.d.ts +1 -0
- package/dist/src/code_assist/experiments/flagNames.js +1 -0
- package/dist/src/code_assist/experiments/flagNames.js.map +1 -1
- package/dist/src/code_assist/oauth2.js +8 -3
- package/dist/src/code_assist/oauth2.js.map +1 -1
- package/dist/src/code_assist/oauth2.test.js +57 -0
- package/dist/src/code_assist/oauth2.test.js.map +1 -1
- package/dist/src/code_assist/server.js +1 -1
- package/dist/src/code_assist/server.js.map +1 -1
- package/dist/src/code_assist/setup.js +5 -2
- package/dist/src/code_assist/setup.js.map +1 -1
- package/dist/src/code_assist/setup.test.js +27 -1
- package/dist/src/code_assist/setup.test.js.map +1 -1
- package/dist/src/code_assist/types.d.ts +80 -80
- package/dist/src/commands/memory.js +1 -1
- package/dist/src/commands/memory.js.map +1 -1
- package/dist/src/config/agent-loop-context.d.ts +2 -0
- package/dist/src/config/config.d.ts +91 -23
- package/dist/src/config/config.js +238 -79
- package/dist/src/config/config.js.map +1 -1
- package/dist/src/config/config.test.js +189 -15
- package/dist/src/config/config.test.js.map +1 -1
- package/dist/src/config/defaultModelConfigs.js +9 -0
- package/dist/src/config/defaultModelConfigs.js.map +1 -1
- package/dist/src/config/extensions/integrity.js +1 -1
- package/dist/src/config/extensions/integrity.js.map +1 -1
- package/dist/src/config/memory.d.ts +1 -0
- package/dist/src/config/memory.js +6 -0
- package/dist/src/config/memory.js.map +1 -1
- package/dist/src/config/projectRegistry.js +5 -3
- package/dist/src/config/projectRegistry.js.map +1 -1
- package/dist/src/config/scoped-config.d.ts +30 -0
- package/dist/src/config/scoped-config.js +69 -0
- package/dist/src/config/scoped-config.js.map +1 -0
- package/dist/src/config/scoped-config.test.d.ts +6 -0
- package/dist/src/config/scoped-config.test.js +161 -0
- package/dist/src/config/scoped-config.test.js.map +1 -0
- package/dist/src/config/storage.d.ts +3 -0
- package/dist/src/config/storage.js +9 -0
- package/dist/src/config/storage.js.map +1 -1
- package/dist/src/config/storage.test.js +10 -5
- package/dist/src/config/storage.test.js.map +1 -1
- package/dist/src/config/topicState.d.ts +21 -0
- package/dist/src/config/topicState.js +41 -0
- package/dist/src/config/topicState.js.map +1 -0
- package/dist/src/confirmation-bus/types.d.ts +13 -4
- package/dist/src/confirmation-bus/types.js +2 -0
- package/dist/src/confirmation-bus/types.js.map +1 -1
- package/dist/src/context/agentHistoryProvider.d.ts +45 -0
- package/dist/src/context/agentHistoryProvider.js +294 -0
- package/dist/src/context/agentHistoryProvider.js.map +1 -0
- package/dist/src/context/agentHistoryProvider.test.d.ts +6 -0
- package/dist/src/context/agentHistoryProvider.test.js +357 -0
- package/dist/src/context/agentHistoryProvider.test.js.map +1 -0
- package/dist/src/context/chatCompressionService.js.map +1 -0
- package/dist/src/context/chatCompressionService.test.js.map +1 -0
- package/dist/src/context/contextCompressionService.d.ts +30 -0
- package/dist/src/context/contextCompressionService.js +405 -0
- package/dist/src/context/contextCompressionService.js.map +1 -0
- package/dist/src/context/contextCompressionService.test.js +253 -0
- package/dist/src/context/contextCompressionService.test.js.map +1 -0
- package/dist/src/{services/contextManager.d.ts → context/memoryContextManager.d.ts} +3 -1
- package/dist/src/{services/contextManager.js → context/memoryContextManager.js} +20 -11
- package/dist/src/context/memoryContextManager.js.map +1 -0
- package/dist/src/{services/contextManager.test.js → context/memoryContextManager.test.js} +42 -33
- package/dist/src/context/memoryContextManager.test.js.map +1 -0
- package/dist/src/context/profiles.d.ts +7 -0
- package/dist/src/context/profiles.js +21 -0
- package/dist/src/context/profiles.js.map +1 -0
- package/dist/src/context/toolDistillationService.d.ts +38 -0
- package/dist/src/context/toolDistillationService.js +170 -0
- package/dist/src/context/toolDistillationService.js.map +1 -0
- package/dist/src/context/toolDistillationService.test.d.ts +6 -0
- package/dist/src/context/toolDistillationService.test.js +86 -0
- package/dist/src/context/toolDistillationService.test.js.map +1 -0
- package/dist/src/{services → context}/toolOutputMaskingService.d.ts +2 -2
- package/dist/src/{services → context}/toolOutputMaskingService.js +7 -7
- package/dist/src/context/toolOutputMaskingService.js.map +1 -0
- package/dist/src/context/toolOutputMaskingService.test.d.ts +6 -0
- package/dist/src/{services → context}/toolOutputMaskingService.test.js +4 -5
- package/dist/src/context/toolOutputMaskingService.test.js.map +1 -0
- package/dist/src/context/truncation.d.ts +26 -0
- package/dist/src/context/truncation.js +102 -0
- package/dist/src/context/truncation.js.map +1 -0
- package/dist/src/context/types.d.ts +36 -0
- package/dist/src/context/types.js +7 -0
- package/dist/src/context/types.js.map +1 -0
- package/dist/src/core/AuthenticatedContentGenerator.js +9 -1
- package/dist/src/core/AuthenticatedContentGenerator.js.map +1 -1
- package/dist/src/core/baseLlmClient.js +1 -1
- package/dist/src/core/baseLlmClient.js.map +1 -1
- package/dist/src/core/baseLlmClient.test.js +1 -0
- package/dist/src/core/baseLlmClient.test.js.map +1 -1
- package/dist/src/core/client.d.ts +3 -1
- package/dist/src/core/client.js +24 -14
- package/dist/src/core/client.js.map +1 -1
- package/dist/src/core/client.test.js +36 -40
- package/dist/src/core/client.test.js.map +1 -1
- package/dist/src/core/contentGenerator.d.ts +0 -1
- package/dist/src/core/contentGenerator.js +2 -28
- package/dist/src/core/contentGenerator.js.map +1 -1
- package/dist/src/core/contentGenerator.test.js +1 -101
- package/dist/src/core/contentGenerator.test.js.map +1 -1
- package/dist/src/core/geminiChat.js +12 -5
- package/dist/src/core/geminiChat.js.map +1 -1
- package/dist/src/core/geminiChat.test.js +72 -18
- package/dist/src/core/geminiChat.test.js.map +1 -1
- package/dist/src/core/geminiChat_network_retry.test.js +1 -0
- package/dist/src/core/geminiChat_network_retry.test.js.map +1 -1
- package/dist/src/core/logger.js +4 -4
- package/dist/src/core/logger.js.map +1 -1
- package/dist/src/core/logger.test.js +1 -1
- package/dist/src/core/logger.test.js.map +1 -1
- package/dist/src/core/loggingContentGenerator.js +1 -1
- package/dist/src/core/loggingContentGenerator.js.map +1 -1
- package/dist/src/core/prompts-substitution.test.js +5 -0
- package/dist/src/core/prompts-substitution.test.js.map +1 -1
- package/dist/src/core/prompts.test.js +3 -0
- 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/hookEventHandler.js +8 -0
- package/dist/src/hooks/hookEventHandler.js.map +1 -1
- package/dist/src/hooks/hookRunner.js +9 -5
- package/dist/src/hooks/hookRunner.js.map +1 -1
- package/dist/src/hooks/hookRunner.test.js +20 -3
- package/dist/src/hooks/hookRunner.test.js.map +1 -1
- package/dist/src/hooks/hookSystem.d.ts +2 -0
- package/dist/src/hooks/hookSystem.js +1 -0
- package/dist/src/hooks/hookSystem.js.map +1 -1
- package/dist/src/hooks/hookTranslator.js +20 -13
- package/dist/src/hooks/hookTranslator.js.map +1 -1
- package/dist/src/hooks/hookTranslator.test.js +36 -0
- package/dist/src/hooks/hookTranslator.test.js.map +1 -1
- package/dist/src/hooks/types.d.ts +2 -0
- package/dist/src/ide/ide-client.js +3 -3
- package/dist/src/ide/ide-client.js.map +1 -1
- package/dist/src/ide/ide-connection-utils.js +1 -1
- package/dist/src/ide/ide-connection-utils.js.map +1 -1
- package/dist/src/ide/ide-installer.js +5 -4
- package/dist/src/ide/ide-installer.js.map +1 -1
- package/dist/src/ide/process-utils.js +3 -3
- package/dist/src/ide/process-utils.js.map +1 -1
- package/dist/src/index.d.ts +10 -3
- package/dist/src/index.js +13 -5
- package/dist/src/index.js.map +1 -1
- package/dist/src/mcp/mcpLauncher.js +1 -1
- package/dist/src/output/json-formatter.js +2 -1
- package/dist/src/output/json-formatter.js.map +1 -1
- package/dist/src/policy/config.d.ts +1 -1
- package/dist/src/policy/config.js +61 -24
- package/dist/src/policy/config.js.map +1 -1
- package/dist/src/policy/config.test.js +21 -20
- package/dist/src/policy/config.test.js.map +1 -1
- package/dist/src/policy/persistence.test.js +42 -0
- package/dist/src/policy/persistence.test.js.map +1 -1
- package/dist/src/policy/policies/discovered.toml +7 -0
- package/dist/src/policy/policies/memory-manager.toml +11 -1
- package/dist/src/policy/policies/non-interactive.toml +7 -0
- package/dist/src/policy/policies/plan.toml +36 -2
- package/dist/src/policy/policies/read-only.toml +12 -0
- package/dist/src/policy/policies/sandbox-default.toml +4 -4
- package/dist/src/policy/policies/write.toml +21 -0
- package/dist/src/policy/policies/yolo.toml +1 -1
- package/dist/src/policy/policy-engine.d.ts +2 -4
- package/dist/src/policy/policy-engine.js +47 -37
- package/dist/src/policy/policy-engine.js.map +1 -1
- package/dist/src/policy/policy-engine.test.js +236 -30
- package/dist/src/policy/policy-engine.test.js.map +1 -1
- package/dist/src/policy/sandboxPolicyManager.d.ts +26 -1
- package/dist/src/policy/sandboxPolicyManager.js +41 -12
- package/dist/src/policy/sandboxPolicyManager.js.map +1 -1
- package/dist/src/policy/sandboxPolicyManager.test.d.ts +6 -0
- package/dist/src/policy/sandboxPolicyManager.test.js +61 -0
- package/dist/src/policy/sandboxPolicyManager.test.js.map +1 -0
- package/dist/src/policy/topic-policy.test.d.ts +6 -0
- package/dist/src/policy/topic-policy.test.js +48 -0
- package/dist/src/policy/topic-policy.test.js.map +1 -0
- package/dist/src/policy/types.d.ts +9 -6
- package/dist/src/policy/types.js +11 -0
- package/dist/src/policy/types.js.map +1 -1
- package/dist/src/policy/workspace-policy.test.js +18 -15
- package/dist/src/policy/workspace-policy.test.js.map +1 -1
- package/dist/src/prompts/promptProvider.js +20 -4
- package/dist/src/prompts/promptProvider.js.map +1 -1
- package/dist/src/prompts/promptProvider.test.js +84 -1
- package/dist/src/prompts/promptProvider.test.js.map +1 -1
- package/dist/src/prompts/snippets-memory-manager.test.js +1 -1
- package/dist/src/prompts/snippets-memory-manager.test.js.map +1 -1
- package/dist/src/prompts/snippets.d.ts +3 -4
- package/dist/src/prompts/snippets.js +37 -52
- package/dist/src/prompts/snippets.js.map +1 -1
- package/dist/src/prompts/snippets.legacy.d.ts +6 -4
- package/dist/src/prompts/snippets.legacy.js +36 -7
- package/dist/src/prompts/snippets.legacy.js.map +1 -1
- package/dist/src/prompts/utils.test.js +7 -5
- package/dist/src/prompts/utils.test.js.map +1 -1
- package/dist/src/safety/built-in.js +1 -1
- package/dist/src/safety/built-in.js.map +1 -1
- package/dist/src/sandbox/linux/LinuxSandboxManager.d.ts +11 -1
- package/dist/src/sandbox/linux/LinuxSandboxManager.js +131 -41
- package/dist/src/sandbox/linux/LinuxSandboxManager.js.map +1 -1
- package/dist/src/sandbox/linux/LinuxSandboxManager.test.js +82 -139
- package/dist/src/sandbox/linux/LinuxSandboxManager.test.js.map +1 -1
- package/dist/src/sandbox/linux/bwrapArgsBuilder.d.ts +24 -0
- package/dist/src/sandbox/linux/bwrapArgsBuilder.js +200 -0
- package/dist/src/sandbox/linux/bwrapArgsBuilder.js.map +1 -0
- package/dist/src/sandbox/linux/bwrapArgsBuilder.test.d.ts +6 -0
- package/dist/src/sandbox/linux/bwrapArgsBuilder.test.js +247 -0
- package/dist/src/sandbox/linux/bwrapArgsBuilder.test.js.map +1 -0
- package/dist/src/sandbox/macos/MacOsSandboxManager.d.ts +10 -22
- package/dist/src/sandbox/macos/MacOsSandboxManager.js +67 -59
- package/dist/src/sandbox/macos/MacOsSandboxManager.js.map +1 -1
- package/dist/src/sandbox/macos/MacOsSandboxManager.test.js +168 -103
- package/dist/src/sandbox/macos/MacOsSandboxManager.test.js.map +1 -1
- package/dist/src/sandbox/macos/baseProfile.d.ts +1 -1
- package/dist/src/sandbox/macos/baseProfile.js +26 -8
- package/dist/src/sandbox/macos/baseProfile.js.map +1 -1
- package/dist/src/sandbox/macos/seatbeltArgsBuilder.d.ts +10 -10
- package/dist/src/sandbox/macos/seatbeltArgsBuilder.js +81 -93
- package/dist/src/sandbox/macos/seatbeltArgsBuilder.js.map +1 -1
- package/dist/src/sandbox/macos/seatbeltArgsBuilder.test.js +136 -99
- package/dist/src/sandbox/macos/seatbeltArgsBuilder.test.js.map +1 -1
- package/dist/src/sandbox/{macos → utils}/commandSafety.d.ts +11 -0
- package/dist/src/sandbox/{macos → utils}/commandSafety.js +47 -14
- package/dist/src/sandbox/utils/commandSafety.js.map +1 -0
- package/dist/src/sandbox/utils/commandUtils.d.ts +9 -0
- package/dist/src/sandbox/utils/commandUtils.js +57 -0
- package/dist/src/sandbox/utils/commandUtils.js.map +1 -0
- package/dist/src/sandbox/utils/fsUtils.d.ts +11 -0
- package/dist/src/sandbox/utils/fsUtils.js +84 -0
- package/dist/src/sandbox/utils/fsUtils.js.map +1 -0
- package/dist/src/sandbox/utils/fsUtils.test.d.ts +6 -0
- package/dist/src/sandbox/utils/fsUtils.test.js +43 -0
- package/dist/src/sandbox/utils/fsUtils.test.js.map +1 -0
- package/dist/src/sandbox/utils/proactivePermissions.d.ts +19 -0
- package/dist/src/sandbox/utils/proactivePermissions.js +163 -0
- package/dist/src/sandbox/utils/proactivePermissions.js.map +1 -0
- package/dist/src/sandbox/utils/proactivePermissions.test.d.ts +6 -0
- package/dist/src/sandbox/utils/proactivePermissions.test.js +145 -0
- package/dist/src/sandbox/utils/proactivePermissions.test.js.map +1 -0
- package/dist/src/sandbox/utils/sandboxDenialUtils.d.ts +27 -0
- package/dist/src/sandbox/utils/sandboxDenialUtils.js +142 -0
- package/dist/src/sandbox/utils/sandboxDenialUtils.js.map +1 -0
- package/dist/src/sandbox/utils/sandboxDenialUtils.test.d.ts +6 -0
- package/dist/src/sandbox/utils/sandboxDenialUtils.test.js +188 -0
- package/dist/src/sandbox/utils/sandboxDenialUtils.test.js.map +1 -0
- package/dist/src/sandbox/utils/sandboxReadWriteUtils.d.ts +5 -0
- package/dist/src/sandbox/utils/sandboxReadWriteUtils.js +64 -0
- package/dist/src/sandbox/utils/sandboxReadWriteUtils.js.map +1 -0
- package/dist/src/sandbox/windows/GeminiSandbox.cs +312 -223
- package/dist/src/sandbox/windows/WindowsSandboxManager.d.ts +16 -2
- package/dist/src/sandbox/windows/WindowsSandboxManager.js +261 -44
- package/dist/src/sandbox/windows/WindowsSandboxManager.js.map +1 -1
- package/dist/src/sandbox/windows/WindowsSandboxManager.test.js +379 -17
- package/dist/src/sandbox/windows/WindowsSandboxManager.test.js.map +1 -1
- package/dist/src/sandbox/windows/commandSafety.d.ts +19 -0
- package/dist/src/sandbox/windows/commandSafety.js +128 -0
- package/dist/src/sandbox/windows/commandSafety.js.map +1 -0
- package/dist/src/sandbox/windows/commandSafety.test.d.ts +6 -0
- package/dist/src/sandbox/windows/commandSafety.test.js +42 -0
- package/dist/src/sandbox/windows/commandSafety.test.js.map +1 -0
- package/dist/src/sandbox/windows/windowsSandboxDenialUtils.d.ts +13 -0
- package/dist/src/sandbox/windows/windowsSandboxDenialUtils.js +69 -0
- package/dist/src/sandbox/windows/windowsSandboxDenialUtils.js.map +1 -0
- package/dist/src/sandbox/windows/windowsSandboxDenialUtils.test.d.ts +6 -0
- package/dist/src/sandbox/windows/windowsSandboxDenialUtils.test.js +68 -0
- package/dist/src/sandbox/windows/windowsSandboxDenialUtils.test.js.map +1 -0
- package/dist/src/scheduler/policy.js +20 -5
- package/dist/src/scheduler/policy.js.map +1 -1
- package/dist/src/scheduler/policy.test.js +80 -0
- package/dist/src/scheduler/policy.test.js.map +1 -1
- package/dist/src/scheduler/scheduler.js +13 -3
- package/dist/src/scheduler/scheduler.js.map +1 -1
- package/dist/src/scheduler/scheduler.test.js +52 -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/state-manager.js +1 -1
- package/dist/src/scheduler/state-manager.js.map +1 -1
- package/dist/src/scheduler/state-manager.test.js +10 -0
- package/dist/src/scheduler/state-manager.test.js.map +1 -1
- package/dist/src/scheduler/tool-executor.js +7 -2
- package/dist/src/scheduler/tool-executor.js.map +1 -1
- package/dist/src/scheduler/tool-executor.test.js +38 -0
- package/dist/src/scheduler/tool-executor.test.js.map +1 -1
- package/dist/src/scheduler/types.d.ts +4 -2
- package/dist/src/services/chatRecordingService.d.ts +1 -13
- package/dist/src/services/chatRecordingService.js +45 -46
- package/dist/src/services/chatRecordingService.js.map +1 -1
- package/dist/src/services/chatRecordingService.test.js +79 -10
- package/dist/src/services/chatRecordingService.test.js.map +1 -1
- package/dist/src/services/executionLifecycleService.d.ts +44 -6
- package/dist/src/services/executionLifecycleService.js +52 -12
- package/dist/src/services/executionLifecycleService.js.map +1 -1
- package/dist/src/services/executionLifecycleService.test.js +157 -3
- package/dist/src/services/executionLifecycleService.test.js.map +1 -1
- package/dist/src/services/fileDiscoveryService.d.ts +17 -2
- package/dist/src/services/fileDiscoveryService.js +84 -20
- package/dist/src/services/fileDiscoveryService.js.map +1 -1
- package/dist/src/services/fileDiscoveryService.test.js +67 -1
- package/dist/src/services/fileDiscoveryService.test.js.map +1 -1
- package/dist/src/services/gitService.js +1 -1
- package/dist/src/services/gitService.js.map +1 -1
- package/dist/src/services/memoryService.d.ts +65 -0
- package/dist/src/services/memoryService.js +511 -0
- package/dist/src/services/memoryService.js.map +1 -0
- package/dist/src/services/memoryService.test.d.ts +6 -0
- package/dist/src/services/memoryService.test.js +563 -0
- package/dist/src/services/memoryService.test.js.map +1 -0
- package/dist/src/services/modelConfigService.d.ts +11 -0
- package/dist/src/services/modelConfigService.js +67 -0
- package/dist/src/services/modelConfigService.js.map +1 -1
- package/dist/src/services/modelConfigService.test.js +30 -0
- package/dist/src/services/modelConfigService.test.js.map +1 -1
- package/dist/src/services/sandboxManager.d.ts +107 -8
- package/dist/src/services/sandboxManager.integration.test.d.ts +1 -0
- package/dist/src/services/sandboxManager.integration.test.js +445 -0
- package/dist/src/services/sandboxManager.integration.test.js.map +1 -0
- package/dist/src/services/sandboxManager.js +176 -13
- package/dist/src/services/sandboxManager.js.map +1 -1
- package/dist/src/services/sandboxManager.test.js +401 -117
- package/dist/src/services/sandboxManager.test.js.map +1 -1
- package/dist/src/services/sandboxManagerFactory.d.ts +2 -3
- package/dist/src/services/sandboxManagerFactory.js +12 -22
- package/dist/src/services/sandboxManagerFactory.js.map +1 -1
- package/dist/src/services/sandboxedFileSystemService.d.ts +1 -0
- package/dist/src/services/sandboxedFileSystemService.js +43 -3
- package/dist/src/services/sandboxedFileSystemService.js.map +1 -1
- package/dist/src/services/sandboxedFileSystemService.test.js +97 -11
- package/dist/src/services/sandboxedFileSystemService.test.js.map +1 -1
- package/dist/src/services/shellExecutionService.d.ts +18 -1
- package/dist/src/services/shellExecutionService.js +115 -26
- package/dist/src/services/shellExecutionService.js.map +1 -1
- package/dist/src/services/shellExecutionService.test.js +70 -8
- package/dist/src/services/shellExecutionService.test.js.map +1 -1
- package/dist/src/services/test-data/resolved-aliases-retry.golden.json +4 -0
- package/dist/src/services/test-data/resolved-aliases.golden.json +4 -0
- package/dist/src/services/worktreeService.test.js +7 -7
- package/dist/src/services/worktreeService.test.js.map +1 -1
- package/dist/src/skills/skillLoader.d.ts +8 -0
- package/dist/src/skills/skillLoader.js +1 -1
- package/dist/src/skills/skillLoader.js.map +1 -1
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.d.ts +29 -1
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.js +107 -0
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.js.map +1 -1
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +172 -1
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +1 -1
- package/dist/src/telemetry/clearcut-logger/event-metadata-key.d.ts +10 -1
- package/dist/src/telemetry/clearcut-logger/event-metadata-key.js +22 -1
- package/dist/src/telemetry/clearcut-logger/event-metadata-key.js.map +1 -1
- package/dist/src/telemetry/loggers.d.ts +22 -0
- package/dist/src/telemetry/loggers.js +41 -2
- package/dist/src/telemetry/loggers.js.map +1 -1
- package/dist/src/telemetry/loggers.test.js +8 -3
- package/dist/src/telemetry/loggers.test.js.map +1 -1
- package/dist/src/telemetry/metrics.d.ts +118 -1
- package/dist/src/telemetry/metrics.js +196 -4
- package/dist/src/telemetry/metrics.js.map +1 -1
- package/dist/src/telemetry/metrics.test.js +298 -0
- package/dist/src/telemetry/metrics.test.js.map +1 -1
- package/dist/src/telemetry/types.d.ts +3 -3
- package/dist/src/telemetry/types.js +9 -4
- package/dist/src/telemetry/types.js.map +1 -1
- package/dist/src/test-utils/mock-message-bus.d.ts +1 -1
- package/dist/src/test-utils/mock-message-bus.js +1 -1
- package/dist/src/test-utils/mock-message-bus.js.map +1 -1
- package/dist/src/tools/complete-task.d.ts +29 -0
- package/dist/src/tools/complete-task.js +123 -0
- package/dist/src/tools/complete-task.js.map +1 -0
- package/dist/src/tools/complete-task.test.d.ts +6 -0
- package/dist/src/tools/complete-task.test.js +114 -0
- package/dist/src/tools/complete-task.test.js.map +1 -0
- package/dist/src/tools/definitions/base-declarations.d.ts +8 -0
- package/dist/src/tools/definitions/base-declarations.js +10 -0
- package/dist/src/tools/definitions/base-declarations.js.map +1 -1
- package/dist/src/tools/definitions/coreTools.d.ts +2 -1
- package/dist/src/tools/definitions/coreTools.js +9 -3
- package/dist/src/tools/definitions/coreTools.js.map +1 -1
- package/dist/src/tools/definitions/dynamic-declaration-helpers.d.ts +4 -0
- package/dist/src/tools/definitions/dynamic-declaration-helpers.js +33 -2
- package/dist/src/tools/definitions/dynamic-declaration-helpers.js.map +1 -1
- package/dist/src/tools/definitions/model-family-sets/default-legacy.js +14 -9
- 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 +13 -7
- package/dist/src/tools/definitions/model-family-sets/gemini-3.js.map +1 -1
- package/dist/src/tools/definitions/trackerTools.js +3 -3
- package/dist/src/tools/definitions/trackerTools.js.map +1 -1
- package/dist/src/tools/definitions/types.d.ts +1 -0
- package/dist/src/tools/enter-plan-mode.js +15 -0
- package/dist/src/tools/enter-plan-mode.js.map +1 -1
- package/dist/src/tools/enter-plan-mode.test.js +25 -0
- package/dist/src/tools/enter-plan-mode.test.js.map +1 -1
- package/dist/src/tools/grep-utils.d.ts +2 -1
- package/dist/src/tools/grep-utils.js +22 -3
- package/dist/src/tools/grep-utils.js.map +1 -1
- package/dist/src/tools/grep.js +16 -3
- package/dist/src/tools/grep.js.map +1 -1
- package/dist/src/tools/grep.test.js +36 -8
- package/dist/src/tools/grep.test.js.map +1 -1
- package/dist/src/tools/jit-context.js +3 -3
- package/dist/src/tools/jit-context.js.map +1 -1
- package/dist/src/tools/jit-context.test.js +15 -13
- package/dist/src/tools/jit-context.test.js.map +1 -1
- package/dist/src/tools/ls.js +6 -4
- package/dist/src/tools/ls.js.map +1 -1
- package/dist/src/tools/ls.test.js +22 -7
- package/dist/src/tools/ls.test.js.map +1 -1
- package/dist/src/tools/mcp-client-manager.js +6 -3
- package/dist/src/tools/mcp-client-manager.js.map +1 -1
- package/dist/src/tools/mcp-client-manager.test.js +35 -0
- package/dist/src/tools/mcp-client-manager.test.js.map +1 -1
- package/dist/src/tools/mcp-client.js +1 -1
- package/dist/src/tools/mcp-client.js.map +1 -1
- package/dist/src/tools/mcp-tool.test.js +1 -1
- package/dist/src/tools/mcp-tool.test.js.map +1 -1
- package/dist/src/tools/memoryTool.d.ts +9 -2
- package/dist/src/tools/memoryTool.js +39 -15
- package/dist/src/tools/memoryTool.js.map +1 -1
- package/dist/src/tools/memoryTool.test.js +61 -2
- package/dist/src/tools/memoryTool.test.js.map +1 -1
- package/dist/src/tools/read-many-files.js +12 -4
- package/dist/src/tools/read-many-files.js.map +1 -1
- package/dist/src/tools/read-many-files.test.js +17 -17
- package/dist/src/tools/read-many-files.test.js.map +1 -1
- package/dist/src/tools/ripGrep.js +14 -1
- package/dist/src/tools/ripGrep.js.map +1 -1
- package/dist/src/tools/ripGrep.test.js +10 -10
- package/dist/src/tools/ripGrep.test.js.map +1 -1
- package/dist/src/tools/shell.d.ts +17 -4
- package/dist/src/tools/shell.js +342 -151
- package/dist/src/tools/shell.js.map +1 -1
- package/dist/src/tools/shell.test.js +204 -11
- package/dist/src/tools/shell.test.js.map +1 -1
- package/dist/src/tools/shellBackgroundTools.d.ts +38 -0
- package/dist/src/tools/shellBackgroundTools.integration.test.d.ts +6 -0
- package/dist/src/tools/shellBackgroundTools.integration.test.js +86 -0
- package/dist/src/tools/shellBackgroundTools.integration.test.js.map +1 -0
- package/dist/src/tools/shellBackgroundTools.js +186 -0
- package/dist/src/tools/shellBackgroundTools.js.map +1 -0
- package/dist/src/tools/shellBackgroundTools.test.d.ts +6 -0
- package/dist/src/tools/shellBackgroundTools.test.js +230 -0
- package/dist/src/tools/shellBackgroundTools.test.js.map +1 -0
- package/dist/src/tools/shell_proactive.test.d.ts +6 -0
- package/dist/src/tools/shell_proactive.test.js +122 -0
- package/dist/src/tools/shell_proactive.test.js.map +1 -0
- package/dist/src/tools/tool-names.d.ts +4 -4
- package/dist/src/tools/tool-names.js +6 -3
- package/dist/src/tools/tool-names.js.map +1 -1
- package/dist/src/tools/tool-registry.js +11 -1
- package/dist/src/tools/tool-registry.js.map +1 -1
- package/dist/src/tools/tool-registry.test.js +43 -1
- package/dist/src/tools/tool-registry.test.js.map +1 -1
- package/dist/src/tools/tools.d.ts +12 -1
- package/dist/src/tools/tools.js +16 -1
- package/dist/src/tools/tools.js.map +1 -1
- package/dist/src/tools/tools.test.js +42 -1
- package/dist/src/tools/tools.test.js.map +1 -1
- package/dist/src/tools/topicTool.d.ts +29 -0
- package/dist/src/tools/topicTool.js +72 -0
- package/dist/src/tools/topicTool.js.map +1 -0
- package/dist/src/tools/topicTool.test.d.ts +6 -0
- package/dist/src/tools/topicTool.test.js +105 -0
- package/dist/src/tools/topicTool.test.js.map +1 -0
- package/dist/src/tools/web-fetch.js +40 -22
- package/dist/src/tools/web-fetch.js.map +1 -1
- package/dist/src/tools/web-fetch.test.js +28 -0
- package/dist/src/tools/web-fetch.test.js.map +1 -1
- package/dist/src/tools/xcode-mcp-fix-transport.js +1 -1
- package/dist/src/tools/xcode-mcp-fix-transport.js.map +1 -1
- package/dist/src/utils/bfsFileSearch.js +3 -6
- package/dist/src/utils/bfsFileSearch.js.map +1 -1
- package/dist/src/utils/checkpointUtils.d.ts +4 -4
- package/dist/src/utils/checkpointUtils.js +11 -8
- package/dist/src/utils/checkpointUtils.js.map +1 -1
- package/dist/src/utils/compatibility.js +0 -7
- package/dist/src/utils/compatibility.js.map +1 -1
- package/dist/src/utils/compatibility.test.js +0 -9
- package/dist/src/utils/compatibility.test.js.map +1 -1
- package/dist/src/utils/editor.js +3 -0
- package/dist/src/utils/editor.js.map +1 -1
- package/dist/src/utils/errorParsing.js +2 -2
- package/dist/src/utils/errorParsing.js.map +1 -1
- package/dist/src/utils/errors.d.ts +3 -0
- package/dist/src/utils/errors.js +28 -6
- package/dist/src/utils/errors.js.map +1 -1
- package/dist/src/utils/errors.test.js +23 -0
- package/dist/src/utils/errors.test.js.map +1 -1
- package/dist/src/utils/events.d.ts +12 -0
- package/dist/src/utils/events.js +7 -0
- package/dist/src/utils/events.js.map +1 -1
- package/dist/src/utils/fetch.d.ts +1 -0
- package/dist/src/utils/fetch.js +22 -6
- package/dist/src/utils/fetch.js.map +1 -1
- package/dist/src/utils/fetch.test.js +26 -1
- package/dist/src/utils/fetch.test.js.map +1 -1
- package/dist/src/utils/fileUtils.js +1 -1
- package/dist/src/utils/fileUtils.js.map +1 -1
- package/dist/src/utils/filesearch/crawler.js +1 -1
- package/dist/src/utils/filesearch/crawler.js.map +1 -1
- package/dist/src/utils/filesearch/fileSearch.test.js +7 -2
- package/dist/src/utils/filesearch/fileSearch.test.js.map +1 -1
- package/dist/src/utils/getFolderStructure.js +1 -1
- package/dist/src/utils/getFolderStructure.js.map +1 -1
- package/dist/src/utils/getPty.js +2 -2
- package/dist/src/utils/getPty.js.map +1 -1
- package/dist/src/utils/gitIgnoreParser.d.ts +2 -2
- package/dist/src/utils/gitIgnoreParser.js +30 -52
- package/dist/src/utils/gitIgnoreParser.js.map +1 -1
- package/dist/src/utils/gitIgnoreParser.test.js +51 -185
- package/dist/src/utils/gitIgnoreParser.test.js.map +1 -1
- package/dist/src/utils/gitUtils.js +2 -2
- package/dist/src/utils/gitUtils.js.map +1 -1
- package/dist/src/utils/googleErrors.js +5 -5
- package/dist/src/utils/googleErrors.js.map +1 -1
- package/dist/src/utils/ignoreFileParser.d.ts +2 -2
- package/dist/src/utils/ignoreFileParser.js +7 -18
- package/dist/src/utils/ignoreFileParser.js.map +1 -1
- package/dist/src/utils/ignoreFileParser.test.js +40 -132
- package/dist/src/utils/ignoreFileParser.test.js.map +1 -1
- package/dist/src/utils/ignorePathUtils.d.ts +11 -0
- package/dist/src/utils/ignorePathUtils.js +39 -0
- package/dist/src/utils/ignorePathUtils.js.map +1 -0
- package/dist/src/utils/ignorePathUtils.test.d.ts +6 -0
- package/dist/src/utils/ignorePathUtils.test.js +70 -0
- package/dist/src/utils/ignorePathUtils.test.js.map +1 -0
- package/dist/src/utils/memoryDiscovery.d.ts +6 -4
- package/dist/src/utils/memoryDiscovery.js +69 -48
- package/dist/src/utils/memoryDiscovery.js.map +1 -1
- package/dist/src/utils/memoryDiscovery.test.js +40 -0
- package/dist/src/utils/memoryDiscovery.test.js.map +1 -1
- package/dist/src/utils/memoryImportProcessor.d.ts +1 -1
- package/dist/src/utils/memoryImportProcessor.js +24 -15
- package/dist/src/utils/memoryImportProcessor.js.map +1 -1
- package/dist/src/utils/paths.d.ts +8 -0
- package/dist/src/utils/paths.js +37 -6
- package/dist/src/utils/paths.js.map +1 -1
- package/dist/src/utils/paths.test.js +61 -3
- package/dist/src/utils/paths.test.js.map +1 -1
- package/dist/src/utils/process-utils.js +2 -2
- package/dist/src/utils/process-utils.js.map +1 -1
- package/dist/src/utils/retry.js +7 -0
- package/dist/src/utils/retry.js.map +1 -1
- package/dist/src/utils/retry.test.js +41 -0
- package/dist/src/utils/retry.test.js.map +1 -1
- package/dist/src/utils/secure-browser-launcher.js +1 -1
- package/dist/src/utils/secure-browser-launcher.js.map +1 -1
- package/dist/src/utils/sessionOperations.d.ts +19 -0
- package/dist/src/utils/sessionOperations.js +101 -0
- package/dist/src/utils/sessionOperations.js.map +1 -0
- package/dist/src/utils/sessionOperations.test.d.ts +6 -0
- package/dist/src/utils/sessionOperations.test.js +92 -0
- package/dist/src/utils/sessionOperations.test.js.map +1 -0
- package/dist/src/utils/shell-utils.d.ts +24 -0
- package/dist/src/utils/shell-utils.integration.test.js +1 -1
- package/dist/src/utils/shell-utils.integration.test.js.map +1 -1
- package/dist/src/utils/shell-utils.js +86 -6
- package/dist/src/utils/shell-utils.js.map +1 -1
- package/dist/src/utils/shell-utils.test.js +13 -1
- package/dist/src/utils/shell-utils.test.js.map +1 -1
- package/dist/src/utils/systemEncoding.js +1 -1
- package/dist/src/utils/systemEncoding.js.map +1 -1
- package/dist/src/utils/terminalSerializer.d.ts +1 -0
- package/dist/src/utils/terminalSerializer.js +31 -8
- package/dist/src/utils/terminalSerializer.js.map +1 -1
- package/dist/src/utils/terminalSerializer.test.js +3 -2
- package/dist/src/utils/terminalSerializer.test.js.map +1 -1
- package/dist/src/utils/textUtils.d.ts +8 -0
- package/dist/src/utils/textUtils.js +16 -0
- package/dist/src/utils/textUtils.js.map +1 -1
- package/dist/src/utils/tokenCalculation.d.ts +2 -0
- package/dist/src/utils/tokenCalculation.js +2 -2
- package/dist/src/utils/tokenCalculation.js.map +1 -1
- package/dist/src/utils/workspaceContext.js +2 -2
- package/dist/src/utils/workspaceContext.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +2 -1
- package/dist/docs/CONTRIBUTING.md +0 -566
- package/dist/docs/get-started/examples.md +0 -141
- package/dist/src/sandbox/macos/MacOsSandboxManager.integration.test.js +0 -164
- package/dist/src/sandbox/macos/MacOsSandboxManager.integration.test.js.map +0 -1
- package/dist/src/sandbox/macos/commandSafety.js.map +0 -1
- package/dist/src/services/chatCompressionService.js.map +0 -1
- package/dist/src/services/chatCompressionService.test.js.map +0 -1
- package/dist/src/services/contextManager.js.map +0 -1
- package/dist/src/services/contextManager.test.js.map +0 -1
- package/dist/src/services/toolOutputMaskingService.js.map +0 -1
- package/dist/src/services/toolOutputMaskingService.test.js.map +0 -1
- /package/dist/src/{services/toolOutputMaskingService.test.d.ts → agents/browser/snapshotSuperseder.test.d.ts} +0 -0
- /package/dist/src/{services → context}/chatCompressionService.d.ts +0 -0
- /package/dist/src/{services → context}/chatCompressionService.js +0 -0
- /package/dist/src/{services → context}/chatCompressionService.test.d.ts +0 -0
- /package/dist/src/{services → context}/chatCompressionService.test.js +0 -0
- /package/dist/src/{sandbox/macos/MacOsSandboxManager.integration.test.d.ts → context/contextCompressionService.test.d.ts} +0 -0
- /package/dist/src/{services/contextManager.test.d.ts → context/memoryContextManager.test.d.ts} +0 -0
|
@@ -1,23 +1,10 @@
|
|
|
1
|
-
# Subagents
|
|
1
|
+
# Subagents
|
|
2
2
|
|
|
3
3
|
Subagents are specialized agents that operate within your main Cell CLI session.
|
|
4
4
|
They are designed to handle specific, complex tasks—like deep codebase analysis,
|
|
5
5
|
documentation lookup, or domain-specific reasoning—without cluttering the main
|
|
6
6
|
agent's context or toolset.
|
|
7
7
|
|
|
8
|
-
<!-- prettier-ignore -->
|
|
9
|
-
> [!NOTE]
|
|
10
|
-
> Subagents are currently an experimental feature.
|
|
11
|
-
>
|
|
12
|
-
To use custom subagents, you must ensure they are enabled in your
|
|
13
|
-
`settings.json` (enabled by default):
|
|
14
|
-
|
|
15
|
-
```json
|
|
16
|
-
{
|
|
17
|
-
"experimental": { "enableAgents": true }
|
|
18
|
-
}
|
|
19
|
-
```
|
|
20
|
-
|
|
21
8
|
## What are subagents?
|
|
22
9
|
|
|
23
10
|
Subagents are "specialists" that the main Gemini agent can hire for a specific
|
|
@@ -125,10 +112,12 @@ Cell CLI comes with the following built-in subagents:
|
|
|
125
112
|
|
|
126
113
|
The browser agent requires:
|
|
127
114
|
|
|
128
|
-
- **Chrome** version 144 or later (any recent stable release
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
115
|
+
- **Chrome** version 144 or later (any recent stable release works).
|
|
116
|
+
|
|
117
|
+
The underlying
|
|
118
|
+
[`chrome-devtools-mcp`](https://www.npmjs.com/package/chrome-devtools-mcp)
|
|
119
|
+
server is bundled with Cell CLI and launched automatically — no separate
|
|
120
|
+
installation is needed.
|
|
132
121
|
|
|
133
122
|
#### Enabling the browser agent
|
|
134
123
|
|
|
@@ -174,26 +163,58 @@ The available modes are:
|
|
|
174
163
|
| `isolated` | Launches Chrome with a temporary profile that is deleted after each session. Use this for clean-state automation. |
|
|
175
164
|
| `existing` | Attaches to an already-running Chrome instance. You must enable remote debugging first by navigating to `chrome://inspect/#remote-debugging` in Chrome. No new browser process is launched. |
|
|
176
165
|
|
|
166
|
+
#### First-run consent
|
|
167
|
+
|
|
168
|
+
The first time the browser agent is invoked, Cell CLI displays a consent dialog.
|
|
169
|
+
You must accept before the browser session starts. This dialog only appears
|
|
170
|
+
once.
|
|
171
|
+
|
|
177
172
|
#### Configuration reference
|
|
178
173
|
|
|
179
174
|
All browser-specific settings go under `agents.browser` in your `settings.json`.
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
|
184
|
-
|
|
|
185
|
-
| `
|
|
186
|
-
| `
|
|
175
|
+
For full details, see the
|
|
176
|
+
[`agents.browser` configuration reference](../reference/configuration.md#agents).
|
|
177
|
+
|
|
178
|
+
| Setting | Type | Default | Description |
|
|
179
|
+
| :------------------------ | :--------- | :------------- | :------------------------------------------------------------------------------ |
|
|
180
|
+
| `sessionMode` | `string` | `"persistent"` | How Chrome is managed: `"persistent"`, `"isolated"`, or `"existing"`. |
|
|
181
|
+
| `headless` | `boolean` | `false` | Run Chrome in headless mode (no visible window). |
|
|
182
|
+
| `profilePath` | `string` | — | Custom path to a browser profile directory. |
|
|
183
|
+
| `visualModel` | `string` | — | Model override for the visual agent. |
|
|
184
|
+
| `allowedDomains` | `string[]` | — | Restrict navigation to specific domains (for example, `["github.com"]`). |
|
|
185
|
+
| `disableUserInput` | `boolean` | `true` | Disable user input on the browser window during automation (non-headless only). |
|
|
186
|
+
| `maxActionsPerTask` | `number` | `100` | Maximum tool calls per task. The agent is terminated when the limit is reached. |
|
|
187
|
+
| `confirmSensitiveActions` | `boolean` | `false` | Require manual confirmation for `upload_file` and `evaluate_script`. |
|
|
188
|
+
| `blockFileUploads` | `boolean` | `false` | Hard-block all file upload requests from the agent. |
|
|
189
|
+
|
|
190
|
+
#### Automation overlay and input blocking
|
|
191
|
+
|
|
192
|
+
In non-headless mode, the browser agent injects a visual overlay into the
|
|
193
|
+
browser window to indicate that automation is in progress. By default, user
|
|
194
|
+
input (keyboard and mouse) is also blocked to prevent accidental interference.
|
|
195
|
+
You can disable this by setting `disableUserInput` to `false`.
|
|
187
196
|
|
|
188
197
|
#### Security
|
|
189
198
|
|
|
190
|
-
The browser agent enforces
|
|
191
|
-
|
|
192
|
-
- **
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
199
|
+
The browser agent enforces several layers of security:
|
|
200
|
+
|
|
201
|
+
- **Domain restrictions:** When `allowedDomains` is set, the agent can only
|
|
202
|
+
navigate to the listed domains (and their subdomains when using `*.` prefix).
|
|
203
|
+
Attempting to visit a disallowed domain throws a fatal error that immediately
|
|
204
|
+
terminates the agent. The agent also attempts to detect and block the use of
|
|
205
|
+
allowed domains as proxies (e.g., via query parameters or fragments) to access
|
|
206
|
+
restricted content.
|
|
207
|
+
- **Blocked URL patterns:** The underlying MCP server blocks dangerous URL
|
|
208
|
+
schemes including `file://`, `javascript:`, `data:text/html`,
|
|
209
|
+
`chrome://extensions`, and `chrome://settings/passwords`.
|
|
210
|
+
- **Sensitive action confirmation:** Form filling (`fill`, `fill_form`) always
|
|
211
|
+
requires user confirmation through the policy engine, regardless of approval
|
|
212
|
+
mode. When `confirmSensitiveActions` is `true`, `upload_file` and
|
|
213
|
+
`evaluate_script` also require confirmation.
|
|
214
|
+
- **File upload blocking:** Set `blockFileUploads` to `true` to hard-block all
|
|
215
|
+
file upload requests, preventing the agent from uploading any files.
|
|
216
|
+
- **Action rate limiting:** The `maxActionsPerTask` setting (default: 100)
|
|
217
|
+
limits the total number of tool calls per task to prevent runaway execution.
|
|
197
218
|
|
|
198
219
|
#### Visual agent
|
|
199
220
|
|
|
@@ -227,19 +248,65 @@ the `click_at` tool for precise, coordinate-based interactions.
|
|
|
227
248
|
> The visual agent requires API key or Vertex AI authentication. It is
|
|
228
249
|
> not available when using "Sign in with Google".
|
|
229
250
|
|
|
251
|
+
#### Sandbox support
|
|
252
|
+
|
|
253
|
+
The browser agent adjusts its behavior automatically when running inside a
|
|
254
|
+
sandbox.
|
|
255
|
+
|
|
256
|
+
##### macOS seatbelt (`sandbox-exec`)
|
|
257
|
+
|
|
258
|
+
When the CLI runs under the macOS seatbelt sandbox, `persistent` and `isolated`
|
|
259
|
+
session modes are forced to `isolated` with `headless` enabled. This avoids
|
|
260
|
+
permission errors caused by seatbelt file-system restrictions on persistent
|
|
261
|
+
browser profiles. If `sessionMode` is set to `existing`, no override is applied.
|
|
262
|
+
|
|
263
|
+
##### Container sandboxes (Docker / Podman)
|
|
264
|
+
|
|
265
|
+
Chrome is not available inside the container, so the browser agent is
|
|
266
|
+
**disabled** unless `sessionMode` is set to `"existing"`. When enabled with
|
|
267
|
+
`existing` mode, the agent automatically connects to Chrome on the host via the
|
|
268
|
+
resolved IP of `host.docker.internal:9222` instead of using local pipe
|
|
269
|
+
discovery. Port `9222` is currently hardcoded and cannot be customized.
|
|
270
|
+
|
|
271
|
+
To use the browser agent in a Docker sandbox:
|
|
272
|
+
|
|
273
|
+
1. Start Chrome on the host with remote debugging enabled:
|
|
274
|
+
|
|
275
|
+
```bash
|
|
276
|
+
# Option A: Launch Chrome from the command line
|
|
277
|
+
google-chrome --remote-debugging-port=9222
|
|
278
|
+
|
|
279
|
+
# Option B: Enable in Chrome settings
|
|
280
|
+
# Navigate to chrome://inspect/#remote-debugging and enable
|
|
281
|
+
```
|
|
282
|
+
|
|
283
|
+
2. Configure `sessionMode` and allowed domains in your project's
|
|
284
|
+
`.cell-cli/settings.json`:
|
|
285
|
+
|
|
286
|
+
```json
|
|
287
|
+
{
|
|
288
|
+
"agents": {
|
|
289
|
+
"overrides": {
|
|
290
|
+
"browser_agent": { "enabled": true }
|
|
291
|
+
},
|
|
292
|
+
"browser": {
|
|
293
|
+
"sessionMode": "existing",
|
|
294
|
+
"allowedDomains": ["example.com"]
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
```
|
|
299
|
+
|
|
300
|
+
3. Launch the CLI with port forwarding:
|
|
301
|
+
|
|
302
|
+
```bash
|
|
303
|
+
GEMINI_SANDBOX=docker SANDBOX_PORTS=9222 gemini
|
|
304
|
+
```
|
|
305
|
+
|
|
230
306
|
## Creating custom subagents
|
|
231
307
|
|
|
232
308
|
You can create your own subagents to automate specific workflows or enforce
|
|
233
|
-
specific personas.
|
|
234
|
-
`settings.json`:
|
|
235
|
-
|
|
236
|
-
```json
|
|
237
|
-
{
|
|
238
|
-
"experimental": {
|
|
239
|
-
"enableAgents": true
|
|
240
|
-
}
|
|
241
|
-
}
|
|
242
|
-
```
|
|
309
|
+
specific personas.
|
|
243
310
|
|
|
244
311
|
### Agent definition files
|
|
245
312
|
|
|
@@ -291,6 +358,7 @@ it yourself; just report it.
|
|
|
291
358
|
| `description` | string | Yes | Short description of what the agent does. This is visible to the main agent to help it decide when to call this subagent. |
|
|
292
359
|
| `kind` | string | No | `local` (default) or `remote`. |
|
|
293
360
|
| `tools` | array | No | List of tool names this agent can use. Supports wildcards: `*` (all tools), `mcp_*` (all MCP tools), `mcp_server_*` (all tools from a server). **If omitted, it inherits all tools from the parent session.** |
|
|
361
|
+
| `mcpServers` | object | No | Configuration for inline Model Context Protocol (MCP) servers isolated to this specific agent. |
|
|
294
362
|
| `model` | string | No | Specific model to use (e.g., `gemini-3-preview`). Defaults to `inherit` (uses the main session model). |
|
|
295
363
|
| `temperature` | number | No | Model temperature (0.0 - 2.0). Defaults to `1`. |
|
|
296
364
|
| `max_turns` | number | No | Maximum number of conversation turns allowed for this agent before it must return. Defaults to `30`. |
|
|
@@ -318,6 +386,78 @@ Each subagent runs in its own isolated context loop. This means:
|
|
|
318
386
|
subagents **cannot** call other subagents. If a subagent is granted the `*`
|
|
319
387
|
tool wildcard, it will still be unable to see or invoke other agents.
|
|
320
388
|
|
|
389
|
+
## Subagent tool isolation
|
|
390
|
+
|
|
391
|
+
Subagent tool isolation moves Cell CLI away from a single global tool registry.
|
|
392
|
+
By providing isolated execution environments, you can ensure that subagents only
|
|
393
|
+
interact with the parts of the system they are designed for. This prevents
|
|
394
|
+
unintended side effects, improves reliability by avoiding state contamination,
|
|
395
|
+
and enables fine-grained permission control.
|
|
396
|
+
|
|
397
|
+
With this feature, you can:
|
|
398
|
+
|
|
399
|
+
- **Specify tool access:** Define exactly which tools an agent can access using
|
|
400
|
+
a `tools` list in the agent definition.
|
|
401
|
+
- **Define inline MCP servers:** Configure Model Context Protocol (MCP) servers
|
|
402
|
+
(which provide a standardized way to connect AI models to external tools and
|
|
403
|
+
data sources) directly in the subagent's markdown frontmatter, isolating them
|
|
404
|
+
to that specific agent.
|
|
405
|
+
- **Maintain state isolation:** Ensure that subagents only interact with their
|
|
406
|
+
own set of tools and servers, preventing side effects and state contamination.
|
|
407
|
+
- **Apply subagent-specific policies:** Enforce granular rules in your
|
|
408
|
+
[Policy Engine](../reference/policy-engine.md) TOML configuration based on the
|
|
409
|
+
executing subagent's name.
|
|
410
|
+
|
|
411
|
+
### Configuring isolated tools and servers
|
|
412
|
+
|
|
413
|
+
You can configure tool isolation for a subagent by updating its markdown
|
|
414
|
+
frontmatter. This allows you to explicitly state which tools the subagent can
|
|
415
|
+
use, rather than relying on the global registry.
|
|
416
|
+
|
|
417
|
+
Add an `mcpServers` object to define inline MCP servers that are unique to the
|
|
418
|
+
agent.
|
|
419
|
+
|
|
420
|
+
**Example:**
|
|
421
|
+
|
|
422
|
+
```yaml
|
|
423
|
+
---
|
|
424
|
+
name: my-isolated-agent
|
|
425
|
+
tools:
|
|
426
|
+
- grep_search
|
|
427
|
+
- read_file
|
|
428
|
+
mcpServers:
|
|
429
|
+
my-custom-server:
|
|
430
|
+
command: 'node'
|
|
431
|
+
args: ['path/to/server.js']
|
|
432
|
+
---
|
|
433
|
+
```
|
|
434
|
+
|
|
435
|
+
### Subagent-specific policies
|
|
436
|
+
|
|
437
|
+
You can enforce fine-grained control over subagents using the
|
|
438
|
+
[Policy Engine's](../reference/policy-engine.md) TOML configuration. This allows
|
|
439
|
+
you to grant or restrict permissions specifically for an agent, without
|
|
440
|
+
affecting the rest of your CLI session.
|
|
441
|
+
|
|
442
|
+
To restrict a policy rule to a specific subagent, add the `subagent` property to
|
|
443
|
+
the `[[rules]]` block in your `policy.toml` file.
|
|
444
|
+
|
|
445
|
+
**Example:**
|
|
446
|
+
|
|
447
|
+
```toml
|
|
448
|
+
[[rules]]
|
|
449
|
+
name = "Allow pr-creator to push code"
|
|
450
|
+
subagent = "pr-creator"
|
|
451
|
+
description = "Permit pr-creator to push branches automatically."
|
|
452
|
+
action = "allow"
|
|
453
|
+
toolName = "run_shell_command"
|
|
454
|
+
commandPrefix = "git push"
|
|
455
|
+
```
|
|
456
|
+
|
|
457
|
+
In this configuration, the policy rule only triggers if the executing subagent's
|
|
458
|
+
name matches `pr-creator`. Rules without the `subagent` property apply
|
|
459
|
+
universally to all agents.
|
|
460
|
+
|
|
321
461
|
## Managing subagents
|
|
322
462
|
|
|
323
463
|
You can manage subagents interactively using the `/agents` command or
|
|
@@ -407,15 +547,11 @@ If you need to further tune your subagent, you can do so by selecting the model
|
|
|
407
547
|
to optimize for with `/model` and then asking the model why it does not think
|
|
408
548
|
that your subagent was called with a specific prompt and the given description.
|
|
409
549
|
|
|
410
|
-
## Remote subagents (Agent2Agent)
|
|
550
|
+
## Remote subagents (Agent2Agent)
|
|
411
551
|
|
|
412
552
|
Cell CLI can also delegate tasks to remote subagents using the Agent-to-Agent
|
|
413
553
|
(A2A) protocol.
|
|
414
554
|
|
|
415
|
-
<!-- prettier-ignore -->
|
|
416
|
-
> [!NOTE]
|
|
417
|
-
> Remote subagents are currently an experimental feature.
|
|
418
|
-
|
|
419
555
|
See the [Remote Subagents documentation](remote-agents) for detailed
|
|
420
556
|
configuration, authentication, and usage instructions.
|
|
421
557
|
|
|
@@ -424,3 +560,14 @@ configuration, authentication, and usage instructions.
|
|
|
424
560
|
Extensions can bundle and distribute subagents. See the
|
|
425
561
|
[Extensions documentation](../extensions/index.md#subagents) for details on how
|
|
426
562
|
to package agents within an extension.
|
|
563
|
+
|
|
564
|
+
## Disabling subagents
|
|
565
|
+
|
|
566
|
+
Subagents are enabled by default. To disable them, set `enableAgents` to `false`
|
|
567
|
+
in your `settings.json`:
|
|
568
|
+
|
|
569
|
+
```json
|
|
570
|
+
{
|
|
571
|
+
"experimental": { "enableAgents": false }
|
|
572
|
+
}
|
|
573
|
+
```
|
|
@@ -398,8 +398,8 @@ on this page.
|
|
|
398
398
|
|
|
399
399
|
## Running in headless mode <a id="headless"></a>
|
|
400
400
|
|
|
401
|
-
[Headless mode](../cli/headless) will use your existing authentication
|
|
402
|
-
if an existing authentication credential is cached.
|
|
401
|
+
[Headless mode](../cli/headless.md) will use your existing authentication
|
|
402
|
+
method, if an existing authentication credential is cached.
|
|
403
403
|
|
|
404
404
|
If you have not already signed in with an authentication credential, you must
|
|
405
405
|
configure authentication using environment variables:
|
|
@@ -62,7 +62,133 @@ Once installed and authenticated, you can start using Cell CLI by issuing
|
|
|
62
62
|
commands and prompts in your terminal. Ask it to generate code, explain files,
|
|
63
63
|
and more.
|
|
64
64
|
|
|
65
|
-
|
|
65
|
+
<!-- prettier-ignore -->
|
|
66
|
+
> [!NOTE]
|
|
67
|
+
> These examples demonstrate potential capabilities. Your actual
|
|
68
|
+
> results can vary based on the model used and your project environment.
|
|
69
|
+
|
|
70
|
+
### Rename your photographs based on content
|
|
71
|
+
|
|
72
|
+
You can use Cell CLI to automate file management tasks that require visual
|
|
73
|
+
analysis. In this example, Cell CLI renames images based on their actual subject
|
|
74
|
+
matter.
|
|
75
|
+
|
|
76
|
+
Scenario: You have a folder containing the following files:
|
|
77
|
+
|
|
78
|
+
```bash
|
|
79
|
+
photos/photo1.png
|
|
80
|
+
photos/photo2.png
|
|
81
|
+
photos/photo3.png
|
|
82
|
+
```
|
|
83
|
+
|
|
84
|
+
Give Gemini the following prompt:
|
|
85
|
+
|
|
86
|
+
```cli
|
|
87
|
+
Rename the photos in my "photos" directory based on their contents.
|
|
88
|
+
```
|
|
89
|
+
|
|
90
|
+
Result: Gemini asks for permission to rename your files.
|
|
91
|
+
|
|
92
|
+
Select **Allow once** and your files are renamed:
|
|
93
|
+
|
|
94
|
+
```bash
|
|
95
|
+
photos/yellow_flowers.png
|
|
96
|
+
photos/antique_dresser.png
|
|
97
|
+
photos/green_android_robot.png
|
|
98
|
+
```
|
|
99
|
+
|
|
100
|
+
### Explain a repository by reading its code
|
|
101
|
+
|
|
102
|
+
Cell CLI is effective for rapid codebase exploration. The following example
|
|
103
|
+
shows how to ask Cell CLI to fetch, analyze, and summarize a remote project.
|
|
104
|
+
|
|
105
|
+
Scenario: You want to understand how a popular open-source utility works by
|
|
106
|
+
inspecting its code, not just its README.
|
|
107
|
+
|
|
108
|
+
Give Cell CLI the following prompt:
|
|
109
|
+
|
|
110
|
+
```cli
|
|
111
|
+
Clone the 'chalk' repository from https://github.com/chalk/chalk, read its key source files, and explain how it works.
|
|
112
|
+
```
|
|
113
|
+
|
|
114
|
+
Result: Gemini performs a sequence of actions to answer your request.
|
|
115
|
+
|
|
116
|
+
1. First, it asks for permission to run `git clone` to download the repository.
|
|
117
|
+
2. Next, it finds the important source files and asks for permission to read
|
|
118
|
+
them.
|
|
119
|
+
3. Finally, after analyzing the code, it provides a summary.
|
|
120
|
+
|
|
121
|
+
Cell CLI returns an explanation based on the actual source code:
|
|
122
|
+
|
|
123
|
+
```markdown
|
|
124
|
+
The `chalk` library is a popular npm package for styling terminal output with
|
|
125
|
+
colors. After analyzing the source code, here's how it works:
|
|
126
|
+
|
|
127
|
+
- **Core functionality:** The main file sets up a chainable API. Each color or
|
|
128
|
+
modifier (like `bold` or `italic`) is a getter that appends the corresponding
|
|
129
|
+
ANSI escape code to an internal stack.
|
|
130
|
+
|
|
131
|
+
- **Chainable API:** When you call `chalk.red.bold('Hello')`, you are accessing
|
|
132
|
+
getters. The `red` getter adds the red color code, and the `bold` getter adds
|
|
133
|
+
the bold code.
|
|
134
|
+
|
|
135
|
+
- **Output generation:** When the chain is treated as a string (e.g., in
|
|
136
|
+
`console.log`), a final `toString()` method is called. This method joins all
|
|
137
|
+
the stored ANSI codes, wraps them around the input string ('Hello'), and adds
|
|
138
|
+
a reset code at the end. This produces the final, styled string that the
|
|
139
|
+
terminal can render.
|
|
140
|
+
```
|
|
141
|
+
|
|
142
|
+
### Combine two spreadsheets into one spreadsheet
|
|
143
|
+
|
|
144
|
+
Cell CLI can process and transform data across multiple files. Use this
|
|
145
|
+
capability to merge reports or reformat data sets without manual copying.
|
|
146
|
+
|
|
147
|
+
Scenario: You have two .csv files: `Revenue - 2023.csv` and
|
|
148
|
+
`Revenue - 2024.csv`. Each file contains monthly revenue figures.
|
|
149
|
+
|
|
150
|
+
Give Cell CLI the following prompt:
|
|
151
|
+
|
|
152
|
+
```cli
|
|
153
|
+
Combine the two .csv files into a single .csv file, with each year a different column.
|
|
154
|
+
```
|
|
155
|
+
|
|
156
|
+
Result: Cell CLI reads each file and then asks for permission to write a new
|
|
157
|
+
file. Provide your permission and Cell CLI provides the combined data:
|
|
158
|
+
|
|
159
|
+
```csv
|
|
160
|
+
Month,2023,2024
|
|
161
|
+
January,0,1000
|
|
162
|
+
February,0,1200
|
|
163
|
+
March,0,2400
|
|
164
|
+
April,900,500
|
|
165
|
+
May,1000,800
|
|
166
|
+
June,1000,900
|
|
167
|
+
July,1200,1000
|
|
168
|
+
August,1800,400
|
|
169
|
+
September,2000,2000
|
|
170
|
+
October,2400,3400
|
|
171
|
+
November,3400,1800
|
|
172
|
+
December,2100,9000
|
|
173
|
+
```
|
|
174
|
+
|
|
175
|
+
### Run unit tests
|
|
176
|
+
|
|
177
|
+
Cell CLI can generate boilerplate code and tests based on your existing
|
|
178
|
+
implementation. This example demonstrates how to request code coverage for a
|
|
179
|
+
JavaScript component.
|
|
180
|
+
|
|
181
|
+
Scenario: You've written a simple login page. You wish to write unit tests to
|
|
182
|
+
ensure that your login page has code coverage.
|
|
183
|
+
|
|
184
|
+
Give Cell CLI the following prompt:
|
|
185
|
+
|
|
186
|
+
```cli
|
|
187
|
+
Write unit tests for Login.js.
|
|
188
|
+
```
|
|
189
|
+
|
|
190
|
+
Result: Cell CLI asks for permission to write a new file and creates a test for
|
|
191
|
+
your login page.
|
|
66
192
|
|
|
67
193
|
## Check usage and quota
|
|
68
194
|
|
|
@@ -122,6 +122,13 @@ code.
|
|
|
122
122
|
# From the root of the repository
|
|
123
123
|
npm run start
|
|
124
124
|
```
|
|
125
|
+
- **Production mode (React optimizations):** This method runs the CLI with React
|
|
126
|
+
production mode enabled, which is useful for testing performance without
|
|
127
|
+
development overhead.
|
|
128
|
+
```bash
|
|
129
|
+
# From the root of the repository
|
|
130
|
+
npm run start:prod
|
|
131
|
+
```
|
|
125
132
|
- **Production-like mode (linked package):** This method simulates a global
|
|
126
133
|
installation by linking your local package. It's useful for testing a local
|
|
127
134
|
build in a production workflow.
|
package/dist/docs/hooks/index.md
CHANGED
|
@@ -22,11 +22,11 @@ With hooks, you can:
|
|
|
22
22
|
|
|
23
23
|
### Getting started
|
|
24
24
|
|
|
25
|
-
- **[Writing hooks guide](../hooks/writing-hooks)**: A tutorial on creating
|
|
26
|
-
first hook with comprehensive examples.
|
|
27
|
-
- **[Best practices](../hooks/best-practices)**: Guidelines on security,
|
|
25
|
+
- **[Writing hooks guide](../hooks/writing-hooks.md)**: A tutorial on creating
|
|
26
|
+
your first hook with comprehensive examples.
|
|
27
|
+
- **[Best practices](../hooks/best-practices.md)**: Guidelines on security,
|
|
28
28
|
performance, and debugging.
|
|
29
|
-
- **[Hooks reference](../hooks/reference)**: The definitive technical
|
|
29
|
+
- **[Hooks reference](../hooks/reference.md)**: The definitive technical
|
|
30
30
|
specification of I/O schemas and exit codes.
|
|
31
31
|
|
|
32
32
|
## Core concepts
|
|
@@ -154,8 +154,8 @@ Cell CLI **fingerprints** project hooks. If a hook's name or command changes
|
|
|
154
154
|
(e.g., via `git pull`), it is treated as a **new, untrusted hook** and you will
|
|
155
155
|
be warned before it executes.
|
|
156
156
|
|
|
157
|
-
See [Security Considerations](../hooks/best-practices#using-hooks-securely)
|
|
158
|
-
a detailed threat model.
|
|
157
|
+
See [Security Considerations](../hooks/best-practices.md#using-hooks-securely)
|
|
158
|
+
for a detailed threat model.
|
|
159
159
|
|
|
160
160
|
## Managing hooks
|
|
161
161
|
|