diff options
| author | Alex Crichton <alex@alexcrichton.com> | 2014-10-27 09:08:04 -0700 |
|---|---|---|
| committer | Alex Crichton <alex@alexcrichton.com> | 2014-10-27 15:12:47 -0700 |
| commit | cfeff3e1c7e52ad2d6f364a53b8066c734dc4d83 (patch) | |
| tree | 5b6d09e0bc30d5b521829a5e8f337bef55bcf821 | |
| parent | 1cc938a69adddc4b8b529c12aec62909c35dd704 (diff) | |
| parent | 79e05e999505a3ed4f3e4e1ed5e57deb39ebe485 (diff) | |
| download | rust-cfeff3e1c7e52ad2d6f364a53b8066c734dc4d83.tar.gz rust-cfeff3e1c7e52ad2d6f364a53b8066c734dc4d83.zip | |
rollup merge of #18344 : aochagavia/show-arc
| -rw-r--r-- | src/liballoc/arc.rs | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/src/liballoc/arc.rs b/src/liballoc/arc.rs index c447cb46c53..0e62fbb0144 100644 --- a/src/liballoc/arc.rs +++ b/src/liballoc/arc.rs @@ -15,6 +15,7 @@ use core::atomic; use core::clone::Clone; +use core::fmt::{mod, Show}; use core::kinds::{Sync, Send}; use core::mem::{min_align_of, size_of, drop}; use core::mem; @@ -147,6 +148,12 @@ impl<T: Send + Sync> Deref<T> for Arc<T> { } } +impl<T: Send + Sync + Show> Show for Arc<T> { + fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { + (**self).fmt(f) + } +} + impl<T: Send + Sync + Clone> Arc<T> { /// Acquires a mutable pointer to the inner contents by guaranteeing that /// the reference count is one (no sharing is possible). @@ -280,6 +287,7 @@ mod tests { use std::mem::drop; use std::ops::Drop; use std::option::{Option, Some, None}; + use std::str::Str; use std::sync::atomic; use std::task; use std::vec::Vec; @@ -426,4 +434,10 @@ mod tests { assert!(canary.load(atomic::Acquire) == 1); drop(arc_weak); } + + #[test] + fn show_arc() { + let a = Arc::new(5u32); + assert!(format!("{}", a).as_slice() == "5") + } } |
