From 09e49a5252e81ef9860c35a710edbf25e50e4e0b Mon Sep 17 00:00:00 2001 From: Daniel Imms <2193314+Tyriar@users.noreply.github.com> Date: Mon, 20 Jan 2025 03:45:21 -0800 Subject: [PATCH] Fix duplicate matching and windowsExecutableExtensions setting Fixes #238285 --- extensions/terminal-suggest/src/helpers/executable.ts | 2 +- extensions/terminal-suggest/src/terminalSuggestMain.ts | 8 ++++---- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/extensions/terminal-suggest/src/helpers/executable.ts b/extensions/terminal-suggest/src/helpers/executable.ts index e93c7781901..cd8fce4f8dc 100644 --- a/extensions/terminal-suggest/src/helpers/executable.ts +++ b/extensions/terminal-suggest/src/helpers/executable.ts @@ -6,7 +6,7 @@ import { osIsWindows } from './os'; import * as fs from 'fs/promises'; -export async function isExecutable(filePath: string, configuredWindowsExecutableExtensions?: { [key: string]: boolean | undefined }): Promise { +export async function isExecutable(filePath: string, configuredWindowsExecutableExtensions?: { [key: string]: boolean | undefined } | undefined): Promise { if (osIsWindows()) { const resolvedWindowsExecutableExtensions = resolveWindowsExecutableExtensions(configuredWindowsExecutableExtensions); return resolvedWindowsExecutableExtensions.find(ext => filePath.endsWith(ext)) !== undefined; diff --git a/extensions/terminal-suggest/src/terminalSuggestMain.ts b/extensions/terminal-suggest/src/terminalSuggestMain.ts index 662df64816d..1ffedf21236 100644 --- a/extensions/terminal-suggest/src/terminalSuggestMain.ts +++ b/extensions/terminal-suggest/src/terminalSuggestMain.ts @@ -15,7 +15,7 @@ import { isExecutable } from './helpers/executable'; const isWindows = osIsWindows(); let cachedAvailableCommandsPath: string | undefined; -let cachedWindowsExecutableExtensions: Object | undefined; +let cachedWindowsExecutableExtensions: { [key: string]: boolean | undefined } | undefined; const cachedWindowsExecutableExtensionsSettingId = 'terminal.integrated.suggest.windowsExecutableExtensions'; let cachedAvailableCommands: Set | undefined; const cachedBuiltinCommands: Map = new Map(); @@ -114,10 +114,10 @@ export async function activate(context: vscode.ExtensionContext) { }, '/', '\\')); if (isWindows) { - cachedWindowsExecutableExtensions = vscode.workspace.getConfiguration(cachedWindowsExecutableExtensionsSettingId); + cachedWindowsExecutableExtensions = vscode.workspace.getConfiguration('terminal.integrated.suggest').get('windowsExecutableExtensions'); context.subscriptions.push(vscode.workspace.onDidChangeConfiguration(e => { if (e.affectsConfiguration(cachedWindowsExecutableExtensionsSettingId)) { - cachedWindowsExecutableExtensions = vscode.workspace.getConfiguration(cachedWindowsExecutableExtensionsSettingId); + cachedWindowsExecutableExtensions = vscode.workspace.getConfiguration('terminal.integrated.suggest').get('windowsExecutableExtensions'); cachedAvailableCommands = undefined; cachedAvailableCommandsPath = undefined; } @@ -233,7 +233,7 @@ async function getCommandsInPath(env: { [key: string]: string | undefined } = pr const files = await vscode.workspace.fs.readDirectory(fileResource); for (const [file, fileType] of files) { const formattedPath = getFriendlyFilePath(vscode.Uri.joinPath(fileResource, file), pathSeparator); - if (!labels.has(file) && fileType !== vscode.FileType.Unknown && fileType !== vscode.FileType.Directory && await isExecutable(formattedPath), cachedWindowsExecutableExtensions) { + if (!labels.has(file) && fileType !== vscode.FileType.Unknown && fileType !== vscode.FileType.Directory && await isExecutable(formattedPath, cachedWindowsExecutableExtensions)) { executables.add({ label: file, path: formattedPath }); labels.add(file); }