From 042ca571d0d0e5d2627bf493dbc0fa12417949a2 Mon Sep 17 00:00:00 2001 From: Andrew Nolte Date: Sun, 3 Nov 2024 12:05:03 -0500 Subject: [PATCH] more type info on completions --- src/analysis/CtagsServerComponent.ts | 6 +++--- src/analysis/Symbol.ts | 22 ++++++++++++++++++---- 2 files changed, 21 insertions(+), 7 deletions(-) diff --git a/src/analysis/CtagsServerComponent.ts b/src/analysis/CtagsServerComponent.ts index 97bf818..e8a9883 100644 --- a/src/analysis/CtagsServerComponent.ts +++ b/src/analysis/CtagsServerComponent.ts @@ -119,7 +119,7 @@ export class CtagsServerComponent async provideCompletionItems( document: vscode.TextDocument, position: vscode.Position, - _token: vscode.CancellationToken, + token: vscode.CancellationToken, context: vscode.CompletionContext ): Promise { let prevChar = getPrevChar(document, position) @@ -133,7 +133,7 @@ export class CtagsServerComponent const moduleCompletions = await this.provideModuleCompletion( document, position, - _token, + token, context ) this.logger.info(`Returning ${moduleCompletions.length} module completions`) @@ -172,7 +172,7 @@ export class CtagsServerComponent return [] } symbols = await ctags.getPackageSymbols() - this.logger.info(`Found ${symbols.length} completions in package`) + this.logger.info(`Found ${symbols.length} completions in package ${pkgName}`) } else if (context.triggerCharacter === '.') { let parentScope = getParentText(document, new vscode.Range(position, position)) diff --git a/src/analysis/Symbol.ts b/src/analysis/Symbol.ts index 2bcb535..e3207c7 100644 --- a/src/analysis/Symbol.ts +++ b/src/analysis/Symbol.ts @@ -319,7 +319,7 @@ export class Symbol { }, this.getCompletionItemKind() ) - if (!(this.type === 'typedef' || this.type === 'instance')) { + if (!(this.type === 'instance')) { let md = new vscode.MarkdownString() md.appendCodeblock(this.getHoverText(), 'systemverilog') item.documentation = md @@ -328,19 +328,33 @@ export class Symbol { } public getTypeInfo(): string { + // maybe one day ctags will have these if (this.type === 'port') { const hover = this.getHoverText() return hover.substring(0, hover.indexOf(this.name) - 1) } else if (this.type === 'parameter') { return getAssignment(this.doc.getText(this.getFullRange()), this.name, 'parameter') } else if (this.type === 'constant') { - // enum case + // enum child case if (this.parentType === 'typedef') { return this.parentScope.split('.').at(-1) ?? '' } + const text = this.doc.getText(this.getFullRange()) - // localparam case - return getAssignment(this.doc.getText(this.getFullRange()), this.name, 'localparam') + if (text.includes('localparam')) { + return getAssignment(text, this.name, 'localparam') + } else if (text.includes('parameter')) { + return getAssignment(text, this.name, 'parameter') + } + } else if (this.type === 'typedef') { + const text = this.doc.getText(this.getFullRange()) + const assign = getAssignment(text, this.name, 'typedef') + if (assign.startsWith('enum')) { + return 'enum' + } else if (assign.startsWith('struct')) { + return 'struct' + } + return 'typedef ' + assign } return this.typeRef ?? this.type }