diff options
| author | Aaron Turon <aturon@mozilla.com> | 2014-11-20 08:43:37 -0800 |
|---|---|---|
| committer | Aaron Turon <aturon@mozilla.com> | 2014-11-20 12:00:07 -0800 |
| commit | bab9564280a02ca04aa95e71c1c7163a31bc7867 (patch) | |
| tree | 0bf643ea7b13c22a7c397ea8cd7c17d8c8035b5f | |
| parent | 793624261a221aa4592381fa8067e1f597b90c22 (diff) | |
| download | rust-bab9564280a02ca04aa95e71c1c7163a31bc7867.tar.gz rust-bab9564280a02ca04aa95e71c1c7163a31bc7867.zip | |
libs: make Cow usable, improve documentation
This commit makes `Cow` more usable by allowing it to be applied to unsized types (as was intended) and providing some basic `ToOwned` implementations on slice types. It also corrects the documentation for `Cow` to no longer mention `DerefMut`, and adds an example.
| -rw-r--r-- | src/libcollections/slice.rs | 7 | ||||
| -rw-r--r-- | src/libcollections/str.rs | 9 | ||||
| -rw-r--r-- | src/libcore/borrow.rs | 30 |
3 files changed, 36 insertions, 10 deletions
diff --git a/src/libcollections/slice.rs b/src/libcollections/slice.rs index 5e341ba8b04..345d8955eec 100644 --- a/src/libcollections/slice.rs +++ b/src/libcollections/slice.rs @@ -89,7 +89,7 @@ use self::Direction::*; use alloc::boxed::Box; -use core::borrow::{BorrowFrom, BorrowFromMut}; +use core::borrow::{BorrowFrom, BorrowFromMut, ToOwned}; use core::cmp; use core::kinds::Sized; use core::mem::size_of; @@ -658,6 +658,11 @@ impl<T> BorrowFromMut<Vec<T>> for [T] { fn borrow_from_mut(owned: &mut Vec<T>) -> &mut [T] { owned[mut] } } +#[unstable = "trait is unstable"] +impl<T: Clone> ToOwned<Vec<T>> for [T] { + fn to_owned(&self) -> Vec<T> { self.to_vec() } +} + /// Unsafe operations pub mod raw { pub use core::slice::raw::{buf_as_slice, mut_buf_as_slice}; diff --git a/src/libcollections/str.rs b/src/libcollections/str.rs index aaa7da312f2..a4c3c43ddb9 100644 --- a/src/libcollections/str.rs +++ b/src/libcollections/str.rs @@ -54,7 +54,7 @@ pub use self::MaybeOwned::*; use self::RecompositionState::*; use self::DecompositionType::*; -use core::borrow::BorrowFrom; +use core::borrow::{BorrowFrom, ToOwned}; use core::default::Default; use core::fmt; use core::cmp; @@ -67,7 +67,7 @@ use core::prelude::{range}; use hash; use ring_buf::RingBuf; -use string::String; +use string::{String, ToString}; use unicode; use vec::Vec; @@ -609,6 +609,11 @@ impl BorrowFrom<String> for str { fn borrow_from(owned: &String) -> &str { owned[] } } +#[unstable = "trait is unstable"] +impl ToOwned<String> for str { + fn to_owned(&self) -> String { self.to_string() } +} + /// Unsafe string operations. pub mod raw { pub use core::str::raw::{from_utf8, c_str_to_static_slice, slice_bytes}; diff --git a/src/libcore/borrow.rs b/src/libcore/borrow.rs index f0a14c02382..f381d70a91b 100644 --- a/src/libcore/borrow.rs +++ b/src/libcore/borrow.rs @@ -37,10 +37,10 @@ //! data lazily when mutation or ownership is required. The type is designed to //! work with general borrowed data via the `BorrowFrom` trait. //! -//! `Cow` implements both `Deref` and `DerefMut`, which means that you can call -//! methods directly on the data it encloses. The first time a mutable reference -//! is required, the data will be cloned (via `to_owned`) if it is not -//! already owned. +//! `Cow` implements both `Deref`, which means that you can call +//! non-mutating methods directly on the data it encloses. If mutation +//! is desired, `to_mut` will obtain a mutable references to an owned +//! value, cloning if necessary. #![unstable = "recently added as part of collections reform"] @@ -84,7 +84,23 @@ impl<T> ToOwned<T> for T where T: Clone { } /// A clone-on-write smart pointer. -pub enum Cow<'a, T, B: 'a> where B: ToOwned<T> { +/// +/// # Example +/// +/// ```rust +/// use std::borrow::Cow; +/// +/// fn abs_all(input: &mut Cow<Vec<int>, [int]>) { +/// for i in range(0, input.len()) { +/// let v = input[i]; +/// if v < 0 { +/// // clones into a vector the first time (if not already owned) +/// input.to_mut()[i] = -v; +/// } +/// } +/// } +/// ``` +pub enum Cow<'a, T, Sized? B: 'a> where B: ToOwned<T> { /// Borrowed data. Borrowed(&'a B), @@ -92,7 +108,7 @@ pub enum Cow<'a, T, B: 'a> where B: ToOwned<T> { Owned(T) } -impl<'a, T, B> Cow<'a, T, B> where B: ToOwned<T> { +impl<'a, T, Sized? B> Cow<'a, T, B> where B: ToOwned<T> { /// Acquire a mutable reference to the owned form of the data. /// /// Copies the data if it is not already owned. @@ -117,7 +133,7 @@ impl<'a, T, B> Cow<'a, T, B> where B: ToOwned<T> { } } -impl<'a, T, B> Deref<B> for Cow<'a, T, B> where B: ToOwned<T> { +impl<'a, T, Sized? B> Deref<B> for Cow<'a, T, B> where B: ToOwned<T> { fn deref(&self) -> &B { match *self { Borrowed(borrowed) => borrowed, |
