Skip to content

Commit

Permalink
Fix #4446, #3312
Browse files Browse the repository at this point in the history
code version 1.26 (2018) added support for custom symbol selection
range through DefinitionLink when providing definitions:
https://code.visualstudio.com/updates/v1_26#_definitionlink

Making use of the interface we don't get unexpected splits of symbols in words anymore.
E.g., before `\ref{fig:abc}` would turn only "fig" or "abc" into a link
when hovering over it with `<Ctrl>` held.

Also addresses the same problem with file names in `\input{abc_def}`.
  • Loading branch information
v4hn committed Oct 25, 2024
1 parent c5eb270 commit a01e6ac
Show file tree
Hide file tree
Showing 3 changed files with 48 additions and 23 deletions.
53 changes: 39 additions & 14 deletions src/language/definition.ts
Original file line number Diff line number Diff line change
Expand Up @@ -40,52 +40,77 @@ export class DefinitionProvider implements vscode.DefinitionProvider {
return
}

async provideDefinition(document: vscode.TextDocument, position: vscode.Position): Promise<vscode.Location | undefined> {
async provideDefinition(document: vscode.TextDocument, position: vscode.Position): Promise<vscode.DefinitionLink[]> {
if (document.uri.scheme !== 'file') {
return
return []
}
const token = tokenizer(document, position)
if (token === undefined) {
return
const tokenRange = tokenizer(document, position)
if (tokenRange === undefined) {
return []
}
const token = document.getText(tokenRange)

if (token.startsWith('\\')) {
const macro = lw.completion.macro.getData().definedCmds.get(token.slice(1))
if (macro) {
return macro.location
return [{
targetUri: macro.location.uri,
targetRange: macro.location.range,
originSelectionRange: tokenRange
}]
}
return
return []
}
const ref = lw.completion.reference.getItem(token)
if (ref) {
return new vscode.Location(vscode.Uri.file(ref.file), ref.position)
return [{
targetUri: vscode.Uri.file(ref.file),
targetRange: new vscode.Range(ref.position, ref.position),
originSelectionRange: tokenRange
}]
}
const cite = lw.completion.citation.getItem(token)
if (cite) {
return new vscode.Location(vscode.Uri.file(cite.file), cite.position)
return [{
targetUri: vscode.Uri.file(cite.file),
targetRange: new vscode.Range(cite.position, cite.position),
originSelectionRange: tokenRange
}]
}
const glossary = lw.completion.glossary.getItem(token)
if (glossary) {
return new vscode.Location(vscode.Uri.file(glossary.filePath), glossary.position)
return [{
targetUri: vscode.Uri.file(glossary.filePath),
targetRange: new vscode.Range(glossary.position, glossary.position),
originSelectionRange: tokenRange
}]
}
if (vscode.window.activeTextEditor && token.includes('.')) {
// We skip graphics files
const graphicsExtensions = ['.pdf', '.eps', '.jpg', '.jpeg', '.JPG', '.JPEG', '.gif', '.png']
const ext = path.extname(token)
if (graphicsExtensions.includes(ext)) {
return
return []
}
const absolutePath = path.resolve(path.dirname(vscode.window.activeTextEditor.document.fileName), token)
if (fs.existsSync(absolutePath)) {
return new vscode.Location( vscode.Uri.file(absolutePath), new vscode.Position(0, 0) )
return [{
targetUri: vscode.Uri.file(absolutePath),
targetRange: new vscode.Range(0, 0, 0, 0),
originSelectionRange: tokenRange
}]
}
}

const filename = await this.onAFilename(document, position, token)
if (filename) {
return new vscode.Location( vscode.Uri.file(filename), new vscode.Position(0, 0) )
return [{
targetUri: vscode.Uri.file(filename),
targetRange: new vscode.Range(0, 0, 0, 0),
originSelectionRange: tokenRange
}]
}
return
return []
}

}
2 changes: 1 addition & 1 deletion src/preview/hover.ts
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ class HoverProvider implements vscode.HoverProvider {
return graphicsHover
}
}
const token = tokenizer(document, position)
const token = document.getText(tokenizer(document, position))
if (!token) {
return
}
Expand Down
16 changes: 8 additions & 8 deletions src/utils/tokenizer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import * as utils from './utils'
* @param document The document to be scanned.
* @param position The position to be scanned at.
*/
function macroTokenizer(document: vscode.TextDocument, position: vscode.Position): string | undefined {
function macroTokenizer(document: vscode.TextDocument, position: vscode.Position): vscode.Range | undefined {
let startRegex: RegExp
if (document.languageId === 'latex-expl3') {
startRegex = /\\(?=[^\\{},[\]]*$)/
Expand All @@ -21,14 +21,14 @@ function macroTokenizer(document: vscode.TextDocument, position: vscode.Position
}
const firstBracket = document.getText(new vscode.Range(position, new vscode.Position(position.line, 65535))).match(/[[{]/)
if (firstBracket && firstBracket.index !== undefined && firstBracket.index > 0) {
return document.getText(new vscode.Range(
return new vscode.Range(
new vscode.Position(position.line, startResult.index),
new vscode.Position(position.line, position.character + firstBracket.index)
)).trim()
)
}
const wordRange = document.getWordRangeAtPosition(position)
if (wordRange) {
return document.getText(wordRange.with(new vscode.Position(position.line, startResult.index))).trim()
return wordRange.with(new vscode.Position(position.line, startResult.index))
}
return
}
Expand All @@ -40,7 +40,7 @@ function macroTokenizer(document: vscode.TextDocument, position: vscode.Position
* @param document The document to be scanned.
* @param position The position to be scanned at.
*/
function argTokenizer(document: vscode.TextDocument, position: vscode.Position): string | undefined {
function argTokenizer(document: vscode.TextDocument, position: vscode.Position): vscode.Range | undefined {
const startResult = document.getText(new vscode.Range(new vscode.Position(position.line, 0), position)).match(/[{,[](?=[^{},[\]]*$)/)
if (startResult === null || startResult.index === undefined || startResult.index < 0) {
return
Expand All @@ -49,10 +49,10 @@ function argTokenizer(document: vscode.TextDocument, position: vscode.Position):
if (endResult === null || endResult.index === undefined || endResult.index < 0) {
return
}
return document.getText(new vscode.Range(
return new vscode.Range(
new vscode.Position(position.line, startResult.index + 1),
new vscode.Position(position.line, position.character + endResult.index)
)).trim()
)
}


Expand All @@ -64,7 +64,7 @@ function argTokenizer(document: vscode.TextDocument, position: vscode.Position):
* @param document The document to be scanned.
* @param position The position to be scanned at.
*/
export function tokenizer(document: vscode.TextDocument, position: vscode.Position): string | undefined {
export function tokenizer(document: vscode.TextDocument, position: vscode.Position): vscode.Range | undefined {
// \macro case
const macroToken = macroTokenizer(document, position)
if (macroToken) {
Expand Down

0 comments on commit a01e6ac

Please sign in to comment.