2021-07-26 15:01:16 -05:00
|
|
|
#![feature(type_alias_impl_trait)]
|
2019-06-17 07:40:50 -05:00
|
|
|
|
|
|
|
#[derive(Clone)]
|
|
|
|
struct CopyIfEq<T, U>(T, U);
|
|
|
|
|
|
|
|
impl<T: Copy> Copy for CopyIfEq<T, T> {}
|
|
|
|
|
2019-07-29 18:11:58 -05:00
|
|
|
type E<'a, 'b> = impl Sized;
|
2019-06-17 07:40:50 -05:00
|
|
|
|
|
|
|
fn foo<'a, 'b, 'c>(x: &'static i32, mut y: &'a i32) -> E<'b, 'c> {
|
2019-12-26 15:13:51 -06: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 07:40:50 -05:00
|
|
|
let u = v;
|
|
|
|
let _: *mut &'a i32 = u.1;
|
2019-12-26 15:13:51 -06:00
|
|
|
unsafe {
|
|
|
|
let _: &'b i32 = *u.0;
|
2020-01-11 11:18:58 -06:00
|
|
|
//~^ ERROR lifetime may not live long enough
|
2019-12-26 15:13:51 -06:00
|
|
|
}
|
2019-06-17 07:40:50 -05:00
|
|
|
u.0
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {}
|