about summary refs log tree commit diff
path: root/tests/ui/overloaded/overloaded-index-in-field.rs
diff options
context:
space:
mode:
authorAlbert Larsan <74931857+albertlarsan68@users.noreply.github.com>2023-01-05 09:13:28 +0100
committerAlbert Larsan <74931857+albertlarsan68@users.noreply.github.com>2023-01-11 09:32:08 +0000
commitcf2dff2b1e3fa55fa5415d524200070d0d7aacfe (patch)
tree40a88d9a46aaf3e8870676eb2538378b75a263eb /tests/ui/overloaded/overloaded-index-in-field.rs
parentca855e6e42787ecd062d81d53336fe6788ef51a9 (diff)
downloadrust-cf2dff2b1e3fa55fa5415d524200070d0d7aacfe.tar.gz
rust-cf2dff2b1e3fa55fa5415d524200070d0d7aacfe.zip
Move /src/test to /tests
Diffstat (limited to 'tests/ui/overloaded/overloaded-index-in-field.rs')
-rw-r--r--tests/ui/overloaded/overloaded-index-in-field.rs46
1 files changed, 46 insertions, 0 deletions
diff --git a/tests/ui/overloaded/overloaded-index-in-field.rs b/tests/ui/overloaded/overloaded-index-in-field.rs
new file mode 100644
index 00000000000..8a1fa7deb99
--- /dev/null
+++ b/tests/ui/overloaded/overloaded-index-in-field.rs
@@ -0,0 +1,46 @@
+// run-pass
+// Test using overloaded indexing when the "map" is stored in a
+// field. This caused problems at some point.
+
+use std::ops::Index;
+
+struct Foo {
+    x: isize,
+    y: isize,
+}
+
+struct Bar {
+    foo: Foo
+}
+
+impl Index<isize> for Foo {
+    type Output = isize;
+
+    fn index(&self, z: isize) -> &isize {
+        if z == 0 {
+            &self.x
+        } else {
+            &self.y
+        }
+    }
+}
+
+trait Int {
+    fn get(self) -> isize;
+    fn get_from_ref(&self) -> isize;
+    fn inc(&mut self);
+}
+
+impl Int for isize {
+    fn get(self) -> isize { self }
+    fn get_from_ref(&self) -> isize { *self }
+    fn inc(&mut self) { *self += 1; }
+}
+
+fn main() {
+    let f = Bar { foo: Foo {
+        x: 1,
+        y: 2,
+    } };
+    assert_eq!(f.foo[1].get(), 2);
+}