2019-07-03 09:54:08 -05:00
|
|
|
// Test explores how `#[structral_match]` behaves in tandem with
|
|
|
|
// `*const` and `*mut` pointers.
|
|
|
|
|
|
|
|
// run-pass
|
|
|
|
|
2020-09-20 10:22:33 -05:00
|
|
|
#![warn(pointer_structural_match)]
|
|
|
|
|
2022-07-25 15:36:03 -05:00
|
|
|
struct NoDerive(#[allow(unused_tuple_struct_fields)] i32);
|
2019-07-03 09:54:08 -05:00
|
|
|
|
|
|
|
// This impl makes NoDerive irreflexive
|
|
|
|
// (which doesn't matter here because `<*const T>::eq` won't recur on `T`).
|
|
|
|
impl PartialEq for NoDerive { fn eq(&self, _: &Self) -> bool { false } }
|
|
|
|
|
|
|
|
impl Eq for NoDerive { }
|
|
|
|
|
|
|
|
#[derive(PartialEq, Eq)]
|
|
|
|
struct WrapEmbedded(*const NoDerive);
|
|
|
|
|
|
|
|
const WRAP_UNSAFE_EMBEDDED: WrapEmbedded = WrapEmbedded(std::ptr::null());
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
match WRAP_UNSAFE_EMBEDDED {
|
|
|
|
WRAP_UNSAFE_EMBEDDED => { println!("WRAP_UNSAFE_EMBEDDED correctly matched itself"); }
|
|
|
|
_ => { panic!("WRAP_UNSAFE_EMBEDDED did not match itself"); }
|
|
|
|
}
|
|
|
|
}
|