2021-08-27 18:04:57 +02:00
|
|
|
#![feature(generic_const_exprs)]
|
2020-09-09 09:43:53 +02:00
|
|
|
#![allow(incomplete_features)]
|
|
|
|
|
2022-10-13 00:12:19 +08:00
|
|
|
// The goal is to get an unevaluated const `ct` with a `Ty::Infer(TyVar(_#1t)` subst.
|
2020-09-09 09:43:53 +02:00
|
|
|
//
|
|
|
|
// If we are then able to infer `ty::Infer(TyVar(_#1t) := Ty<ct>` we introduced an
|
|
|
|
// artificial inference cycle.
|
|
|
|
struct Foo<const N: usize>;
|
|
|
|
|
|
|
|
trait Bind<T> {
|
|
|
|
fn bind() -> (T, Self);
|
|
|
|
}
|
|
|
|
|
|
|
|
// `N` has to be `ConstKind::Unevaluated`.
|
|
|
|
impl<T> Bind<T> for Foo<{ 6 + 1 }> {
|
|
|
|
fn bind() -> (T, Self) {
|
|
|
|
(panic!(), Foo)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let (mut t, foo) = Foo::bind();
|
|
|
|
// `t` is `ty::Infer(TyVar(_#1t))`
|
|
|
|
// `foo` contains `ty::Infer(TyVar(_#1t))` in its substs
|
|
|
|
t = foo;
|
2021-01-24 20:08:12 +01:00
|
|
|
//~^ ERROR mismatched types
|
|
|
|
//~| NOTE cyclic type
|
2020-09-09 09:43:53 +02:00
|
|
|
}
|