summaryrefslogtreecommitdiffstats
path: root/tests/ui/structs/method-chain-expression-failure.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-07 05:48:48 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-07 05:48:48 +0000
commitef24de24a82fe681581cc130f342363c47c0969a (patch)
tree0d494f7e1a38b95c92426f58fe6eaa877303a86c /tests/ui/structs/method-chain-expression-failure.rs
parentReleasing progress-linux version 1.74.1+dfsg1-1~progress7.99u1. (diff)
downloadrustc-ef24de24a82fe681581cc130f342363c47c0969a.tar.xz
rustc-ef24de24a82fe681581cc130f342363c47c0969a.zip
Merging upstream version 1.75.0+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'tests/ui/structs/method-chain-expression-failure.rs')
-rw-r--r--tests/ui/structs/method-chain-expression-failure.rs31
1 files changed, 31 insertions, 0 deletions
diff --git a/tests/ui/structs/method-chain-expression-failure.rs b/tests/ui/structs/method-chain-expression-failure.rs
new file mode 100644
index 000000000..43ebc5bac
--- /dev/null
+++ b/tests/ui/structs/method-chain-expression-failure.rs
@@ -0,0 +1,31 @@
+struct A;
+struct B;
+struct C;
+struct D;
+struct E;
+
+impl A {
+ fn b(&self) -> B { B }
+ fn foo(&self) {}
+}
+
+impl B {
+ fn c(&self) -> C { C }
+}
+
+impl C {
+ fn d(&self) -> D { D }
+ fn foo(&self) {}
+}
+
+impl D {
+ fn e(&self) -> E { E }
+}
+
+impl E {
+ fn f(&self) {}
+}
+fn main() {
+ A.b().c().d().e().foo();
+//~^ ERROR no method named `foo` found for struct `E` in the current scope
+}