diff options
| author | 2022-05-08 20:35:37 +0200 | |
|---|---|---|
| committer | 2022-05-08 20:35:37 +0200 | |
| commit | 76e7c307dfdd4759366b76d3cbb5b31d6fb11016 (patch) | |
| tree | ec422ae7cb7cb25b5ed8fda642f43fa09a879b5d /pure/src/widget | |
| 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/widget/tree.rs | 33 | 
1 files changed, 20 insertions, 13 deletions
| 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 | 
