mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-19 08:34:09 +00:00
Auto merge of #11985 - Veykril:config-valid, r=Veykril
minor: Simplify config.rs a bit
This commit is contained in:
commit
5620d25972
1 changed files with 96 additions and 50 deletions
|
@ -380,6 +380,8 @@ pub struct Config {
|
||||||
snippets: Vec<Snippet>,
|
snippets: Vec<Snippet>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type ParallelPrimeCachesNumThreads = u8;
|
||||||
|
|
||||||
#[derive(Debug, Clone, Eq, PartialEq)]
|
#[derive(Debug, Clone, Eq, PartialEq)]
|
||||||
pub enum LinkedProject {
|
pub enum LinkedProject {
|
||||||
ProjectManifest(ProjectManifest),
|
ProjectManifest(ProjectManifest),
|
||||||
|
@ -400,9 +402,14 @@ impl From<ProjectJson> for LinkedProject {
|
||||||
|
|
||||||
#[derive(Clone, Debug, PartialEq, Eq)]
|
#[derive(Clone, Debug, PartialEq, Eq)]
|
||||||
pub struct LensConfig {
|
pub struct LensConfig {
|
||||||
|
// runnables
|
||||||
pub run: bool,
|
pub run: bool,
|
||||||
pub debug: bool,
|
pub debug: bool,
|
||||||
|
|
||||||
|
// implementations
|
||||||
pub implementations: bool,
|
pub implementations: bool,
|
||||||
|
|
||||||
|
// references
|
||||||
pub method_refs: bool,
|
pub method_refs: bool,
|
||||||
pub refs: bool, // for Struct, Enum, Union and Trait
|
pub refs: bool, // for Struct, Enum, Union and Trait
|
||||||
pub enum_variant_refs: bool,
|
pub enum_variant_refs: bool,
|
||||||
|
@ -410,7 +417,12 @@ pub struct LensConfig {
|
||||||
|
|
||||||
impl LensConfig {
|
impl LensConfig {
|
||||||
pub fn any(&self) -> bool {
|
pub fn any(&self) -> bool {
|
||||||
self.implementations || self.runnable() || self.references()
|
self.run
|
||||||
|
|| self.debug
|
||||||
|
|| self.implementations
|
||||||
|
|| self.method_refs
|
||||||
|
|| self.refs
|
||||||
|
|| self.enum_variant_refs
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn none(&self) -> bool {
|
pub fn none(&self) -> bool {
|
||||||
|
@ -623,6 +635,12 @@ macro_rules! try_or {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
macro_rules! try_or_def {
|
||||||
|
($expr:expr) => {
|
||||||
|
try_!($expr).unwrap_or_default()
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
impl Config {
|
impl Config {
|
||||||
pub fn linked_projects(&self) -> Vec<LinkedProject> {
|
pub fn linked_projects(&self) -> Vec<LinkedProject> {
|
||||||
match self.data.linkedProjects.as_slice() {
|
match self.data.linkedProjects.as_slice() {
|
||||||
|
@ -651,14 +669,13 @@ impl Config {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn did_save_text_document_dynamic_registration(&self) -> bool {
|
pub fn did_save_text_document_dynamic_registration(&self) -> bool {
|
||||||
let caps =
|
let caps = try_or_def!(self.caps.text_document.as_ref()?.synchronization.clone()?);
|
||||||
try_or!(self.caps.text_document.as_ref()?.synchronization.clone()?, Default::default());
|
|
||||||
caps.did_save == Some(true) && caps.dynamic_registration == Some(true)
|
caps.did_save == Some(true) && caps.dynamic_registration == Some(true)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn did_change_watched_files_dynamic_registration(&self) -> bool {
|
pub fn did_change_watched_files_dynamic_registration(&self) -> bool {
|
||||||
try_or!(
|
try_or_def!(
|
||||||
self.caps.workspace.as_ref()?.did_change_watched_files.as_ref()?.dynamic_registration?,
|
self.caps.workspace.as_ref()?.did_change_watched_files.as_ref()?.dynamic_registration?
|
||||||
false
|
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -667,22 +684,24 @@ impl Config {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn location_link(&self) -> bool {
|
pub fn location_link(&self) -> bool {
|
||||||
try_or!(self.caps.text_document.as_ref()?.definition?.link_support?, false)
|
try_or_def!(self.caps.text_document.as_ref()?.definition?.link_support?)
|
||||||
}
|
}
|
||||||
|
|
||||||
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_def!(self.caps.text_document.as_ref()?.folding_range.as_ref()?.line_folding_only?)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn hierarchical_symbols(&self) -> bool {
|
pub fn hierarchical_symbols(&self) -> bool {
|
||||||
try_or!(
|
try_or_def!(
|
||||||
self.caps
|
self.caps
|
||||||
.text_document
|
.text_document
|
||||||
.as_ref()?
|
.as_ref()?
|
||||||
.document_symbol
|
.document_symbol
|
||||||
.as_ref()?
|
.as_ref()?
|
||||||
.hierarchical_document_symbol_support?,
|
.hierarchical_document_symbol_support?
|
||||||
false
|
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn code_action_literals(&self) -> bool {
|
pub fn code_action_literals(&self) -> bool {
|
||||||
try_!(self
|
try_!(self
|
||||||
.caps
|
.caps
|
||||||
|
@ -694,12 +713,15 @@ impl Config {
|
||||||
.as_ref()?)
|
.as_ref()?)
|
||||||
.is_some()
|
.is_some()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn work_done_progress(&self) -> bool {
|
pub fn work_done_progress(&self) -> bool {
|
||||||
try_or!(self.caps.window.as_ref()?.work_done_progress?, false)
|
try_or_def!(self.caps.window.as_ref()?.work_done_progress?)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn will_rename(&self) -> bool {
|
pub fn will_rename(&self) -> bool {
|
||||||
try_or!(self.caps.workspace.as_ref()?.file_operations.as_ref()?.will_rename?, false)
|
try_or_def!(self.caps.workspace.as_ref()?.file_operations.as_ref()?.will_rename?)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn change_annotation_support(&self) -> bool {
|
pub fn change_annotation_support(&self) -> bool {
|
||||||
try_!(self
|
try_!(self
|
||||||
.caps
|
.caps
|
||||||
|
@ -711,9 +733,10 @@ impl Config {
|
||||||
.as_ref()?)
|
.as_ref()?)
|
||||||
.is_some()
|
.is_some()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn code_action_resolve(&self) -> bool {
|
pub fn code_action_resolve(&self) -> bool {
|
||||||
try_or!(
|
try_or_def!(self
|
||||||
self.caps
|
.caps
|
||||||
.text_document
|
.text_document
|
||||||
.as_ref()?
|
.as_ref()?
|
||||||
.code_action
|
.code_action
|
||||||
|
@ -721,14 +744,13 @@ impl Config {
|
||||||
.resolve_support
|
.resolve_support
|
||||||
.as_ref()?
|
.as_ref()?
|
||||||
.properties
|
.properties
|
||||||
.as_slice(),
|
.as_slice())
|
||||||
&[]
|
|
||||||
)
|
|
||||||
.iter()
|
.iter()
|
||||||
.any(|it| it == "edit")
|
.any(|it| it == "edit")
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn signature_help_label_offsets(&self) -> bool {
|
pub fn signature_help_label_offsets(&self) -> bool {
|
||||||
try_or!(
|
try_or_def!(
|
||||||
self.caps
|
self.caps
|
||||||
.text_document
|
.text_document
|
||||||
.as_ref()?
|
.as_ref()?
|
||||||
|
@ -738,10 +760,10 @@ impl Config {
|
||||||
.as_ref()?
|
.as_ref()?
|
||||||
.parameter_information
|
.parameter_information
|
||||||
.as_ref()?
|
.as_ref()?
|
||||||
.label_offset_support?,
|
.label_offset_support?
|
||||||
false
|
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn offset_encoding(&self) -> OffsetEncoding {
|
pub fn offset_encoding(&self) -> OffsetEncoding {
|
||||||
if supports_utf8(&self.caps) {
|
if supports_utf8(&self.caps) {
|
||||||
OffsetEncoding::Utf8
|
OffsetEncoding::Utf8
|
||||||
|
@ -751,11 +773,13 @@ impl Config {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn experimental(&self, index: &'static str) -> bool {
|
fn experimental(&self, index: &'static str) -> bool {
|
||||||
try_or!(self.caps.experimental.as_ref()?.get(index)?.as_bool()?, false)
|
try_or_def!(self.caps.experimental.as_ref()?.get(index)?.as_bool()?)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn code_action_group(&self) -> bool {
|
pub fn code_action_group(&self) -> bool {
|
||||||
self.experimental("codeActionGroup")
|
self.experimental("codeActionGroup")
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn server_status_notification(&self) -> bool {
|
pub fn server_status_notification(&self) -> bool {
|
||||||
self.experimental("serverStatusNotification")
|
self.experimental("serverStatusNotification")
|
||||||
}
|
}
|
||||||
|
@ -763,6 +787,7 @@ impl Config {
|
||||||
pub fn publish_diagnostics(&self) -> bool {
|
pub fn publish_diagnostics(&self) -> bool {
|
||||||
self.data.diagnostics_enable
|
self.data.diagnostics_enable
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn diagnostics(&self) -> DiagnosticsConfig {
|
pub fn diagnostics(&self) -> DiagnosticsConfig {
|
||||||
DiagnosticsConfig {
|
DiagnosticsConfig {
|
||||||
disable_experimental: !self.data.diagnostics_enableExperimental,
|
disable_experimental: !self.data.diagnostics_enableExperimental,
|
||||||
|
@ -773,6 +798,7 @@ impl Config {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn diagnostics_map(&self) -> DiagnosticsMapConfig {
|
pub fn diagnostics_map(&self) -> DiagnosticsMapConfig {
|
||||||
DiagnosticsMapConfig {
|
DiagnosticsMapConfig {
|
||||||
remap_prefix: self.data.diagnostics_remapPrefix.clone(),
|
remap_prefix: self.data.diagnostics_remapPrefix.clone(),
|
||||||
|
@ -780,9 +806,11 @@ impl Config {
|
||||||
warnings_as_hint: self.data.diagnostics_warningsAsHint.clone(),
|
warnings_as_hint: self.data.diagnostics_warningsAsHint.clone(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn lru_capacity(&self) -> Option<usize> {
|
pub fn lru_capacity(&self) -> Option<usize> {
|
||||||
self.data.lruCapacity
|
self.data.lruCapacity
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn proc_macro_srv(&self) -> Option<(AbsPathBuf, Vec<OsString>)> {
|
pub fn proc_macro_srv(&self) -> Option<(AbsPathBuf, Vec<OsString>)> {
|
||||||
if !self.data.procMacro_enable {
|
if !self.data.procMacro_enable {
|
||||||
return None;
|
return None;
|
||||||
|
@ -793,12 +821,15 @@ impl Config {
|
||||||
};
|
};
|
||||||
Some((path, vec!["proc-macro".into()]))
|
Some((path, vec!["proc-macro".into()]))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn dummy_replacements(&self) -> &FxHashMap<Box<str>, Box<[Box<str>]>> {
|
pub fn dummy_replacements(&self) -> &FxHashMap<Box<str>, Box<[Box<str>]>> {
|
||||||
&self.data.procMacro_ignored
|
&self.data.procMacro_ignored
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn expand_proc_attr_macros(&self) -> bool {
|
pub fn expand_proc_attr_macros(&self) -> bool {
|
||||||
self.data.experimental_procAttrMacros
|
self.data.experimental_procAttrMacros
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn files(&self) -> FilesConfig {
|
pub fn files(&self) -> FilesConfig {
|
||||||
FilesConfig {
|
FilesConfig {
|
||||||
watcher: match self.data.files_watcher.as_str() {
|
watcher: match self.data.files_watcher.as_str() {
|
||||||
|
@ -811,15 +842,19 @@ impl Config {
|
||||||
exclude: self.data.files_excludeDirs.iter().map(|it| self.root_path.join(it)).collect(),
|
exclude: self.data.files_excludeDirs.iter().map(|it| self.root_path.join(it)).collect(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn notifications(&self) -> NotificationsConfig {
|
pub fn notifications(&self) -> NotificationsConfig {
|
||||||
NotificationsConfig { cargo_toml_not_found: self.data.notifications_cargoTomlNotFound }
|
NotificationsConfig { cargo_toml_not_found: self.data.notifications_cargoTomlNotFound }
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn cargo_autoreload(&self) -> bool {
|
pub fn cargo_autoreload(&self) -> bool {
|
||||||
self.data.cargo_autoreload
|
self.data.cargo_autoreload
|
||||||
}
|
}
|
||||||
|
|
||||||
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_runBuildScripts || 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.rustcSource.as_ref().map(|rustc_src| {
|
||||||
if rustc_src == "discover" {
|
if rustc_src == "discover" {
|
||||||
|
@ -855,6 +890,7 @@ impl Config {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn flycheck(&self) -> Option<FlycheckConfig> {
|
pub fn flycheck(&self) -> Option<FlycheckConfig> {
|
||||||
if !self.data.checkOnSave_enable {
|
if !self.data.checkOnSave_enable {
|
||||||
return None;
|
return None;
|
||||||
|
@ -891,12 +927,14 @@ impl Config {
|
||||||
};
|
};
|
||||||
Some(flycheck_config)
|
Some(flycheck_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_overrideCargo.clone(),
|
||||||
cargo_extra_args: self.data.runnables_cargoExtraArgs.clone(),
|
cargo_extra_args: self.data.runnables_cargoExtraArgs.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,
|
||||||
|
@ -917,6 +955,7 @@ impl Config {
|
||||||
max_length: self.data.inlayHints_maxLength,
|
max_length: self.data.inlayHints_maxLength,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn insert_use_config(&self) -> InsertUseConfig {
|
fn insert_use_config(&self) -> InsertUseConfig {
|
||||||
InsertUseConfig {
|
InsertUseConfig {
|
||||||
granularity: match self.data.assist_importGranularity {
|
granularity: match self.data.assist_importGranularity {
|
||||||
|
@ -935,6 +974,7 @@ impl Config {
|
||||||
skip_glob_imports: !self.data.assist_allowMergingIntoGlobImports,
|
skip_glob_imports: !self.data.assist_allowMergingIntoGlobImports,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn completion(&self) -> CompletionConfig {
|
pub fn completion(&self) -> CompletionConfig {
|
||||||
CompletionConfig {
|
CompletionConfig {
|
||||||
enable_postfix_completions: self.data.completion_postfix_enable,
|
enable_postfix_completions: self.data.completion_postfix_enable,
|
||||||
|
@ -945,7 +985,7 @@ impl Config {
|
||||||
add_call_parenthesis: self.data.completion_addCallParenthesis,
|
add_call_parenthesis: self.data.completion_addCallParenthesis,
|
||||||
add_call_argument_snippets: self.data.completion_addCallArgumentSnippets,
|
add_call_argument_snippets: self.data.completion_addCallArgumentSnippets,
|
||||||
insert_use: self.insert_use_config(),
|
insert_use: self.insert_use_config(),
|
||||||
snippet_cap: SnippetCap::new(try_or!(
|
snippet_cap: SnippetCap::new(try_or_def!(
|
||||||
self.caps
|
self.caps
|
||||||
.text_document
|
.text_document
|
||||||
.as_ref()?
|
.as_ref()?
|
||||||
|
@ -953,12 +993,12 @@ impl Config {
|
||||||
.as_ref()?
|
.as_ref()?
|
||||||
.completion_item
|
.completion_item
|
||||||
.as_ref()?
|
.as_ref()?
|
||||||
.snippet_support?,
|
.snippet_support?
|
||||||
false
|
|
||||||
)),
|
)),
|
||||||
snippets: self.snippets.clone(),
|
snippets: self.snippets.clone(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn assist(&self) -> AssistConfig {
|
pub fn assist(&self) -> AssistConfig {
|
||||||
AssistConfig {
|
AssistConfig {
|
||||||
snippet_cap: SnippetCap::new(self.experimental("snippetTextEdit")),
|
snippet_cap: SnippetCap::new(self.experimental("snippetTextEdit")),
|
||||||
|
@ -966,6 +1006,7 @@ impl Config {
|
||||||
insert_use: self.insert_use_config(),
|
insert_use: self.insert_use_config(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn join_lines(&self) -> JoinLinesConfig {
|
pub fn join_lines(&self) -> JoinLinesConfig {
|
||||||
JoinLinesConfig {
|
JoinLinesConfig {
|
||||||
join_else_if: self.data.joinLines_joinElseIf,
|
join_else_if: self.data.joinLines_joinElseIf,
|
||||||
|
@ -974,9 +1015,11 @@ impl Config {
|
||||||
join_assignments: self.data.joinLines_joinAssignments,
|
join_assignments: self.data.joinLines_joinAssignments,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn call_info_full(&self) -> bool {
|
pub fn call_info_full(&self) -> bool {
|
||||||
self.data.callInfo_full
|
self.data.callInfo_full
|
||||||
}
|
}
|
||||||
|
|
||||||
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,
|
||||||
|
@ -987,6 +1030,7 @@ impl Config {
|
||||||
enum_variant_refs: self.data.lens_enable && self.data.lens_enumVariantReferences,
|
enum_variant_refs: self.data.lens_enable && self.data.lens_enumVariantReferences,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
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.hoverActions_enable;
|
||||||
HoverActionsConfig {
|
HoverActionsConfig {
|
||||||
|
@ -997,24 +1041,24 @@ impl Config {
|
||||||
goto_type_def: enable && self.data.hoverActions_gotoTypeDef,
|
goto_type_def: enable && self.data.hoverActions_gotoTypeDef,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn highlighting_strings(&self) -> bool {
|
pub fn highlighting_strings(&self) -> bool {
|
||||||
self.data.highlighting_strings
|
self.data.highlighting_strings
|
||||||
}
|
}
|
||||||
|
|
||||||
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_linksInHover,
|
||||||
documentation: self.data.hover_documentation.then(|| {
|
documentation: self.data.hover_documentation.then(|| {
|
||||||
let is_markdown = try_or!(
|
let is_markdown = try_or_def!(self
|
||||||
self.caps
|
.caps
|
||||||
.text_document
|
.text_document
|
||||||
.as_ref()?
|
.as_ref()?
|
||||||
.hover
|
.hover
|
||||||
.as_ref()?
|
.as_ref()?
|
||||||
.content_format
|
.content_format
|
||||||
.as_ref()?
|
.as_ref()?
|
||||||
.as_slice(),
|
.as_slice())
|
||||||
&[]
|
|
||||||
)
|
|
||||||
.contains(&MarkupKind::Markdown);
|
.contains(&MarkupKind::Markdown);
|
||||||
if is_markdown {
|
if is_markdown {
|
||||||
HoverDocFormat::Markdown
|
HoverDocFormat::Markdown
|
||||||
|
@ -1042,13 +1086,15 @@ impl Config {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn semantic_tokens_refresh(&self) -> bool {
|
pub fn semantic_tokens_refresh(&self) -> bool {
|
||||||
try_or!(self.caps.workspace.as_ref()?.semantic_tokens.as_ref()?.refresh_support?, false)
|
try_or_def!(self.caps.workspace.as_ref()?.semantic_tokens.as_ref()?.refresh_support?)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn code_lens_refresh(&self) -> bool {
|
pub fn code_lens_refresh(&self) -> bool {
|
||||||
try_or!(self.caps.workspace.as_ref()?.code_lens.as_ref()?.refresh_support?, false)
|
try_or_def!(self.caps.workspace.as_ref()?.code_lens.as_ref()?.refresh_support?)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn insert_replace_support(&self) -> bool {
|
pub fn insert_replace_support(&self) -> bool {
|
||||||
try_or!(
|
try_or_def!(
|
||||||
self.caps
|
self.caps
|
||||||
.text_document
|
.text_document
|
||||||
.as_ref()?
|
.as_ref()?
|
||||||
|
@ -1056,10 +1102,10 @@ impl Config {
|
||||||
.as_ref()?
|
.as_ref()?
|
||||||
.completion_item
|
.completion_item
|
||||||
.as_ref()?
|
.as_ref()?
|
||||||
.insert_replace_support?,
|
.insert_replace_support?
|
||||||
false
|
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn client_commands(&self) -> ClientCommandsConfig {
|
pub fn client_commands(&self) -> ClientCommandsConfig {
|
||||||
let commands =
|
let commands =
|
||||||
try_or!(self.caps.experimental.as_ref()?.get("commands")?, &serde_json::Value::Null);
|
try_or!(self.caps.experimental.as_ref()?.get("commands")?, &serde_json::Value::Null);
|
||||||
|
@ -1096,6 +1142,8 @@ impl Config {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Deserialization definitions
|
||||||
|
|
||||||
#[derive(Deserialize, Debug, Clone, Copy)]
|
#[derive(Deserialize, Debug, Clone, Copy)]
|
||||||
#[serde(rename_all = "snake_case")]
|
#[serde(rename_all = "snake_case")]
|
||||||
enum SnippetScopeDef {
|
enum SnippetScopeDef {
|
||||||
|
@ -1218,8 +1266,6 @@ enum WorkspaceSymbolSearchKindDef {
|
||||||
AllSymbols,
|
AllSymbols,
|
||||||
}
|
}
|
||||||
|
|
||||||
type ParallelPrimeCachesNumThreads = u8;
|
|
||||||
|
|
||||||
macro_rules! _config_data {
|
macro_rules! _config_data {
|
||||||
(struct $name:ident {
|
(struct $name:ident {
|
||||||
$(
|
$(
|
||||||
|
|
Loading…
Reference in a new issue