diff options
| author | bors <bors@rust-lang.org> | 2014-11-24 13:56:36 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2014-11-24 13:56:36 +0000 |
| commit | 377d7524a897ae91dfd48e7e34847af88dac49cb (patch) | |
| tree | 514cb2b06ad64da560ba34e8eeb0e157dccabf49 /src | |
| parent | 4334d3c19699c65ba8cb354f84fa40e4b678bfa6 (diff) | |
| parent | 26c93433dafaabfd6f61d15c03fde68c9f214bf5 (diff) | |
| download | rust-377d7524a897ae91dfd48e7e34847af88dac49cb.tar.gz rust-377d7524a897ae91dfd48e7e34847af88dac49cb.zip | |
auto merge of #19250 : kmcallister/rust/atomicoption, r=alexcrichton
Fixes #19247.
Diffstat (limited to 'src')
| -rw-r--r-- | src/libsync/atomic.rs | 6 | ||||
| -rw-r--r-- | src/test/compile-fail/atomicoption-not-send-ref.rs | 16 | ||||
| -rw-r--r-- | src/test/compile-fail/atomicoption-not-send.rs | 16 |
3 files changed, 35 insertions, 3 deletions
diff --git a/src/libsync/atomic.rs b/src/libsync/atomic.rs index b4b2ef5218c..0bc5dd11c25 100644 --- a/src/libsync/atomic.rs +++ b/src/libsync/atomic.rs @@ -96,7 +96,7 @@ use alloc::boxed::Box; use core::mem; -use core::prelude::{Drop, None, Option, Some}; +use core::prelude::{Send, Drop, None, Option, Some}; pub use core::atomic::{AtomicBool, AtomicInt, AtomicUint, AtomicPtr}; pub use core::atomic::{Ordering, Relaxed, Release, Acquire, AcqRel, SeqCst}; @@ -114,7 +114,7 @@ pub struct AtomicOption<T> { p: AtomicUint, } -impl<T> AtomicOption<T> { +impl<T: Send> AtomicOption<T> { /// Create a new `AtomicOption` pub fn new(p: Box<T>) -> AtomicOption<T> { unsafe { AtomicOption { p: AtomicUint::new(mem::transmute(p)) } } @@ -170,7 +170,7 @@ impl<T> AtomicOption<T> { } #[unsafe_destructor] -impl<T> Drop for AtomicOption<T> { +impl<T: Send> Drop for AtomicOption<T> { fn drop(&mut self) { let _ = self.take(SeqCst); } diff --git a/src/test/compile-fail/atomicoption-not-send-ref.rs b/src/test/compile-fail/atomicoption-not-send-ref.rs new file mode 100644 index 00000000000..15c726be2fd --- /dev/null +++ b/src/test/compile-fail/atomicoption-not-send-ref.rs @@ -0,0 +1,16 @@ +// Copyright 2014 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or +// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license +// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +use std::sync::atomic::AtomicOption; + +fn main() { + let x = 0u; + AtomicOption::new(box &x); //~ ERROR `x` does not live long enough +} diff --git a/src/test/compile-fail/atomicoption-not-send.rs b/src/test/compile-fail/atomicoption-not-send.rs new file mode 100644 index 00000000000..df3ebf530df --- /dev/null +++ b/src/test/compile-fail/atomicoption-not-send.rs @@ -0,0 +1,16 @@ +// Copyright 2014 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or +// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license +// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +use std::kinds::marker; +use std::sync::atomic::AtomicOption; + +fn main() { + AtomicOption::new(box marker::NoSend); //~ ERROR `core::kinds::Send` is not implemented +} |
