| // Test that we consider equal regions when checking for hidden regions in |
| // opaque types |
| |
| //@ check-pass |
| |
| // `'a == 'static` so `&'a i32` is fine as the return type |
| fn equal_regions_static<'a: 'static>(x: &'a i32) -> impl Sized { |
| x |
| } |
| |
| // `'a == 'b` so `&'b i32` is fine as the return type |
| fn equal_regions<'a: 'b, 'b: 'a>(x: &'b i32) -> impl Sized + 'a { |
| let y: &'a i32 = x; |
| let z: &'b i32 = y; |
| x |
| } |
| |
| // `'a == 'b` so `&'a i32` is fine as the return type |
| fn equal_regions_rev<'a: 'b, 'b: 'a>(x: &'a i32) -> impl Sized + 'b { |
| let y: &'a i32 = x; |
| let z: &'b i32 = y; |
| x |
| } |
| |
| // `'a == 'b` so `*mut &'b i32` is fine as the return type |
| fn equal_regions_inv<'a: 'b, 'b: 'a>(x: *mut &'b i32) -> impl Sized + 'a { |
| let y: *mut &'a i32 = x; |
| let z: *mut &'b i32 = y; |
| x |
| } |
| |
| // `'a == 'b` so `*mut &'a i32` is fine as the return type |
| fn equal_regions_inv_rev<'a: 'b, 'b: 'a>(x: *mut &'a i32) -> impl Sized + 'b { |
| let y: *mut &'a i32 = x; |
| let z: *mut &'b i32 = y; |
| x |
| } |
| |
| // Should be able to infer `fn(&'static ())` as the return type. |
| fn contravariant_lub<'a, 'b: 'a, 'c: 'a, 'd: 'b + 'c>( |
| x: fn(&'b ()), |
| y: fn(&'c ()), |
| c: bool, |
| ) -> impl Sized + 'a { |
| if c { x } else { y } |
| } |
| |
| fn main() {} |