Cargo.lock 🔗
@@ -12077,7 +12077,7 @@ dependencies = [
"paths",
"schemars",
"serde",
- "serde_json",
+ "serde_json_lenient",
"snippet",
"util",
]
loczek created
Closes #23699
Release Notes:
- Fixed issue where snippets would not update when a snippets file
contained comments.
Cargo.lock | 2 +-
crates/snippet_provider/Cargo.toml | 2 +-
crates/snippet_provider/src/format.rs | 4 ++--
crates/snippet_provider/src/lib.rs | 3 ++-
crates/snippet_provider/src/registry.rs | 3 ++-
5 files changed, 8 insertions(+), 6 deletions(-)
@@ -12077,7 +12077,7 @@ dependencies = [
"paths",
"schemars",
"serde",
- "serde_json",
+ "serde_json_lenient",
"snippet",
"util",
]
@@ -18,7 +18,7 @@ gpui.workspace = true
parking_lot.workspace = true
paths.workspace = true
serde.workspace = true
-serde_json.workspace = true
+serde_json_lenient.workspace = true
snippet.workspace = true
util.workspace = true
schemars.workspace = true
@@ -5,7 +5,7 @@ use schemars::{
JsonSchema,
};
use serde::Deserialize;
-use serde_json::Value;
+use serde_json_lenient::Value;
#[derive(Deserialize)]
pub struct VSSnippetsFile {
@@ -20,7 +20,7 @@ impl VSSnippetsFile {
.into_generator()
.into_root_schema_for::<Self>();
- serde_json::to_value(schema).unwrap()
+ serde_json_lenient::to_value(schema).unwrap()
}
}
@@ -98,7 +98,8 @@ async fn process_updates(
let Some(file_contents) = contents else {
return;
};
- let Ok(as_json) = serde_json::from_str::<VSSnippetsFile>(&file_contents) else {
+ let Ok(as_json) = serde_json_lenient::from_str::<VSSnippetsFile>(&file_contents)
+ else {
return;
};
let snippets = file_to_snippets(as_json);
@@ -37,7 +37,8 @@ impl SnippetRegistry {
}
pub fn register_snippets(&self, file_path: &Path, contents: &str) -> Result<()> {
- let snippets_in_file: crate::format::VSSnippetsFile = serde_json::from_str(contents)?;
+ let snippets_in_file: crate::format::VSSnippetsFile =
+ serde_json_lenient::from_str(contents)?;
let kind = file_path
.file_stem()
.and_then(|stem| stem.to_str().and_then(file_stem_to_key));