diff --git a/Extension/src/LanguageServer/client.ts b/Extension/src/LanguageServer/client.ts index b72de58ad2..ab8efb0bfe 100644 --- a/Extension/src/LanguageServer/client.ts +++ b/Extension/src/LanguageServer/client.ts @@ -27,7 +27,7 @@ import * as fs from 'fs'; import * as os from 'os'; import { SourceFileConfiguration, SourceFileConfigurationItem, Version, WorkspaceBrowseConfiguration } from 'vscode-cpptools'; import { IntelliSenseStatus, Status } from 'vscode-cpptools/out/testApi'; -import { CloseAction, DidOpenTextDocumentParams, ErrorAction, LanguageClientOptions, NotificationType, Position, Range, RequestType, TextDocumentIdentifier, TextDocumentPositionParams } from 'vscode-languageclient'; +import { CloseAction, DidOpenTextDocumentParams, ErrorAction, LanguageClientOptions, NotificationType, Position, Range, RequestType, ResponseError, TextDocumentIdentifier, TextDocumentPositionParams } from 'vscode-languageclient'; import { LanguageClient, ServerOptions } from 'vscode-languageclient/node'; import * as nls from 'vscode-nls'; import { DebugConfigurationProvider } from '../Debugger/configurationProvider'; @@ -801,7 +801,7 @@ export interface Client { setShowConfigureIntelliSenseButton(show: boolean): void; addTrustedCompiler(path: string): Promise; getIncludes(maxDepth: number): Promise; - getChatContext(token: vscode.CancellationToken): Promise; + getChatContext(token: vscode.CancellationToken): Promise; } export function createClient(workspaceFolder?: vscode.WorkspaceFolder): Client { @@ -2244,12 +2244,20 @@ export class DefaultClient implements Client { return this.languageClient.sendRequest(IncludesRequest, params); } - public async getChatContext(token: vscode.CancellationToken): Promise { + public async getChatContext(token: vscode.CancellationToken): Promise { await withCancellation(this.ready, token); - const result = await this.languageClient.sendRequest(CppContextRequest, null, token); + let result: ChatContextResult; + try { + result = await this.languageClient.sendRequest(CppContextRequest, null, token); + } catch (e: any) { + // From + // RequestCancelled = -32800, ServerCancelled = -32802, + if (e instanceof ResponseError && (e.code === -32800 /*RequestCancelled*/ || e.code === -32802 /*ServerCancelled*/)) { + throw new vscode.CancellationError(); + } - // sendRequest() won't throw on cancellation, but will return an - // unexpected object with an error code and message. + throw e; + } if (token.isCancellationRequested) { throw new vscode.CancellationError(); } diff --git a/Extension/src/LanguageServer/lmTool.ts b/Extension/src/LanguageServer/lmTool.ts index 91d877f18c..65ac7d08cf 100644 --- a/Extension/src/LanguageServer/lmTool.ts +++ b/Extension/src/LanguageServer/lmTool.ts @@ -77,8 +77,7 @@ export class CppConfigurationLanguageModelTool implements vscode.LanguageModelTo for (const key in knownValues) { const knownKey = key as keyof ChatContextResult; - if (knownValues[knownKey] && chatContext[knownKey]) - { + if (knownValues[knownKey] && chatContext[knownKey]) { chatContext[knownKey] = knownValues[knownKey][chatContext[knownKey]] || chatContext[knownKey]; } }