summaryrefslogtreecommitdiffstats
path: root/tests/pretty/block-disambig.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:19:03 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:19:03 +0000
commit64d98f8ee037282c35007b64c2649055c56af1db (patch)
tree5492bcf97fce41ee1c0b1cc2add283f3e66cdab0 /tests/pretty/block-disambig.rs
parentAdding debian version 1.67.1+dfsg1-1. (diff)
downloadrustc-64d98f8ee037282c35007b64c2649055c56af1db.tar.xz
rustc-64d98f8ee037282c35007b64c2649055c56af1db.zip
Merging upstream version 1.68.2+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'tests/pretty/block-disambig.rs')
-rw-r--r--tests/pretty/block-disambig.rs59
1 files changed, 59 insertions, 0 deletions
diff --git a/tests/pretty/block-disambig.rs b/tests/pretty/block-disambig.rs
new file mode 100644
index 000000000..ac9b84a5d
--- /dev/null
+++ b/tests/pretty/block-disambig.rs
@@ -0,0 +1,59 @@
+// compile-flags: --crate-type=lib
+
+// A bunch of tests for syntactic forms involving blocks that were
+// previously ambiguous (e.g., 'if true { } *val;' gets parsed as a
+// binop)
+
+
+use std::cell::Cell;
+
+fn test1() { let val = &0; { } *val; }
+
+fn test2() -> isize { let val = &0; { } *val }
+
+#[derive(Copy, Clone)]
+struct S { eax: isize }
+
+fn test3() {
+ let regs = &Cell::new(S {eax: 0});
+ match true { true => { } _ => { } }
+ regs.set(S {eax: 1});
+}
+
+fn test4() -> bool { let regs = &true; if true { } *regs || false }
+
+fn test5() -> (isize, isize) { { } (0, 1) }
+
+fn test6() -> bool { { } (true || false) && true }
+
+fn test7() -> usize {
+ let regs = &0;
+ match true { true => { } _ => { } }
+ (*regs < 2) as usize
+}
+
+fn test8() -> isize {
+ let val = &0;
+ match true {
+ true => { }
+ _ => { }
+ }
+ if *val < 1 {
+ 0
+ } else {
+ 1
+ }
+}
+
+fn test9() {
+ let regs = &Cell::new(0);
+ match true { true => { } _ => { } } regs.set(regs.get() + 1);
+}
+
+fn test10() -> isize {
+ let regs = vec![0];
+ match true { true => { } _ => { } }
+ regs[0]
+}
+
+fn test11() -> Vec<isize> { if true { } vec![1, 2] }