rust/tests/ui/coroutine/iterator-count.rs
surechen 40ae34194c remove redundant imports
detects redundant imports that can be eliminated.

for #117772 :

In order to facilitate review and modification, split the checking code and
removing redundant imports code into two PR.
2023-12-10 10:56:22 +08:00

44 lines
929 B
Rust

// run-pass
#![feature(coroutines, coroutine_trait)]
use std::ops::{Coroutine, CoroutineState};
use std::pin::Pin;
struct W<T>(T);
// This impl isn't safe in general, but the coroutine used in this test is movable
// so it won't cause problems.
impl<T: Coroutine<(), Return = ()> + Unpin> Iterator for W<T> {
type Item = T::Yield;
fn next(&mut self) -> Option<Self::Item> {
match Pin::new(&mut self.0).resume(()) {
CoroutineState::Complete(..) => None,
CoroutineState::Yielded(v) => Some(v),
}
}
}
fn test() -> impl Coroutine<(), Return = (), Yield = u8> + Unpin {
|| {
for i in 1..6 {
yield i
}
}
}
fn main() {
let end = 11;
let closure_test = |start| {
move || {
for i in start..end {
yield i
}
}
};
assert!(W(test()).chain(W(closure_test(6))).eq(1..11));
}