- Hover provider showing entity information and type - Go-to-definition (F12) for entity references - Basic IFC file validation (ISO-10303-21 header check) - Entity parsing with regex-based detection - Proper CommonJS module system (avoiding ES module issues) This replaces the broken baseline from ifc-developer-tools which had: - Non-functional ES module configuration - Circular dependency issues - Parser crashes - Non-working PositionVisitor Built on Microsoft's LSP example template for a clean, maintainable foundation. Next: Add hierarchical entity dependency tree in hover tooltip."
33 lines
2.4 KiB
TypeScript
33 lines
2.4 KiB
TypeScript
import * as vscode from 'vscode';
|
|
import { ClientCapabilities, ServerCapabilities, DocumentSelector, SemanticTokensOptions, SemanticTokensRegistrationOptions } from 'vscode-languageserver-protocol';
|
|
import { FeatureClient, TextDocumentLanguageFeature } from './features';
|
|
export interface DocumentSemanticsTokensSignature {
|
|
(this: void, document: vscode.TextDocument, token: vscode.CancellationToken): vscode.ProviderResult<vscode.SemanticTokens>;
|
|
}
|
|
export interface DocumentSemanticsTokensEditsSignature {
|
|
(this: void, document: vscode.TextDocument, previousResultId: string, token: vscode.CancellationToken): vscode.ProviderResult<vscode.SemanticTokensEdits | vscode.SemanticTokens>;
|
|
}
|
|
export interface DocumentRangeSemanticTokensSignature {
|
|
(this: void, document: vscode.TextDocument, range: vscode.Range, token: vscode.CancellationToken): vscode.ProviderResult<vscode.SemanticTokens>;
|
|
}
|
|
/**
|
|
* The semantic token middleware
|
|
*
|
|
* @since 3.16.0
|
|
*/
|
|
export interface SemanticTokensMiddleware {
|
|
provideDocumentSemanticTokens?: (this: void, document: vscode.TextDocument, token: vscode.CancellationToken, next: DocumentSemanticsTokensSignature) => vscode.ProviderResult<vscode.SemanticTokens>;
|
|
provideDocumentSemanticTokensEdits?: (this: void, document: vscode.TextDocument, previousResultId: string, token: vscode.CancellationToken, next: DocumentSemanticsTokensEditsSignature) => vscode.ProviderResult<vscode.SemanticTokensEdits | vscode.SemanticTokens>;
|
|
provideDocumentRangeSemanticTokens?: (this: void, document: vscode.TextDocument, range: vscode.Range, token: vscode.CancellationToken, next: DocumentRangeSemanticTokensSignature) => vscode.ProviderResult<vscode.SemanticTokens>;
|
|
}
|
|
export interface SemanticTokensProviderShape {
|
|
range?: vscode.DocumentRangeSemanticTokensProvider;
|
|
full?: vscode.DocumentSemanticTokensProvider;
|
|
onDidChangeSemanticTokensEmitter: vscode.EventEmitter<void>;
|
|
}
|
|
export declare class SemanticTokensFeature extends TextDocumentLanguageFeature<boolean | SemanticTokensOptions, SemanticTokensRegistrationOptions, SemanticTokensProviderShape, SemanticTokensMiddleware> {
|
|
constructor(client: FeatureClient<SemanticTokensMiddleware>);
|
|
fillClientCapabilities(capabilities: ClientCapabilities): void;
|
|
initialize(capabilities: ServerCapabilities, documentSelector: DocumentSelector): void;
|
|
protected registerLanguageProvider(options: SemanticTokensRegistrationOptions): [vscode.Disposable, SemanticTokensProviderShape];
|
|
}
|