From 59f4dbd43bfbd370392f31f9ec76731f2d428dcf Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?W=C3=B6lfchen?= <115360611+W-lfchen@users.noreply.github.com> Date: Sat, 7 Sep 2024 13:57:36 +0200 Subject: [PATCH 1/2] chore: switch to new unescaping crate --- Cargo.lock | 13 ++++++++----- Cargo.toml | 2 +- crates/eww/Cargo.toml | 2 +- crates/eww/src/widgets/widget_definitions.rs | 2 +- 4 files changed, 11 insertions(+), 8 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 6b5b3c90..1db6cc03 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -965,7 +965,7 @@ dependencies = [ "sysinfo", "tokio", "tokio-util", - "unescape", + "unescaper", "wait-timeout", "x11rb", "yuck", @@ -2933,10 +2933,13 @@ dependencies = [ ] [[package]] -name = "unescape" -version = "0.1.0" +name = "unescaper" +version = "0.1.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ccb97dac3243214f8d8507998906ca3e2e0b900bf9bf4870477f125b82e68f6e" +checksum = "c878a167baa8afd137494101a688ef8c67125089ff2249284bd2b5f9bfedb815" +dependencies = [ + "thiserror", +] [[package]] name = "unicode-ident" @@ -3092,7 +3095,7 @@ version = "0.1.9" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "cf221c93e13a30d793f7645a0e7762c55d169dbb0a49671918a2319d289b10bb" dependencies = [ - "windows-sys 0.48.0", + "windows-sys 0.59.0", ] [[package]] diff --git a/Cargo.toml b/Cargo.toml index b457ed4b..21399f96 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -58,7 +58,7 @@ sysinfo = "0.31.2" thiserror = "1.0" tokio-util = "0.7.11" tokio = { version = "1.39.2", features = ["full"] } -unescape = "0.1" +unescaper = "0.1" wait-timeout = "0.2" zbus = { version = "4.4.0", default-features = false, features = ["tokio"] } diff --git a/crates/eww/Cargo.toml b/crates/eww/Cargo.toml index d934c455..af07c017 100644 --- a/crates/eww/Cargo.toml +++ b/crates/eww/Cargo.toml @@ -54,6 +54,6 @@ simple-signal.workspace = true sysinfo = { workspace = true } tokio-util.workspace = true tokio = { workspace = true, features = ["full"] } -unescape.workspace = true +unescaper.workspace = true wait-timeout.workspace = true zbus = { workspace = true, default-features = false, features = ["tokio"] } diff --git a/crates/eww/src/widgets/widget_definitions.rs b/crates/eww/src/widgets/widget_definitions.rs index 0fb88f13..991c5989 100644 --- a/crates/eww/src/widgets/widget_definitions.rs +++ b/crates/eww/src/widgets/widget_definitions.rs @@ -992,7 +992,7 @@ fn build_gtk_label(bargs: &mut BuilderArgs) -> Result { } }; - let text = unescape::unescape(&text).context(format!("Failed to unescape label text {}", &text))?; + let text = unescaper::unescape(&text)?; let text = if unindent { util::unindent(&text) } else { text }; gtk_widget.set_text(&text); }, From 5cc51d2847509edf3aa7ce070052cc0cca6559b2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?W=C3=B6lfchen?= <115360611+W-lfchen@users.noreply.github.com> Date: Sat, 7 Sep 2024 13:58:33 +0200 Subject: [PATCH 2/2] feat!: only unescape if text contains '\u' --- crates/eww/src/widgets/widget_definitions.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/crates/eww/src/widgets/widget_definitions.rs b/crates/eww/src/widgets/widget_definitions.rs index 991c5989..5bb63913 100644 --- a/crates/eww/src/widgets/widget_definitions.rs +++ b/crates/eww/src/widgets/widget_definitions.rs @@ -992,7 +992,7 @@ fn build_gtk_label(bargs: &mut BuilderArgs) -> Result { } }; - let text = unescaper::unescape(&text)?; + let text = if text.contains("\\u") { unescaper::unescape(&text)? } else { text }; let text = if unindent { util::unindent(&text) } else { text }; gtk_widget.set_text(&text); },