diff options
| author | Ulrik Sverdrup <bluss@users.noreply.github.com> | 2015-12-07 00:29:21 +0100 |
|---|---|---|
| committer | Ulrik Sverdrup <bluss@users.noreply.github.com> | 2015-12-07 00:29:21 +0100 |
| commit | 0a9c46319589a229da899fb550ee741d7ae3e5e7 (patch) | |
| tree | e17c066cbcec2fd208cdf1e3d8b91999ba712e17 /src/libcore/array.rs | |
| parent | 64c21f9ee2c6a7e6a530d4bb889676c296e1fe68 (diff) | |
| download | rust-0a9c46319589a229da899fb550ee741d7ae3e5e7.tar.gz rust-0a9c46319589a229da899fb550ee741d7ae3e5e7.zip | |
Revert "PR #30130 Implement `Clone` for more arrays"
This reverts commit e22a64e8d8d4da46c74f878ce1c23ad1c88982e8. This caused a regression such that types like `[[u8; 256]; 4]` no longer implemented Clone. This previously worked due to Clone for `[T; N]` (N in 0 to 32) being implemented for T: Copy. Due to fixed size arrays not implementing Clone for sizes above 32, the new implementation requiring T: Clone would not allow `[[u8; 256]; 4]` to be Clone.
Diffstat (limited to 'src/libcore/array.rs')
| -rw-r--r-- | src/libcore/array.rs | 36 |
1 files changed, 8 insertions, 28 deletions
diff --git a/src/libcore/array.rs b/src/libcore/array.rs index 613ed0d14ee..0c5eada2165 100644 --- a/src/libcore/array.rs +++ b/src/libcore/array.rs @@ -27,7 +27,7 @@ use default::Default; use fmt; use hash::{Hash, self}; use iter::IntoIterator; -use marker::{Sized, Unsize}; +use marker::{Copy, Sized, Unsize}; use option::Option; use slice::{Iter, IterMut, SliceExt}; @@ -127,6 +127,13 @@ macro_rules! array_impls { } #[stable(feature = "rust1", since = "1.0.0")] + impl<T:Copy> Clone for [T; $N] { + fn clone(&self) -> [T; $N] { + *self + } + } + + #[stable(feature = "rust1", since = "1.0.0")] impl<T: Hash> Hash for [T; $N] { fn hash<H: hash::Hasher>(&self, state: &mut H) { Hash::hash(&self[..], state) @@ -235,30 +242,3 @@ macro_rules! array_impl_default { } array_impl_default!{32, T T T T T T T T T T T T T T T T T T T T T T T T T T T T T T T T} - -macro_rules! array_impl_clone { - {$n:expr, $i:expr, $($idx:expr,)*} => { - #[stable(feature = "rust1", since = "1.0.0")] - impl<T: Clone> Clone for [T; $n] { - fn clone(&self) -> [T; $n] { - [self[$i-$i].clone(), $(self[$i-$idx].clone()),*] - } - } - array_impl_clone!{$i, $($idx,)*} - }; - {$n:expr,} => { - #[stable(feature = "rust1", since = "1.0.0")] - impl<T: Clone> Clone for [T; 0] { - fn clone(&self) -> [T; 0] { - [] - } - } - }; -} - -array_impl_clone! { - 32, 31, 30, - 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, - 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, - 9, 8, 7, 6, 5, 4, 3, 2, 1, 0, -} |
