2021-07-26 17:01:16 -03:00
|
|
|
#![feature(type_alias_impl_trait)]
|
2019-06-17 08:40:50 -04:00
|
|
|
|
|
|
|
#[derive(Clone)]
|
|
|
|
struct CopyIfEq<T, U>(T, U);
|
|
|
|
|
|
|
|
impl<T: Copy> Copy for CopyIfEq<T, T> {}
|
|
|
|
|
2019-07-30 00:11:58 +01:00
|
|
|
type E<'a, 'b> = impl Sized;
|
2019-06-17 08:40:50 -04:00
|
|
|
|
|
|
|
fn foo<'a, 'b, 'c>(x: &'static i32, mut y: &'a i32) -> E<'b, 'c> {
|
2019-12-26 21:13:51 +00:00
|
|
|
let v = CopyIfEq::<*mut _, *mut _>(&mut { x }, &mut y);
|
|
|
|
|
|
|
|
// This assignment requires that `x` and `y` have the same type due to the
|
|
|
|
// `Copy` impl. The reason why we are using a copy to create a constraint
|
|
|
|
// is that only borrow checking (not regionck in type checking) enforces
|
|
|
|
// this bound.
|
2019-06-17 08:40:50 -04:00
|
|
|
let u = v;
|
|
|
|
let _: *mut &'a i32 = u.1;
|
2019-12-26 21:13:51 +00:00
|
|
|
unsafe {
|
|
|
|
let _: &'b i32 = *u.0;
|
2020-01-11 17:18:58 +00:00
|
|
|
//~^ ERROR lifetime may not live long enough
|
2019-12-26 21:13:51 +00:00
|
|
|
}
|
2019-06-17 08:40:50 -04:00
|
|
|
u.0
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {}
|