From 3b61acb4ae15a1ec6071db40e09437319795db67 Mon Sep 17 00:00:00 2001 From: Wilco Kusee Date: Fri, 18 Oct 2019 13:40:03 +0200 Subject: [PATCH] Make inlay hint length configurable --- editors/code/package.json | 5 +++ editors/code/src/commands/inlay_hints.ts | 40 +++++++++++++++--------- editors/code/src/config.ts | 6 ++++ 3 files changed, 37 insertions(+), 14 deletions(-) diff --git a/editors/code/package.json b/editors/code/package.json index b9982c624a..35211bcc23 100644 --- a/editors/code/package.json +++ b/editors/code/package.json @@ -260,6 +260,11 @@ "type": "boolean", "default": true, "description": "Display additional type information in the editor" + }, + "rust-analyzer.maxInlayHintLength": { + "type": "number", + "default": 20, + "description": "Maximum length for inlay hints" } } }, diff --git a/editors/code/src/commands/inlay_hints.ts b/editors/code/src/commands/inlay_hints.ts index 3157c04c8b..454a464d4a 100644 --- a/editors/code/src/commands/inlay_hints.ts +++ b/editors/code/src/commands/inlay_hints.ts @@ -13,8 +13,6 @@ interface InlayHint { label: string; } -const maxHintLength = 20; - const typeHintDecorationType = vscode.window.createTextEditorDecorationType({ after: { color: new vscode.ThemeColor('ralsp.inlayHint') @@ -86,12 +84,12 @@ export class HintsUpdater { const newHints = await this.queryHints(editor.document.uri.toString()); if (newHints !== null) { const newDecorations = newHints.map(hint => { - let label = hint.label.substring(0, maxHintLength); - if (hint.label.length > maxHintLength) { - label += '…'; - } + const [label, range] = this.truncateHint( + hint.label, + hint.range + ); return { - range: this.truncateHint(hint.range), + range, renderOptions: { after: { contentText: `: ${label}` @@ -106,16 +104,30 @@ export class HintsUpdater { } } - private truncateHint(range: Range): Range { - if (!range.isSingleLine) { - return range; + private truncateHint( + label: string, + range: vscode.Range + ): [string, vscode.Range] { + if (!Server.config.maxInlayHintLength) { + return [label, range]; } - const maxEnd = new vscode.Position( + + let newLabel = label.substring(0, Server.config.maxInlayHintLength); + if (label.length > Server.config.maxInlayHintLength) { + newLabel += '…'; + } + + range = new vscode.Range( range.start.line, - range.start.character + maxHintLength + range.start.character, + range.end.line, + Math.min( + range.start.character + Server.config.maxInlayHintLength, + range.end.character + ) ); - const end = range.end.isAfter(maxEnd) ? maxEnd : range.end; - return new Range(range.start, end); + + return [newLabel, range]; } private async queryHints(documentUri: string): Promise { diff --git a/editors/code/src/config.ts b/editors/code/src/config.ts index a4581485cc..2578bc6d10 100644 --- a/editors/code/src/config.ts +++ b/editors/code/src/config.ts @@ -22,6 +22,7 @@ export class Config { public showWorkspaceLoadedNotification = true; public lruCapacity: null | number = null; public displayInlayHints = true; + public maxInlayHintLength: null | number = null; public excludeGlobs = []; public useClientWatching = false; public featureFlags = {}; @@ -131,6 +132,11 @@ export class Config { if (config.has('displayInlayHints')) { this.displayInlayHints = config.get('displayInlayHints') as boolean; } + if (config.has('maxInlayHintLength')) { + this.maxInlayHintLength = config.get( + 'maxInlayHintLength' + ) as number; + } if (config.has('excludeGlobs')) { this.excludeGlobs = config.get('excludeGlobs') || []; }