summaryrefslogtreecommitdiffstats
path: root/tests/ui/or-patterns/inconsistent-modes.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:19:13 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:19:13 +0000
commit218caa410aa38c29984be31a5229b9fa717560ee (patch)
treec54bd55eeb6e4c508940a30e94c0032fbd45d677 /tests/ui/or-patterns/inconsistent-modes.rs
parentReleasing progress-linux version 1.67.1+dfsg1-1~progress7.99u1. (diff)
downloadrustc-218caa410aa38c29984be31a5229b9fa717560ee.tar.xz
rustc-218caa410aa38c29984be31a5229b9fa717560ee.zip
Merging upstream version 1.68.2+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'tests/ui/or-patterns/inconsistent-modes.rs')
-rw-r--r--tests/ui/or-patterns/inconsistent-modes.rs25
1 files changed, 25 insertions, 0 deletions
diff --git a/tests/ui/or-patterns/inconsistent-modes.rs b/tests/ui/or-patterns/inconsistent-modes.rs
new file mode 100644
index 000000000..a87a10ce8
--- /dev/null
+++ b/tests/ui/or-patterns/inconsistent-modes.rs
@@ -0,0 +1,25 @@
+// This test ensures that or patterns require binding mode consistency across arms.
+
+#![allow(non_camel_case_types)]
+fn main() {
+ // One level:
+ let (Ok(a) | Err(ref a)): Result<&u8, u8> = Ok(&0);
+ //~^ ERROR variable `a` is bound inconsistently
+ let (Ok(ref mut a) | Err(a)): Result<u8, &mut u8> = Ok(0);
+ //~^ ERROR variable `a` is bound inconsistently
+ let (Ok(ref a) | Err(ref mut a)): Result<&u8, &mut u8> = Ok(&0);
+ //~^ ERROR variable `a` is bound inconsistently
+ //~| ERROR mismatched types
+ let (Ok((ref a, b)) | Err((ref mut a, ref b))) = Ok((0, &0));
+ //~^ ERROR variable `a` is bound inconsistently
+ //~| ERROR variable `b` is bound inconsistently
+ //~| ERROR mismatched types
+
+ // Two levels:
+ let (Ok(Ok(a) | Err(a)) | Err(ref a)) = Err(0);
+ //~^ ERROR variable `a` is bound inconsistently
+
+ // Three levels:
+ let (Ok([Ok((Ok(ref a) | Err(a),)) | Err(a)]) | Err(a)) = Err(&1);
+ //~^ ERROR variable `a` is bound inconsistently
+}