diff --git a/crates/rust-analyzer/src/main_loop/handlers.rs b/crates/rust-analyzer/src/main_loop/handlers.rs index 12f8ca2976..f60a3f0a0b 100644 --- a/crates/rust-analyzer/src/main_loop/handlers.rs +++ b/crates/rust-analyzer/src/main_loop/handlers.rs @@ -14,7 +14,7 @@ use lsp_types::{ CodeAction, CodeActionResponse, CodeLens, Command, CompletionItem, Diagnostic, DocumentFormattingParams, DocumentHighlight, DocumentSymbol, FoldingRange, FoldingRangeParams, Hover, HoverContents, Location, MarkupContent, MarkupKind, Position, PrepareRenameResponse, - Range, RenameParams, SemanticTokens, SemanticTokensParams, SemanticTokensRangeParams, + Range, RenameParams, SemanticTokensParams, SemanticTokensRangeParams, SemanticTokensRangeResult, SemanticTokensResult, SymbolInformation, TextDocumentIdentifier, TextEdit, WorkspaceEdit, }; @@ -1145,7 +1145,7 @@ pub fn handle_semantic_tokens( } } - let tokens = SemanticTokens { data: builder.build(), ..Default::default() }; + let tokens = builder.build(); Ok(Some(tokens.into())) } @@ -1166,7 +1166,7 @@ pub fn handle_semantic_tokens_range( builder.push(highlight_range.range.conv_with(&line_index), token_type, token_modifiers); } - let tokens = SemanticTokens { data: builder.build(), ..Default::default() }; + let tokens = builder.build(); Ok(Some(tokens.into())) } diff --git a/crates/rust-analyzer/src/semantic_tokens.rs b/crates/rust-analyzer/src/semantic_tokens.rs index d9ba770509..2a66bbfd85 100644 --- a/crates/rust-analyzer/src/semantic_tokens.rs +++ b/crates/rust-analyzer/src/semantic_tokens.rs @@ -2,7 +2,7 @@ use std::ops; -use lsp_types::{Range, SemanticToken, SemanticTokenModifier, SemanticTokenType}; +use lsp_types::{Range, SemanticToken, SemanticTokenModifier, SemanticTokenType, SemanticTokens}; pub(crate) const ATTRIBUTE: SemanticTokenType = SemanticTokenType::new("attribute"); pub(crate) const BUILTIN_TYPE: SemanticTokenType = SemanticTokenType::new("builtinType"); @@ -109,8 +109,8 @@ impl SemanticTokensBuilder { self.prev_char = range.start.character as u32; } - pub fn build(self) -> Vec { - self.data + pub fn build(self) -> SemanticTokens { + SemanticTokens { result_id: None, data: self.data } } }