summaryrefslogtreecommitdiffstats
path: root/src/test/ui/implied-bounds/hrlt-implied-trait-bounds-roundtrip.rs
blob: 69847d6a8bb53be9140f060fda6950608e42fe70 (plain)
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
// check-pass
struct Foo<'a>(&'a ())
where
    (): Trait<'a>;

trait Trait<'a> {
    fn id<T>(value: &'a T) -> &'static T;
}

impl Trait<'static> for () {
    fn id<T>(value: &'static T) -> &'static T {
        value
    }
}

fn could_use_implied_bounds<'a, T>(_: Foo<'a>, x: &'a T) -> &'static T
where
    (): Trait<'a>, // This could be an implied bound
{
    <()>::id(x)
}

fn main() {
    let bar: for<'a, 'b> fn(Foo<'a>, &'b ()) = |_, _| {};

    // If `could_use_implied_bounds` were to use implied bounds,
    // keeping 'a late-bound, then we could assign that function
    // to this variable.
    let bar: for<'a> fn(Foo<'a>, &'a ()) = bar;

    // In this case, the subtyping relation here would be unsound,
    // allowing us to transmute lifetimes. This currently compiles
    // because we incorrectly deal with implied bounds inside of binders.
    let _bar: for<'a, 'b> fn(Foo<'a>, &'b ()) = bar;
}