@google/gemini-cli 0.1.19-nightly.250813.9d023be1 → 0.1.19-nightly.250814.514e883a

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.
Files changed (79) hide show
  1. package/README.md +1 -1
  2. package/dist/package.json +3 -3
  3. package/dist/src/config/config.d.ts +1 -1
  4. package/dist/src/config/config.js +11 -8
  5. package/dist/src/config/config.js.map +1 -1
  6. package/dist/src/config/keyBindings.js +4 -0
  7. package/dist/src/config/keyBindings.js.map +1 -1
  8. package/dist/src/config/trustedFolders.d.ts +36 -0
  9. package/dist/src/config/trustedFolders.js +112 -0
  10. package/dist/src/config/trustedFolders.js.map +1 -0
  11. package/dist/src/gemini.js +6 -3
  12. package/dist/src/gemini.js.map +1 -1
  13. package/dist/src/generated/git-commit.d.ts +1 -1
  14. package/dist/src/generated/git-commit.js +1 -1
  15. package/dist/src/nonInteractiveCli.js +2 -3
  16. package/dist/src/nonInteractiveCli.js.map +1 -1
  17. package/dist/src/services/BuiltinCommandLoader.js +2 -0
  18. package/dist/src/services/BuiltinCommandLoader.js.map +1 -1
  19. package/dist/src/ui/App.js +8 -2
  20. package/dist/src/ui/App.js.map +1 -1
  21. package/dist/src/ui/commands/directoryCommand.js +2 -4
  22. package/dist/src/ui/commands/directoryCommand.js.map +1 -1
  23. package/dist/src/ui/commands/mcpCommand.js +4 -0
  24. package/dist/src/ui/commands/mcpCommand.js.map +1 -1
  25. package/dist/src/ui/commands/terminalSetupCommand.d.ts +13 -0
  26. package/dist/src/ui/commands/terminalSetupCommand.js +41 -0
  27. package/dist/src/ui/commands/terminalSetupCommand.js.map +1 -0
  28. package/dist/src/ui/commands/types.d.ts +1 -0
  29. package/dist/src/ui/commands/types.js.map +1 -1
  30. package/dist/src/ui/components/InputPrompt.js +7 -1
  31. package/dist/src/ui/components/InputPrompt.js.map +1 -1
  32. package/dist/src/ui/components/shared/vim-buffer-actions.js +2 -1
  33. package/dist/src/ui/components/shared/vim-buffer-actions.js.map +1 -1
  34. package/dist/src/ui/hooks/slashCommandProcessor.js +67 -46
  35. package/dist/src/ui/hooks/slashCommandProcessor.js.map +1 -1
  36. package/dist/src/ui/hooks/useFocus.d.ts +4 -0
  37. package/dist/src/ui/hooks/useFocus.js +4 -4
  38. package/dist/src/ui/hooks/useFocus.js.map +1 -1
  39. package/dist/src/ui/hooks/useFolderTrust.d.ts +3 -2
  40. package/dist/src/ui/hooks/useFolderTrust.js +24 -9
  41. package/dist/src/ui/hooks/useFolderTrust.js.map +1 -1
  42. package/dist/src/ui/hooks/useGeminiStream.js +1 -2
  43. package/dist/src/ui/hooks/useGeminiStream.js.map +1 -1
  44. package/dist/src/ui/hooks/useKeypress.d.ts +9 -1
  45. package/dist/src/ui/hooks/useKeypress.js +197 -8
  46. package/dist/src/ui/hooks/useKeypress.js.map +1 -1
  47. package/dist/src/ui/hooks/useKittyKeyboardProtocol.d.ts +15 -0
  48. package/dist/src/ui/hooks/useKittyKeyboardProtocol.js +20 -0
  49. package/dist/src/ui/hooks/useKittyKeyboardProtocol.js.map +1 -0
  50. package/dist/src/ui/utils/kittyProtocolDetector.d.ts +13 -0
  51. package/dist/src/ui/utils/kittyProtocolDetector.js +88 -0
  52. package/dist/src/ui/utils/kittyProtocolDetector.js.map +1 -0
  53. package/dist/src/ui/utils/platformConstants.d.ts +38 -0
  54. package/dist/src/ui/utils/platformConstants.js +39 -0
  55. package/dist/src/ui/utils/platformConstants.js.map +1 -0
  56. package/dist/src/ui/utils/terminalSetup.d.ts +30 -0
  57. package/dist/src/ui/utils/terminalSetup.js +281 -0
  58. package/dist/src/ui/utils/terminalSetup.js.map +1 -0
  59. package/dist/src/utils/checks.d.ts +19 -0
  60. package/dist/src/utils/checks.js +24 -0
  61. package/dist/src/utils/checks.js.map +1 -0
  62. package/dist/src/zed-integration/acp.d.ts +63 -0
  63. package/dist/src/{acp → zed-integration}/acp.js +76 -44
  64. package/dist/src/zed-integration/acp.js.map +1 -0
  65. package/dist/src/zed-integration/schema.d.ts +11679 -0
  66. package/dist/src/zed-integration/schema.js +305 -0
  67. package/dist/src/zed-integration/schema.js.map +1 -0
  68. package/dist/src/zed-integration/zedIntegration.d.ts +10 -0
  69. package/dist/src/{acp/acpPeer.js → zed-integration/zedIntegration.js} +333 -187
  70. package/dist/src/zed-integration/zedIntegration.js.map +1 -0
  71. package/dist/tsconfig.tsbuildinfo +1 -1
  72. package/package.json +4 -4
  73. package/dist/src/acp/acp.d.ts +0 -208
  74. package/dist/src/acp/acp.js.map +0 -1
  75. package/dist/src/acp/acpPeer.d.ts +0 -8
  76. package/dist/src/acp/acpPeer.js.map +0 -1
  77. package/dist/src/ui/utils/errorParsing.d.ts +0 -7
  78. package/dist/src/ui/utils/errorParsing.js +0 -90
  79. package/dist/src/ui/utils/errorParsing.js.map +0 -1
@@ -0,0 +1,281 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2025 Google LLC
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+ /**
7
+ * Terminal setup utility for configuring Shift+Enter and Ctrl+Enter support.
8
+ *
9
+ * This module provides automatic detection and configuration of various terminal
10
+ * emulators to support multiline input through modified Enter keys.
11
+ *
12
+ * Supported terminals:
13
+ * - VS Code: Configures keybindings.json to send \\\r\n
14
+ * - Cursor: Configures keybindings.json to send \\\r\n (VS Code fork)
15
+ * - Windsurf: Configures keybindings.json to send \\\r\n (VS Code fork)
16
+ *
17
+ * For VS Code and its forks:
18
+ * - Shift+Enter: Sends \\\r\n (backslash followed by CRLF)
19
+ * - Ctrl+Enter: Sends \\\r\n (backslash followed by CRLF)
20
+ *
21
+ * The module will not modify existing shift+enter or ctrl+enter keybindings
22
+ * to avoid conflicts with user customizations.
23
+ */
24
+ import { promises as fs } from 'fs';
25
+ import * as os from 'os';
26
+ import * as path from 'path';
27
+ import { exec } from 'child_process';
28
+ import { promisify } from 'util';
29
+ import { isKittyProtocolEnabled } from './kittyProtocolDetector.js';
30
+ import { VSCODE_SHIFT_ENTER_SEQUENCE } from './platformConstants.js';
31
+ const execAsync = promisify(exec);
32
+ /**
33
+ * Removes single-line JSON comments (// ...) from a string to allow parsing
34
+ * VS Code style JSON files that may contain comments.
35
+ */
36
+ function stripJsonComments(content) {
37
+ // Remove single-line comments (// ...)
38
+ return content.replace(/^\s*\/\/.*$/gm, '');
39
+ }
40
+ // Terminal detection
41
+ async function detectTerminal() {
42
+ const termProgram = process.env.TERM_PROGRAM;
43
+ // Check VS Code and its forks - check forks first to avoid false positives
44
+ // Check for Cursor-specific indicators
45
+ if (process.env.CURSOR_TRACE_ID ||
46
+ process.env.VSCODE_GIT_ASKPASS_MAIN?.toLowerCase().includes('cursor')) {
47
+ return 'cursor';
48
+ }
49
+ // Check for Windsurf-specific indicators
50
+ if (process.env.VSCODE_GIT_ASKPASS_MAIN?.toLowerCase().includes('windsurf')) {
51
+ return 'windsurf';
52
+ }
53
+ // Check VS Code last since forks may also set VSCODE env vars
54
+ if (termProgram === 'vscode' || process.env.VSCODE_GIT_IPC_HANDLE) {
55
+ return 'vscode';
56
+ }
57
+ // Check parent process name
58
+ if (os.platform() !== 'win32') {
59
+ try {
60
+ const { stdout } = await execAsync('ps -o comm= -p $PPID');
61
+ const parentName = stdout.trim();
62
+ // Check forks before VS Code to avoid false positives
63
+ if (parentName.includes('windsurf') || parentName.includes('Windsurf'))
64
+ return 'windsurf';
65
+ if (parentName.includes('cursor') || parentName.includes('Cursor'))
66
+ return 'cursor';
67
+ if (parentName.includes('code') || parentName.includes('Code'))
68
+ return 'vscode';
69
+ }
70
+ catch (error) {
71
+ // Continue detection even if process check fails
72
+ console.debug('Parent process detection failed:', error);
73
+ }
74
+ }
75
+ return null;
76
+ }
77
+ // Backup file helper
78
+ async function backupFile(filePath) {
79
+ try {
80
+ const timestamp = new Date().toISOString().replace(/[:.]/g, '-');
81
+ const backupPath = `${filePath}.backup.${timestamp}`;
82
+ await fs.copyFile(filePath, backupPath);
83
+ }
84
+ catch (error) {
85
+ // Log backup errors but continue with operation
86
+ console.warn(`Failed to create backup of ${filePath}:`, error);
87
+ }
88
+ }
89
+ // Helper function to get VS Code-style config directory
90
+ function getVSCodeStyleConfigDir(appName) {
91
+ const platform = os.platform();
92
+ if (platform === 'darwin') {
93
+ return path.join(os.homedir(), 'Library', 'Application Support', appName, 'User');
94
+ }
95
+ else if (platform === 'win32') {
96
+ if (!process.env.APPDATA) {
97
+ return null;
98
+ }
99
+ return path.join(process.env.APPDATA, appName, 'User');
100
+ }
101
+ else {
102
+ return path.join(os.homedir(), '.config', appName, 'User');
103
+ }
104
+ }
105
+ // Generic VS Code-style terminal configuration
106
+ async function configureVSCodeStyle(terminalName, appName) {
107
+ const configDir = getVSCodeStyleConfigDir(appName);
108
+ if (!configDir) {
109
+ return {
110
+ success: false,
111
+ message: `Could not determine ${terminalName} config path on Windows: APPDATA environment variable is not set.`,
112
+ };
113
+ }
114
+ const keybindingsFile = path.join(configDir, 'keybindings.json');
115
+ try {
116
+ await fs.mkdir(configDir, { recursive: true });
117
+ let keybindings = [];
118
+ try {
119
+ const content = await fs.readFile(keybindingsFile, 'utf8');
120
+ await backupFile(keybindingsFile);
121
+ try {
122
+ const cleanContent = stripJsonComments(content);
123
+ const parsedContent = JSON.parse(cleanContent);
124
+ if (!Array.isArray(parsedContent)) {
125
+ return {
126
+ success: false,
127
+ message: `${terminalName} keybindings.json exists but is not a valid JSON array. ` +
128
+ `Please fix the file manually or delete it to allow automatic configuration.\n` +
129
+ `File: ${keybindingsFile}`,
130
+ };
131
+ }
132
+ keybindings = parsedContent;
133
+ }
134
+ catch (parseError) {
135
+ return {
136
+ success: false,
137
+ message: `Failed to parse ${terminalName} keybindings.json. The file contains invalid JSON.\n` +
138
+ `Please fix the file manually or delete it to allow automatic configuration.\n` +
139
+ `File: ${keybindingsFile}\n` +
140
+ `Error: ${parseError}`,
141
+ };
142
+ }
143
+ }
144
+ catch {
145
+ // File doesn't exist, will create new one
146
+ }
147
+ const shiftEnterBinding = {
148
+ key: 'shift+enter',
149
+ command: 'workbench.action.terminal.sendSequence',
150
+ when: 'terminalFocus',
151
+ args: { text: VSCODE_SHIFT_ENTER_SEQUENCE },
152
+ };
153
+ const ctrlEnterBinding = {
154
+ key: 'ctrl+enter',
155
+ command: 'workbench.action.terminal.sendSequence',
156
+ when: 'terminalFocus',
157
+ args: { text: VSCODE_SHIFT_ENTER_SEQUENCE },
158
+ };
159
+ // Check if ANY shift+enter or ctrl+enter bindings already exist
160
+ const existingShiftEnter = keybindings.find((kb) => {
161
+ const binding = kb;
162
+ return binding.key === 'shift+enter';
163
+ });
164
+ const existingCtrlEnter = keybindings.find((kb) => {
165
+ const binding = kb;
166
+ return binding.key === 'ctrl+enter';
167
+ });
168
+ if (existingShiftEnter || existingCtrlEnter) {
169
+ const messages = [];
170
+ if (existingShiftEnter) {
171
+ messages.push(`- Shift+Enter binding already exists`);
172
+ }
173
+ if (existingCtrlEnter) {
174
+ messages.push(`- Ctrl+Enter binding already exists`);
175
+ }
176
+ return {
177
+ success: false,
178
+ message: `Existing keybindings detected. Will not modify to avoid conflicts.\n` +
179
+ messages.join('\n') +
180
+ '\n' +
181
+ `Please check and modify manually if needed: ${keybindingsFile}`,
182
+ };
183
+ }
184
+ // Check if our specific bindings already exist
185
+ const hasOurShiftEnter = keybindings.some((kb) => {
186
+ const binding = kb;
187
+ return (binding.key === 'shift+enter' &&
188
+ binding.command === 'workbench.action.terminal.sendSequence' &&
189
+ binding.args?.text === '\\\r\n');
190
+ });
191
+ const hasOurCtrlEnter = keybindings.some((kb) => {
192
+ const binding = kb;
193
+ return (binding.key === 'ctrl+enter' &&
194
+ binding.command === 'workbench.action.terminal.sendSequence' &&
195
+ binding.args?.text === '\\\r\n');
196
+ });
197
+ if (!hasOurShiftEnter || !hasOurCtrlEnter) {
198
+ if (!hasOurShiftEnter)
199
+ keybindings.unshift(shiftEnterBinding);
200
+ if (!hasOurCtrlEnter)
201
+ keybindings.unshift(ctrlEnterBinding);
202
+ await fs.writeFile(keybindingsFile, JSON.stringify(keybindings, null, 4));
203
+ return {
204
+ success: true,
205
+ message: `Added Shift+Enter and Ctrl+Enter keybindings to ${terminalName}.\nModified: ${keybindingsFile}`,
206
+ requiresRestart: true,
207
+ };
208
+ }
209
+ else {
210
+ return {
211
+ success: true,
212
+ message: `${terminalName} keybindings already configured.`,
213
+ };
214
+ }
215
+ }
216
+ catch (error) {
217
+ return {
218
+ success: false,
219
+ message: `Failed to configure ${terminalName}.\nFile: ${keybindingsFile}\nError: ${error}`,
220
+ };
221
+ }
222
+ }
223
+ // Terminal-specific configuration functions
224
+ async function configureVSCode() {
225
+ return configureVSCodeStyle('VS Code', 'Code');
226
+ }
227
+ async function configureCursor() {
228
+ return configureVSCodeStyle('Cursor', 'Cursor');
229
+ }
230
+ async function configureWindsurf() {
231
+ return configureVSCodeStyle('Windsurf', 'Windsurf');
232
+ }
233
+ /**
234
+ * Main terminal setup function that detects and configures the current terminal.
235
+ *
236
+ * This function:
237
+ * 1. Detects the current terminal emulator
238
+ * 2. Applies appropriate configuration for Shift+Enter and Ctrl+Enter support
239
+ * 3. Creates backups of configuration files before modifying them
240
+ *
241
+ * @returns Promise<TerminalSetupResult> Result object with success status and message
242
+ *
243
+ * @example
244
+ * const result = await terminalSetup();
245
+ * if (result.success) {
246
+ * console.log(result.message);
247
+ * if (result.requiresRestart) {
248
+ * console.log('Please restart your terminal');
249
+ * }
250
+ * }
251
+ */
252
+ export async function terminalSetup() {
253
+ // Check if terminal already has optimal keyboard support
254
+ if (isKittyProtocolEnabled()) {
255
+ return {
256
+ success: true,
257
+ message: 'Your terminal is already configured for an optimal experience with multiline input (Shift+Enter and Ctrl+Enter).',
258
+ };
259
+ }
260
+ const terminal = await detectTerminal();
261
+ if (!terminal) {
262
+ return {
263
+ success: false,
264
+ message: 'Could not detect terminal type. Supported terminals: VS Code, Cursor, and Windsurf.',
265
+ };
266
+ }
267
+ switch (terminal) {
268
+ case 'vscode':
269
+ return configureVSCode();
270
+ case 'cursor':
271
+ return configureCursor();
272
+ case 'windsurf':
273
+ return configureWindsurf();
274
+ default:
275
+ return {
276
+ success: false,
277
+ message: `Terminal "${terminal}" is not supported yet.`,
278
+ };
279
+ }
280
+ }
281
+ //# sourceMappingURL=terminalSetup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"terminalSetup.js","sourceRoot":"","sources":["../../../../src/ui/utils/terminalSetup.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2025 Google LLC
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+ export declare function assumeExhaustive(_value: never): void;
7
+ /**
8
+ * Throws an exception on unexpected values.
9
+ *
10
+ * A common use case is switch statements:
11
+ * switch(enumValue) {
12
+ * case Enum.A:
13
+ * case Enum.B:
14
+ * break;
15
+ * default:
16
+ * checkExhaustive(enumValue);
17
+ * }
18
+ */
19
+ export declare function checkExhaustive(value: never, msg?: string): never;
@@ -0,0 +1,24 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2025 Google LLC
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+ /* Fail to compile on unexpected values. */
7
+ export function assumeExhaustive(_value) { }
8
+ /**
9
+ * Throws an exception on unexpected values.
10
+ *
11
+ * A common use case is switch statements:
12
+ * switch(enumValue) {
13
+ * case Enum.A:
14
+ * case Enum.B:
15
+ * break;
16
+ * default:
17
+ * checkExhaustive(enumValue);
18
+ * }
19
+ */
20
+ export function checkExhaustive(value, msg = `unexpected value ${value}!`) {
21
+ assumeExhaustive(value);
22
+ throw new Error(msg);
23
+ }
24
+ //# sourceMappingURL=checks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"checks.js","sourceRoot":"","sources":["../../../src/utils/checks.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,2CAA2C;AAC3C,MAAM,UAAU,gBAAgB,CAAC,MAAa,IAAS,CAAC;AAExD;;;;;;;;;;;GAWG;AACH,MAAM,UAAU,eAAe,CAC7B,KAAY,EACZ,GAAG,GAAG,oBAAoB,KAAK,GAAG;IAElC,gBAAgB,CAAC,KAAK,CAAC,CAAC;IACxB,MAAM,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC;AACvB,CAAC"}
@@ -0,0 +1,63 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2025 Google LLC
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+ import * as schema from './schema.js';
7
+ export * from './schema.js';
8
+ import { WritableStream, ReadableStream } from 'node:stream/web';
9
+ export declare class AgentSideConnection implements Client {
10
+ #private;
11
+ constructor(toAgent: (conn: Client) => Agent, input: WritableStream<Uint8Array>, output: ReadableStream<Uint8Array>);
12
+ /**
13
+ * Streams new content to the client including text, tool calls, etc.
14
+ */
15
+ sessionUpdate(params: schema.SessionNotification): Promise<void>;
16
+ /**
17
+ * Request permission before running a tool
18
+ *
19
+ * The agent specifies a series of permission options with different granularity,
20
+ * and the client returns the chosen one.
21
+ */
22
+ requestPermission(params: schema.RequestPermissionRequest): Promise<schema.RequestPermissionResponse>;
23
+ readTextFile(params: schema.ReadTextFileRequest): Promise<schema.ReadTextFileResponse>;
24
+ writeTextFile(params: schema.WriteTextFileRequest): Promise<schema.WriteTextFileResponse>;
25
+ }
26
+ type Result<T> = {
27
+ result: T;
28
+ } | {
29
+ error: ErrorResponse;
30
+ };
31
+ type ErrorResponse = {
32
+ code: number;
33
+ message: string;
34
+ data?: unknown;
35
+ };
36
+ export declare class RequestError extends Error {
37
+ code: number;
38
+ data?: {
39
+ details?: string;
40
+ };
41
+ constructor(code: number, message: string, details?: string);
42
+ static parseError(details?: string): RequestError;
43
+ static invalidRequest(details?: string): RequestError;
44
+ static methodNotFound(details?: string): RequestError;
45
+ static invalidParams(details?: string): RequestError;
46
+ static internalError(details?: string): RequestError;
47
+ static authRequired(details?: string): RequestError;
48
+ toResult<T>(): Result<T>;
49
+ }
50
+ export interface Client {
51
+ requestPermission(params: schema.RequestPermissionRequest): Promise<schema.RequestPermissionResponse>;
52
+ sessionUpdate(params: schema.SessionNotification): Promise<void>;
53
+ writeTextFile(params: schema.WriteTextFileRequest): Promise<schema.WriteTextFileResponse>;
54
+ readTextFile(params: schema.ReadTextFileRequest): Promise<schema.ReadTextFileResponse>;
55
+ }
56
+ export interface Agent {
57
+ initialize(params: schema.InitializeRequest): Promise<schema.InitializeResponse>;
58
+ newSession(params: schema.NewSessionRequest): Promise<schema.NewSessionResponse>;
59
+ loadSession?(params: schema.LoadSessionRequest): Promise<schema.LoadSessionResponse>;
60
+ authenticate(params: schema.AuthenticateRequest): Promise<void>;
61
+ prompt(params: schema.PromptRequest): Promise<schema.PromptResponse>;
62
+ cancel(params: schema.CancelNotification): Promise<void>;
63
+ }
@@ -3,59 +3,82 @@
3
3
  * Copyright 2025 Google LLC
4
4
  * SPDX-License-Identifier: Apache-2.0
5
5
  */
6
- export class ClientConnection {
6
+ /* ACP defines a schema for a simple (experimental) JSON-RPC protocol that allows GUI applications to interact with agents. */
7
+ import { z } from 'zod';
8
+ import * as schema from './schema.js';
9
+ export * from './schema.js';
10
+ export class AgentSideConnection {
7
11
  #connection;
8
- constructor(agent, input, output) {
9
- this.#connection = new Connection(agent(this), input, output);
12
+ constructor(toAgent, input, output) {
13
+ const agent = toAgent(this);
14
+ const handler = async (method, params) => {
15
+ switch (method) {
16
+ case schema.AGENT_METHODS.initialize: {
17
+ const validatedParams = schema.initializeRequestSchema.parse(params);
18
+ return agent.initialize(validatedParams);
19
+ }
20
+ case schema.AGENT_METHODS.session_new: {
21
+ const validatedParams = schema.newSessionRequestSchema.parse(params);
22
+ return agent.newSession(validatedParams);
23
+ }
24
+ case schema.AGENT_METHODS.session_load: {
25
+ if (!agent.loadSession) {
26
+ throw RequestError.methodNotFound();
27
+ }
28
+ const validatedParams = schema.loadSessionRequestSchema.parse(params);
29
+ return agent.loadSession(validatedParams);
30
+ }
31
+ case schema.AGENT_METHODS.authenticate: {
32
+ const validatedParams = schema.authenticateRequestSchema.parse(params);
33
+ return agent.authenticate(validatedParams);
34
+ }
35
+ case schema.AGENT_METHODS.session_prompt: {
36
+ const validatedParams = schema.promptRequestSchema.parse(params);
37
+ return agent.prompt(validatedParams);
38
+ }
39
+ case schema.AGENT_METHODS.session_cancel: {
40
+ const validatedParams = schema.cancelNotificationSchema.parse(params);
41
+ return agent.cancel(validatedParams);
42
+ }
43
+ default:
44
+ throw RequestError.methodNotFound(method);
45
+ }
46
+ };
47
+ this.#connection = new Connection(handler, input, output);
10
48
  }
11
49
  /**
12
- * Streams part of an assistant response to the client
50
+ * Streams new content to the client including text, tool calls, etc.
13
51
  */
14
- async streamAssistantMessageChunk(params) {
15
- await this.#connection.sendRequest('streamAssistantMessageChunk', params);
52
+ async sessionUpdate(params) {
53
+ return await this.#connection.sendNotification(schema.CLIENT_METHODS.session_update, params);
16
54
  }
17
55
  /**
18
- * Request confirmation before running a tool
56
+ * Request permission before running a tool
19
57
  *
20
- * When allowed, the client returns a [`ToolCallId`] which can be used
21
- * to update the tool call's `status` and `content` as it runs.
58
+ * The agent specifies a series of permission options with different granularity,
59
+ * and the client returns the chosen one.
22
60
  */
23
- requestToolCallConfirmation(params) {
24
- return this.#connection.sendRequest('requestToolCallConfirmation', params);
61
+ async requestPermission(params) {
62
+ return await this.#connection.sendRequest(schema.CLIENT_METHODS.session_request_permission, params);
25
63
  }
26
- /**
27
- * pushToolCall allows the agent to start a tool call
28
- * when it does not need to request permission to do so.
29
- *
30
- * The returned id can be used to update the UI for the tool
31
- * call as needed.
32
- */
33
- pushToolCall(params) {
34
- return this.#connection.sendRequest('pushToolCall', params);
64
+ async readTextFile(params) {
65
+ return await this.#connection.sendRequest(schema.CLIENT_METHODS.fs_read_text_file, params);
35
66
  }
36
- /**
37
- * updateToolCall allows the agent to update the content and status of the tool call.
38
- *
39
- * The new content replaces what is currently displayed in the UI.
40
- *
41
- * The [`ToolCallId`] is included in the response of
42
- * `pushToolCall` or `requestToolCallConfirmation` respectively.
43
- */
44
- async updateToolCall(params) {
45
- await this.#connection.sendRequest('updateToolCall', params);
67
+ async writeTextFile(params) {
68
+ return await this.#connection.sendRequest(schema.CLIENT_METHODS.fs_write_text_file, params);
46
69
  }
47
70
  }
48
71
  class Connection {
49
72
  #pendingResponses = new Map();
50
73
  #nextRequestId = 0;
51
- #delegate;
74
+ #handler;
52
75
  #peerInput;
53
76
  #writeQueue = Promise.resolve();
54
77
  #textEncoder;
55
- constructor(delegate, peerInput, peerOutput) {
78
+ constructor(handler, peerInput, peerOutput) {
79
+ this.#handler = handler;
56
80
  this.#peerInput = peerInput;
57
81
  this.#textEncoder = new TextEncoder();
58
- this.#delegate = delegate;
59
82
  this.#receive(peerOutput);
60
83
  }
61
84
  async #receive(output) {
@@ -75,31 +98,36 @@ class Connection {
75
98
  }
76
99
  }
77
100
  async #processMessage(message) {
78
- if ('method' in message) {
79
- const response = await this.#tryCallDelegateMethod(message.method, message.params);
101
+ if ('method' in message && 'id' in message) {
102
+ // It's a request
103
+ const response = await this.#tryCallHandler(message.method, message.params);
80
104
  await this.#sendMessage({
81
105
  jsonrpc: '2.0',
82
106
  id: message.id,
83
107
  ...response,
84
108
  });
85
109
  }
86
- else {
110
+ else if ('method' in message) {
111
+ // It's a notification
112
+ await this.#tryCallHandler(message.method, message.params);
113
+ }
114
+ else if ('id' in message) {
115
+ // It's a response
87
116
  this.#handleResponse(message);
88
117
  }
89
118
  }
90
- async #tryCallDelegateMethod(method, params) {
91
- const methodName = method;
92
- if (typeof this.#delegate[methodName] !== 'function') {
93
- return RequestError.methodNotFound(method).toResult();
94
- }
119
+ async #tryCallHandler(method, params) {
95
120
  try {
96
- const result = await this.#delegate[methodName](params);
121
+ const result = await this.#handler(method, params);
97
122
  return { result: result ?? null };
98
123
  }
99
124
  catch (error) {
100
125
  if (error instanceof RequestError) {
101
126
  return error.toResult();
102
127
  }
128
+ if (error instanceof z.ZodError) {
129
+ return RequestError.invalidParams(JSON.stringify(error.format(), undefined, 2)).toResult();
130
+ }
103
131
  let details;
104
132
  if (error instanceof Error) {
105
133
  details = error.message;
@@ -133,6 +161,9 @@ class Connection {
133
161
  await this.#sendMessage({ jsonrpc: '2.0', id, method, params });
134
162
  return responsePromise;
135
163
  }
164
+ async sendNotification(method, params) {
165
+ await this.#sendMessage({ jsonrpc: '2.0', method, params });
166
+ }
136
167
  async #sendMessage(json) {
137
168
  const content = JSON.stringify(json) + '\n';
138
169
  this.#writeQueue = this.#writeQueue
@@ -178,6 +209,9 @@ export class RequestError extends Error {
178
209
  static internalError(details) {
179
210
  return new RequestError(-32603, 'Internal error', details);
180
211
  }
212
+ static authRequired(details) {
213
+ return new RequestError(-32000, 'Authentication required', details);
214
+ }
181
215
  toResult() {
182
216
  return {
183
217
  error: {
@@ -188,6 +222,4 @@ export class RequestError extends Error {
188
222
  };
189
223
  }
190
224
  }
191
- // Protocol types
192
- export const LATEST_PROTOCOL_VERSION = '0.0.9';
193
225
  //# sourceMappingURL=acp.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"acp.js","sourceRoot":"","sources":["../../../src/zed-integration/acp.ts"],"names":[],"mappings":"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"}