File: normalize-allow-too-many-vars.rs

package info (click to toggle)
rustc 1.86.0%2Bdfsg1-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental, forky, sid
  • size: 913,560 kB
  • sloc: xml: 158,127; python: 35,921; javascript: 19,689; sh: 19,600; cpp: 18,906; ansic: 13,124; asm: 4,376; makefile: 708; perl: 29; lisp: 29; ruby: 19; sql: 11
file content (52 lines) | stat: -rw-r--r-- 1,167 bytes parent folder | download | duplicates (6)
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
//@ check-pass

// When canonicalizing a response in the trait solver, we bail with overflow
// if there are too many non-region inference variables. Doing so in normalizes-to
// goals ends up hiding inference constraints in cases which we want to support,
// see #131969. To prevent this issue we do not check for too many inference
// variables in normalizes-to goals.
#![recursion_limit = "8"]

trait Bound {}
trait Trait {
    type Assoc;
}


impl<T0, T1, T2, T3, T4, T5, T6, T7> Trait for (T0, T1, T2, T3, T4, T5, T6, T7)
where
    T0: Trait,
    T1: Trait,
    T2: Trait,
    T3: Trait,
    T4: Trait,
    T5: Trait,
    T6: Trait,
    T7: Trait,
    (
        T0::Assoc,
        T1::Assoc,
        T2::Assoc,
        T3::Assoc,
        T4::Assoc,
        T5::Assoc,
        T6::Assoc,
        T7::Assoc,
    ): Clone,
{
    type Assoc = (
        T0::Assoc,
        T1::Assoc,
        T2::Assoc,
        T3::Assoc,
        T4::Assoc,
        T5::Assoc,
        T6::Assoc,
        T7::Assoc,
    );
}

trait Overlap {}
impl<T: Trait<Assoc = ()>> Overlap for T {}
impl<T0, T1, T2, T3, T4, T5, T6, T7> Overlap for (T0, T1, T2, T3, T4, T5, T6, T7) {}
fn main() {}