diff options
author | 2020-04-08 23:07:42 +0100 | |
---|---|---|
committer | 2020-04-08 23:07:42 +0100 | |
commit | 6e7769b65dfda1ab748eb26f8832fd32714f6fc1 (patch) | |
tree | 75013377f67c5f8632fe3e5ae3d1b6c914e84a1b /wgpu | |
parent | ad0a6c4c10afe6dceed52b953cd90aa04e91098a (diff) | |
download | iced-6e7769b65dfda1ab748eb26f8832fd32714f6fc1.tar.gz iced-6e7769b65dfda1ab748eb26f8832fd32714f6fc1.tar.bz2 iced-6e7769b65dfda1ab748eb26f8832fd32714f6fc1.zip |
impl default for canvas cache
Diffstat (limited to 'wgpu')
-rw-r--r-- | wgpu/src/widget/canvas/layer/cache.rs | 31 |
1 files changed, 24 insertions, 7 deletions
diff --git a/wgpu/src/widget/canvas/layer/cache.rs b/wgpu/src/widget/canvas/layer/cache.rs index 20a095bd..4f8c2bec 100644 --- a/wgpu/src/widget/canvas/layer/cache.rs +++ b/wgpu/src/widget/canvas/layer/cache.rs @@ -6,6 +6,19 @@ use crate::{ use iced_native::Size; use std::{cell::RefCell, marker::PhantomData, sync::Arc}; +enum State { + Empty, + Filled { + bounds: Size, + primitive: Arc<Primitive>, + }, +} + +impl Default for State { + fn default() -> Self { + State::Empty + } +} /// A simple cache that stores generated geometry to avoid recomputation. /// /// A [`Cache`] will not redraw its geometry unless the dimensions of its layer @@ -19,12 +32,16 @@ pub struct Cache<T: Drawable> { state: RefCell<State>, } -enum State { - Empty, - Filled { - bounds: Size, - primitive: Arc<Primitive>, - }, +impl<T> Default for Cache<T> +where + T: Drawable, +{ + fn default() -> Self { + Self { + input: PhantomData, + state: Default::default(), + } + } } impl<T> Cache<T> @@ -37,7 +54,7 @@ where pub fn new() -> Self { Cache { input: PhantomData, - state: RefCell::new(State::Empty), + state: Default::default(), } } |