From 70290947355188be67db4f721be636b0695a4c80 Mon Sep 17 00:00:00 2001 From: Jamie Turner Date: Mon, 25 Feb 2019 00:33:44 -0800 Subject: [PATCH] Test that binop subtyping in rustc_typeck fixes #27949 --- src/test/run-pass/issues/issue-27949.rs | 41 +++++++++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 src/test/run-pass/issues/issue-27949.rs diff --git a/src/test/run-pass/issues/issue-27949.rs b/src/test/run-pass/issues/issue-27949.rs new file mode 100644 index 0000000000000..e905da72aad70 --- /dev/null +++ b/src/test/run-pass/issues/issue-27949.rs @@ -0,0 +1,41 @@ +// run-pass +// +// At one time, the `==` operator (and other binary operators) did not +// support subtyping during type checking, and would therefore require +// LHS and RHS to be exactly identical--i.e. to have the same lifetimes. +// +// This was fixed in 1a7fb7dc78439a704f024609ce3dc0beb1386552. + +#[derive(Copy, Clone)] +struct Input<'a> { + foo: &'a u32 +} + +impl <'a> std::cmp::PartialEq> for Input<'a> { + fn eq(&self, other: &Input<'a>) -> bool { + self.foo == other.foo + } + + fn ne(&self, other: &Input<'a>) -> bool { + self.foo != other.foo + } +} + + +fn check_equal<'a, 'b>(x: Input<'a>, y: Input<'b>) -> bool { + // Type checking error due to 'a != 'b prior to 1a7fb7dc78 + x == y +} + +fn main() { + let i = 1u32; + let j = 1u32; + let k = 2u32; + + let input_i = Input { foo: &i }; + let input_j = Input { foo: &j }; + let input_k = Input { foo: &k }; + assert!(check_equal(input_i, input_i)); + assert!(check_equal(input_i, input_j)); + assert!(!check_equal(input_i, input_k)); +}