2018-09-06 14:41:12 +02:00
|
|
|
// run-pass
|
|
|
|
|
2016-03-03 10:43:52 +01:00
|
|
|
// pretty-expanded FIXME #23616
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let _ = test(Some(0).into_iter());
|
|
|
|
}
|
|
|
|
|
|
|
|
trait Parser {
|
|
|
|
type Input: Iterator;
|
|
|
|
type Output;
|
|
|
|
fn parse(self, input: Self::Input) -> Result<(Self::Output, Self::Input), ()>;
|
|
|
|
fn chain<P>(self, p: P) -> Chain<Self, P> where Self: Sized {
|
|
|
|
Chain(self, p)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-07-25 22:36:03 +02:00
|
|
|
struct Token<T>(#[allow(unused_tuple_struct_fields)] T::Item) where T: Iterator;
|
2016-03-03 10:43:52 +01:00
|
|
|
|
|
|
|
impl<T> Parser for Token<T> where T: Iterator {
|
|
|
|
type Input = T;
|
|
|
|
type Output = T::Item;
|
|
|
|
fn parse(self, _input: Self::Input) -> Result<(Self::Output, Self::Input), ()> {
|
|
|
|
Err(())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-07-25 22:36:03 +02:00
|
|
|
struct Chain<L, R>(#[allow(unused_tuple_struct_fields)] L, #[allow(unused_tuple_struct_fields)] R);
|
2016-03-03 10:43:52 +01:00
|
|
|
|
|
|
|
impl<L, R> Parser for Chain<L, R> where L: Parser, R: Parser<Input = L::Input> {
|
|
|
|
type Input = L::Input;
|
|
|
|
type Output = (L::Output, R::Output);
|
|
|
|
fn parse(self, _input: Self::Input) -> Result<(Self::Output, Self::Input), ()> {
|
|
|
|
Err(())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn test<I>(i: I) -> Result<((), I), ()> where I: Iterator<Item = i32> {
|
|
|
|
Chain(Token(0), Token(1))
|
|
|
|
.chain(Chain(Token(0), Token(1)))
|
|
|
|
.chain(Chain(Token(0), Token(1)))
|
|
|
|
.chain(Chain(Token(0), Token(1)))
|
|
|
|
.chain(Chain(Token(0), Token(1)))
|
|
|
|
.chain(Chain(Token(0), Token(1)))
|
|
|
|
.chain(Chain(Token(0), Token(1)))
|
|
|
|
.chain(Chain(Token(0), Token(1)))
|
|
|
|
.chain(Chain(Token(0), Token(1)))
|
|
|
|
.parse(i)
|
|
|
|
.map(|(_, i)| ((), i))
|
|
|
|
}
|