From 99f3c2c7e76f9ad06db06ba3775ddb69d2c4d6f6 Mon Sep 17 00:00:00 2001 From: Jackson Kearl Date: Fri, 4 Feb 2022 11:56:13 -0800 Subject: [PATCH] Fix #140280 --- extensions/search-result/src/extension.ts | 21 ++++++++++++--------- 1 file changed, 12 insertions(+), 9 deletions(-) diff --git a/extensions/search-result/src/extension.ts b/extensions/search-result/src/extension.ts index f8253ccb16e..3c397453d04 100644 --- a/extensions/search-result/src/extension.ts +++ b/extensions/search-result/src/extension.ts @@ -227,14 +227,6 @@ function parseSearchResults(document: vscode.TextDocument, token?: vscode.Cancel let locations: Required[] = []; - // Allow line number, indentation, etc to take you to definition as well. - locations.push({ - targetRange, - targetSelectionRange: new vscode.Range(lineNumber, 0, lineNumber, 1), - targetUri: currentTarget, - originSelectionRange: new vscode.Range(i, 0, i, metadataOffset - 1), - }); - let lastEnd = metadataOffset; let offset = 0; ELISION_REGEX.lastIndex = metadataOffset; @@ -258,8 +250,19 @@ function parseSearchResults(document: vscode.TextDocument, token?: vscode.Cancel originSelectionRange: new vscode.Range(i, lastEnd, i, line.length), }); } + // only show result lines in file-level peek + if (separator.includes(':')) { + currentTargetLocations?.push(...locations); + } - currentTargetLocations?.push(...locations); + // Allow line number, indentation, etc to take you to definition as well. + let convenienceLocation: Required = { + targetRange, + targetSelectionRange: new vscode.Range(lineNumber, 0, lineNumber, 1), + targetUri: currentTarget, + originSelectionRange: new vscode.Range(i, 0, i, metadataOffset - 1), + }; + locations.push(convenienceLocation); links[i] = { type: 'result', locations, isContext: separator === ' ', prefixRange: new vscode.Range(i, 0, i, metadataOffset) }; } }