1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100
|
// revisions: no_drop_tracking drop_tracking drop_tracking_mir
// [drop_tracking] compile-flags: -Zdrop-tracking
// [drop_tracking_mir] compile-flags: -Zdrop-tracking-mir
// Test that impl trait does not allow creating recursive types that are
// otherwise forbidden.
#![feature(generators)]
#![allow(unconditional_recursion)]
fn option(i: i32) -> impl Sized {
//~^ ERROR cannot resolve opaque type
if i < 0 { None } else { Some((option(i - 1), i)) }
}
fn tuple() -> impl Sized {
//~^ ERROR
(tuple(),)
}
fn array() -> impl Sized {
//~^ ERROR
[array()]
}
fn ptr() -> impl Sized {
//~^ ERROR
&ptr() as *const _
}
fn fn_ptr() -> impl Sized {
//~^ ERROR
fn_ptr as fn() -> _
}
fn closure_capture() -> impl Sized {
//~^ ERROR
let x = closure_capture();
move || {
x;
}
}
fn closure_ref_capture() -> impl Sized {
//~^ ERROR
let x = closure_ref_capture();
move || {
&x;
}
}
fn closure_sig() -> impl Sized {
//~^ ERROR
|| closure_sig()
}
fn generator_sig() -> impl Sized {
//~^ ERROR
|| generator_sig()
}
fn generator_capture() -> impl Sized {
//~^ ERROR
let x = generator_capture();
move || {
yield;
x;
}
}
fn substs_change<T: 'static>() -> impl Sized {
//~^ ERROR
(substs_change::<&T>(),)
}
fn generator_hold() -> impl Sized {
//~^ ERROR
move || {
let x = generator_hold();
yield;
x;
}
}
fn use_fn_ptr() -> impl Sized {
// OK, error already reported
fn_ptr()
}
fn mutual_recursion() -> impl Sync {
//~^ ERROR
mutual_recursion_b()
}
fn mutual_recursion_b() -> impl Sized {
//~^ ERROR
mutual_recursion()
}
fn main() {}
|