summaryrefslogtreecommitdiffstats
path: root/native
diff options
context:
space:
mode:
authorLibravatar Olivier Pinon <oliv.pinon@gmail.com>2020-04-12 00:40:51 +0200
committerLibravatar Olivier Pinon <oliv.pinon@gmail.com>2020-04-12 00:57:44 +0200
commitf7d7ab1ba9a037be6bf2a32f7b2662e5314ae3a5 (patch)
treea2c4f93e55eecb10faafd4239e9ec5ef5588c06a /native
parente941eab4ab58da4473dd4473215bc4f36684dafb (diff)
downloadiced-f7d7ab1ba9a037be6bf2a32f7b2662e5314ae3a5.tar.gz
iced-f7d7ab1ba9a037be6bf2a32f7b2662e5314ae3a5.tar.bz2
iced-f7d7ab1ba9a037be6bf2a32f7b2662e5314ae3a5.zip
Remove unnecessary 'static lifetime on Renderer
Diffstat (limited to 'native')
-rw-r--r--native/src/widget/button.rs7
-rw-r--r--native/src/widget/checkbox.rs7
-rw-r--r--native/src/widget/column.rs7
-rw-r--r--native/src/widget/container.rs7
-rw-r--r--native/src/widget/pane_grid.rs7
-rw-r--r--native/src/widget/progress_bar.rs7
-rw-r--r--native/src/widget/radio.rs7
-rw-r--r--native/src/widget/row.rs7
-rw-r--r--native/src/widget/scrollable.rs7
-rw-r--r--native/src/widget/slider.rs7
-rw-r--r--native/src/widget/text_input.rs8
11 files changed, 44 insertions, 34 deletions
diff --git a/native/src/widget/button.rs b/native/src/widget/button.rs
index 7b5c349c..409ec41d 100644
--- a/native/src/widget/button.rs
+++ b/native/src/widget/button.rs
@@ -143,7 +143,7 @@ impl State {
impl<'a, Message, Renderer> Widget<Message, Renderer>
for Button<'a, Message, Renderer>
where
- Renderer: 'static + self::Renderer,
+ Renderer: self::Renderer,
Message: Clone,
{
fn width(&self) -> Length {
@@ -234,7 +234,8 @@ where
}
fn hash_layout(&self, state: &mut Hasher) {
- std::any::TypeId::of::<Button<'_, (), Renderer>>().hash(state);
+ struct ButtonWidget;
+ std::any::TypeId::of::<ButtonWidget>().hash(state);
self.width.hash(state);
self.content.hash_layout(state);
@@ -276,7 +277,7 @@ pub trait Renderer: crate::Renderer + Sized {
impl<'a, Message, Renderer> From<Button<'a, Message, Renderer>>
for Element<'a, Message, Renderer>
where
- Renderer: 'static + self::Renderer,
+ Renderer: 'a + self::Renderer,
Message: 'a + Clone,
{
fn from(
diff --git a/native/src/widget/checkbox.rs b/native/src/widget/checkbox.rs
index ccf13848..482e379f 100644
--- a/native/src/widget/checkbox.rs
+++ b/native/src/widget/checkbox.rs
@@ -110,7 +110,7 @@ impl<Message, Renderer: self::Renderer + text::Renderer>
impl<Message, Renderer> Widget<Message, Renderer>
for Checkbox<Message, Renderer>
where
- Renderer: 'static + self::Renderer + text::Renderer + row::Renderer,
+ Renderer: self::Renderer + text::Renderer + row::Renderer,
{
fn width(&self) -> Length {
self.width
@@ -205,7 +205,8 @@ where
}
fn hash_layout(&self, state: &mut Hasher) {
- std::any::TypeId::of::<Checkbox<(), Renderer>>().hash(state);
+ struct CheckboxWidget;
+ std::any::TypeId::of::<CheckboxWidget>().hash(state);
self.label.hash(state);
}
@@ -254,7 +255,7 @@ pub trait Renderer: crate::Renderer {
impl<'a, Message, Renderer> From<Checkbox<Message, Renderer>>
for Element<'a, Message, Renderer>
where
- Renderer: 'static + self::Renderer + text::Renderer + row::Renderer,
+ Renderer: 'a + self::Renderer + text::Renderer + row::Renderer,
Message: 'a,
{
fn from(
diff --git a/native/src/widget/column.rs b/native/src/widget/column.rs
index 77b8496b..ee02244d 100644
--- a/native/src/widget/column.rs
+++ b/native/src/widget/column.rs
@@ -124,7 +124,7 @@ impl<'a, Message, Renderer> Column<'a, Message, Renderer> {
impl<'a, Message, Renderer> Widget<Message, Renderer>
for Column<'a, Message, Renderer>
where
- Renderer: 'static + self::Renderer,
+ Renderer: self::Renderer,
{
fn width(&self) -> Length {
self.width
@@ -190,7 +190,8 @@ where
}
fn hash_layout(&self, state: &mut Hasher) {
- std::any::TypeId::of::<Column<'_, (), Renderer>>().hash(state);
+ struct ColumnWidget;
+ std::any::TypeId::of::<ColumnWidget>().hash(state);
self.width.hash(state);
self.height.hash(state);
@@ -234,7 +235,7 @@ pub trait Renderer: crate::Renderer + Sized {
impl<'a, Message, Renderer> From<Column<'a, Message, Renderer>>
for Element<'a, Message, Renderer>
where
- Renderer: 'static + self::Renderer,
+ Renderer: 'a + self::Renderer,
Message: 'a,
{
fn from(
diff --git a/native/src/widget/container.rs b/native/src/widget/container.rs
index 34032c3a..3b661c05 100644
--- a/native/src/widget/container.rs
+++ b/native/src/widget/container.rs
@@ -132,7 +132,7 @@ where
impl<'a, Message, Renderer> Widget<Message, Renderer>
for Container<'a, Message, Renderer>
where
- Renderer: 'static + self::Renderer,
+ Renderer: self::Renderer,
{
fn width(&self) -> Length {
self.width
@@ -203,7 +203,8 @@ where
}
fn hash_layout(&self, state: &mut Hasher) {
- std::any::TypeId::of::<Container<'_, (), Renderer>>().hash(state);
+ struct ContainerWidget;
+ std::any::TypeId::of::<ContainerWidget>().hash(state);
self.padding.hash(state);
self.width.hash(state);
@@ -243,7 +244,7 @@ pub trait Renderer: crate::Renderer {
impl<'a, Message, Renderer> From<Container<'a, Message, Renderer>>
for Element<'a, Message, Renderer>
where
- Renderer: 'static + self::Renderer,
+ Renderer: 'a + self::Renderer,
Message: 'a,
{
fn from(
diff --git a/native/src/widget/pane_grid.rs b/native/src/widget/pane_grid.rs
index f6dd328e..01b008da 100644
--- a/native/src/widget/pane_grid.rs
+++ b/native/src/widget/pane_grid.rs
@@ -356,7 +356,7 @@ pub struct KeyPressEvent {
impl<'a, Message, Renderer> Widget<Message, Renderer>
for PaneGrid<'a, Message, Renderer>
where
- Renderer: 'static + self::Renderer,
+ Renderer: self::Renderer,
{
fn width(&self) -> Length {
self.width
@@ -597,8 +597,9 @@ where
fn hash_layout(&self, state: &mut Hasher) {
use std::hash::Hash;
+ struct PaneGridWidget;
+ std::any::TypeId::of::<PaneGridWidget>().hash(state);
- std::any::TypeId::of::<PaneGrid<'_, (), Renderer>>().hash(state);
self.width.hash(state);
self.height.hash(state);
self.state.hash_layout(state);
@@ -643,7 +644,7 @@ pub trait Renderer: crate::Renderer + Sized {
impl<'a, Message, Renderer> From<PaneGrid<'a, Message, Renderer>>
for Element<'a, Message, Renderer>
where
- Renderer: 'static + self::Renderer,
+ Renderer: 'a + self::Renderer,
Message: 'a,
{
fn from(
diff --git a/native/src/widget/progress_bar.rs b/native/src/widget/progress_bar.rs
index 897edb30..0e6e9367 100644
--- a/native/src/widget/progress_bar.rs
+++ b/native/src/widget/progress_bar.rs
@@ -72,7 +72,7 @@ impl<Renderer: self::Renderer> ProgressBar<Renderer> {
impl<Message, Renderer> Widget<Message, Renderer> for ProgressBar<Renderer>
where
- Renderer: 'static + self::Renderer,
+ Renderer: self::Renderer,
{
fn width(&self) -> Length {
self.width
@@ -114,7 +114,8 @@ where
}
fn hash_layout(&self, state: &mut Hasher) {
- std::any::TypeId::of::<ProgressBar<Renderer>>().hash(state);
+ struct ProgressBarWidget;
+ std::any::TypeId::of::<ProgressBarWidget>().hash(state);
self.width.hash(state);
self.height.hash(state);
@@ -159,7 +160,7 @@ pub trait Renderer: crate::Renderer {
impl<'a, Message, Renderer> From<ProgressBar<Renderer>>
for Element<'a, Message, Renderer>
where
- Renderer: 'static + self::Renderer,
+ Renderer: 'a + self::Renderer,
Message: 'a,
{
fn from(
diff --git a/native/src/widget/radio.rs b/native/src/widget/radio.rs
index bc23c116..c1e36e3d 100644
--- a/native/src/widget/radio.rs
+++ b/native/src/widget/radio.rs
@@ -82,7 +82,7 @@ impl<Message, Renderer: self::Renderer> Radio<Message, Renderer> {
impl<Message, Renderer> Widget<Message, Renderer> for Radio<Message, Renderer>
where
- Renderer: 'static + self::Renderer + text::Renderer + row::Renderer,
+ Renderer: self::Renderer + text::Renderer + row::Renderer,
Message: Clone,
{
fn width(&self) -> Length {
@@ -174,7 +174,8 @@ where
}
fn hash_layout(&self, state: &mut Hasher) {
- std::any::TypeId::of::<Radio<(), Renderer>>().hash(state);
+ struct RadioWidget;
+ std::any::TypeId::of::<RadioWidget>().hash(state);
self.label.hash(state);
}
@@ -218,7 +219,7 @@ pub trait Renderer: crate::Renderer {
impl<'a, Message, Renderer> From<Radio<Message, Renderer>>
for Element<'a, Message, Renderer>
where
- Renderer: 'static + self::Renderer + row::Renderer + text::Renderer,
+ Renderer: 'a + self::Renderer + row::Renderer + text::Renderer,
Message: 'a + Clone,
{
fn from(radio: Radio<Message, Renderer>) -> Element<'a, Message, Renderer> {
diff --git a/native/src/widget/row.rs b/native/src/widget/row.rs
index 5f139f66..405ba001 100644
--- a/native/src/widget/row.rs
+++ b/native/src/widget/row.rs
@@ -125,7 +125,7 @@ impl<'a, Message, Renderer> Row<'a, Message, Renderer> {
impl<'a, Message, Renderer> Widget<Message, Renderer>
for Row<'a, Message, Renderer>
where
- Renderer: 'static + self::Renderer,
+ Renderer: self::Renderer,
{
fn width(&self) -> Length {
self.width
@@ -191,7 +191,8 @@ where
}
fn hash_layout(&self, state: &mut Hasher) {
- std::any::TypeId::of::<Row<'_, (), Renderer>>().hash(state);
+ struct RowWidget;
+ std::any::TypeId::of::<RowWidget>().hash(state);
self.width.hash(state);
self.height.hash(state);
@@ -236,7 +237,7 @@ pub trait Renderer: crate::Renderer + Sized {
impl<'a, Message, Renderer> From<Row<'a, Message, Renderer>>
for Element<'a, Message, Renderer>
where
- Renderer: 'static + self::Renderer,
+ Renderer: 'a + self::Renderer,
Message: 'a,
{
fn from(row: Row<'a, Message, Renderer>) -> Element<'a, Message, Renderer> {
diff --git a/native/src/widget/scrollable.rs b/native/src/widget/scrollable.rs
index ba39edb1..f1506a3e 100644
--- a/native/src/widget/scrollable.rs
+++ b/native/src/widget/scrollable.rs
@@ -115,7 +115,7 @@ impl<'a, Message, Renderer: self::Renderer> Scrollable<'a, Message, Renderer> {
impl<'a, Message, Renderer> Widget<Message, Renderer>
for Scrollable<'a, Message, Renderer>
where
- Renderer: 'static + self::Renderer + column::Renderer,
+ Renderer: self::Renderer + column::Renderer,
{
fn width(&self) -> Length {
Widget::<Message, Renderer>::width(&self.content)
@@ -311,7 +311,8 @@ where
}
fn hash_layout(&self, state: &mut Hasher) {
- std::any::TypeId::of::<Scrollable<'_, (), Renderer>>().hash(state);
+ struct ScrollableWidget;
+ std::any::TypeId::of::<ScrollableWidget>().hash(state);
self.height.hash(state);
self.max_height.hash(state);
@@ -505,7 +506,7 @@ pub trait Renderer: crate::Renderer + Sized {
impl<'a, Message, Renderer> From<Scrollable<'a, Message, Renderer>>
for Element<'a, Message, Renderer>
where
- Renderer: 'static + self::Renderer + column::Renderer,
+ Renderer: 'a + self::Renderer + column::Renderer,
Message: 'a,
{
fn from(
diff --git a/native/src/widget/slider.rs b/native/src/widget/slider.rs
index b2fa5c9d..3e8c836e 100644
--- a/native/src/widget/slider.rs
+++ b/native/src/widget/slider.rs
@@ -114,7 +114,7 @@ impl State {
impl<'a, Message, Renderer> Widget<Message, Renderer>
for Slider<'a, Message, Renderer>
where
- Renderer: 'static + self::Renderer,
+ Renderer: self::Renderer,
{
fn width(&self) -> Length {
self.width
@@ -205,7 +205,8 @@ where
}
fn hash_layout(&self, state: &mut Hasher) {
- std::any::TypeId::of::<Slider<'_, (), Renderer>>().hash(state);
+ struct SliderWidget;
+ std::any::TypeId::of::<SliderWidget>().hash(state);
self.width.hash(state);
}
@@ -253,7 +254,7 @@ pub trait Renderer: crate::Renderer {
impl<'a, Message, Renderer> From<Slider<'a, Message, Renderer>>
for Element<'a, Message, Renderer>
where
- Renderer: 'static + self::Renderer,
+ Renderer: 'a + self::Renderer,
Message: 'a,
{
fn from(
diff --git a/native/src/widget/text_input.rs b/native/src/widget/text_input.rs
index ae3d74ae..7a171d57 100644
--- a/native/src/widget/text_input.rs
+++ b/native/src/widget/text_input.rs
@@ -171,7 +171,7 @@ impl<'a, Message, Renderer: self::Renderer> TextInput<'a, Message, Renderer> {
impl<'a, Message, Renderer> Widget<Message, Renderer>
for TextInput<'a, Message, Renderer>
where
- Renderer: 'static + self::Renderer,
+ Renderer: self::Renderer,
Message: Clone,
{
fn width(&self) -> Length {
@@ -526,8 +526,8 @@ where
fn hash_layout(&self, state: &mut Hasher) {
use std::{any::TypeId, hash::Hash};
-
- TypeId::of::<TextInput<'_, (), Renderer>>().hash(state);
+ struct TextInputWidget;
+ TypeId::of::<TextInputWidget>().hash(state);
self.width.hash(state);
self.max_width.hash(state);
@@ -632,7 +632,7 @@ pub trait Renderer: crate::Renderer + Sized {
impl<'a, Message, Renderer> From<TextInput<'a, Message, Renderer>>
for Element<'a, Message, Renderer>
where
- Renderer: 'static + self::Renderer,
+ Renderer: 'a + self::Renderer,
Message: 'a + Clone,
{
fn from(