Rollup merge of #129323 - Urgau:ptr_fn_addr_eq, r=Mark-Simulacrum

Implement `ptr::fn_addr_eq`

This PR implements https://github.com/rust-lang/libs-team/issues/323: `ptr::fn_addr_eq`.

r? libs
This commit is contained in:
Matthias Krüger 2024-08-24 22:14:13 +02:00 committed by GitHub
commit 2c4338802a
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -2130,6 +2130,33 @@ pub fn addr_eq<T: ?Sized, U: ?Sized>(p: *const T, q: *const U) -> bool {
(p as *const ()) == (q as *const ()) (p as *const ()) == (q as *const ())
} }
/// Compares the *addresses* of the two function pointers for equality.
///
/// Function pointers comparisons can have surprising results since
/// they are never guaranteed to be unique and could vary between different
/// code generation units. Furthermore, different functions could have the
/// same address after being merged together.
///
/// This is the same as `f == g` but using this function makes clear
/// that you are aware of these potentially surprising semantics.
///
/// # Examples
///
/// ```
/// #![feature(ptr_fn_addr_eq)]
/// use std::ptr;
///
/// fn a() { println!("a"); }
/// fn b() { println!("b"); }
/// assert!(!ptr::fn_addr_eq(a as fn(), b as fn()));
/// ```
#[unstable(feature = "ptr_fn_addr_eq", issue = "129322")]
#[inline(always)]
#[must_use = "function pointer comparison produces a value"]
pub fn fn_addr_eq<T: FnPtr, U: FnPtr>(f: T, g: U) -> bool {
f.addr() == g.addr()
}
/// Hash a raw pointer. /// Hash a raw pointer.
/// ///
/// This can be used to hash a `&T` reference (which coerces to `*const T` implicitly) /// This can be used to hash a `&T` reference (which coerces to `*const T` implicitly)