summaryrefslogtreecommitdiffstats
path: root/src/test/ui/issues/issue-27949.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/test/ui/issues/issue-27949.rs')
-rw-r--r--src/test/ui/issues/issue-27949.rs41
1 files changed, 41 insertions, 0 deletions
diff --git a/src/test/ui/issues/issue-27949.rs b/src/test/ui/issues/issue-27949.rs
new file mode 100644
index 000000000..e905da72a
--- /dev/null
+++ b/src/test/ui/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<Input<'a>> 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));
+}