minor: adjust config name

This commit is contained in:
Aleksey Kladov 2021-05-17 18:37:06 +03:00
parent f9d4a9eaee
commit 41510f437e
8 changed files with 41 additions and 74 deletions

View file

@ -124,6 +124,13 @@ config_data! {
/// These directories will be ignored by rust-analyzer. /// These directories will be ignored by rust-analyzer.
files_excludeDirs: Vec<PathBuf> = "[]", files_excludeDirs: Vec<PathBuf> = "[]",
/// Use semantic tokens for strings.
///
/// In some editors (e.g. vscode) semantic tokens override other highlighting grammars.
/// By disabling semantic tokens for strings, other grammars can be used to highlight
/// their contents.
highlighting_strings: bool = "true",
/// Whether to show `Debug` action. Only applies when /// Whether to show `Debug` action. Only applies when
/// `#rust-analyzer.hoverActions.enable#` is set. /// `#rust-analyzer.hoverActions.enable#` is set.
hoverActions_debug: bool = "true", hoverActions_debug: bool = "true",
@ -208,13 +215,6 @@ config_data! {
/// Advanced option, fully override the command rust-analyzer uses for /// Advanced option, fully override the command rust-analyzer uses for
/// formatting. /// formatting.
rustfmt_overrideCommand: Option<Vec<String>> = "null", rustfmt_overrideCommand: Option<Vec<String>> = "null",
/// Use semantic tokens for strings.
///
/// In some editors (e.g. vscode) semantic tokens override other highlighting grammars.
/// By disabling semantic tokens for strings, other grammars can be used to highlight
/// their contents.
semanticStringTokens: bool = "true",
} }
} }
@ -388,9 +388,6 @@ impl Config {
pub fn line_folding_only(&self) -> bool { pub fn line_folding_only(&self) -> bool {
try_or!(self.caps.text_document.as_ref()?.folding_range.as_ref()?.line_folding_only?, false) try_or!(self.caps.text_document.as_ref()?.folding_range.as_ref()?.line_folding_only?, false)
} }
pub fn semantic_strings(&self) -> bool {
self.data.semanticStringTokens
}
pub fn hierarchical_symbols(&self) -> bool { pub fn hierarchical_symbols(&self) -> bool {
try_or!( try_or!(
self.caps self.caps
@ -665,6 +662,9 @@ impl Config {
refs: self.data.lens_enable && self.data.lens_references, refs: self.data.lens_enable && self.data.lens_references,
} }
} }
pub fn highlighting_strings(&self) -> bool {
self.data.highlighting_strings
}
pub fn hover(&self) -> HoverConfig { pub fn hover(&self) -> HoverConfig {
HoverConfig { HoverConfig {
implementations: self.data.hoverActions_enable implementations: self.data.hoverActions_enable

View file

@ -1394,9 +1394,9 @@ pub(crate) fn handle_semantic_tokens_full(
let line_index = snap.file_line_index(file_id)?; let line_index = snap.file_line_index(file_id)?;
let highlights = snap.analysis.highlight(file_id)?; let highlights = snap.analysis.highlight(file_id)?;
let semantic_strings = snap.config.semantic_strings(); let highlight_strings = snap.config.highlighting_strings();
let semantic_tokens = let semantic_tokens =
to_proto::semantic_tokens(&text, &line_index, highlights, semantic_strings); to_proto::semantic_tokens(&text, &line_index, highlights, highlight_strings);
// Unconditionally cache the tokens // Unconditionally cache the tokens
snap.semantic_tokens_cache.lock().insert(params.text_document.uri, semantic_tokens.clone()); snap.semantic_tokens_cache.lock().insert(params.text_document.uri, semantic_tokens.clone());
@ -1415,9 +1415,9 @@ pub(crate) fn handle_semantic_tokens_full_delta(
let line_index = snap.file_line_index(file_id)?; let line_index = snap.file_line_index(file_id)?;
let highlights = snap.analysis.highlight(file_id)?; let highlights = snap.analysis.highlight(file_id)?;
let semantic_strings = snap.config.semantic_strings(); let highlight_strings = snap.config.highlighting_strings();
let semantic_tokens = let semantic_tokens =
to_proto::semantic_tokens(&text, &line_index, highlights, semantic_strings); to_proto::semantic_tokens(&text, &line_index, highlights, highlight_strings);
let mut cache = snap.semantic_tokens_cache.lock(); let mut cache = snap.semantic_tokens_cache.lock();
let cached_tokens = cache.entry(params.text_document.uri).or_default(); let cached_tokens = cache.entry(params.text_document.uri).or_default();
@ -1446,9 +1446,9 @@ pub(crate) fn handle_semantic_tokens_range(
let line_index = snap.file_line_index(frange.file_id)?; let line_index = snap.file_line_index(frange.file_id)?;
let highlights = snap.analysis.highlight_range(frange)?; let highlights = snap.analysis.highlight_range(frange)?;
let semantic_strings = snap.config.semantic_strings(); let highlight_strings = snap.config.highlighting_strings();
let semantic_tokens = let semantic_tokens =
to_proto::semantic_tokens(&text, &line_index, highlights, semantic_strings); to_proto::semantic_tokens(&text, &line_index, highlights, highlight_strings);
Ok(Some(semantic_tokens.into())) Ok(Some(semantic_tokens.into()))
} }

View file

@ -184,8 +184,8 @@ pub(crate) fn diff_tokens(old: &[SemanticToken], new: &[SemanticToken]) -> Vec<S
} }
} }
pub(crate) fn type_index(type_: SemanticTokenType) -> u32 { pub(crate) fn type_index(ty: SemanticTokenType) -> u32 {
SUPPORTED_TYPES.iter().position(|it| *it == type_).unwrap() as u32 SUPPORTED_TYPES.iter().position(|it| *it == ty).unwrap() as u32
} }
#[cfg(test)] #[cfg(test)]

View file

@ -381,7 +381,7 @@ pub(crate) fn semantic_tokens(
text: &str, text: &str,
line_index: &LineIndex, line_index: &LineIndex,
highlights: Vec<HlRange>, highlights: Vec<HlRange>,
include_strings: bool, highlight_strings: bool,
) -> lsp_types::SemanticTokens { ) -> lsp_types::SemanticTokens {
let id = TOKEN_RESULT_COUNTER.fetch_add(1, Ordering::SeqCst).to_string(); let id = TOKEN_RESULT_COUNTER.fetch_add(1, Ordering::SeqCst).to_string();
let mut builder = semantic_tokens::SemanticTokensBuilder::new(id); let mut builder = semantic_tokens::SemanticTokensBuilder::new(id);
@ -390,11 +390,11 @@ pub(crate) fn semantic_tokens(
if highlight_range.highlight.is_empty() { if highlight_range.highlight.is_empty() {
continue; continue;
} }
let (typ, mods) = semantic_token_type_and_modifiers(highlight_range.highlight); let (ty, mods) = semantic_token_type_and_modifiers(highlight_range.highlight);
if !include_strings && typ == lsp_types::SemanticTokenType::STRING { if !highlight_strings && ty == lsp_types::SemanticTokenType::STRING {
continue; continue;
} }
let token_index = semantic_tokens::type_index(typ); let token_index = semantic_tokens::type_index(ty);
let modifier_bitset = mods.0; let modifier_bitset = mods.0;
for mut text_range in line_index.index.lines(highlight_range.range) { for mut text_range in line_index.index.lines(highlight_range.range) {

View file

@ -38,40 +38,6 @@ use crate::{
const PROFILE: &str = ""; const PROFILE: &str = "";
// const PROFILE: &'static str = "*@3>100"; // const PROFILE: &'static str = "*@3>100";
#[test]
fn can_disable_semantic_strings() {
if skip_slow_tests() {
return;
}
[true, false].iter().for_each(|semantic_strings| {
let server = Project::with_fixture(
r#"
//- /Cargo.toml
[package]
name = "foo"
version = "0.0.0"
//- /src/lib.rs
const foo: &'static str = "hi";
"#,
)
.with_config(serde_json::json!({ "semanticStringTokens": semantic_strings }))
.server()
.wait_until_workspace_is_loaded();
let res = server.send_request::<SemanticTokensRangeRequest>(SemanticTokensRangeParams {
text_document: server.doc_id("src/lib.rs"),
partial_result_params: PartialResultParams::default(),
work_done_progress_params: WorkDoneProgressParams::default(),
range: Range::new(Position::new(0, 26), Position::new(0, 30)),
});
let tok_res: SemanticTokens = from_value(res).expect("invalid server response");
assert!(tok_res.data.len() == *semantic_strings as usize);
});
}
#[test] #[test]
fn completes_items_from_standard_library() { fn completes_items_from_standard_library() {
if skip_slow_tests() { if skip_slow_tests() {

View file

@ -791,13 +791,14 @@ Many names in rust-analyzer conflict with keywords.
We use mangled names instead of `r#ident` syntax: We use mangled names instead of `r#ident` syntax:
``` ```
struct -> strukt
crate -> krate crate -> krate
impl -> imp
trait -> trait_
fn -> func
enum -> enum_ enum -> enum_
fn -> func
impl -> imp
mod -> module mod -> module
struct -> strukt
trait -> trait_
type -> ty
``` ```
**Rationale:** consistency. **Rationale:** consistency.

View file

@ -179,6 +179,15 @@ Controls file watching implementation.
-- --
These directories will be ignored by rust-analyzer. These directories will be ignored by rust-analyzer.
-- --
[[rust-analyzer.highlighting.strings]]rust-analyzer.highlighting.strings (default: `true`)::
+
--
Use semantic tokens for strings.
In some editors (e.g. vscode) semantic tokens override other highlighting grammars.
By disabling semantic tokens for strings, other grammars can be used to highlight
their contents.
--
[[rust-analyzer.hoverActions.debug]]rust-analyzer.hoverActions.debug (default: `true`):: [[rust-analyzer.hoverActions.debug]]rust-analyzer.hoverActions.debug (default: `true`)::
+ +
-- --
@ -332,12 +341,3 @@ Additional arguments to `rustfmt`.
Advanced option, fully override the command rust-analyzer uses for Advanced option, fully override the command rust-analyzer uses for
formatting. formatting.
-- --
[[rust-analyzer.semanticStringTokens]]rust-analyzer.semanticStringTokens (default: `true`)::
+
--
Use semantic tokens for strings.
In some editors (e.g. vscode) semantic tokens override other highlighting grammars.
By disabling semantic tokens for strings, other grammars can be used to highlight
their contents.
--

View file

@ -613,6 +613,11 @@
"type": "string" "type": "string"
} }
}, },
"rust-analyzer.highlighting.strings": {
"markdownDescription": "Use semantic tokens for strings.\n\nIn some editors (e.g. vscode) semantic tokens override other highlighting grammars.\nBy disabling semantic tokens for strings, other grammars can be used to highlight\ntheir contents.",
"default": true,
"type": "boolean"
},
"rust-analyzer.hoverActions.debug": { "rust-analyzer.hoverActions.debug": {
"markdownDescription": "Whether to show `Debug` action. Only applies when\n`#rust-analyzer.hoverActions.enable#` is set.", "markdownDescription": "Whether to show `Debug` action. Only applies when\n`#rust-analyzer.hoverActions.enable#` is set.",
"default": true, "default": true,
@ -778,11 +783,6 @@
"type": "string" "type": "string"
} }
}, },
"rust-analyzer.semanticStringTokens": {
"markdownDescription": "Use semantic tokens for strings.\n\nIn some editors (e.g. vscode) semantic tokens override other highlighting grammars.\nBy disabling semantic tokens for strings, other grammars can be used to highlight\ntheir contents.",
"default": true,
"type": "boolean"
},
"$generated-end": false "$generated-end": false
} }
}, },