mirror of
https://github.com/rust-lang/rust.git
synced 2025-01-23 05:03:47 +00:00
remove Copy impls from iterators
This commit is contained in:
parent
9070345c0e
commit
ed82b5a70e
@ -1329,7 +1329,7 @@ impl<T, D, I> ExactSizeIterator for Cloned<I> where
|
|||||||
{}
|
{}
|
||||||
|
|
||||||
/// An iterator that repeats endlessly
|
/// An iterator that repeats endlessly
|
||||||
#[derive(Clone, Copy)]
|
#[derive(Clone)]
|
||||||
#[must_use = "iterator adaptors are lazy and do nothing unless consumed"]
|
#[must_use = "iterator adaptors are lazy and do nothing unless consumed"]
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
pub struct Cycle<I> {
|
pub struct Cycle<I> {
|
||||||
@ -1827,7 +1827,6 @@ impl<I> RandomAccessIterator for Enumerate<I> where I: RandomAccessIterator {
|
|||||||
/// An iterator with a `peek()` that returns an optional reference to the next element.
|
/// An iterator with a `peek()` that returns an optional reference to the next element.
|
||||||
#[must_use = "iterator adaptors are lazy and do nothing unless consumed"]
|
#[must_use = "iterator adaptors are lazy and do nothing unless consumed"]
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
#[derive(Copy)]
|
|
||||||
pub struct Peekable<T, I> where I: Iterator<Item=T> {
|
pub struct Peekable<T, I> where I: Iterator<Item=T> {
|
||||||
iter: I,
|
iter: I,
|
||||||
peeked: Option<T>,
|
peeked: Option<T>,
|
||||||
@ -2501,7 +2500,7 @@ impl<A, St, F> Iterator for Unfold<A, St, F> where F: FnMut(&mut St) -> Option<A
|
|||||||
|
|
||||||
/// An infinite iterator starting at `start` and advancing by `step` with each
|
/// An infinite iterator starting at `start` and advancing by `step` with each
|
||||||
/// iteration
|
/// iteration
|
||||||
#[derive(Clone, Copy)]
|
#[derive(Clone)]
|
||||||
#[unstable(feature = "core",
|
#[unstable(feature = "core",
|
||||||
reason = "may be renamed or replaced by range notation adapaters")]
|
reason = "may be renamed or replaced by range notation adapaters")]
|
||||||
pub struct Counter<A> {
|
pub struct Counter<A> {
|
||||||
@ -2537,7 +2536,7 @@ impl<A: Add<Output=A> + Clone> Iterator for Counter<A> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// An iterator over the range [start, stop)
|
/// An iterator over the range [start, stop)
|
||||||
#[derive(Clone, Copy)]
|
#[derive(Clone)]
|
||||||
#[unstable(feature = "core",
|
#[unstable(feature = "core",
|
||||||
reason = "will be replaced by range notation")]
|
reason = "will be replaced by range notation")]
|
||||||
pub struct Range<A> {
|
pub struct Range<A> {
|
||||||
|
@ -41,7 +41,6 @@ use cmp::Ordering::{Less, Equal, Greater};
|
|||||||
use cmp;
|
use cmp;
|
||||||
use default::Default;
|
use default::Default;
|
||||||
use iter::*;
|
use iter::*;
|
||||||
use marker::Copy;
|
|
||||||
use num::Int;
|
use num::Int;
|
||||||
use ops::{FnMut, self, Index};
|
use ops::{FnMut, self, Index};
|
||||||
#[cfg(stage0)]
|
#[cfg(stage0)]
|
||||||
@ -800,8 +799,6 @@ impl<'a, T> Iter<'a, T> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a,T> Copy for Iter<'a,T> {}
|
|
||||||
|
|
||||||
iterator!{struct Iter -> *const T, &'a T}
|
iterator!{struct Iter -> *const T, &'a T}
|
||||||
|
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
@ -809,7 +806,7 @@ impl<'a, T> ExactSizeIterator for Iter<'a, T> {}
|
|||||||
|
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
impl<'a, T> Clone for Iter<'a, T> {
|
impl<'a, T> Clone for Iter<'a, T> {
|
||||||
fn clone(&self) -> Iter<'a, T> { *self }
|
fn clone(&self) -> Iter<'a, T> { Iter { ptr: self.ptr, end: self.end, marker: self.marker } }
|
||||||
}
|
}
|
||||||
|
|
||||||
#[unstable(feature = "core", reason = "trait is experimental")]
|
#[unstable(feature = "core", reason = "trait is experimental")]
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
|
|
||||||
use self::Searcher::{Naive, TwoWay, TwoWayLong};
|
use self::Searcher::{Naive, TwoWay, TwoWayLong};
|
||||||
|
|
||||||
|
use clone::Clone;
|
||||||
use cmp::{self, Eq};
|
use cmp::{self, Eq};
|
||||||
use default::Default;
|
use default::Default;
|
||||||
use error::Error;
|
use error::Error;
|
||||||
@ -279,7 +280,7 @@ Section: Iterators
|
|||||||
/// Iterator for the char (representing *Unicode Scalar Values*) of a string
|
/// Iterator for the char (representing *Unicode Scalar Values*) of a string
|
||||||
///
|
///
|
||||||
/// Created with the method `.chars()`.
|
/// Created with the method `.chars()`.
|
||||||
#[derive(Clone, Copy)]
|
#[derive(Clone)]
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
pub struct Chars<'a> {
|
pub struct Chars<'a> {
|
||||||
iter: slice::Iter<'a, u8>
|
iter: slice::Iter<'a, u8>
|
||||||
@ -1007,11 +1008,11 @@ fn run_utf8_validation_iterator(iter: &mut slice::Iter<u8>)
|
|||||||
let whole = iter.as_slice();
|
let whole = iter.as_slice();
|
||||||
loop {
|
loop {
|
||||||
// save the current thing we're pointing at.
|
// save the current thing we're pointing at.
|
||||||
let old = *iter;
|
let old = iter.clone();
|
||||||
|
|
||||||
// restore the iterator we had at the start of this codepoint.
|
// restore the iterator we had at the start of this codepoint.
|
||||||
macro_rules! err { () => {{
|
macro_rules! err { () => {{
|
||||||
*iter = old;
|
*iter = old.clone();
|
||||||
return Err(Utf8Error::InvalidByte(whole.len() - iter.as_slice().len()))
|
return Err(Utf8Error::InvalidByte(whole.len() - iter.as_slice().len()))
|
||||||
}}}
|
}}}
|
||||||
|
|
||||||
|
@ -366,32 +366,32 @@ fn test_iterator_size_hint() {
|
|||||||
let vi = v.iter();
|
let vi = v.iter();
|
||||||
|
|
||||||
assert_eq!(c.size_hint(), (uint::MAX, None));
|
assert_eq!(c.size_hint(), (uint::MAX, None));
|
||||||
assert_eq!(vi.size_hint(), (10, Some(10)));
|
assert_eq!(vi.clone().size_hint(), (10, Some(10)));
|
||||||
|
|
||||||
assert_eq!(c.take(5).size_hint(), (5, Some(5)));
|
assert_eq!(c.clone().take(5).size_hint(), (5, Some(5)));
|
||||||
assert_eq!(c.skip(5).size_hint().1, None);
|
assert_eq!(c.clone().skip(5).size_hint().1, None);
|
||||||
assert_eq!(c.take_while(|_| false).size_hint(), (0, None));
|
assert_eq!(c.clone().take_while(|_| false).size_hint(), (0, None));
|
||||||
assert_eq!(c.skip_while(|_| false).size_hint(), (0, None));
|
assert_eq!(c.clone().skip_while(|_| false).size_hint(), (0, None));
|
||||||
assert_eq!(c.enumerate().size_hint(), (uint::MAX, None));
|
assert_eq!(c.clone().enumerate().size_hint(), (uint::MAX, None));
|
||||||
assert_eq!(c.chain(vi.map(|&i| i)).size_hint(), (uint::MAX, None));
|
assert_eq!(c.clone().chain(vi.clone().map(|&i| i)).size_hint(), (uint::MAX, None));
|
||||||
assert_eq!(c.zip(vi).size_hint(), (10, Some(10)));
|
assert_eq!(c.clone().zip(vi.clone()).size_hint(), (10, Some(10)));
|
||||||
assert_eq!(c.scan(0i, |_,_| Some(0i)).size_hint(), (0, None));
|
assert_eq!(c.clone().scan(0i, |_,_| Some(0i)).size_hint(), (0, None));
|
||||||
assert_eq!(c.filter(|_| false).size_hint(), (0, None));
|
assert_eq!(c.clone().filter(|_| false).size_hint(), (0, None));
|
||||||
assert_eq!(c.map(|_| 0i).size_hint(), (uint::MAX, None));
|
assert_eq!(c.clone().map(|_| 0i).size_hint(), (uint::MAX, None));
|
||||||
assert_eq!(c.filter_map(|_| Some(0i)).size_hint(), (0, None));
|
assert_eq!(c.filter_map(|_| Some(0i)).size_hint(), (0, None));
|
||||||
|
|
||||||
assert_eq!(vi.take(5).size_hint(), (5, Some(5)));
|
assert_eq!(vi.clone().take(5).size_hint(), (5, Some(5)));
|
||||||
assert_eq!(vi.take(12).size_hint(), (10, Some(10)));
|
assert_eq!(vi.clone().take(12).size_hint(), (10, Some(10)));
|
||||||
assert_eq!(vi.skip(3).size_hint(), (7, Some(7)));
|
assert_eq!(vi.clone().skip(3).size_hint(), (7, Some(7)));
|
||||||
assert_eq!(vi.skip(12).size_hint(), (0, Some(0)));
|
assert_eq!(vi.clone().skip(12).size_hint(), (0, Some(0)));
|
||||||
assert_eq!(vi.take_while(|_| false).size_hint(), (0, Some(10)));
|
assert_eq!(vi.clone().take_while(|_| false).size_hint(), (0, Some(10)));
|
||||||
assert_eq!(vi.skip_while(|_| false).size_hint(), (0, Some(10)));
|
assert_eq!(vi.clone().skip_while(|_| false).size_hint(), (0, Some(10)));
|
||||||
assert_eq!(vi.enumerate().size_hint(), (10, Some(10)));
|
assert_eq!(vi.clone().enumerate().size_hint(), (10, Some(10)));
|
||||||
assert_eq!(vi.chain(v2.iter()).size_hint(), (13, Some(13)));
|
assert_eq!(vi.clone().chain(v2.iter()).size_hint(), (13, Some(13)));
|
||||||
assert_eq!(vi.zip(v2.iter()).size_hint(), (3, Some(3)));
|
assert_eq!(vi.clone().zip(v2.iter()).size_hint(), (3, Some(3)));
|
||||||
assert_eq!(vi.scan(0i, |_,_| Some(0i)).size_hint(), (0, Some(10)));
|
assert_eq!(vi.clone().scan(0i, |_,_| Some(0i)).size_hint(), (0, Some(10)));
|
||||||
assert_eq!(vi.filter(|_| false).size_hint(), (0, Some(10)));
|
assert_eq!(vi.clone().filter(|_| false).size_hint(), (0, Some(10)));
|
||||||
assert_eq!(vi.map(|&i| i+1).size_hint(), (10, Some(10)));
|
assert_eq!(vi.clone().map(|&i| i+1).size_hint(), (10, Some(10)));
|
||||||
assert_eq!(vi.filter_map(|_| Some(0i)).size_hint(), (0, Some(10)));
|
assert_eq!(vi.filter_map(|_| Some(0i)).size_hint(), (0, Some(10)));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -904,7 +904,7 @@ fn bench_multiple_take(b: &mut Bencher) {
|
|||||||
b.iter(|| {
|
b.iter(|| {
|
||||||
let n = it.next().unwrap();
|
let n = it.next().unwrap();
|
||||||
for _ in 0u..n {
|
for _ in 0u..n {
|
||||||
it.take(it.next().unwrap()).all(|_| true);
|
it.clone().take(it.next().unwrap()).all(|_| true);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -447,7 +447,7 @@ impl<'a> Iterator for Utf16Items<'a> {
|
|||||||
Some(Utf16Item::LoneSurrogate(u))
|
Some(Utf16Item::LoneSurrogate(u))
|
||||||
} else {
|
} else {
|
||||||
// preserve state for rewinding.
|
// preserve state for rewinding.
|
||||||
let old = self.iter;
|
let old = self.iter.clone();
|
||||||
|
|
||||||
let u2 = match self.iter.next() {
|
let u2 = match self.iter.next() {
|
||||||
Some(u2) => *u2,
|
Some(u2) => *u2,
|
||||||
@ -457,7 +457,7 @@ impl<'a> Iterator for Utf16Items<'a> {
|
|||||||
if u2 < 0xDC00 || u2 > 0xDFFF {
|
if u2 < 0xDC00 || u2 > 0xDFFF {
|
||||||
// not a trailing surrogate so we're not a valid
|
// not a trailing surrogate so we're not a valid
|
||||||
// surrogate pair, so rewind to redecode u2 next time.
|
// surrogate pair, so rewind to redecode u2 next time.
|
||||||
self.iter = old;
|
self.iter = old.clone();
|
||||||
return Some(Utf16Item::LoneSurrogate(u))
|
return Some(Utf16Item::LoneSurrogate(u))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user