From 73314ab10ce27e2f0860520dadeee2ce6eb88f3c Mon Sep 17 00:00:00 2001 From: Corey Farwell Date: Mon, 9 Nov 2015 18:17:14 -0500 Subject: Add Dimension member to AttrValue Fixes #8417 --- components/script/dom/macros.rs | 15 +++++++++++++++ 1 file changed, 15 insertions(+) (limited to 'components/script/dom/macros.rs') diff --git a/components/script/dom/macros.rs b/components/script/dom/macros.rs index d230bec5404..007abac569d 100644 --- a/components/script/dom/macros.rs +++ b/components/script/dom/macros.rs @@ -230,6 +230,21 @@ macro_rules! make_legacy_color_setter( ); ); +#[macro_export] +macro_rules! make_dimension_setter( + ( $attr:ident, $htmlname:expr ) => ( + fn $attr(&self, value: DOMString) { + use dom::bindings::inheritance::Castable; + use dom::element::Element; + use string_cache::Atom; + let element = self.upcast::(); + let value = AttrValue::parse_dimension(value); + // FIXME(pcwalton): Do this at compile time, not at runtime. + element.set_attribute(&Atom::from_slice($htmlname), value) + } + ); +); + /// For use on non-jsmanaged types /// Use #[derive(JSTraceable)] on JS managed types macro_rules! no_jsmanaged_fields( -- cgit v1.2.3