| // Issue #14893. Tests that casts from vectors don't behave strangely in the |
| // presence of the `_` type shorthand notation. |
| // |
| // Update: after a change to the way casts are done, we have more type information |
| // around and so the errors here are no longer exactly the same. |
| // |
| // Update: With PR #81479 some of the previously rejected cases are now allowed. |
| // New test cases added. |
| |
| struct X { |
| y: [u8; 2], |
| } |
| |
| fn main() { |
| let x1 = X { y: [0, 0] }; |
| |
| // No longer a type mismatch - the `_` can be fully resolved by type inference. |
| let p1: *const u8 = &x1.y as *const _; |
| let p1: *mut u8 = &x1.y as *mut _; |
| //~^ ERROR: casting `&[u8; 2]` as `*mut u8` is invalid |
| let t1: *const [u8; 2] = &x1.y as *const _; |
| let t1: *mut [u8; 2] = &x1.y as *mut _; |
| //~^ ERROR: casting `&[u8; 2]` as `*mut [u8; 2]` is invalid |
| let h1: *const [u8; 2] = &x1.y as *const [u8; 2]; |
| let t1: *mut [u8; 2] = &x1.y as *mut [u8; 2]; |
| //~^ ERROR: casting `&[u8; 2]` as `*mut [u8; 2]` is invalid |
| |
| let mut x1 = X { y: [0, 0] }; |
| |
| let p1: *mut u8 = &mut x1.y as *mut _; |
| let p2: *const u8 = &mut x1.y as *const _; |
| let t1: *mut [u8; 2] = &mut x1.y as *mut _; |
| let h1: *mut [u8; 2] = &mut x1.y as *mut [u8; 2]; |
| } |