Remove serde flag from indexmap dependency

This commit is contained in:
Lukas Wirth 2024-06-30 18:14:53 +02:00
parent 956c8521a9
commit b60b27bd22
5 changed files with 31 additions and 24 deletions

2
Cargo.lock generated
View file

@ -809,7 +809,6 @@ checksum = "168fb715dda47215e360912c096649d23d58bf392ac62f73919e831745e40f26"
dependencies = [ dependencies = [
"equivalent", "equivalent",
"hashbrown", "hashbrown",
"serde",
] ]
[[package]] [[package]]
@ -1683,7 +1682,6 @@ dependencies = [
"ide", "ide",
"ide-db", "ide-db",
"ide-ssr", "ide-ssr",
"indexmap",
"itertools", "itertools",
"load-cargo", "load-cargo",
"lsp-server 0.7.6 (registry+https://github.com/rust-lang/crates.io-index)", "lsp-server 0.7.6 (registry+https://github.com/rust-lang/crates.io-index)",

View file

@ -47,7 +47,6 @@ always-assert = "0.2.0"
walkdir = "2.3.2" walkdir = "2.3.2"
semver.workspace = true semver.workspace = true
memchr = "2.7.1" memchr = "2.7.1"
indexmap = { workspace = true, features = ["serde"] }
cfg.workspace = true cfg.workspace = true
flycheck.workspace = true flycheck.workspace = true

View file

@ -18,7 +18,6 @@ use ide_db::{
imports::insert_use::{ImportGranularity, InsertUseConfig, PrefixKind}, imports::insert_use::{ImportGranularity, InsertUseConfig, PrefixKind},
SnippetCap, SnippetCap,
}; };
use indexmap::IndexMap;
use itertools::Itertools; use itertools::Itertools;
use lsp_types::{ClientCapabilities, MarkupKind}; use lsp_types::{ClientCapabilities, MarkupKind};
use paths::{Utf8Path, Utf8PathBuf}; use paths::{Utf8Path, Utf8PathBuf};
@ -382,8 +381,7 @@ config_data! {
/// Enables completions of private items and fields that are defined in the current workspace even if they are not visible at the current position. /// Enables completions of private items and fields that are defined in the current workspace even if they are not visible at the current position.
completion_privateEditable_enable: bool = false, completion_privateEditable_enable: bool = false,
/// Custom completion snippets. /// Custom completion snippets.
// NOTE: we use IndexMap for deterministic serialization ordering completion_snippets_custom: FxHashMap<String, SnippetDef> = serde_json::from_str(r#"{
completion_snippets_custom: IndexMap<String, SnippetDef> = serde_json::from_str(r#"{
"Arc::new": { "Arc::new": {
"postfix": "arc", "postfix": "arc",
"body": "Arc::new(${receiver})", "body": "Arc::new(${receiver})",
@ -1243,7 +1241,19 @@ impl Config {
} }
pub fn json_schema() -> serde_json::Value { pub fn json_schema() -> serde_json::Value {
FullConfigInput::json_schema() let mut s = FullConfigInput::json_schema();
fn sort_objects_by_field(json: &mut serde_json::Value) {
if let serde_json::Value::Object(object) = json {
let old = std::mem::take(object);
old.into_iter().sorted_by(|(k, _), (k2, _)| k.cmp(k2)).for_each(|(k, mut v)| {
sort_objects_by_field(&mut v);
object.insert(k, v);
});
}
}
sort_objects_by_field(&mut s);
s
} }
pub fn root_path(&self) -> &AbsPathBuf { pub fn root_path(&self) -> &AbsPathBuf {
@ -2640,9 +2650,8 @@ macro_rules! _config_data {
/// All fields `Option<T>`, `None` representing fields not set in a particular JSON/TOML blob. /// All fields `Option<T>`, `None` representing fields not set in a particular JSON/TOML blob.
#[allow(non_snake_case)] #[allow(non_snake_case)]
#[derive(Clone, Serialize, Default)] #[derive(Clone, Default)]
struct $input { $( struct $input { $(
#[serde(skip_serializing_if = "Option::is_none")]
$field: Option<$ty>, $field: Option<$ty>,
)* } )* }
@ -2725,7 +2734,7 @@ struct DefaultConfigData {
/// All of the config levels, all fields `Option<T>`, to describe fields that are actually set by /// All of the config levels, all fields `Option<T>`, to describe fields that are actually set by
/// some rust-analyzer.toml file or JSON blob. An empty rust-analyzer.toml corresponds to /// some rust-analyzer.toml file or JSON blob. An empty rust-analyzer.toml corresponds to
/// all fields being None. /// all fields being None.
#[derive(Debug, Clone, Default, Serialize)] #[derive(Debug, Clone, Default)]
struct FullConfigInput { struct FullConfigInput {
global: GlobalConfigInput, global: GlobalConfigInput,
local: LocalConfigInput, local: LocalConfigInput,
@ -2770,7 +2779,7 @@ impl FullConfigInput {
/// All of the config levels, all fields `Option<T>`, to describe fields that are actually set by /// All of the config levels, all fields `Option<T>`, to describe fields that are actually set by
/// some rust-analyzer.toml file or JSON blob. An empty rust-analyzer.toml corresponds to /// some rust-analyzer.toml file or JSON blob. An empty rust-analyzer.toml corresponds to
/// all fields being None. /// all fields being None.
#[derive(Debug, Clone, Default, Serialize)] #[derive(Debug, Clone, Default)]
struct GlobalLocalConfigInput { struct GlobalLocalConfigInput {
global: GlobalConfigInput, global: GlobalConfigInput,
local: LocalConfigInput, local: LocalConfigInput,
@ -2932,7 +2941,7 @@ fn field_props(field: &str, ty: &str, doc: &[&str], default: &str) -> serde_json
"FxHashMap<Box<str>, Box<[Box<str>]>>" => set! { "FxHashMap<Box<str>, Box<[Box<str>]>>" => set! {
"type": "object", "type": "object",
}, },
"IndexMap<String, SnippetDef>" => set! { "FxHashMap<String, SnippetDef>" => set! {
"type": "object", "type": "object",
}, },
"FxHashMap<String, String>" => set! { "FxHashMap<String, String>" => set! {
@ -3347,6 +3356,7 @@ mod tests {
#[test] #[test]
fn generate_package_json_config() { fn generate_package_json_config() {
let s = Config::json_schema(); let s = Config::json_schema();
let schema = format!("{s:#}"); let schema = format!("{s:#}");
let mut schema = schema let mut schema = schema
.trim_start_matches('[') .trim_start_matches('[')

View file

@ -350,12 +350,6 @@ Default:
"description": "Put the expression into a pinned `Box`", "description": "Put the expression into a pinned `Box`",
"scope": "expr" "scope": "expr"
}, },
"Ok": {
"postfix": "ok",
"body": "Ok(${receiver})",
"description": "Wrap the expression in a `Result::Ok`",
"scope": "expr"
},
"Err": { "Err": {
"postfix": "err", "postfix": "err",
"body": "Err(${receiver})", "body": "Err(${receiver})",
@ -367,6 +361,12 @@ Default:
"body": "Some(${receiver})", "body": "Some(${receiver})",
"description": "Wrap the expression in an `Option::Some`", "description": "Wrap the expression in an `Option::Some`",
"scope": "expr" "scope": "expr"
},
"Ok": {
"postfix": "ok",
"body": "Ok(${receiver})",
"description": "Wrap the expression in a `Result::Ok`",
"scope": "expr"
} }
} }
---- ----

View file

@ -1187,12 +1187,6 @@
"description": "Put the expression into a pinned `Box`", "description": "Put the expression into a pinned `Box`",
"scope": "expr" "scope": "expr"
}, },
"Ok": {
"postfix": "ok",
"body": "Ok(${receiver})",
"description": "Wrap the expression in a `Result::Ok`",
"scope": "expr"
},
"Err": { "Err": {
"postfix": "err", "postfix": "err",
"body": "Err(${receiver})", "body": "Err(${receiver})",
@ -1204,6 +1198,12 @@
"body": "Some(${receiver})", "body": "Some(${receiver})",
"description": "Wrap the expression in an `Option::Some`", "description": "Wrap the expression in an `Option::Some`",
"scope": "expr" "scope": "expr"
},
"Ok": {
"postfix": "ok",
"body": "Ok(${receiver})",
"description": "Wrap the expression in a `Result::Ok`",
"scope": "expr"
} }
}, },
"type": "object" "type": "object"