From 9697076b62553fe8ca3dc23d5cc067a94d9e4570 Mon Sep 17 00:00:00 2001 From: Sebastian Hahn Date: Fri, 18 Dec 2015 23:32:16 +0100 Subject: [PATCH] Implement arc::Weak::new() --- src/liballoc/arc.rs | 37 +++++++++++++++++++++++++++++++++++++ 1 file changed, 37 insertions(+) diff --git a/src/liballoc/arc.rs b/src/liballoc/arc.rs index 9479d47943e..377dfb11f92 100644 --- a/src/liballoc/arc.rs +++ b/src/liballoc/arc.rs @@ -79,6 +79,7 @@ use core::cmp::Ordering; use core::mem::{align_of_val, size_of_val}; use core::intrinsics::abort; use core::mem; +use core::mem::uninitialized; use core::ops::Deref; #[cfg(not(stage0))] use core::ops::CoerceUnsized; @@ -910,6 +911,36 @@ impl From for Arc { } } +impl Weak { + /// Constructs a new `Weak` without an accompanying instance of T. + /// + /// This allocates memory for T, but does not initialize it. Calling + /// Weak::upgrade() on the return value always gives None. + /// + /// # Examples + /// + /// ``` + /// #![feature(downgraded_weak)] + /// + /// use std::sync::Arc; + /// + /// let five = Arc::new(5); + /// ``` + #[unstable(feature = "downgraded_weak", + reason = "recently added", + issue = "30425")] + pub fn new() -> Weak { + unsafe { + let x: Box<_> = box ArcInner { + strong: atomic::AtomicUsize::new(0), + weak: atomic::AtomicUsize::new(1), + data: uninitialized(), + }; + Weak { _ptr: Shared::new(Box::into_raw(x)) } + } + } +} + #[cfg(test)] mod tests { use std::clone::Clone; @@ -1160,6 +1191,12 @@ mod tests { let foo_arc = Arc::from(foo); assert!(123 == *foo_arc); } + + #[test] + fn test_new_weak() { + let foo: Weak = Weak::new(); + assert!(foo.upgrade().is_none()); + } } #[stable(feature = "rust1", since = "1.0.0")]