diff options
| author | Shreya Keshive <[email protected]> | 2025-08-07 17:19:31 -0400 |
|---|---|---|
| committer | GitHub <[email protected]> | 2025-08-07 21:19:31 +0000 |
| commit | 4d4eacfc40f87ecc991aaecc12c046d49654425c (patch) | |
| tree | 933a4bbf90b1651d839aaa727df34f77610ad872 /packages/core/src | |
| parent | 19491b7b940912c2fb3fe24b2f189d3fd5668669 (diff) | |
Few IDE integration polishes (#5727)
Diffstat (limited to 'packages/core/src')
| -rw-r--r-- | packages/core/src/ide/ide-client.ts | 43 |
1 files changed, 39 insertions, 4 deletions
diff --git a/packages/core/src/ide/ide-client.ts b/packages/core/src/ide/ide-client.ts index 42b79c44..508dfea1 100644 --- a/packages/core/src/ide/ide-client.ts +++ b/packages/core/src/ide/ide-client.ts @@ -4,6 +4,7 @@ * SPDX-License-Identifier: Apache-2.0 */ +import * as fs from 'node:fs'; import { detectIde, DetectedIde, @@ -23,6 +24,8 @@ import { StreamableHTTPClientTransport } from '@modelcontextprotocol/sdk/client/ const logger = { // eslint-disable-next-line @typescript-eslint/no-explicit-any debug: (...args: any[]) => console.debug('[DEBUG] [IDEClient]', ...args), + // eslint-disable-next-line @typescript-eslint/no-explicit-any + error: (...args: any[]) => console.error('[ERROR] [IDEClient]', ...args), }; export type IDEConnectionState = { @@ -36,6 +39,16 @@ export enum IDEConnectionStatus { Connecting = 'connecting', } +function getRealPath(path: string): string { + try { + return fs.realpathSync(path); + } catch (_e) { + // If realpathSync fails, it might be because the path doesn't exist. + // In that case, we can fall back to the original path. + return path; + } +} + /** * Manages the connection to and interaction with the IDE server. */ @@ -69,7 +82,15 @@ export class IdeClient { this.setState(IDEConnectionStatus.Connecting); if (!this.currentIde || !this.currentIdeDisplayName) { - this.setState(IDEConnectionStatus.Disconnected); + this.setState( + IDEConnectionStatus.Disconnected, + `IDE integration is not supported in your current environment. To use this feature, run Gemini CLI in one of these supported IDEs: ${Object.values( + DetectedIde, + ) + .map((ide) => getIdeDisplayName(ide)) + .join(', ')}`, + true, + ); return; } @@ -174,7 +195,11 @@ export class IdeClient { return this.currentIdeDisplayName; } - private setState(status: IDEConnectionStatus, details?: string) { + private setState( + status: IDEConnectionStatus, + details?: string, + logToConsole = false, + ) { const isAlreadyDisconnected = this.state.status === IDEConnectionStatus.Disconnected && status === IDEConnectionStatus.Disconnected; @@ -186,7 +211,10 @@ export class IdeClient { } if (status === IDEConnectionStatus.Disconnected) { - logger.debug('IDE integration disconnected:', details); + if (logToConsole) { + logger.error(details); + } + logger.debug(details); ideContext.clearIdeContext(); } } @@ -197,6 +225,7 @@ export class IdeClient { this.setState( IDEConnectionStatus.Disconnected, `Failed to connect to IDE companion extension for ${this.currentIdeDisplayName}. Please ensure the extension is running and try refreshing your terminal. To install the extension, run /ide install.`, + true, ); return false; } @@ -204,13 +233,15 @@ export class IdeClient { this.setState( IDEConnectionStatus.Disconnected, `To use this feature, please open a single workspace folder in ${this.currentIdeDisplayName} and try again.`, + true, ); return false; } - if (ideWorkspacePath !== process.cwd()) { + if (getRealPath(ideWorkspacePath) !== getRealPath(process.cwd())) { this.setState( IDEConnectionStatus.Disconnected, `Directory mismatch. Gemini CLI is running in a different location than the open workspace in ${this.currentIdeDisplayName}. Please run the CLI from the same directory as your project's root folder.`, + true, ); return false; } @@ -223,6 +254,7 @@ export class IdeClient { this.setState( IDEConnectionStatus.Disconnected, `Failed to connect to IDE companion extension for ${this.currentIdeDisplayName}. Please ensure the extension is running and try refreshing your terminal. To install the extension, run /ide install.`, + true, ); return undefined; } @@ -244,12 +276,14 @@ export class IdeClient { this.setState( IDEConnectionStatus.Disconnected, `IDE connection error. The connection was lost unexpectedly. Please try reconnecting by running /ide enable`, + true, ); }; this.client.onclose = () => { this.setState( IDEConnectionStatus.Disconnected, `IDE connection error. The connection was lost unexpectedly. Please try reconnecting by running /ide enable`, + true, ); }; this.client.setNotificationHandler( @@ -299,6 +333,7 @@ export class IdeClient { this.setState( IDEConnectionStatus.Disconnected, `Failed to connect to IDE companion extension for ${this.currentIdeDisplayName}. Please ensure the extension is running and try refreshing your terminal. To install the extension, run /ide install.`, + true, ); if (transport) { try { |
