about summary refs log tree commit diff
path: root/src/liballoc/boxed.rs
diff options
context:
space:
mode:
authorBarosl Lee <vcs@barosl.com>2014-12-20 07:44:21 +0900
committerBarosl Lee <vcs@barosl.com>2014-12-20 08:58:33 +0900
commit39f249067a2b0773d887bb311573dc258118d34d (patch)
tree5703e45e9b49c109cfa9a000f924e41cc185a9fd /src/liballoc/boxed.rs
parent95c2ed31aeb66b2662933200dbfd661a573b1f49 (diff)
downloadrust-39f249067a2b0773d887bb311573dc258118d34d.tar.gz
rust-39f249067a2b0773d887bb311573dc258118d34d.zip
Implement Deref for Box
Fixes #18624.
Diffstat (limited to 'src/liballoc/boxed.rs')
-rw-r--r--src/liballoc/boxed.rs15
1 files changed, 15 insertions, 0 deletions
diff --git a/src/liballoc/boxed.rs b/src/liballoc/boxed.rs
index 879a8cc6951..ea7b32ace49 100644
--- a/src/liballoc/boxed.rs
+++ b/src/liballoc/boxed.rs
@@ -22,6 +22,7 @@ use core::option::Option;
 use core::raw::TraitObject;
 use core::result::Result;
 use core::result::Result::{Ok, Err};
+use core::ops::{Deref, DerefMut};
 
 /// A value that represents the global exchange heap. This is the default
 /// place that the `box` keyword allocates into when no place is supplied.
@@ -147,6 +148,14 @@ impl fmt::Show for Box<Any+'static> {
     }
 }
 
+impl<Sized? T> Deref<T> for Box<T> {
+    fn deref(&self) -> &T { &**self }
+}
+
+impl<Sized? T> DerefMut<T> for Box<T> {
+    fn deref_mut(&mut self) -> &mut T { &mut **self }
+}
+
 #[cfg(test)]
 mod test {
     #[test]
@@ -193,4 +202,10 @@ mod test {
         let s = format!("{}", b);
         assert_eq!(s, "&Any");
     }
+
+    #[test]
+    fn deref() {
+        fn homura<T: Deref<i32>>(_: T) { }
+        homura(box 765i32);
+    }
 }