about summary refs log tree commit diff
path: root/tests/ui/implied-bounds/gluon_salsa.rs
blob: cc6352c4a32e9887cc98a0eaf19b6b1a7c6e6c24 (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
36
37
//@ check-pass
// Related to Bevy regression #115559, found in
// a crater run on #118553.

pub trait QueryBase {
    type Db;
}

pub trait AsyncQueryFunction<'f>: // 'f is important
    QueryBase<Db = <Self as AsyncQueryFunction<'f>>::SendDb> // bound is important
{
    type SendDb;
}

pub struct QueryTable<'me, Q, DB> {
    _q: Option<Q>,
    _db: Option<DB>,
    _marker: Option<&'me ()>,
}

impl<'me, Q> QueryTable<'me, Q, <Q as QueryBase>::Db>
where
    Q: for<'f> AsyncQueryFunction<'f>,
{
    // When borrowchechking this function we normalize `<Q as QueryBase>::Db` in the
    // function signature to `<Self as QueryFunction<'?x>>::SendDb`, where `'?x` is an
    // unconstrained region variable. We then addd `<Self as QueryFunction<'?x>>::SendDb: 'a`
    // as an implied bound. We currently a structural equality to decide whether this bound
    // should be used to prove the bound  `<Self as QueryFunction<'?x>>::SendDb: 'a`. For this
    // to work we may have to structurally resolve regions as the actually used vars may
    // otherwise be semantically equal but structurally different.
    pub fn get_async<'a>(&'a mut self) {
        panic!();
    }
}

fn main() {}