2021-10-03 16:05:55 +01:00
|
|
|
#![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>);
|
|
|
|
|
2024-01-26 13:23:55 +00:00
|
|
|
#[derive(PartialEq, Eq)]
|
|
|
|
pub struct CovariantRef<'a, T: ?Sized>(&'a T);
|
|
|
|
|
2021-10-03 16:05:55 +01:00
|
|
|
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(&());
|
|
|
|
}
|
|
|
|
|
2024-01-26 13:23:55 +00:00
|
|
|
impl<'a> CovariantRef<'a, ()> {
|
|
|
|
pub const NEW: Self = CovariantRef(&());
|
|
|
|
}
|
|
|
|
|
2021-10-03 16:05:55 +01:00
|
|
|
fn match_invariant_ref<'a>() {
|
|
|
|
let y = ();
|
|
|
|
match InvariantRef::new(&y) {
|
2024-01-26 13:23:55 +00:00
|
|
|
//~^ ERROR `y` does not live long enough [E0597]
|
2021-10-03 16:05:55 +01:00
|
|
|
const { InvariantRef::<'a>::NEW } => (),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-01-26 13:23:55 +00:00
|
|
|
fn match_covariant_ref<'a>() {
|
|
|
|
// Unclear if we should error here (should we be able to subtype the type of
|
|
|
|
// `y.0`), but using the associated const directly in the pattern also
|
|
|
|
// errors.
|
|
|
|
let y: (CovariantRef<'static, _>,) = (CovariantRef(&()),);
|
|
|
|
//~^ ERROR lifetime may not live long enough
|
|
|
|
match y.0 {
|
|
|
|
const { CovariantRef::<'a>::NEW } => (),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-10-03 16:05:55 +01:00
|
|
|
fn main() {
|
|
|
|
match_invariant_ref();
|
2024-01-26 13:23:55 +00:00
|
|
|
match_covariant_ref();
|
2021-10-03 16:05:55 +01:00
|
|
|
}
|