2023-04-15 16:11:42 -07:00
|
|
|
// ignore-test (This is currently broken)
|
2021-10-03 16:05:55 +01:00
|
|
|
|
|
|
|
#![allow(incomplete_features)]
|
|
|
|
#![feature(const_mut_refs)]
|
2021-11-22 16:25:28 +00:00
|
|
|
#![feature(inline_const_pat)]
|
2021-10-03 16:05:55 +01:00
|
|
|
|
|
|
|
use std::marker::PhantomData;
|
|
|
|
|
|
|
|
#[derive(PartialEq, Eq)]
|
|
|
|
pub struct InvariantRef<'a, T: ?Sized>(&'a T, PhantomData<&'a mut &'a T>);
|
|
|
|
|
|
|
|
impl<'a, T: ?Sized> InvariantRef<'a, T> {
|
|
|
|
pub const fn new(r: &'a T) -> Self {
|
|
|
|
InvariantRef(r, PhantomData)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<'a> InvariantRef<'a, ()> {
|
|
|
|
pub const NEW: Self = InvariantRef::new(&());
|
|
|
|
}
|
|
|
|
|
|
|
|
fn match_invariant_ref<'a>() {
|
|
|
|
let y = ();
|
|
|
|
match InvariantRef::new(&y) {
|
|
|
|
//~^ ERROR `y` does not live long enough [E0597]
|
|
|
|
// FIXME(nbdd0121): This should give the same error as `InvariantRef::<'a>::NEW` (without
|
|
|
|
// const block)
|
|
|
|
const { InvariantRef::<'a>::NEW } => (),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
match_invariant_ref();
|
|
|
|
}
|