mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-12 13:18:47 +00:00
Add configuration deprecation
This commit is contained in:
parent
9043c5db86
commit
178b5ffba3
3 changed files with 50 additions and 10 deletions
|
@ -163,6 +163,9 @@ config_data! {
|
||||||
/// 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",
|
hoverActions_run: bool = "true",
|
||||||
|
#[deprecated = "Use hover.linksInHover instead"]
|
||||||
|
/// Use markdown syntax for links in hover.
|
||||||
|
hoverActions_linksInHover: bool = "false",
|
||||||
|
|
||||||
/// Whether to show inlay type hints for method chains.
|
/// Whether to show inlay type hints for method chains.
|
||||||
inlayHints_chainingHints: bool = "true",
|
inlayHints_chainingHints: bool = "true",
|
||||||
|
@ -729,7 +732,7 @@ impl Config {
|
||||||
run: self.data.hoverActions_enable && self.data.hoverActions_run,
|
run: self.data.hoverActions_enable && self.data.hoverActions_run,
|
||||||
debug: self.data.hoverActions_enable && self.data.hoverActions_debug,
|
debug: self.data.hoverActions_enable && self.data.hoverActions_debug,
|
||||||
goto_type_def: self.data.hoverActions_enable && self.data.hoverActions_gotoTypeDef,
|
goto_type_def: self.data.hoverActions_enable && self.data.hoverActions_gotoTypeDef,
|
||||||
links_in_hover: self.data.hover_linksInHover,
|
links_in_hover: self.data.hoverActions_linksInHover || self.data.hover_linksInHover,
|
||||||
markdown: try_or!(
|
markdown: try_or!(
|
||||||
self.caps
|
self.caps
|
||||||
.text_document
|
.text_document
|
||||||
|
@ -826,6 +829,7 @@ enum WorskpaceSymbolSearchKindDef {
|
||||||
macro_rules! _config_data {
|
macro_rules! _config_data {
|
||||||
(struct $name:ident {
|
(struct $name:ident {
|
||||||
$(
|
$(
|
||||||
|
$(#[deprecated=$deprecation_msg:literal])?
|
||||||
$(#[doc=$doc:literal])*
|
$(#[doc=$doc:literal])*
|
||||||
$field:ident $(| $alias:ident)*: $ty:ty = $default:expr,
|
$field:ident $(| $alias:ident)*: $ty:ty = $default:expr,
|
||||||
)*
|
)*
|
||||||
|
@ -850,7 +854,9 @@ macro_rules! _config_data {
|
||||||
$({
|
$({
|
||||||
let field = stringify!($field);
|
let field = stringify!($field);
|
||||||
let ty = stringify!($ty);
|
let ty = stringify!($ty);
|
||||||
(field, ty, &[$($doc),*], $default)
|
let deprecation_msg = None $( .or(Some($deprecation_msg)) )?;
|
||||||
|
|
||||||
|
(field, ty, &[$($doc),*], $default, deprecation_msg)
|
||||||
},)*
|
},)*
|
||||||
])
|
])
|
||||||
}
|
}
|
||||||
|
@ -861,7 +867,9 @@ macro_rules! _config_data {
|
||||||
$({
|
$({
|
||||||
let field = stringify!($field);
|
let field = stringify!($field);
|
||||||
let ty = stringify!($ty);
|
let ty = stringify!($ty);
|
||||||
(field, ty, &[$($doc),*], $default)
|
let deprecation_msg = None $( .or(Some($deprecation_msg)) )?;
|
||||||
|
|
||||||
|
(field, ty, &[$($doc),*], $default, deprecation_msg)
|
||||||
},)*
|
},)*
|
||||||
])
|
])
|
||||||
}
|
}
|
||||||
|
@ -891,7 +899,9 @@ fn get_field<T: DeserializeOwned>(
|
||||||
.unwrap_or(default)
|
.unwrap_or(default)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn schema(fields: &[(&'static str, &'static str, &[&str], &str)]) -> serde_json::Value {
|
fn schema(
|
||||||
|
fields: &[(&'static str, &'static str, &[&str], &str, Option<&str>)],
|
||||||
|
) -> serde_json::Value {
|
||||||
for ((f1, ..), (f2, ..)) in fields.iter().zip(&fields[1..]) {
|
for ((f1, ..), (f2, ..)) in fields.iter().zip(&fields[1..]) {
|
||||||
fn key(f: &str) -> &str {
|
fn key(f: &str) -> &str {
|
||||||
f.splitn(2, '_').next().unwrap()
|
f.splitn(2, '_').next().unwrap()
|
||||||
|
@ -901,17 +911,23 @@ fn schema(fields: &[(&'static str, &'static str, &[&str], &str)]) -> serde_json:
|
||||||
|
|
||||||
let map = fields
|
let map = fields
|
||||||
.iter()
|
.iter()
|
||||||
.map(|(field, ty, doc, default)| {
|
.map(|(field, ty, doc, default, deprecation_msg)| {
|
||||||
let name = field.replace("_", ".");
|
let name = field.replace("_", ".");
|
||||||
let name = format!("rust-analyzer.{}", name);
|
let name = format!("rust-analyzer.{}", name);
|
||||||
let props = field_props(field, ty, doc, default);
|
let props = field_props(field, ty, doc, default, deprecation_msg.as_deref());
|
||||||
(name, props)
|
(name, props)
|
||||||
})
|
})
|
||||||
.collect::<serde_json::Map<_, _>>();
|
.collect::<serde_json::Map<_, _>>();
|
||||||
map.into()
|
map.into()
|
||||||
}
|
}
|
||||||
|
|
||||||
fn field_props(field: &str, ty: &str, doc: &[&str], default: &str) -> serde_json::Value {
|
fn field_props(
|
||||||
|
field: &str,
|
||||||
|
ty: &str,
|
||||||
|
doc: &[&str],
|
||||||
|
default: &str,
|
||||||
|
deprecation_msg: Option<&str>,
|
||||||
|
) -> serde_json::Value {
|
||||||
let doc = doc_comment_to_string(doc);
|
let doc = doc_comment_to_string(doc);
|
||||||
let doc = doc.trim_end_matches('\n');
|
let doc = doc.trim_end_matches('\n');
|
||||||
assert!(
|
assert!(
|
||||||
|
@ -930,6 +946,9 @@ fn field_props(field: &str, ty: &str, doc: &[&str], default: &str) -> serde_json
|
||||||
}
|
}
|
||||||
set!("markdownDescription": doc);
|
set!("markdownDescription": doc);
|
||||||
set!("default": default);
|
set!("default": default);
|
||||||
|
if let Some(deprecation_msg) = deprecation_msg {
|
||||||
|
set!("deprecationMessage": deprecation_msg);
|
||||||
|
}
|
||||||
|
|
||||||
match ty {
|
match ty {
|
||||||
"bool" => set!("type": "boolean"),
|
"bool" => set!("type": "boolean"),
|
||||||
|
@ -1026,13 +1045,23 @@ fn field_props(field: &str, ty: &str, doc: &[&str], default: &str) -> serde_json
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
fn manual(fields: &[(&'static str, &'static str, &[&str], &str)]) -> String {
|
fn manual(fields: &[(&'static str, &'static str, &[&str], &str, Option<&str>)]) -> String {
|
||||||
fields
|
fields
|
||||||
.iter()
|
.iter()
|
||||||
.map(|(field, _ty, doc, default)| {
|
.map(|(field, _ty, doc, default, deprecation_msg)| {
|
||||||
let name = format!("rust-analyzer.{}", field.replace("_", "."));
|
let name = format!("rust-analyzer.{}", field.replace("_", "."));
|
||||||
let doc = doc_comment_to_string(*doc);
|
let doc = doc_comment_to_string(*doc);
|
||||||
format!("[[{}]]{} (default: `{}`)::\n+\n--\n{}--\n", name, name, default, doc)
|
match deprecation_msg {
|
||||||
|
Some(deprecation_msg) => {
|
||||||
|
format!(
|
||||||
|
"[[{}]]{} (deprecated: `{}`)::\n+\n--\n{}--\n",
|
||||||
|
name, name, deprecation_msg, doc
|
||||||
|
)
|
||||||
|
}
|
||||||
|
None => {
|
||||||
|
format!("[[{}]]{} (default: `{}`)::\n+\n--\n{}--\n", name, name, default, doc)
|
||||||
|
}
|
||||||
|
}
|
||||||
})
|
})
|
||||||
.collect::<String>()
|
.collect::<String>()
|
||||||
}
|
}
|
||||||
|
|
|
@ -250,6 +250,11 @@ Whether to show `References` action. Only applies when
|
||||||
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.
|
||||||
--
|
--
|
||||||
|
[[rust-analyzer.hoverActions.linksInHover]]rust-analyzer.hoverActions.linksInHover (deprecated: `Use hover.linksInHover instead`)::
|
||||||
|
+
|
||||||
|
--
|
||||||
|
Use markdown syntax for links in hover.
|
||||||
|
--
|
||||||
[[rust-analyzer.inlayHints.chainingHints]]rust-analyzer.inlayHints.chainingHints (default: `true`)::
|
[[rust-analyzer.inlayHints.chainingHints]]rust-analyzer.inlayHints.chainingHints (default: `true`)::
|
||||||
+
|
+
|
||||||
--
|
--
|
||||||
|
|
|
@ -680,6 +680,12 @@
|
||||||
"default": true,
|
"default": true,
|
||||||
"type": "boolean"
|
"type": "boolean"
|
||||||
},
|
},
|
||||||
|
"rust-analyzer.hoverActions.linksInHover": {
|
||||||
|
"markdownDescription": "Use markdown syntax for links in hover.",
|
||||||
|
"default": false,
|
||||||
|
"deprecationMessage": "Use hover.linksInHover instead",
|
||||||
|
"type": "boolean"
|
||||||
|
},
|
||||||
"rust-analyzer.inlayHints.chainingHints": {
|
"rust-analyzer.inlayHints.chainingHints": {
|
||||||
"markdownDescription": "Whether to show inlay type hints for method chains.",
|
"markdownDescription": "Whether to show inlay type hints for method chains.",
|
||||||
"default": true,
|
"default": true,
|
||||||
|
|
Loading…
Reference in a new issue