diff options
author | 2022-05-08 20:35:37 +0200 | |
---|---|---|
committer | 2022-05-08 20:35:37 +0200 | |
commit | 76e7c307dfdd4759366b76d3cbb5b31d6fb11016 (patch) | |
tree | ec422ae7cb7cb25b5ed8fda642f43fa09a879b5d /pure | |
parent | 2243e461909e58a6dc5a12fb237929e47c2864e5 (diff) | |
parent | 59aeb20600661e55e59223a309146eea68b4c32f (diff) | |
download | iced-76e7c307dfdd4759366b76d3cbb5b31d6fb11016.tar.gz iced-76e7c307dfdd4759366b76d3cbb5b31d6fb11016.tar.bz2 iced-76e7c307dfdd4759366b76d3cbb5b31d6fb11016.zip |
Merge pull request #1337 from iced-rs/generic-widget-tree
Take `Borrow<dyn Widget>` instead of `Element` in `Tree` API
Diffstat (limited to '')
-rw-r--r-- | pure/src/element.rs | 18 | ||||
-rw-r--r-- | pure/src/widget/tree.rs | 33 |
2 files changed, 38 insertions, 13 deletions
diff --git a/pure/src/element.rs b/pure/src/element.rs index 704b3d0b..5450db20 100644 --- a/pure/src/element.rs +++ b/pure/src/element.rs @@ -8,6 +8,8 @@ use iced_native::mouse; use iced_native::renderer; use iced_native::{Clipboard, Length, Point, Rectangle, Shell}; +use std::borrow::Borrow; + /// A generic [`Widget`]. /// /// It is useful to build composable user interfaces that do not leak @@ -321,3 +323,19 @@ where .map(move |overlay| overlay.map(mapper)) } } + +impl<'a, Message, Renderer> Borrow<dyn Widget<Message, Renderer> + 'a> + for Element<'a, Message, Renderer> +{ + fn borrow(&self) -> &(dyn Widget<Message, Renderer> + 'a) { + self.widget.borrow() + } +} + +impl<'a, Message, Renderer> Borrow<dyn Widget<Message, Renderer> + 'a> + for &Element<'a, Message, Renderer> +{ + fn borrow(&self) -> &(dyn Widget<Message, Renderer> + 'a) { + self.widget.borrow() + } +} diff --git a/pure/src/widget/tree.rs b/pure/src/widget/tree.rs index d81dd02c..0bb3107a 100644 --- a/pure/src/widget/tree.rs +++ b/pure/src/widget/tree.rs @@ -1,7 +1,8 @@ //! Store internal widget state in a state tree to ensure continuity. -use crate::Element; +use crate::Widget; use std::any::{self, Any}; +use std::borrow::Borrow; /// A persistent state widget tree. /// @@ -28,13 +29,15 @@ impl Tree { } /// Creates a new [`Tree`] for the provided [`Element`]. - pub fn new<Message, Renderer>( - element: &Element<'_, Message, Renderer>, + pub fn new<'a, Message, Renderer>( + widget: impl Borrow<dyn Widget<Message, Renderer> + 'a>, ) -> Self { + let widget = widget.borrow(); + Self { - tag: element.as_widget().tag(), - state: element.as_widget().state(), - children: element.as_widget().children(), + tag: widget.tag(), + state: widget.state(), + children: widget.children(), } } @@ -46,23 +49,27 @@ impl Tree { /// Otherwise, the whole [`Tree`] is recreated. /// /// [`Widget::diff`]: crate::Widget::diff - pub fn diff<Message, Renderer>( + pub fn diff<'a, Message, Renderer>( &mut self, - new: &Element<'_, Message, Renderer>, + new: impl Borrow<dyn Widget<Message, Renderer> + 'a>, ) { - if self.tag == new.as_widget().tag() { - new.as_widget().diff(self) + if self.tag == new.borrow().tag() { + new.borrow().diff(self) } else { *self = Self::new(new); } } /// Reconciliates the children of the tree with the provided list of [`Element`]. - pub fn diff_children<Message, Renderer>( + pub fn diff_children<'a, Message, Renderer>( &mut self, - new_children: &[Element<'_, Message, Renderer>], + new_children: &[impl Borrow<dyn Widget<Message, Renderer> + 'a>], ) { - self.diff_children_custom(new_children, Self::diff, Self::new) + self.diff_children_custom( + new_children, + |tree, widget| tree.diff(widget.borrow()), + |widget| Self::new(widget.borrow()), + ) } /// Reconciliates the children of the tree with the provided list of [`Element`] using custom |