Merge pull request #32 from hellow554/master
[anymap] / src / raw.rs
index 7d537832e424fef9862570295188644663260743..dbd5e2cb120e2bf8700754ed87dfa925e7853da1 100644 (file)
@@ -7,9 +7,9 @@ use std::borrow::Borrow;
 use std::collections::hash_map::{self, HashMap};
 use std::hash::Hash;
 use std::hash::{Hasher, BuildHasherDefault};
+#[cfg(test)]
 use std::mem;
 use std::ops::{Index, IndexMut};
-use std::ptr;
 
 use any::{Any, UncheckedAnyExt};
 
@@ -22,10 +22,11 @@ impl Hasher for TypeIdHasher {
     #[inline]
     fn write(&mut self, bytes: &[u8]) {
         // This expects to receive one and exactly one 64-bit value
-        debug_assert!(bytes.len() == 8);
-        unsafe {
-            ptr::copy_nonoverlapping(mem::transmute(&bytes[0]), &mut self.value, 1)
-        }
+        assert!(bytes.len() == 8);
+        self.value = u64::from(bytes[0])       | u64::from(bytes[1]) << 8  |
+                     u64::from(bytes[2]) << 16 | u64::from(bytes[3]) << 24 |
+                     u64::from(bytes[4]) << 32 | u64::from(bytes[5]) << 40 |
+                     u64::from(bytes[6]) << 48 | u64::from(bytes[7]) << 56;
     }
 
     #[inline]
@@ -69,13 +70,6 @@ impl<A: ?Sized + UncheckedAnyExt> Clone for RawMap<A> where Box<A>: Clone {
     }
 }
 
-impl<A: ?Sized + UncheckedAnyExt> Default for RawMap<A> {
-    #[inline]
-    fn default() -> RawMap<A> {
-        RawMap::new()
-    }
-}
-
 impl_common_methods! {
     field: RawMap.inner;
     new() => HashMap::with_hasher(Default::default());