diff options
| author | Ulrik Sverdrup <bluss@users.noreply.github.com> | 2016-12-05 21:48:53 +0100 |
|---|---|---|
| committer | Ulrik Sverdrup <bluss@users.noreply.github.com> | 2016-12-06 07:58:56 +0100 |
| commit | 02bf1ce9cc617979478aac09a95486696f2c4b36 (patch) | |
| tree | 1e55a0c981baa4dd6159e3f5b687ee2d53d37683 | |
| parent | d14d74d5f7d39d1e2583bca231c26bbc0d4ee9a0 (diff) | |
| download | rust-02bf1ce9cc617979478aac09a95486696f2c4b36.tar.gz rust-02bf1ce9cc617979478aac09a95486696f2c4b36.zip | |
vec: More specialization for Extend<&T> for vec
Specialize to use copy_from_slice when extending a Vec with &[T] where T: Copy.
| -rw-r--r-- | src/libcollections/vec.rs | 39 |
1 files changed, 33 insertions, 6 deletions
diff --git a/src/libcollections/vec.rs b/src/libcollections/vec.rs index f2632412700..c9f9e513ef3 100644 --- a/src/libcollections/vec.rs +++ b/src/libcollections/vec.rs @@ -1244,7 +1244,7 @@ impl<T: Clone> Vec<T> { /// ``` #[stable(feature = "vec_extend_from_slice", since = "1.6.0")] pub fn extend_from_slice(&mut self, other: &[T]) { - self.extend(other.iter().cloned()) + self.spec_extend(other.iter()) } } @@ -1499,7 +1499,7 @@ impl<T> ops::DerefMut for Vec<T> { impl<T> FromIterator<T> for Vec<T> { #[inline] fn from_iter<I: IntoIterator<Item = T>>(iter: I) -> Vec<T> { - <Self as SpecExtend<_>>::from_iter(iter.into_iter()) + <Self as SpecExtend<_, _>>::from_iter(iter.into_iter()) } } @@ -1572,12 +1572,12 @@ impl<T> Extend<T> for Vec<T> { } // Specialization trait used for Vec::from_iter and Vec::extend -trait SpecExtend<I> { +trait SpecExtend<T, I> { fn from_iter(iter: I) -> Self; fn spec_extend(&mut self, iter: I); } -impl<I, T> SpecExtend<I> for Vec<T> +impl<T, I> SpecExtend<T, I> for Vec<T> where I: Iterator<Item=T>, { default fn from_iter(mut iterator: I) -> Self { @@ -1607,7 +1607,7 @@ impl<I, T> SpecExtend<I> for Vec<T> } } -impl<I, T> SpecExtend<I> for Vec<T> +impl<T, I> SpecExtend<T, I> for Vec<T> where I: TrustedLen<Item=T>, { fn from_iter(iterator: I) -> Self { @@ -1642,6 +1642,33 @@ impl<I, T> SpecExtend<I> for Vec<T> } } +impl<'a, T: 'a, I> SpecExtend<&'a T, I> for Vec<T> + where I: Iterator<Item=&'a T>, + T: Clone, +{ + default fn from_iter(iterator: I) -> Self { + SpecExtend::from_iter(iterator.cloned()) + } + + default fn spec_extend(&mut self, iterator: I) { + self.spec_extend(iterator.cloned()) + } +} + +impl<'a, T: 'a> SpecExtend<&'a T, slice::Iter<'a, T>> for Vec<T> + where T: Copy, +{ + fn spec_extend(&mut self, iterator: slice::Iter<'a, T>) { + let slice = iterator.as_slice(); + self.reserve(slice.len()); + unsafe { + let len = self.len(); + self.set_len(len + slice.len()); + self.get_unchecked_mut(len..).copy_from_slice(slice); + } + } +} + impl<T> Vec<T> { fn extend_desugared<I: Iterator<Item = T>>(&mut self, mut iterator: I) { // This is the case for a general iterator. @@ -1669,7 +1696,7 @@ impl<T> Vec<T> { #[stable(feature = "extend_ref", since = "1.2.0")] impl<'a, T: 'a + Copy> Extend<&'a T> for Vec<T> { fn extend<I: IntoIterator<Item = &'a T>>(&mut self, iter: I) { - self.extend(iter.into_iter().map(|&x| x)) + self.spec_extend(iter.into_iter()) } } |
