diff options
| author | Eduard-Mihai Burtescu <edy.burt@gmail.com> | 2016-08-14 20:29:47 +0300 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2016-08-14 20:29:47 +0300 |
| commit | fa57f358a326af04eb354fb37c9afd38e8bb87bd (patch) | |
| tree | 3a8e5c424a48ff9d990d799c68bd1ef57762be57 /src | |
| parent | 9d1900b417a8425c887b1007df6b1c4eaebddb08 (diff) | |
| parent | 1403df72c82d3c3c2c19369c5f4bb34b3e095604 (diff) | |
| download | rust-fa57f358a326af04eb354fb37c9afd38e8bb87bd.tar.gz rust-fa57f358a326af04eb354fb37c9afd38e8bb87bd.zip | |
Rollup merge of #35392 - malbarbo:cell-from, r=brson
Implement From for Cell, RefCell and UnsafeCell Considering that `From` is implemented for `Box`, `Rc` and `Arc`, it seems [reasonable](https://internals.rust-lang.org/t/implementing-from-t-for-other-std-types/3744) to implement it for `Cell`, `RefCell` and `UnsafeCell`.
Diffstat (limited to 'src')
| -rw-r--r-- | src/libcore/cell.rs | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/src/libcore/cell.rs b/src/libcore/cell.rs index 434084d3af8..17ec325e257 100644 --- a/src/libcore/cell.rs +++ b/src/libcore/cell.rs @@ -146,6 +146,7 @@ use clone::Clone; use cmp::{PartialEq, Eq, PartialOrd, Ord, Ordering}; +use convert::From; use default::Default; use fmt::{self, Debug, Display}; use marker::{Copy, PhantomData, Send, Sync, Sized, Unsize}; @@ -329,6 +330,13 @@ impl<T:Ord + Copy> Ord for Cell<T> { } } +#[stable(feature = "cell_from", since = "1.12.0")] +impl<T: Copy> From<T> for Cell<T> { + fn from(t: T) -> Cell<T> { + Cell::new(t) + } +} + /// A mutable memory location with dynamically checked borrow rules /// /// See the [module-level documentation](index.html) for more. @@ -742,6 +750,13 @@ impl<T: ?Sized + Ord> Ord for RefCell<T> { } } +#[stable(feature = "cell_from", since = "1.12.0")] +impl<T> From<T> for RefCell<T> { + fn from(t: T) -> RefCell<T> { + RefCell::new(t) + } +} + struct BorrowRef<'b> { borrow: &'b Cell<BorrowFlag>, } @@ -1064,3 +1079,10 @@ impl<T: Default> Default for UnsafeCell<T> { UnsafeCell::new(Default::default()) } } + +#[stable(feature = "cell_from", since = "1.12.0")] +impl<T> From<T> for UnsafeCell<T> { + fn from(t: T) -> UnsafeCell<T> { + UnsafeCell::new(t) + } +} |
