aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSimon Sapin <simon.sapin@exyr.org>2014-09-20 21:03:58 +0100
committerKeegan McAllister <kmcallister@mozilla.com>2014-09-20 13:32:52 -0700
commita40b94d7f946d75e1a66af206efda9879b89c707 (patch)
tree1d5f8d958e12ae59e0ac720a7873e3c3b08cb1e8
parentaf96e8e4093fd332467dab318ef08e4ced0503ad (diff)
downloadservo-a40b94d7f946d75e1a66af206efda9879b89c707.tar.gz
servo-a40b94d7f946d75e1a66af206efda9879b89c707.zip
Use upstream lazy_static!() macro through Cargo
... instead of having our own copy. https://github.com/Kimundi/lazy-static.rs
-rw-r--r--Cargo.lock1
-rw-r--r--components/macros/lib.rs63
-rw-r--r--components/style/Cargo.toml2
-rw-r--r--components/style/lib.rs4
-rw-r--r--components/style/properties/mod.rs.mako2
-rw-r--r--ports/cef/Cargo.lock1
6 files changed, 7 insertions, 66 deletions
diff --git a/Cargo.lock b/Cargo.lock
index ff2afaa6f6b..51b6bc7775e 100644
--- a/Cargo.lock
+++ b/Cargo.lock
@@ -457,6 +457,7 @@ dependencies = [
"cssparser 0.1.0 (git+https://github.com/servo/rust-cssparser#fa619d4ffd6920dee6e7ea79f42d9cceb9015407)",
"encoding 0.1.0 (git+https://github.com/lifthrasiir/rust-encoding#35f0d70f65f73ba16f296f9ec675eddee661ba79)",
"geom 0.1.0 (git+https://github.com/servo/rust-geom#50a294fd997f0c6eb43e9a58ad6e227fdc2a4692)",
+ "lazy_static 0.1.0 (git+https://github.com/Kimundi/lazy-static.rs#e62a65372f1dd9019e37eb9381d819edff80e360)",
"macros 0.0.1",
"url 0.1.0 (git+https://github.com/servo/rust-url#bfdf809365600a7941a77524f9bb065886de3379)",
"util 0.0.1",
diff --git a/components/macros/lib.rs b/components/macros/lib.rs
index daf5eb3c52c..b8db24baea1 100644
--- a/components/macros/lib.rs
+++ b/components/macros/lib.rs
@@ -184,66 +184,3 @@ macro_rules! bitfield(
}
)
)
-
-
-#[macro_export]
-macro_rules! lazy_init(
- ($(static ref $N:ident : $T:ty = $e:expr;)*) => (
- $(
- #[allow(non_camel_case_types)]
- struct $N {__unit__: ()}
- static $N: $N = $N {__unit__: ()};
- impl Deref<$T> for $N {
- fn deref<'a>(&'a self) -> &'a $T {
- unsafe {
- static mut s: *const $T = 0 as *const $T;
- static mut ONCE: ::sync::one::Once = ::sync::one::ONCE_INIT;
- ONCE.doit(|| {
- s = ::std::mem::transmute::<Box<$T>, *const $T>(box () ($e));
- });
- &*s
- }
- }
- }
-
- )*
- )
-)
-
-
-#[cfg(test)]
-mod tests {
- use std::collections::hashmap::HashMap;
- lazy_init! {
- static ref NUMBER: uint = times_two(3);
- static ref VEC: [Box<uint>, ..3] = [box 1, box 2, box 3];
- static ref OWNED_STRING: String = "hello".to_string();
- static ref HASHMAP: HashMap<uint, &'static str> = {
- let mut m = HashMap::new();
- m.insert(0u, "abc");
- m.insert(1, "def");
- m.insert(2, "ghi");
- m
- };
- }
-
- fn times_two(n: uint) -> uint {
- n * 2
- }
-
- #[test]
- fn test_basic() {
- assert_eq!(*OWNED_STRING, "hello".to_string());
- assert_eq!(*NUMBER, 6);
- assert!(HASHMAP.find(&1).is_some());
- assert!(HASHMAP.find(&3).is_none());
- assert_eq!(VEC.as_slice(), &[box 1, box 2, box 3]);
- }
-
- #[test]
- fn test_repeat() {
- assert_eq!(*NUMBER, 6);
- assert_eq!(*NUMBER, 6);
- assert_eq!(*NUMBER, 6);
- }
-}
diff --git a/components/style/Cargo.toml b/components/style/Cargo.toml
index a8ccfc42e35..38964c0e4da 100644
--- a/components/style/Cargo.toml
+++ b/components/style/Cargo.toml
@@ -29,3 +29,5 @@ git = "https://github.com/servo/rust-cssparser"
[dependencies.encoding]
git = "https://github.com/lifthrasiir/rust-encoding"
+[dependencies.lazy_static]
+git = "https://github.com/Kimundi/lazy-static.rs"
diff --git a/components/style/lib.rs b/components/style/lib.rs
index 412c7f142a2..05b358eec70 100644
--- a/components/style/lib.rs
+++ b/components/style/lib.rs
@@ -22,9 +22,9 @@ extern crate url;
extern crate cssparser;
extern crate encoding;
-
#[phase(plugin)]
-extern crate "macros" as servo_macros;
+extern crate lazy_static;
+
extern crate "util" as servo_util;
diff --git a/components/style/properties/mod.rs.mako b/components/style/properties/mod.rs.mako
index 0befa50158c..a38c7568ca0 100644
--- a/components/style/properties/mod.rs.mako
+++ b/components/style/properties/mod.rs.mako
@@ -1822,7 +1822,7 @@ fn get_writing_mode(inheritedbox_style: &style_structs::InheritedBox) -> Writing
/// The initial values for all style structs as defined by the specification.
-lazy_init! {
+lazy_static! {
static ref INITIAL_VALUES: ComputedValues = ComputedValues {
% for style_struct in STYLE_STRUCTS:
${style_struct.ident}: Arc::new(style_structs::${style_struct.name} {
diff --git a/ports/cef/Cargo.lock b/ports/cef/Cargo.lock
index 41541c4cf6b..51894ebec17 100644
--- a/ports/cef/Cargo.lock
+++ b/ports/cef/Cargo.lock
@@ -483,6 +483,7 @@ dependencies = [
"cssparser 0.1.0 (git+https://github.com/servo/rust-cssparser#fa619d4ffd6920dee6e7ea79f42d9cceb9015407)",
"encoding 0.1.0 (git+https://github.com/lifthrasiir/rust-encoding#35f0d70f65f73ba16f296f9ec675eddee661ba79)",
"geom 0.1.0 (git+https://github.com/servo/rust-geom#50a294fd997f0c6eb43e9a58ad6e227fdc2a4692)",
+ "lazy_static 0.1.0 (git+https://github.com/Kimundi/lazy-static.rs#e62a65372f1dd9019e37eb9381d819edff80e360)",
"macros 0.0.1",
"url 0.1.0 (git+https://github.com/servo/rust-url#bfdf809365600a7941a77524f9bb065886de3379)",
"util 0.0.1",