diff options
| author | 2024-04-01 17:14:39 +0200 | |
|---|---|---|
| committer | 2024-04-01 17:14:39 +0200 | |
| commit | c30b4b0a1c9b191bcb65ae1732581b5c96b8bcfe (patch) | |
| tree | e6e7b42852a2eaf1bcf4a757f217a4a3eda2642a /widget/src | |
| parent | b40db569a2369dbdc79e40dc700974c2f7ac8d4b (diff) | |
| parent | db4b03a6599c5c131b0672431f0c5c4afb4ac8d2 (diff) | |
| download | iced-c30b4b0a1c9b191bcb65ae1732581b5c96b8bcfe.tar.gz iced-c30b4b0a1c9b191bcb65ae1732581b5c96b8bcfe.tar.bz2 iced-c30b4b0a1c9b191bcb65ae1732581b5c96b8bcfe.zip | |
Merge pull request #2362 from iced-rs/size-hint-for-row-columns
Use `Iterator::size_hint` to initialize `Column` and `Row` capacity
Diffstat (limited to '')
| -rw-r--r-- | widget/src/column.rs | 9 | ||||
| -rw-r--r-- | widget/src/keyed/column.rs | 46 | ||||
| -rw-r--r-- | widget/src/row.rs | 9 | 
3 files changed, 56 insertions, 8 deletions
| diff --git a/widget/src/column.rs b/widget/src/column.rs index d37ef695..df7829b3 100644 --- a/widget/src/column.rs +++ b/widget/src/column.rs @@ -33,11 +33,18 @@ where          Self::from_vec(Vec::new())      } +    /// Creates a [`Column`] with the given capacity. +    pub fn with_capacity(capacity: usize) -> Self { +        Self::from_vec(Vec::with_capacity(capacity)) +    } +      /// Creates a [`Column`] with the given elements.      pub fn with_children(          children: impl IntoIterator<Item = Element<'a, Message, Theme, Renderer>>,      ) -> Self { -        Self::new().extend(children) +        let iterator = children.into_iter(); + +        Self::with_capacity(iterator.size_hint().0).extend(iterator)      }      /// Creates a [`Column`] from an already allocated [`Vec`]. diff --git a/widget/src/keyed/column.rs b/widget/src/keyed/column.rs index 8a8d5fe7..a34ce9e6 100644 --- a/widget/src/keyed/column.rs +++ b/widget/src/keyed/column.rs @@ -40,27 +40,49 @@ where  {      /// Creates an empty [`Column`].      pub fn new() -> Self { -        Column { +        Self::from_vecs(Vec::new(), Vec::new()) +    } + +    /// Creates a [`Column`] from already allocated [`Vec`]s. +    /// +    /// Keep in mind that the [`Column`] will not inspect the [`Vec`]s, which means +    /// it won't automatically adapt to the sizing strategy of its contents. +    /// +    /// If any of the children have a [`Length::Fill`] strategy, you will need to +    /// call [`Column::width`] or [`Column::height`] accordingly. +    pub fn from_vecs( +        keys: Vec<Key>, +        children: Vec<Element<'a, Message, Theme, Renderer>>, +    ) -> Self { +        Self {              spacing: 0.0,              padding: Padding::ZERO,              width: Length::Shrink,              height: Length::Shrink,              max_width: f32::INFINITY,              align_items: Alignment::Start, -            keys: Vec::new(), -            children: Vec::new(), +            keys, +            children,          }      } +    /// Creates a [`Column`] with the given capacity. +    pub fn with_capacity(capacity: usize) -> Self { +        Self::from_vecs( +            Vec::with_capacity(capacity), +            Vec::with_capacity(capacity), +        ) +    } +      /// Creates a [`Column`] with the given elements.      pub fn with_children(          children: impl IntoIterator<              Item = (Key, Element<'a, Message, Theme, Renderer>),          >,      ) -> Self { -        children -            .into_iter() -            .fold(Self::new(), |column, (key, child)| column.push(key, child)) +        let iterator = children.into_iter(); + +        Self::with_capacity(iterator.size_hint().0).extend(iterator)      }      /// Sets the vertical spacing _between_ elements. @@ -132,6 +154,18 @@ where              self          }      } + +    /// Extends the [`Column`] with the given children. +    pub fn extend( +        self, +        children: impl IntoIterator< +            Item = (Key, Element<'a, Message, Theme, Renderer>), +        >, +    ) -> Self { +        children +            .into_iter() +            .fold(self, |column, (key, child)| column.push(key, child)) +    }  }  impl<'a, Key, Message, Renderer> Default for Column<'a, Key, Message, Renderer> diff --git a/widget/src/row.rs b/widget/src/row.rs index 47feff9c..fa352171 100644 --- a/widget/src/row.rs +++ b/widget/src/row.rs @@ -31,11 +31,18 @@ where          Self::from_vec(Vec::new())      } +    /// Creates a [`Row`] with the given capacity. +    pub fn with_capacity(capacity: usize) -> Self { +        Self::from_vec(Vec::with_capacity(capacity)) +    } +      /// Creates a [`Row`] with the given elements.      pub fn with_children(          children: impl IntoIterator<Item = Element<'a, Message, Theme, Renderer>>,      ) -> Self { -        Self::new().extend(children) +        let iterator = children.into_iter(); + +        Self::with_capacity(iterator.size_hint().0).extend(iterator)      }      /// Creates a [`Row`] from an already allocated [`Vec`]. | 
