2019-12-14 04:28:32 +01:00
|
|
|
// build-fail
|
2023-09-09 08:36:50 +02:00
|
|
|
// normalize-stderr-test: "<\{closure@.+`" -> "$$CLOSURE`"
|
2020-09-16 03:45:58 +01:00
|
|
|
// normalize-stderr-test: ".nll/" -> "/"
|
2018-08-09 12:48:31 +02:00
|
|
|
|
2015-09-10 11:26:19 -04:00
|
|
|
#![allow(unused)]
|
|
|
|
|
2016-11-15 23:25:59 +02:00
|
|
|
#![recursion_limit = "20"]
|
|
|
|
#![type_length_limit = "20000000"]
|
2017-10-30 18:19:31 +01:00
|
|
|
#![crate_type = "rlib"]
|
2015-11-18 12:27:35 -05:00
|
|
|
|
2015-09-10 11:26:19 -04:00
|
|
|
#[derive(Clone)]
|
|
|
|
struct A (B);
|
|
|
|
|
|
|
|
impl A {
|
|
|
|
pub fn matches<F: Fn()>(&self, f: &F) {
|
|
|
|
let &A(ref term) = self;
|
|
|
|
term.matches(f);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Clone)]
|
|
|
|
enum B {
|
|
|
|
Variant1,
|
|
|
|
Variant2(C),
|
|
|
|
}
|
|
|
|
|
|
|
|
impl B {
|
|
|
|
pub fn matches<F: Fn()>(&self, f: &F) {
|
|
|
|
match self {
|
|
|
|
&B::Variant2(ref factor) => {
|
|
|
|
factor.matches(&|| ())
|
|
|
|
}
|
|
|
|
_ => unreachable!("")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Clone)]
|
|
|
|
struct C (D);
|
|
|
|
|
|
|
|
impl C {
|
|
|
|
pub fn matches<F: Fn()>(&self, f: &F) {
|
|
|
|
let &C(ref base) = self;
|
|
|
|
base.matches(&|| {
|
|
|
|
C(base.clone()).matches(f)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Clone)]
|
|
|
|
struct D (Box<A>);
|
|
|
|
|
|
|
|
impl D {
|
|
|
|
pub fn matches<F: Fn()>(&self, f: &F) {
|
|
|
|
let &D(ref a) = self;
|
|
|
|
a.matches(f)
|
2023-09-09 08:36:50 +02:00
|
|
|
//~^ ERROR reached the recursion limit while instantiating `A::matches::<{closure
|
2015-09-10 11:26:19 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn matches() {
|
|
|
|
A(B::Variant1).matches(&(|| ()))
|
|
|
|
}
|