Skip to content

Commit

Permalink
Rollup merge of #88565 - lqd:issue-83190, r=spastorino
Browse files Browse the repository at this point in the history
Add regression test for issue 83190

Reduced from `bioyino-metric` by ````@hellow554```` and myself.

Closes #83190.

r? ````@spastorino````
  • Loading branch information
m-ou-se committed Sep 2, 2021
2 parents 0d105c0 + a5fd955 commit e248c4d
Showing 1 changed file with 49 additions and 0 deletions.
49 changes: 49 additions & 0 deletions src/test/ui/issues/issue-83190.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
// check-pass

// Regression test for issue #83190, triggering an ICE in borrowck.

pub trait Any {}
impl<T> Any for T {}

pub trait StreamOnce {
type Range;
}

pub trait Parser<Input>: Sized {
type Output;
type PartialState;
fn map(self) -> Map<Self> {
todo!()
}
}

pub struct Map<P>(P);
impl<I, P: Parser<I, Output = ()>> Parser<I> for Map<P> {
type Output = ();
type PartialState = P::PartialState;
}

struct TakeWhile1<Input>(Input);
impl<I: StreamOnce> Parser<I> for TakeWhile1<I> {
type Output = I::Range;
type PartialState = ();
}
impl<I> TakeWhile1<I> {
fn new() -> Self {
todo!()
}
}

impl<I, A: Parser<I>> Parser<I> for (A,) {
type Output = ();
type PartialState = Map<A::Output>;
}

pub fn metric_stream_parser<'a, I>() -> impl Parser<I, Output = (), PartialState = impl Any + 'a>
where
I: StreamOnce<Range = &'a [()]>,
{
(TakeWhile1::new(),).map()
}

fn main() {}

0 comments on commit e248c4d

Please sign in to comment.