Add configuration deprecation

This commit is contained in:
Lukas Wirth 2021-06-14 15:44:32 +02:00
parent 9043c5db86
commit 178b5ffba3
3 changed files with 50 additions and 10 deletions

View file

@ -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);
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) format!("[[{}]]{} (default: `{}`)::\n+\n--\n{}--\n", name, name, default, doc)
}
}
}) })
.collect::<String>() .collect::<String>()
} }

View file

@ -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`)::
+ +
-- --

View file

@ -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,