Skip to content

Commit

Permalink
Rollup merge of #113318 - tgross35:113283-allocator-trait-eq, r=m-ou-se
Browse files Browse the repository at this point in the history
Revert "alloc: Allow comparing Boxs over different allocators", add regression test

Temporary fix for #113283

Adds a test to fix the regression introduced in 001b081 and revert that commit. The test fails without the revert.
  • Loading branch information
compiler-errors committed Jul 7, 2023
2 parents 1cb31e7 + a635bf7 commit 7913d76
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 26 deletions.
35 changes: 9 additions & 26 deletions library/alloc/src/boxed.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1319,56 +1319,39 @@ impl Clone for Box<str> {
}

#[stable(feature = "rust1", since = "1.0.0")]
impl<T, A1, A2> PartialEq<Box<T, A2>> for Box<T, A1>
where
T: ?Sized + PartialEq,
A1: Allocator,
A2: Allocator,
{
impl<T: ?Sized + PartialEq, A: Allocator> PartialEq for Box<T, A> {
#[inline]
fn eq(&self, other: &Box<T, A2>) -> bool {
fn eq(&self, other: &Self) -> bool {
PartialEq::eq(&**self, &**other)
}

#[inline]
fn ne(&self, other: &Box<T, A2>) -> bool {
fn ne(&self, other: &Self) -> bool {
PartialEq::ne(&**self, &**other)
}
}

#[stable(feature = "rust1", since = "1.0.0")]
impl<T, A1, A2> PartialOrd<Box<T, A2>> for Box<T, A1>
where
T: ?Sized + PartialOrd,
A1: Allocator,
A2: Allocator,
{
impl<T: ?Sized + PartialOrd, A: Allocator> PartialOrd for Box<T, A> {
#[inline]
fn partial_cmp(&self, other: &Box<T, A2>) -> Option<Ordering> {
fn partial_cmp(&self, other: &Self) -> Option<Ordering> {
PartialOrd::partial_cmp(&**self, &**other)
}

#[inline]
fn lt(&self, other: &Box<T, A2>) -> bool {
fn lt(&self, other: &Self) -> bool {
PartialOrd::lt(&**self, &**other)
}

#[inline]
fn le(&self, other: &Box<T, A2>) -> bool {
fn le(&self, other: &Self) -> bool {
PartialOrd::le(&**self, &**other)
}

#[inline]
fn ge(&self, other: &Box<T, A2>) -> bool {
fn ge(&self, other: &Self) -> bool {
PartialOrd::ge(&**self, &**other)
}

#[inline]
fn gt(&self, other: &Box<T, A2>) -> bool {
fn gt(&self, other: &Self) -> bool {
PartialOrd::gt(&**self, &**other)
}
}

#[stable(feature = "rust1", since = "1.0.0")]
impl<T: ?Sized + Ord, A: Allocator> Ord for Box<T, A> {
#[inline]
Expand Down
18 changes: 18 additions & 0 deletions tests/ui/type-inference/issue-113283-alllocator-trait-eq.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
// run-pass
// Verify that PartialEq implementations do not break type inference when
// accepting types with different allocators

use std::rc::Rc;
use std::sync::Arc;


fn main() {
let boxed: Vec<Box<i32>> = vec![];
assert_eq!(boxed, vec![]);

let rc: Vec<Rc<i32>> = vec![];
assert_eq!(rc, vec![]);

let arc: Vec<Arc<i32>> = vec![];
assert_eq!(arc, vec![]);
}

0 comments on commit 7913d76

Please sign in to comment.