From 8c8a5ad27586df3e938959b114a4ebdc2423428c Mon Sep 17 00:00:00 2001 From: Marshall Bowers Date: Wed, 31 Jan 2024 11:05:22 -0500 Subject: [PATCH] Make theme parsing more lenient (#7154) This PR improves the theme parsing to be a bit more lenient, allowing things like comments and trailing commas in theme files. Release Notes: - N/A --- Cargo.lock | 1 + Cargo.toml | 1 + crates/settings/Cargo.toml | 2 +- crates/theme/Cargo.toml | 1 + crates/theme/src/registry.rs | 2 +- 5 files changed, 5 insertions(+), 2 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 00917fb3dd7d04e503ec4e1db71ed478a19df139..ae9cf8525d7bbc6cdba9450c316c59ffa70bcb4e 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -8183,6 +8183,7 @@ dependencies = [ "serde", "serde_derive", "serde_json", + "serde_json_lenient", "serde_repr", "settings", "story", diff --git a/Cargo.toml b/Cargo.toml index b423969259ae30f49b0a59d6815b6b3e56fc999f..ffb1ef532813b271e8c02d85e4940545319fa909 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -120,6 +120,7 @@ schemars = "0.8" serde = { version = "1.0", features = ["derive", "rc"] } serde_derive = { version = "1.0", features = ["deserialize_in_place"] } serde_json = { version = "1.0", features = ["preserve_order", "raw_value"] } +serde_json_lenient = { version = "0.1", features = ["preserve_order", "raw_value"] } serde_repr = "0.1" smallvec = { version = "1.6", features = ["union"] } smol = "1.2" diff --git a/crates/settings/Cargo.toml b/crates/settings/Cargo.toml index 5e93189a2300db4107236473c435f4eb493d8992..2d0669cadabb20338d79347426d1d1210cd97d4f 100644 --- a/crates/settings/Cargo.toml +++ b/crates/settings/Cargo.toml @@ -27,7 +27,7 @@ schemars.workspace = true serde.workspace = true serde_derive.workspace = true serde_json.workspace = true -serde_json_lenient = {version = "0.1", features = ["preserve_order", "raw_value"] } +serde_json_lenient.workspace = true smallvec.workspace = true toml.workspace = true tree-sitter-json = "*" diff --git a/crates/theme/Cargo.toml b/crates/theme/Cargo.toml index d459661706c7726b65c68cbad5d7af6c6cde3bf6..b29ac5d2fe534a82e3d1a4f5d74afc1d3307f1ef 100644 --- a/crates/theme/Cargo.toml +++ b/crates/theme/Cargo.toml @@ -34,6 +34,7 @@ schemars = { workspace = true, features = ["indexmap"] } serde.workspace = true serde_derive.workspace = true serde_json.workspace = true +serde_json_lenient.workspace = true serde_repr.workspace = true settings = { path = "../settings" } story = { path = "../story", optional = true } diff --git a/crates/theme/src/registry.rs b/crates/theme/src/registry.rs index b5f15004290ae2788ab7a456ed744ba7792bdcce..2bbb5c6120c9527695bf9c9d65e112ffec936b9f 100644 --- a/crates/theme/src/registry.rs +++ b/crates/theme/src/registry.rs @@ -259,7 +259,7 @@ impl ThemeRegistry { continue; }; - let Some(theme) = serde_json::from_reader(reader).log_err() else { + let Some(theme) = serde_json_lenient::from_reader(reader).log_err() else { continue; };