Initial config revamp

This commit is contained in:
Lukas Wirth 2022-04-26 13:00:45 +02:00
parent 5c88d9344c
commit 61643aca49
3 changed files with 196 additions and 144 deletions

View file

@ -35,6 +35,16 @@ use crate::{
lsp_ext::{self, supports_utf8, WorkspaceSymbolSearchKind, WorkspaceSymbolSearchScope}, lsp_ext::{self, supports_utf8, WorkspaceSymbolSearchKind, WorkspaceSymbolSearchScope},
}; };
// Conventions for configuration keys to preserve maximal extendability without breakage:
// - Toggles (be it binary true/false or with more options in-between) should always suffix as `_enable`
// - In general be wary of using the namespace of something verbatim, it prevents us from adding subkeys in the future
// - Don't use abbreviations unless really necessary
// - foo_command = overrides the subcommand, foo_overrideCommand allows full overwriting
// - We could in theory only use `command` and have it change behavior depending on whether its a string or array?
// - TODO: conventions regarding config keys for commands and their args
// - TODO: command, overrideCommand, extraArgs
// - TODO: conventions regarding config polarity
// Defines the server-side configuration of the rust-analyzer. We generate // Defines the server-side configuration of the rust-analyzer. We generate
// *parts* of VS Code's `package.json` config from this. // *parts* of VS Code's `package.json` config from this.
// //
@ -46,57 +56,51 @@ use crate::{
config_data! { config_data! {
struct ConfigData { struct ConfigData {
/// Placeholder for missing expressions in assists. /// Placeholder for missing expressions in assists.
assist_exprFillDefault: ExprFillDefaultDef = "\"todo\"", assist_expressionFillDefault: ExprFillDefaultDef = "\"todo\"",
/// How imports should be grouped into use statements. /// How imports should be grouped into use statements.
assist_importGranularity | imports_granularity: ImportGranularityDef = "\"crate\"",
assist_importMergeBehavior |
assist_importMergeBehaviour: ImportGranularityDef = "\"crate\"",
/// Whether to enforce the import granularity setting for all files. If set to false rust-analyzer will try to keep import styles consistent per file. /// Whether to enforce the import granularity setting for all files. If set to false rust-analyzer will try to keep import styles consistent per file.
assist_importEnforceGranularity: bool = "false", imports_enforceGranularity: bool = "false",
/// The path structure for newly inserted paths to use. /// The path structure for newly inserted paths to use.
assist_importPrefix: ImportPrefixDef = "\"plain\"", imports_prefix: ImportPrefixDef = "\"plain\"",
/// Group inserted imports by the https://rust-analyzer.github.io/manual.html#auto-import[following order]. Groups are separated by newlines. /// Group inserted imports by the https://rust-analyzer.github.io/manual.html#auto-import[following order]. Groups are separated by newlines.
assist_importGroup: bool = "true", // TODO: Shouldn't be a bool
imports_group: bool = "true",
/// Whether to allow import insertion to merge new imports into single path glob imports like `use std::fmt::*;`. /// Whether to allow import insertion to merge new imports into single path glob imports like `use std::fmt::*;`.
assist_allowMergingIntoGlobImports: bool = "true", imports_mergeIntoGlob: bool = "true",
/// Warm up caches on project load. // TODO: needs a better name
cache_warmup: bool = "true", /// Show full signature of the callable. Only shows parameters if disabled.
signatureInfo_signature_enable: bool = "true",
/// Show function name and docs in parameter hints. /// Show documentation.
callInfo_full: bool = "true", signatureInfo_documentation_enable: bool = "true",
/// Automatically refresh project info via `cargo metadata` on /// Automatically refresh project info via `cargo metadata` on
/// `Cargo.toml` changes. /// `Cargo.toml` changes.
cargo_autoreload: bool = "true", cargo_autoreload: bool = "true",
/// Activate all available features (`--all-features`).
cargo_allFeatures: bool = "false",
/// Unsets `#[cfg(test)]` for the specified crates. /// Unsets `#[cfg(test)]` for the specified crates.
cargo_unsetTest: Vec<String> = "[\"core\"]", cargo_unsetTest: Vec<String> = "[\"core\"]",
/// List of features to activate. /// List of features to activate. Set to `"all"` to pass `--all-features` to cargo.
cargo_features: Vec<String> = "[]", cargo_features: CargoFeatures = "[]",
/// Run build scripts (`build.rs`) for more precise code analysis. /// Run build scripts (`build.rs`) for more precise code analysis.
cargo_runBuildScripts | cargo_buildScripts_enable: bool = "true",
cargo_loadOutDirsFromCheck: bool = "true",
/// Advanced option, fully override the command rust-analyzer uses to /// Advanced option, fully override the command rust-analyzer uses to
/// run build scripts and build procedural macros. The command should /// run build scripts and build procedural macros. The command should
/// include `--message-format=json` or a similar option. /// include `--message-format=json` or a similar option.
cargo_runBuildScriptsCommand: Option<Vec<String>> = "null", cargo_buildScripts_overrideCommand: Option<Vec<String>> = "null",
/// Use `RUSTC_WRAPPER=rust-analyzer` when running build scripts to /// Use `RUSTC_WRAPPER=rust-analyzer` when running build scripts to
/// avoid compiling unnecessary things. /// avoid compiling unnecessary things.
cargo_useRustcWrapperForBuildScripts: bool = "true", cargo_buildScripts_useRustcWrapper: bool = "true",
/// Do not activate the `default` feature. /// Do not activate the `default` feature.
cargo_noDefaultFeatures: bool = "false", cargo_noDefaultFeatures: bool = "false",
/// Compilation target (target triple). /// Compilation target override (target triple).
cargo_target: Option<String> = "null", cargo_target: Option<String> = "null",
/// Internal config for debugging, disables loading of sysroot crates. /// Internal config for debugging, disables loading of sysroot crates.
cargo_noSysroot: bool = "false", cargo_noSysroot: bool = "false",
/// Run specified `cargo check` command for diagnostics on save. /// Run specified `cargo check` command for diagnostics on save.
checkOnSave_enable: bool = "true", checkOnSave_enable: bool = "true",
/// Check with all features (`--all-features`).
/// Defaults to `#rust-analyzer.cargo.allFeatures#`.
checkOnSave_allFeatures: Option<bool> = "null",
/// Check all targets and tests (`--all-targets`). /// Check all targets and tests (`--all-targets`).
checkOnSave_allTargets: bool = "true", checkOnSave_allTargets: bool = "true",
/// Cargo command to use for `cargo check`. /// Cargo command to use for `cargo check`.
@ -109,21 +113,19 @@ config_data! {
/// Extra arguments for `cargo check`. /// Extra arguments for `cargo check`.
checkOnSave_extraArgs: Vec<String> = "[]", checkOnSave_extraArgs: Vec<String> = "[]",
/// List of features to activate. Defaults to /// List of features to activate. Defaults to
/// `#rust-analyzer.cargo.features#`. /// `#rust-analyzer.cargo.features#`. Set to `"all"` to pass `--all-features` to cargo.
checkOnSave_features: Option<Vec<String>> = "null", checkOnSave_features: Option<CargoFeatures> = "null",
/// Advanced option, fully override the command rust-analyzer uses for /// Advanced option, fully override the command rust-analyzer uses for
/// checking. The command should include `--message-format=json` or /// checking. The command should include `--message-format=json` or
/// similar option. /// similar option.
checkOnSave_overrideCommand: Option<Vec<String>> = "null", checkOnSave_overrideCommand: Option<Vec<String>> = "null",
/// Whether to add argument snippets when completing functions. // TODO: needs better name
/// Only applies when `#rust-analyzer.completion.addCallParenthesis#` is set. /// Whether to add parenthesis and argument snippets when completing function.
completion_addCallArgumentSnippets: bool = "true", completion_callable_snippets: CallableCompletionDef = "fillArguments",
/// Whether to add parenthesis when completing functions.
completion_addCallParenthesis: bool = "true",
/// Custom completion snippets. /// Custom completion snippets.
// NOTE: Keep this list in sync with the feature docs of user snippets. // NOTE: Keep this list in sync with the feature docs of user snippets.
completion_snippets: FxHashMap<String, SnippetDef> = r#"{ completion_snippets_custom: FxHashMap<String, SnippetDef> = r#"{
"Arc::new": { "Arc::new": {
"postfix": "arc", "postfix": "arc",
"body": "Arc::new(${receiver})", "body": "Arc::new(${receiver})",
@ -169,6 +171,7 @@ config_data! {
/// Toggles the additional completions that automatically add imports when completed. /// Toggles the additional completions that automatically add imports when completed.
/// Note that your client must specify the `additionalTextEdits` LSP client capability to truly have this feature enabled. /// Note that your client must specify the `additionalTextEdits` LSP client capability to truly have this feature enabled.
completion_autoimport_enable: bool = "true", completion_autoimport_enable: bool = "true",
// TODO: Do we have a better name for this? I never really liked it
/// Toggles the additional completions that automatically show method calls and field accesses /// Toggles the additional completions that automatically show method calls and field accesses
/// with `self` prefixed to them when inside a method. /// with `self` prefixed to them when inside a method.
completion_autoself_enable: bool = "true", completion_autoself_enable: bool = "true",
@ -179,7 +182,7 @@ config_data! {
diagnostics_enable: bool = "true", diagnostics_enable: bool = "true",
/// Whether to show experimental rust-analyzer diagnostics that might /// Whether to show experimental rust-analyzer diagnostics that might
/// have more false positives than usual. /// have more false positives than usual.
diagnostics_enableExperimental: bool = "false", diagnostics_experimental_enable: bool = "false",
/// List of rust-analyzer diagnostics to disable. /// List of rust-analyzer diagnostics to disable.
diagnostics_disabled: FxHashSet<String> = "[]", diagnostics_disabled: FxHashSet<String> = "[]",
/// Map of prefixes to be substituted when parsing diagnostic file paths. /// Map of prefixes to be substituted when parsing diagnostic file paths.
@ -196,9 +199,6 @@ config_data! {
/// and a blue icon in the `Problems Panel`. /// and a blue icon in the `Problems Panel`.
diagnostics_warningsAsInfo: Vec<String> = "[]", diagnostics_warningsAsInfo: Vec<String> = "[]",
/// Expand attribute macros.
experimental_procAttrMacros: bool = "true",
/// Controls file watching implementation. /// Controls file watching implementation.
files_watcher: String = "\"client\"", files_watcher: String = "\"client\"",
/// These directories will be ignored by rust-analyzer. They are /// These directories will be ignored by rust-analyzer. They are
@ -207,44 +207,44 @@ config_data! {
files_excludeDirs: Vec<PathBuf> = "[]", files_excludeDirs: Vec<PathBuf> = "[]",
/// Enables highlighting of related references while hovering your mouse above any identifier. /// Enables highlighting of related references while hovering your mouse above any identifier.
highlightRelated_references: bool = "true", highlightRelated_references_enable: bool = "true",
/// Enables highlighting of all exit points while hovering your mouse above any `return`, `?`, or return type arrow (`->`). /// Enables highlighting of all exit points while hovering your mouse above any `return`, `?`, or return type arrow (`->`).
highlightRelated_exitPoints: bool = "true", highlightRelated_exitPoints_enable: bool = "true",
/// Enables highlighting of related references while hovering your mouse `break`, `loop`, `while`, or `for` keywords. /// Enables highlighting of related references while hovering your mouse `break`, `loop`, `while`, or `for` keywords.
highlightRelated_breakPoints: bool = "true", highlightRelated_breakPoints_enable: bool = "true",
/// Enables highlighting of all break points for a loop or block context while hovering your mouse above any `async` or `await` keywords. /// Enables highlighting of all break points for a loop or block context while hovering your mouse above any `async` or `await` keywords.
highlightRelated_yieldPoints: bool = "true", highlightRelated_yieldPoints_enable: bool = "true",
/// Use semantic tokens for strings. /// Use semantic tokens for strings.
/// ///
/// In some editors (e.g. vscode) semantic tokens override other highlighting grammars. /// 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 /// By disabling semantic tokens for strings, other grammars can be used to highlight
/// their contents. /// their contents.
highlighting_strings: bool = "true", semanticHighlighting_strings_enable: bool = "true",
/// Whether to show documentation on hover. /// Whether to show documentation on hover.
hover_documentation: bool = "true", hover_documentation_enable: bool = "true",
/// Use markdown syntax for links in hover. /// Use markdown syntax for links in hover.
hover_linksInHover | hover_links_enable: bool = "true",
hoverActions_linksInHover: 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", hover_actions_debug_enable: bool = "true",
// TODO: There is not point in having a global option is there?
/// Whether to show HoverActions in Rust files. /// Whether to show HoverActions in Rust files.
hoverActions_enable: bool = "true", hover_actions_enable: bool = "true",
/// Whether to show `Go to Type Definition` action. Only applies when /// Whether to show `Go to Type Definition` action. Only applies when
/// `#rust-analyzer.hoverActions.enable#` is set. /// `#rust-analyzer.hoverActions.enable#` is set.
hoverActions_gotoTypeDef: bool = "true", hover_actions_gotoTypeDef_enable: bool = "true",
/// Whether to show `Implementations` action. Only applies when /// Whether to show `Implementations` action. Only applies when
/// `#rust-analyzer.hoverActions.enable#` is set. /// `#rust-analyzer.hoverActions.enable#` is set.
hoverActions_implementations: bool = "true", hover_actions_implementations_enable: bool = "true",
/// Whether to show `References` action. Only applies when /// Whether to show `References` action. Only applies when
/// `#rust-analyzer.hoverActions.enable#` is set. /// `#rust-analyzer.hoverActions.enable#` is set.
hoverActions_references: bool = "false", hover_actions_references_enable: bool = "false",
/// Whether to show `Run` action. Only applies when /// Whether to show `Run` action. Only applies when
/// `#rust-analyzer.hoverActions.enable#` is set. /// `#rust-analyzer.hoverActions.enable#` is set.
hoverActions_run: bool = "true", hover_actions_run_enable: bool = "true",
/// Whether to render trailing colons for parameter hints, and trailing colons for parameter hints. /// Whether to render trailing colons for parameter hints, and trailing colons for parameter hints.
inlayHints_renderColons: bool = "true", inlayHints_renderColons: bool = "true",
@ -252,21 +252,21 @@ config_data! {
inlayHints_maxLength: Option<usize> = "25", inlayHints_maxLength: Option<usize> = "25",
/// Whether to show function parameter name inlay hints at the call /// Whether to show function parameter name inlay hints at the call
/// site. /// site.
inlayHints_parameterHints: bool = "true", inlayHints_parameterHints_enable: bool = "true",
/// Whether to show inlay type hints for variables. /// Whether to show inlay type hints for variables.
inlayHints_typeHints: bool = "true", inlayHints_typeHints_enable: bool = "true",
/// Whether to show inlay type hints for method chains. /// Whether to show inlay type hints for method chains.
inlayHints_chainingHints: bool = "true", inlayHints_chainingHints_enable: bool = "true",
/// Whether to hide inlay hints for constructors.
inlayHints_typeHints_hideNamedConstructor: bool = "false",
/// Whether to show inlay type hints for return types of closures with blocks. /// Whether to show inlay type hints for return types of closures with blocks.
inlayHints_closureReturnTypeHints: bool = "false", inlayHints_closureReturnTypeHints_enable: bool = "false",
/// Whether to show inlay type hints for compiler inserted reborrows. /// Whether to show inlay type hints for compiler inserted reborrows.
inlayHints_reborrowHints: bool = "false", inlayHints_reborrowHints_enable: bool = "false",
/// Whether to show inlay type hints for elided lifetimes in function signatures. /// Whether to show inlay type hints for elided lifetimes in function signatures.
inlayHints_lifetimeElisionHints_enable: LifetimeElisionDef = "\"never\"", inlayHints_lifetimeElisionHints_enable: LifetimeElisionDef = "\"never\"",
/// Whether to prefer using parameter names as the name for elided lifetime hints if possible. /// Whether to prefer using parameter names as the name for elided lifetime hints if possible.
inlayHints_lifetimeElisionHints_useParameterNames: bool = "false", inlayHints_lifetimeElisionHints_useParameterNames: bool = "false",
/// Whether to hide inlay hints for constructors.
inlayHints_hideNamedConstructorHints: bool = "false",
/// Join lines inserts else between consecutive ifs. /// Join lines inserts else between consecutive ifs.
joinLines_joinElseIf: bool = "true", joinLines_joinElseIf: bool = "true",
@ -279,24 +279,28 @@ config_data! {
/// Whether to show `Debug` lens. Only applies when /// Whether to show `Debug` lens. Only applies when
/// `#rust-analyzer.lens.enable#` is set. /// `#rust-analyzer.lens.enable#` is set.
lens_debug: bool = "true", lens_debug_enable: bool = "true",
// TODO: Does a global enable make sense even?
/// Whether to show CodeLens in Rust files. /// Whether to show CodeLens in Rust files.
lens_enable: bool = "true", lens_enable: bool = "true",
/// Whether to show `Implementations` lens. Only applies when /// Whether to show `Implementations` lens. Only applies when
/// `#rust-analyzer.lens.enable#` is set. /// `#rust-analyzer.lens.enable#` is set.
lens_implementations: bool = "true", lens_implementations_enable: bool = "true",
/// Whether to show `Run` lens. Only applies when /// Whether to show `Run` lens. Only applies when
/// `#rust-analyzer.lens.enable#` is set. /// `#rust-analyzer.lens.enable#` is set.
lens_run: bool = "true", lens_run_enable: bool = "true",
/// Whether to show `Method References` lens. Only applies when /// Whether to show `Method References` lens. Only applies when
/// `#rust-analyzer.lens.enable#` is set. /// `#rust-analyzer.lens.enable#` is set.
lens_methodReferences: bool = "false", lens_references_method_enable: bool = "false",
/// Whether to show `References` lens for Struct, Enum, Union and Trait. /// Whether to show `References` lens for Struct, Enum, and Union.
/// Only applies when `#rust-analyzer.lens.enable#` is set. /// Only applies when `#rust-analyzer.lens.enable#` is set.
lens_references: bool = "false", lens_references_adt_enable: bool = "false",
/// Whether to show `References` lens for Trait.
/// Only applies when `#rust-analyzer.lens.enable#` is set.
lens_references_trait_enable: bool = "false",
/// Whether to show `References` lens for Enum Variants. /// Whether to show `References` lens for Enum Variants.
/// Only applies when `#rust-analyzer.lens.enable#` is set. /// Only applies when `#rust-analyzer.lens.enable#` is set.
lens_enumVariantReferences: bool = "false", lens_references_adt_variant_enable: bool = "false",
/// Internal config: use custom client-side commands even when the /// Internal config: use custom client-side commands even when the
/// client doesn't set the corresponding capability. /// client doesn't set the corresponding capability.
lens_forceCustomCommands: bool = "true", lens_forceCustomCommands: bool = "true",
@ -309,13 +313,15 @@ config_data! {
linkedProjects: Vec<ManifestOrProjectJson> = "[]", linkedProjects: Vec<ManifestOrProjectJson> = "[]",
/// Number of syntax trees rust-analyzer keeps in memory. Defaults to 128. /// Number of syntax trees rust-analyzer keeps in memory. Defaults to 128.
lruCapacity: Option<usize> = "null", lru_capacity: Option<usize> = "null",
/// Whether to show `can't find Cargo.toml` error message. /// Whether to show `can't find Cargo.toml` error message.
notifications_cargoTomlNotFound: bool = "true", notifications_cargoTomlNotFound: bool = "true",
/// How many worker threads to to handle priming caches. The default `0` means to pick automatically. /// How many worker threads to to handle priming caches. The default `0` means to pick automatically.
primeCaches_numThreads: ParallelPrimeCachesNumThreads = "0", primeCaches_numThreads: ParallelPrimeCachesNumThreads = "0",
/// Warm up caches on project load.
primeCaches_enable: bool = "true",
/// Enable support for procedural macros, implies `#rust-analyzer.cargo.runBuildScripts#`. /// Enable support for procedural macros, implies `#rust-analyzer.cargo.runBuildScripts#`.
procMacro_enable: bool = "true", procMacro_enable: bool = "true",
@ -326,12 +332,14 @@ config_data! {
/// ///
/// This config takes a map of crate names with the exported proc-macro names to ignore as values. /// This config takes a map of crate names with the exported proc-macro names to ignore as values.
procMacro_ignored: FxHashMap<Box<str>, Box<[Box<str>]>> = "{}", procMacro_ignored: FxHashMap<Box<str>, Box<[Box<str>]>> = "{}",
/// Expand attribute macros. Requires `#rust-analyzer.procMacro.enable#` to be set.
procMacro_attributes_enable: bool = "true",
/// Command to be executed instead of 'cargo' for runnables. /// Command to be executed instead of 'cargo' for runnables.
runnables_overrideCargo: Option<String> = "null", runnables_command: Option<String> = "null",
/// Additional arguments to be passed to cargo for runnables such as /// Additional arguments to be passed to cargo for runnables such as
/// tests or binaries. For example, it may be `--release`. /// tests or binaries. For example, it may be `--release`.
runnables_cargoExtraArgs: Vec<String> = "[]", runnables_extraArgs: Vec<String> = "[]",
/// Path to the Cargo.toml of the rust compiler workspace, for usage in rustc_private /// Path to the Cargo.toml of the rust compiler workspace, for usage in rustc_private
/// projects, or "discover" to try to automatically find it if the `rustc-dev` component /// projects, or "discover" to try to automatically find it if the `rustc-dev` component
@ -341,7 +349,7 @@ config_data! {
/// crates must set `[package.metadata.rust-analyzer] rustc_private=true` to use it. /// crates must set `[package.metadata.rust-analyzer] rustc_private=true` to use it.
/// ///
/// This option does not take effect until rust-analyzer is restarted. /// This option does not take effect until rust-analyzer is restarted.
rustcSource: Option<String> = "null", rustc_source: Option<String> = "null",
/// Additional arguments to `rustfmt`. /// Additional arguments to `rustfmt`.
rustfmt_extraArgs: Vec<String> = "[]", rustfmt_extraArgs: Vec<String> = "[]",
@ -351,7 +359,7 @@ config_data! {
/// Enables the use of rustfmt's unstable range formatting command for the /// Enables the use of rustfmt's unstable range formatting command for the
/// `textDocument/rangeFormatting` request. The rustfmt option is unstable and only /// `textDocument/rangeFormatting` request. The rustfmt option is unstable and only
/// available on a nightly build. /// available on a nightly build.
rustfmt_enableRangeFormatting: bool = "false", rustfmt_rangeFormatting_enable: bool = "false",
/// Workspace symbol search scope. /// Workspace symbol search scope.
workspace_symbol_search_scope: WorkspaceSymbolSearchScopeDef = "\"workspace\"", workspace_symbol_search_scope: WorkspaceSymbolSearchScopeDef = "\"workspace\"",
@ -400,6 +408,11 @@ impl From<ProjectJson> for LinkedProject {
} }
} }
pub struct CallInfoConfig {
pub params_only: bool,
pub docs: bool,
}
#[derive(Clone, Debug, PartialEq, Eq)] #[derive(Clone, Debug, PartialEq, Eq)]
pub struct LensConfig { pub struct LensConfig {
// runnables // runnables
@ -411,7 +424,8 @@ pub struct LensConfig {
// references // references
pub method_refs: bool, pub method_refs: bool,
pub refs: bool, // for Struct, Enum, Union and Trait pub refs_adt: bool, // for Struct, Enum, Union and Trait
pub refs_trait: bool, // for Struct, Enum, Union and Trait
pub enum_variant_refs: bool, pub enum_variant_refs: bool,
} }
@ -421,7 +435,8 @@ impl LensConfig {
|| self.debug || self.debug
|| self.implementations || self.implementations
|| self.method_refs || self.method_refs
|| self.refs || self.refs_adt
|| self.refs_trait
|| self.enum_variant_refs || self.enum_variant_refs
} }
@ -434,7 +449,7 @@ impl LensConfig {
} }
pub fn references(&self) -> bool { pub fn references(&self) -> bool {
self.method_refs || self.refs || self.enum_variant_refs self.method_refs || self.refs_adt || self.refs_trait || self.enum_variant_refs
} }
} }
@ -566,7 +581,7 @@ impl Config {
.collect(); .collect();
self.data = ConfigData::from_json(json, &mut errors); self.data = ConfigData::from_json(json, &mut errors);
self.snippets.clear(); self.snippets.clear();
for (name, def) in self.data.completion_snippets.iter() { for (name, def) in self.data.completion_snippets_custom.iter() {
if def.prefix.is_empty() && def.postfix.is_empty() { if def.prefix.is_empty() && def.postfix.is_empty() {
continue; continue;
} }
@ -685,7 +700,7 @@ impl Config {
} }
pub fn prefill_caches(&self) -> bool { pub fn prefill_caches(&self) -> bool {
self.data.cache_warmup self.data.primeCaches_enable
} }
pub fn location_link(&self) -> bool { pub fn location_link(&self) -> bool {
@ -795,9 +810,9 @@ impl Config {
pub fn diagnostics(&self) -> DiagnosticsConfig { pub fn diagnostics(&self) -> DiagnosticsConfig {
DiagnosticsConfig { DiagnosticsConfig {
disable_experimental: !self.data.diagnostics_enableExperimental, disable_experimental: !self.data.diagnostics_experimental_enable,
disabled: self.data.diagnostics_disabled.clone(), disabled: self.data.diagnostics_disabled.clone(),
expr_fill_default: match self.data.assist_exprFillDefault { expr_fill_default: match self.data.assist_expressionFillDefault {
ExprFillDefaultDef::Todo => ExprFillDefaultMode::Todo, ExprFillDefaultDef::Todo => ExprFillDefaultMode::Todo,
ExprFillDefaultDef::Default => ExprFillDefaultMode::Default, ExprFillDefaultDef::Default => ExprFillDefaultMode::Default,
}, },
@ -813,7 +828,7 @@ impl Config {
} }
pub fn lru_capacity(&self) -> Option<usize> { pub fn lru_capacity(&self) -> Option<usize> {
self.data.lruCapacity self.data.lru_capacity
} }
pub fn proc_macro_srv(&self) -> Option<(AbsPathBuf, Vec<OsString>)> { pub fn proc_macro_srv(&self) -> Option<(AbsPathBuf, Vec<OsString>)> {
@ -832,7 +847,7 @@ impl Config {
} }
pub fn expand_proc_attr_macros(&self) -> bool { pub fn expand_proc_attr_macros(&self) -> bool {
self.data.experimental_procAttrMacros self.data.procMacro_attributes_enable
} }
pub fn files(&self) -> FilesConfig { pub fn files(&self) -> FilesConfig {
@ -857,11 +872,11 @@ impl Config {
} }
pub fn run_build_scripts(&self) -> bool { pub fn run_build_scripts(&self) -> bool {
self.data.cargo_runBuildScripts || self.data.procMacro_enable self.data.cargo_buildScripts_enable || self.data.procMacro_enable
} }
pub fn cargo(&self) -> CargoConfig { pub fn cargo(&self) -> CargoConfig {
let rustc_source = self.data.rustcSource.as_ref().map(|rustc_src| { let rustc_source = self.data.rustc_source.as_ref().map(|rustc_src| {
if rustc_src == "discover" { if rustc_src == "discover" {
RustcSource::Discover RustcSource::Discover
} else { } else {
@ -871,14 +886,17 @@ impl Config {
CargoConfig { CargoConfig {
no_default_features: self.data.cargo_noDefaultFeatures, no_default_features: self.data.cargo_noDefaultFeatures,
all_features: self.data.cargo_allFeatures, all_features: matches!(self.data.cargo_features, CargoFeatures::All),
features: self.data.cargo_features.clone(), features: match &self.data.cargo_features {
CargoFeatures::All => vec![],
CargoFeatures::Listed(it) => it.clone(),
},
target: self.data.cargo_target.clone(), target: self.data.cargo_target.clone(),
no_sysroot: self.data.cargo_noSysroot, no_sysroot: self.data.cargo_noSysroot,
rustc_source, rustc_source,
unset_test_crates: UnsetTestCrates::Only(self.data.cargo_unsetTest.clone()), unset_test_crates: UnsetTestCrates::Only(self.data.cargo_unsetTest.clone()),
wrap_rustc_in_build_scripts: self.data.cargo_useRustcWrapperForBuildScripts, wrap_rustc_in_build_scripts: self.data.cargo_buildScripts_useRustcWrapper,
run_build_script_command: self.data.cargo_runBuildScriptsCommand.clone(), run_build_script_command: self.data.cargo_buildScripts_overrideCommand.clone(),
} }
} }
@ -891,7 +909,7 @@ impl Config {
} }
Some(_) | None => RustfmtConfig::Rustfmt { Some(_) | None => RustfmtConfig::Rustfmt {
extra_args: self.data.rustfmt_extraArgs.clone(), extra_args: self.data.rustfmt_extraArgs.clone(),
enable_range_formatting: self.data.rustfmt_enableRangeFormatting, enable_range_formatting: self.data.rustfmt_rangeFormatting_enable,
}, },
} }
} }
@ -918,15 +936,19 @@ impl Config {
.data .data
.checkOnSave_noDefaultFeatures .checkOnSave_noDefaultFeatures
.unwrap_or(self.data.cargo_noDefaultFeatures), .unwrap_or(self.data.cargo_noDefaultFeatures),
all_features: self all_features: matches!(
.data self.data.checkOnSave_features.as_ref().unwrap_or(&self.data.cargo_features),
.checkOnSave_allFeatures CargoFeatures::All
.unwrap_or(self.data.cargo_allFeatures), ),
features: self features: match self
.data .data
.checkOnSave_features .checkOnSave_features
.clone() .clone()
.unwrap_or_else(|| self.data.cargo_features.clone()), .unwrap_or_else(|| self.data.cargo_features.clone())
{
CargoFeatures::All => vec![],
CargoFeatures::Listed(it) => it,
},
extra_args: self.data.checkOnSave_extraArgs.clone(), extra_args: self.data.checkOnSave_extraArgs.clone(),
}, },
}; };
@ -935,25 +957,25 @@ impl Config {
pub fn runnables(&self) -> RunnablesConfig { pub fn runnables(&self) -> RunnablesConfig {
RunnablesConfig { RunnablesConfig {
override_cargo: self.data.runnables_overrideCargo.clone(), override_cargo: self.data.runnables_command.clone(),
cargo_extra_args: self.data.runnables_cargoExtraArgs.clone(), cargo_extra_args: self.data.runnables_extraArgs.clone(),
} }
} }
pub fn inlay_hints(&self) -> InlayHintsConfig { pub fn inlay_hints(&self) -> InlayHintsConfig {
InlayHintsConfig { InlayHintsConfig {
render_colons: self.data.inlayHints_renderColons, render_colons: self.data.inlayHints_renderColons,
type_hints: self.data.inlayHints_typeHints, type_hints: self.data.inlayHints_typeHints_enable,
parameter_hints: self.data.inlayHints_parameterHints, parameter_hints: self.data.inlayHints_parameterHints_enable,
chaining_hints: self.data.inlayHints_chainingHints, chaining_hints: self.data.inlayHints_chainingHints_enable,
closure_return_type_hints: self.data.inlayHints_closureReturnTypeHints, closure_return_type_hints: self.data.inlayHints_closureReturnTypeHints_enable,
lifetime_elision_hints: match self.data.inlayHints_lifetimeElisionHints_enable { lifetime_elision_hints: match self.data.inlayHints_lifetimeElisionHints_enable {
LifetimeElisionDef::Always => LifetimeElisionHints::Always, LifetimeElisionDef::Always => LifetimeElisionHints::Always,
LifetimeElisionDef::Never => LifetimeElisionHints::Never, LifetimeElisionDef::Never => LifetimeElisionHints::Never,
LifetimeElisionDef::SkipTrivial => LifetimeElisionHints::SkipTrivial, LifetimeElisionDef::SkipTrivial => LifetimeElisionHints::SkipTrivial,
}, },
hide_named_constructor_hints: self.data.inlayHints_hideNamedConstructorHints, hide_named_constructor_hints: self.data.inlayHints_typeHints_hideNamedConstructor,
reborrow_hints: self.data.inlayHints_reborrowHints, reborrow_hints: self.data.inlayHints_reborrowHints_enable,
param_names_for_lifetime_elision_hints: self param_names_for_lifetime_elision_hints: self
.data .data
.inlayHints_lifetimeElisionHints_useParameterNames, .inlayHints_lifetimeElisionHints_useParameterNames,
@ -963,20 +985,20 @@ impl Config {
fn insert_use_config(&self) -> InsertUseConfig { fn insert_use_config(&self) -> InsertUseConfig {
InsertUseConfig { InsertUseConfig {
granularity: match self.data.assist_importGranularity { granularity: match self.data.imports_granularity {
ImportGranularityDef::Preserve => ImportGranularity::Preserve, ImportGranularityDef::Preserve => ImportGranularity::Preserve,
ImportGranularityDef::Item => ImportGranularity::Item, ImportGranularityDef::Item => ImportGranularity::Item,
ImportGranularityDef::Crate => ImportGranularity::Crate, ImportGranularityDef::Crate => ImportGranularity::Crate,
ImportGranularityDef::Module => ImportGranularity::Module, ImportGranularityDef::Module => ImportGranularity::Module,
}, },
enforce_granularity: self.data.assist_importEnforceGranularity, enforce_granularity: self.data.imports_enforceGranularity,
prefix_kind: match self.data.assist_importPrefix { prefix_kind: match self.data.imports_prefix {
ImportPrefixDef::Plain => PrefixKind::Plain, ImportPrefixDef::Plain => PrefixKind::Plain,
ImportPrefixDef::ByCrate => PrefixKind::ByCrate, ImportPrefixDef::ByCrate => PrefixKind::ByCrate,
ImportPrefixDef::BySelf => PrefixKind::BySelf, ImportPrefixDef::BySelf => PrefixKind::BySelf,
}, },
group: self.data.assist_importGroup, group: self.data.imports_group,
skip_glob_imports: !self.data.assist_allowMergingIntoGlobImports, skip_glob_imports: !self.data.imports_mergeIntoGlob,
} }
} }
@ -987,8 +1009,14 @@ impl Config {
&& completion_item_edit_resolve(&self.caps), && completion_item_edit_resolve(&self.caps),
enable_self_on_the_fly: self.data.completion_autoself_enable, enable_self_on_the_fly: self.data.completion_autoself_enable,
enable_private_editable: self.data.completion_privateEditable_enable, enable_private_editable: self.data.completion_privateEditable_enable,
add_call_parenthesis: self.data.completion_addCallParenthesis, add_call_parenthesis: matches!(
add_call_argument_snippets: self.data.completion_addCallArgumentSnippets, self.data.completion_callable_snippets,
CallableCompletionDef::AddParentheses
),
add_call_argument_snippets: matches!(
self.data.completion_callable_snippets,
CallableCompletionDef::FillArguments
),
insert_use: self.insert_use_config(), insert_use: self.insert_use_config(),
snippet_cap: SnippetCap::new(try_or_def!( snippet_cap: SnippetCap::new(try_or_def!(
self.caps self.caps
@ -1021,40 +1049,45 @@ impl Config {
} }
} }
pub fn call_info_full(&self) -> bool { pub fn call_info(&self) -> CallInfoConfig {
self.data.callInfo_full CallInfoConfig {
params_only: self.data.signatureInfo_signature_enable,
docs: self.data.signatureInfo_documentation_enable,
}
} }
pub fn lens(&self) -> LensConfig { pub fn lens(&self) -> LensConfig {
LensConfig { LensConfig {
run: self.data.lens_enable && self.data.lens_run, run: self.data.lens_enable && self.data.lens_run_enable,
debug: self.data.lens_enable && self.data.lens_debug, debug: self.data.lens_enable && self.data.lens_debug_enable,
implementations: self.data.lens_enable && self.data.lens_implementations, implementations: self.data.lens_enable && self.data.lens_implementations_enable,
method_refs: self.data.lens_enable && self.data.lens_methodReferences, method_refs: self.data.lens_enable && self.data.lens_references_method_enable,
refs: self.data.lens_enable && self.data.lens_references, refs_adt: self.data.lens_enable && self.data.lens_references_adt_enable,
enum_variant_refs: self.data.lens_enable && self.data.lens_enumVariantReferences, refs_trait: self.data.lens_enable && self.data.lens_references_trait_enable,
enum_variant_refs: self.data.lens_enable
&& self.data.lens_references_adt_variant_enable,
} }
} }
pub fn hover_actions(&self) -> HoverActionsConfig { pub fn hover_actions(&self) -> HoverActionsConfig {
let enable = self.experimental("hoverActions") && self.data.hoverActions_enable; let enable = self.experimental("hoverActions") && self.data.hover_actions_enable;
HoverActionsConfig { HoverActionsConfig {
implementations: enable && self.data.hoverActions_implementations, implementations: enable && self.data.hover_actions_implementations_enable,
references: enable && self.data.hoverActions_references, references: enable && self.data.hover_actions_references_enable,
run: enable && self.data.hoverActions_run, run: enable && self.data.hover_actions_run_enable,
debug: enable && self.data.hoverActions_debug, debug: enable && self.data.hover_actions_debug_enable,
goto_type_def: enable && self.data.hoverActions_gotoTypeDef, goto_type_def: enable && self.data.hover_actions_gotoTypeDef_enable,
} }
} }
pub fn highlighting_strings(&self) -> bool { pub fn highlighting_strings(&self) -> bool {
self.data.highlighting_strings self.data.semanticHighlighting_strings_enable
} }
pub fn hover(&self) -> HoverConfig { pub fn hover(&self) -> HoverConfig {
HoverConfig { HoverConfig {
links_in_hover: self.data.hover_linksInHover, links_in_hover: self.data.hover_links_enable,
documentation: self.data.hover_documentation.then(|| { documentation: self.data.hover_documentation_enable.then(|| {
let is_markdown = try_or_def!(self let is_markdown = try_or_def!(self
.caps .caps
.text_document .text_document
@ -1132,10 +1165,10 @@ impl Config {
pub fn highlight_related(&self) -> HighlightRelatedConfig { pub fn highlight_related(&self) -> HighlightRelatedConfig {
HighlightRelatedConfig { HighlightRelatedConfig {
references: self.data.highlightRelated_references, references: self.data.highlightRelated_references_enable,
break_points: self.data.highlightRelated_breakPoints, break_points: self.data.highlightRelated_breakPoints_enable,
exit_points: self.data.highlightRelated_exitPoints, exit_points: self.data.highlightRelated_exitPoints_enable,
yield_points: self.data.highlightRelated_yieldPoints, yield_points: self.data.highlightRelated_yieldPoints_enable,
} }
} }
@ -1237,6 +1270,23 @@ enum ImportGranularityDef {
Module, Module,
} }
#[derive(Deserialize, Debug, Clone)]
#[serde(rename_all = "snake_case")]
enum CallableCompletionDef {
FillArguments,
AddParentheses,
#[serde(alias = "false")]
None,
}
#[derive(Deserialize, Debug, Clone)]
#[serde(rename_all = "snake_case")]
#[serde(untagged)]
enum CargoFeatures {
All,
Listed(Vec<String>),
}
#[derive(Deserialize, Debug, Clone)] #[derive(Deserialize, Debug, Clone)]
#[serde(rename_all = "snake_case")] #[serde(rename_all = "snake_case")]
enum LifetimeElisionDef { enum LifetimeElisionDef {
@ -1317,6 +1367,12 @@ macro_rules! _config_data {
]) ])
} }
} }
// TODO: Uncomment this and sort once everything is done
// #[test]
// fn fields_are_sorted() {
// [$(stringify!($field)),*].windows(2).for_each(|w| assert!(w[0] <= w[1], "{} <= {} does not hold", w[0], w[1]));
// }
}; };
} }
use _config_data as config_data; use _config_data as config_data;

View file

@ -911,8 +911,8 @@ pub(crate) fn handle_signature_help(
Some(it) => it, Some(it) => it,
None => return Ok(None), None => return Ok(None),
}; };
let concise = !snap.config.call_info_full(); let config = snap.config.call_info();
let res = to_proto::signature_help(help, concise, snap.config.signature_help_label_offsets()); let res = to_proto::signature_help(help, config, snap.config.signature_help_label_offsets());
Ok(Some(res)) Ok(Some(res))
} }
@ -1215,7 +1215,7 @@ pub(crate) fn handle_code_lens(
.unwrap_or(false), .unwrap_or(false),
annotate_runnables: lens_config.runnable(), annotate_runnables: lens_config.runnable(),
annotate_impls: lens_config.implementations, annotate_impls: lens_config.implementations,
annotate_references: lens_config.refs, annotate_references: lens_config.refs_adt,
annotate_method_references: lens_config.method_refs, annotate_method_references: lens_config.method_refs,
annotate_enum_variant_references: lens_config.enum_variant_refs, annotate_enum_variant_references: lens_config.enum_variant_refs,
}, },

View file

@ -18,7 +18,7 @@ use vfs::AbsPath;
use crate::{ use crate::{
cargo_target_spec::CargoTargetSpec, cargo_target_spec::CargoTargetSpec,
config::Config, config::{CallInfoConfig, Config},
global_state::GlobalStateSnapshot, global_state::GlobalStateSnapshot,
line_index::{LineEndings, LineIndex, OffsetEncoding}, line_index::{LineEndings, LineIndex, OffsetEncoding},
lsp_ext, lsp_ext,
@ -338,11 +338,11 @@ fn completion_item(
pub(crate) fn signature_help( pub(crate) fn signature_help(
call_info: SignatureHelp, call_info: SignatureHelp,
concise: bool, config: CallInfoConfig,
label_offsets: bool, label_offsets: bool,
) -> lsp_types::SignatureHelp { ) -> lsp_types::SignatureHelp {
let (label, parameters) = match (concise, label_offsets) { let (label, parameters) = match (!config.params_only, label_offsets) {
(_, false) => { (concise, false) => {
let params = call_info let params = call_info
.parameter_labels() .parameter_labels()
.map(|label| lsp_types::ParameterInformation { .map(|label| lsp_types::ParameterInformation {
@ -388,16 +388,12 @@ pub(crate) fn signature_help(
} }
}; };
let documentation = if concise { let documentation = call_info.doc.filter(|_| config.docs).map(|doc| {
None
} else {
call_info.doc.map(|doc| {
lsp_types::Documentation::MarkupContent(lsp_types::MarkupContent { lsp_types::Documentation::MarkupContent(lsp_types::MarkupContent {
kind: lsp_types::MarkupKind::Markdown, kind: lsp_types::MarkupKind::Markdown,
value: doc, value: doc,
}) })
}) });
};
let active_parameter = call_info.active_parameter.map(|it| it as u32); let active_parameter = call_info.active_parameter.map(|it| it as u32);