From 23a7235243cadd9c0d0cbf3ac8bdc565013abf30 Mon Sep 17 00:00:00 2001 From: Emilio Gonzalez Date: Sat, 21 Mar 2020 15:22:38 -0600 Subject: [PATCH 1/2] Allow druid_derive macros in druid crate This makes use of feature `extern_crate_self` to refer to the current crate with another name, in this case, druid. This allows druid_derive macros to expand to something like `druid::Data` instead of `crate::Data`. --- druid/src/lib.rs | 3 +++ 1 file changed, 3 insertions(+) diff --git a/druid/src/lib.rs b/druid/src/lib.rs index 6055c9cf05..29c6999c14 100644 --- a/druid/src/lib.rs +++ b/druid/src/lib.rs @@ -102,6 +102,9 @@ #![allow(clippy::new_ret_no_self, clippy::needless_doctest_main)] #![cfg_attr(docsrs, feature(doc_cfg))] +// Allows to use macros from druid_derive in this crate +extern crate self as druid; + use druid_shell as shell; pub use druid_shell::{kurbo, piet}; From 6eae638de8ebe312d250a789d258a7de1ddb81be Mon Sep 17 00:00:00 2001 From: Emilio Gonzalez Date: Sun, 22 Mar 2020 11:14:25 -0600 Subject: [PATCH 2/2] Use derive macros to implement Data in Flex types --- druid/src/widget/flex.rs | 18 ++---------------- 1 file changed, 2 insertions(+), 16 deletions(-) diff --git a/druid/src/widget/flex.rs b/druid/src/widget/flex.rs index d1fc89c0d1..8dcff9d2f7 100644 --- a/druid/src/widget/flex.rs +++ b/druid/src/widget/flex.rs @@ -204,7 +204,7 @@ pub(crate) enum Axis { /// /// If a widget is smaller than the container on the minor axis, this determines /// where it is positioned. -#[derive(Debug, Clone, Copy, PartialEq)] +#[derive(Debug, Clone, Copy, PartialEq, Data)] pub enum CrossAxisAlignment { /// Top or leading. /// @@ -224,7 +224,7 @@ pub enum CrossAxisAlignment { /// /// If there is surplus space on the main axis after laying out children, this /// enum represents how children are laid out in this space. -#[derive(Debug, Clone, Copy, PartialEq)] +#[derive(Debug, Clone, Copy, PartialEq, Data)] pub enum MainAxisAlignment { /// Top or leading. /// @@ -700,20 +700,6 @@ impl Spacing { } } -// we have these impls mostly for our 'flex' example, but I could imagine -// them being broadly useful? -impl Data for MainAxisAlignment { - fn same(&self, other: &MainAxisAlignment) -> bool { - self == other - } -} - -impl Data for CrossAxisAlignment { - fn same(&self, other: &CrossAxisAlignment) -> bool { - self == other - } -} - impl Widget for Spacer { fn event(&mut self, _: &mut EventCtx, _: &Event, _: &mut T, _: &Env) {} fn lifecycle(&mut self, _: &mut LifeCycleCtx, _: &LifeCycle, _: &T, _: &Env) {}