From 9c1c5a48758ad63370d1ea4b4535951827f54092 Mon Sep 17 00:00:00 2001 From: silicon-salamander <106124606+silicon-salamander@users.noreply.github.com> Date: Tue, 17 Dec 2024 13:03:33 -0500 Subject: [PATCH] Add :escape property to label --- CHANGELOG.md | 1 + crates/eww/src/widgets/widget_definitions.rs | 5 +++-- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 3710363e..552c0eda 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -28,6 +28,7 @@ All notable changes to eww will be listed here, starting at changes since versio - Add `transform-origin-x`/`transform-origin-y` properties to transform widget (By: mario-kr) - Add keyboard support for button presses (By: julianschuler) - Support empty string for safe access operator (By: ModProg) +- Add `:escape` property to label. Determines weather escape sequences are interpreted in the `:text` property. (By: silicon-salamander) ## [0.6.0] (21.04.2024) diff --git a/crates/eww/src/widgets/widget_definitions.rs b/crates/eww/src/widgets/widget_definitions.rs index 29c14a08..125276d9 100644 --- a/crates/eww/src/widgets/widget_definitions.rs +++ b/crates/eww/src/widgets/widget_definitions.rs @@ -965,12 +965,13 @@ fn build_gtk_label(bargs: &mut BuilderArgs) -> Result { def_widget!(bargs, _g, gtk_widget, { // @prop text - the text to display + // @prop escape - whether to interpret escape sequences in the text // @prop truncate - whether to truncate text (or pango markup). If `show-truncated` is `false`, or if `limit-width` has a value, this property has no effect and truncation is enabled. // @prop limit-width - maximum count of characters to display // @prop truncate-left - whether to truncate on the left side // @prop show-truncated - show whether the text was truncated. Disabling it will also disable dynamic truncation (the labels won't be truncated more than `limit-width`, even if there is not enough space for them), and will completly disable truncation on pango markup. // @prop unindent - whether to remove leading spaces - prop(text: as_string, truncate: as_bool = false, limit_width: as_i32 = i32::MAX, truncate_left: as_bool = false, show_truncated: as_bool = true, unindent: as_bool = true) { + prop(text: as_string, truncate: as_bool = false, limit_width: as_i32 = i32::MAX, truncate_left: as_bool = false, show_truncated: as_bool = true, unindent: as_bool = true, escape: as_bool = true) { let text = if show_truncated { // gtk does weird thing if we set max_width_chars to i32::MAX if limit_width == i32::MAX { @@ -1005,7 +1006,7 @@ fn build_gtk_label(bargs: &mut BuilderArgs) -> Result { } }; - let text = unescape::unescape(&text).context(format!("Failed to unescape label text {}", &text))?; + let text = if escape { unescape::unescape(&text).context(format!("Failed to unescape label text {}", &text))? } else { text }; let text = if unindent { util::unindent(&text) } else { text }; gtk_widget.set_text(&text); },