File: nested_uneval_unification-2.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 (31 lines) | stat: -rw-r--r-- 756 bytes parent folder | download | duplicates (18)
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
//@ run-pass
#![feature(generic_const_exprs)]
#![allow(incomplete_features, unused_parens, unused_braces)]

fn zero_init<const N: usize>() -> Substs1<{{ N }}>
where
    [u8; {{ N }}]: ,
{
    Substs1([0; {{ N }}])
}

struct Substs1<const N: usize>([u8; {{ N }}])
where
    [(); {{ N }}]: ;

fn substs2<const M: usize>() -> Substs1<{{ M }}> {
    zero_init::<{{ M }}>()
}

fn substs3<const L: usize>() -> Substs1<{{ L }}> {
    substs2::<{{ L }}>()
}

fn main() {
    assert_eq!(substs3::<2>().0, [0; 2]);
}

// Test that the implicit ``{{ L }}`` bound on ``substs3`` satisfies the
// ``{{ N }}`` bound on ``Substs1``
// FIXME(generic_const_exprs): come up with a less brittle test for this using assoc consts
// once normalization is implemented for them.