about summary refs log tree commit diff
path: root/src/test
diff options
context:
space:
mode:
authorMazdak Farrokhzad <twingoow@gmail.com>2020-02-02 16:07:51 +0100
committerMazdak Farrokhzad <twingoow@gmail.com>2020-02-02 16:07:51 +0100
commit8d4973f5871fd36b5946b9a06bd1157d4a87bbe0 (patch)
treed3571f42f507db511ea9814f502157f810cc5134 /src/test
parent0253f868cab2c5be84d354589b4b833aedbc9987 (diff)
downloadrust-8d4973f5871fd36b5946b9a06bd1157d4a87bbe0.tar.gz
rust-8d4973f5871fd36b5946b9a06bd1157d4a87bbe0.zip
move_ref_pattern: don't ICE on unreachable 2xby-move conflicts
Diffstat (limited to 'src/test')
-rw-r--r--src/test/ui/pattern/move-ref-patterns/by-move-sub-pat-unreachable.rs15
1 files changed, 15 insertions, 0 deletions
diff --git a/src/test/ui/pattern/move-ref-patterns/by-move-sub-pat-unreachable.rs b/src/test/ui/pattern/move-ref-patterns/by-move-sub-pat-unreachable.rs
new file mode 100644
index 00000000000..08fb5cd2e16
--- /dev/null
+++ b/src/test/ui/pattern/move-ref-patterns/by-move-sub-pat-unreachable.rs
@@ -0,0 +1,15 @@
+// When conflicts between by-move bindings in `by_move_1 @ has_by_move` patterns
+// happen and that code is unreachable according to borrowck, we accept this code.
+// In particular, we want to ensure here that an ICE does not happen, which it did originally.
+
+// check-pass
+
+#![feature(move_ref_pattern)]
+#![feature(bindings_after_at)]
+
+fn main() {
+    return;
+
+    struct S;
+    let a @ (b, c) = (S, S);
+}