From 9083f0171613bbbc01bf5ec26c7a602b70435aba Mon Sep 17 00:00:00 2001 From: Matt Bierner Date: Tue, 10 Dec 2024 15:10:10 -0800 Subject: [PATCH] Add extra type check in `findFiles2` (#235692) For https://github.com/microsoft/vscode-copilot-release/issues/2493 Looking at the code I'm still not sure how this can happen but it seems like we end up trying to call `.map` on a value that is not an array. Adding a more explicit exception here to hopefully track this down --- .../workbench/api/common/extHostWorkspace.ts | 26 +++++++++++-------- 1 file changed, 15 insertions(+), 11 deletions(-) diff --git a/src/vs/workbench/api/common/extHostWorkspace.ts b/src/vs/workbench/api/common/extHostWorkspace.ts index 2f40bb8a39271..b490bf7a242d1 100644 --- a/src/vs/workbench/api/common/extHostWorkspace.ts +++ b/src/vs/workbench/api/common/extHostWorkspace.ts @@ -468,7 +468,7 @@ export class ExtHostWorkspace implements ExtHostWorkspaceShape, IExtHostWorkspac } // todo: consider exclude baseURI if available - return this._findFilesImpl(include, undefined, { + return this._findFilesImpl({ type: 'include', value: include }, { exclude: [excludeString], maxResults, useExcludeSettings: useFileExcludes ? ExcludeSettingOptions.FilesExclude : ExcludeSettingOptions.None, @@ -484,23 +484,26 @@ export class ExtHostWorkspace implements ExtHostWorkspaceShape, IExtHostWorkspac extensionId: ExtensionIdentifier, token: vscode.CancellationToken = CancellationToken.None): Promise { this._logService.trace(`extHostWorkspace#findFiles2New: fileSearch, extension: ${extensionId.value}, entryPoint: findFiles2New`); - return this._findFilesImpl(undefined, filePatterns, options, token); + return this._findFilesImpl({ type: 'filePatterns', value: filePatterns }, options, token); } private async _findFilesImpl( // the old `findFiles` used `include` to query, but the new `findFiles2` uses `filePattern` to query. // `filePattern` is the proper way to handle this, since it takes less precedence than the ignore files. - include: vscode.GlobPattern | undefined, - filePatterns: vscode.GlobPattern[] | undefined, + query: { type: 'include'; value: vscode.GlobPattern | undefined } | { type: 'filePatterns'; value: vscode.GlobPattern[] }, options: vscode.FindFiles2Options, - token: vscode.CancellationToken = CancellationToken.None): Promise { - if (token && token.isCancellationRequested) { + token: vscode.CancellationToken + ): Promise { + if (token.isCancellationRequested) { return Promise.resolve([]); } + const filePatternsToUse = query.type === 'include' ? [query.value] : query.value ?? []; + if (!Array.isArray(filePatternsToUse)) { + throw new Error(`Invalid file pattern provided ${filePatternsToUse}`); + } - const filePatternsToUse = include !== undefined ? [include] : filePatterns; - const queryOptions: QueryOptions[] = filePatternsToUse?.map(filePattern => { + const queryOptions: QueryOptions[] = filePatternsToUse.map(filePattern => { const excludePatterns = globsToISearchPatternBuilder(options.exclude); @@ -514,21 +517,22 @@ export class ExtHostWorkspace implements ExtHostWorkspaceShape, IExtHostWorkspac maxResults: options.maxResults, excludePattern: excludePatterns.length > 0 ? excludePatterns : undefined, _reason: 'startFileSearch', - shouldGlobSearch: include ? undefined : true, + shouldGlobSearch: query.type === 'include' ? undefined : true, }; const parseInclude = parseSearchExcludeInclude(GlobPattern.from(filePattern)); const folderToUse = parseInclude?.folder; - if (include) { + if (query.type === 'include') { fileQueries.includePattern = parseInclude?.pattern; } else { fileQueries.filePattern = parseInclude?.pattern; } + return { folder: folderToUse, options: fileQueries }; - }) ?? []; + }); return this._findFilesBase(queryOptions, token); }