From 00716b480fa8fbbfc0a3d64b908cafe7141b1f09 Mon Sep 17 00:00:00 2001 From: Chris Gregory Date: Sat, 23 Mar 2019 19:43:32 -0400 Subject: [PATCH 1/4] Make `ptr::eq` documentation mention smart-pointer behavior Resolves #59214 --- src/libcore/ptr.rs | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/libcore/ptr.rs b/src/libcore/ptr.rs index a9a029d606d6f..c9f1a87ba9ff2 100644 --- a/src/libcore/ptr.rs +++ b/src/libcore/ptr.rs @@ -2483,6 +2483,10 @@ impl Eq for *mut T {} /// by their address rather than comparing the values they point to /// (which is what the `PartialEq for &T` implementation does). /// +/// Smart pointer types, such as `Box`, `Rc`, and `Arc` do not compare +/// using this function, instead they compare the values rather than +/// their addresses. +/// /// # Examples /// /// ``` From e91689cd97657ae2db5e716a5178ea4f5779570a Mon Sep 17 00:00:00 2001 From: Chris Gregory Date: Mon, 25 Mar 2019 16:38:12 -0400 Subject: [PATCH 2/4] Rework documentation to be about fat pointers --- src/libcore/ptr.rs | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/src/libcore/ptr.rs b/src/libcore/ptr.rs index c9f1a87ba9ff2..d795bf0ad8303 100644 --- a/src/libcore/ptr.rs +++ b/src/libcore/ptr.rs @@ -2483,9 +2483,13 @@ impl Eq for *mut T {} /// by their address rather than comparing the values they point to /// (which is what the `PartialEq for &T` implementation does). /// -/// Smart pointer types, such as `Box`, `Rc`, and `Arc` do not compare -/// using this function, instead they compare the values rather than -/// their addresses. +/// A reference in Rust is sometimes stored different than a raw +/// memory address. These cases are called fat pointers. A reference +/// to a slice must store both the address of the slice and the length +/// of the slice. A reference to an object satisfying a trait must +/// also point to the vtable for the trait's methods. Since this +/// function compares pointers in totality, careful consideration to +/// the type of the variable must be made. /// /// # Examples /// @@ -2499,9 +2503,9 @@ impl Eq for *mut T {} /// let other_five_ref = &other_five; /// /// assert!(five_ref == same_five_ref); -/// assert!(five_ref == other_five_ref); -/// /// assert!(ptr::eq(five_ref, same_five_ref)); +/// +/// assert!(five_ref == other_five_ref); /// assert!(!ptr::eq(five_ref, other_five_ref)); /// ``` #[stable(feature = "ptr_eq", since = "1.17.0")] From fbfc8082b425b8812a725a7d3097b124acde10ea Mon Sep 17 00:00:00 2001 From: Chris Gregory Date: Mon, 25 Mar 2019 17:19:47 -0400 Subject: [PATCH 3/4] Rework documentation into examples --- src/libcore/ptr.rs | 54 +++++++++++++++++++++++++++++++++++++++------- 1 file changed, 46 insertions(+), 8 deletions(-) diff --git a/src/libcore/ptr.rs b/src/libcore/ptr.rs index d795bf0ad8303..55af518b886b0 100644 --- a/src/libcore/ptr.rs +++ b/src/libcore/ptr.rs @@ -2483,14 +2483,6 @@ impl Eq for *mut T {} /// by their address rather than comparing the values they point to /// (which is what the `PartialEq for &T` implementation does). /// -/// A reference in Rust is sometimes stored different than a raw -/// memory address. These cases are called fat pointers. A reference -/// to a slice must store both the address of the slice and the length -/// of the slice. A reference to an object satisfying a trait must -/// also point to the vtable for the trait's methods. Since this -/// function compares pointers in totality, careful consideration to -/// the type of the variable must be made. -/// /// # Examples /// /// ``` @@ -2508,6 +2500,52 @@ impl Eq for *mut T {} /// assert!(five_ref == other_five_ref); /// assert!(!ptr::eq(five_ref, other_five_ref)); /// ``` +/// +/// Slices are also compared by their length (fat pointers): +/// +/// ``` +/// let a = [1, 2, 3]; +/// assert!(std::ptr::eq(&a[..3], &a[..3])); +/// assert!(!std::ptr::eq(&a[..2], &a[..3])); +/// assert!(!std::ptr::eq(&a[0..2], &a[1..3])); +/// ``` +/// +/// Traits are also compared by their implementation: +/// +/// ``` +/// #[repr(transparent)] +/// struct Wrapper { member: i32 } +/// +/// trait Trait {} +/// impl Trait for Wrapper {} +/// impl Trait for i32 {} +/// +/// fn main() { +/// let wrapper = Wrapper { member: 10 }; +/// +/// // Pointers are equal address +/// assert!(std::ptr::eq( +/// &wrapper as *const Wrapper as *const u8, +/// &wrapper.member as *const i32 as *const u8 +/// )); +/// +/// // Objects have equal addresses, but `Trait` has different implementations +/// assert!(!std::ptr::eq( +/// &wrapper as &Trait, +/// &wrapper.member as &Trait, +/// )); +/// assert!(!std::ptr::eq( +/// &wrapper as &Trait as *const Trait, +/// &wrapper.member as &Trait as *const Trait, +/// )); +/// +/// // Converting the reference to a `*const u8` compares by address +/// assert!(std::ptr::eq( +/// &wrapper as &Trait as *const Trait as *const u8, +/// &wrapper.member as &Trait as *const Trait as *const u8, +/// )); +/// } +/// ``` #[stable(feature = "ptr_eq", since = "1.17.0")] #[inline] pub fn eq(a: *const T, b: *const T) -> bool { From 61b6c56f50af6ca2848f4bd623c8b2cd2b24cb77 Mon Sep 17 00:00:00 2001 From: Chris Gregory Date: Wed, 27 Mar 2019 01:46:24 -0400 Subject: [PATCH 4/4] Minor rewordings and add `dyn` keyword --- src/libcore/ptr.rs | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/src/libcore/ptr.rs b/src/libcore/ptr.rs index 55af518b886b0..3121346988e82 100644 --- a/src/libcore/ptr.rs +++ b/src/libcore/ptr.rs @@ -2523,26 +2523,26 @@ impl Eq for *mut T {} /// fn main() { /// let wrapper = Wrapper { member: 10 }; /// -/// // Pointers are equal address +/// // Pointers have equal addresses. /// assert!(std::ptr::eq( /// &wrapper as *const Wrapper as *const u8, /// &wrapper.member as *const i32 as *const u8 /// )); /// -/// // Objects have equal addresses, but `Trait` has different implementations +/// // Objects have equal addresses, but `Trait` has different implementations. /// assert!(!std::ptr::eq( -/// &wrapper as &Trait, -/// &wrapper.member as &Trait, +/// &wrapper as &dyn Trait, +/// &wrapper.member as &dyn Trait, /// )); /// assert!(!std::ptr::eq( -/// &wrapper as &Trait as *const Trait, -/// &wrapper.member as &Trait as *const Trait, +/// &wrapper as &dyn Trait as *const dyn Trait, +/// &wrapper.member as &dyn Trait as *const dyn Trait, /// )); /// -/// // Converting the reference to a `*const u8` compares by address +/// // Converting the reference to a `*const u8` compares by address. /// assert!(std::ptr::eq( -/// &wrapper as &Trait as *const Trait as *const u8, -/// &wrapper.member as &Trait as *const Trait as *const u8, +/// &wrapper as &dyn Trait as *const dyn Trait as *const u8, +/// &wrapper.member as &dyn Trait as *const dyn Trait as *const u8, /// )); /// } /// ```