File: inverse-bounds.rs

package info (click to toggle)
rustc 1.85.0%2Bdfsg3-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental, sid, trixie
  • size: 893,396 kB
  • sloc: xml: 158,127; python: 35,830; javascript: 19,497; cpp: 19,002; sh: 17,245; ansic: 13,127; asm: 4,376; makefile: 1,051; perl: 29; lisp: 29; ruby: 19; sql: 11
file content (50 lines) | stat: -rw-r--r-- 1,172 bytes parent folder | download | duplicates (5)
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
//@ edition:2018
//@ check-pass

trait Trait<'a, 'b> {}
impl<T> Trait<'_, '_> for T {}

// `Invert<'a> <: Invert<'b>` if `'b: 'a`, unlike most types.
//
// I am purposefully avoiding the terms co- and contra-variant because
// their application to regions depends on how you interpreted Rust
// regions. -nikomatsakis
struct Invert<'a>(fn(&'a u8));

fn upper_bounds<'a, 'b, 'c, 'd, 'e>(a: Invert<'a>, b: Invert<'b>) -> impl Trait<'d, 'e>
where
    'c: 'a,
    'c: 'b,
    'd: 'c,
{
    // Representing the where clauses as a graph, where `A: B` is an
    // edge `B -> A`:
    //
    // ```
    // 'a -> 'c -> 'd
    //        ^
    //        |
    //       'b
    // ```
    //
    // Meanwhile we return a value &'0 u8 where we have the constraints:
    //
    // ```
    // '0: 'a
    // '0: 'b
    // '0 in ['d, 'e]
    // ```
    //
    // Here, ignoring the "in" constraint, the minimal choice for `'0`
    // is `'c`, but that is not in the "in set". Still, that reduces
    // the range of options in the "in set" to just `'d` (`'e: 'c`
    // does not hold).
    let p = if condition() { a } else { b };
    p
}

fn condition() -> bool {
    true
}

fn main() {}