From 519516b4f57cb4ef3fbaed52b9d172fd9a116eb2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?W=C3=B6lfchen?= <115360611+W-lfchen@users.noreply.github.com> Date: Thu, 5 Sep 2024 22:21:10 +0200 Subject: [PATCH] fix: new scope for every child --- crates/eww/src/widgets/build_widget.rs | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/crates/eww/src/widgets/build_widget.rs b/crates/eww/src/widgets/build_widget.rs index 5adf6600..04c21483 100644 --- a/crates/eww/src/widgets/build_widget.rs +++ b/crates/eww/src/widgets/build_widget.rs @@ -288,9 +288,6 @@ fn build_children_special_widget( gtk_container: >k::Container, custom_widget_invocation: Rc, ) -> Result<()> { - // open a new scope for the children - // TODO this might be unnecessary, evaluate whether we can just use the calling_scope - let scope = tree.register_new_scope("children".into(), Some(calling_scope), calling_scope, HashMap::new())?; if let Some(nth) = widget_use.nth_expr { // TODORW this might not be necessary, if I can keep a copy of the widget I can destroy it directly, no need to go through the container. // This should be a custom gtk::Bin subclass,.. @@ -309,6 +306,12 @@ fn build_children_special_widget( .children .get(nth_value as usize) .with_context(|| format!("No child at index {}", nth_value))?; + let scope = tree.register_new_scope( + format!("child {nth_value}"), + Some(custom_widget_invocation.scope), + calling_scope, + HashMap::new(), + )?; let new_child_widget = build_gtk_widget(tree, widget_defs.clone(), scope, nth_child_widget_use.clone(), None)?; child_container.children().iter().for_each(|f| child_container.remove(f)); @@ -321,6 +324,8 @@ fn build_children_special_widget( )?; } else { for child in &custom_widget_invocation.children { + let scope = + tree.register_new_scope(String::from("child"), Some(custom_widget_invocation.scope), calling_scope, HashMap::new())?; let child_widget = build_gtk_widget(tree, widget_defs.clone(), scope, child.clone(), None)?; gtk_container.add(&child_widget); }