1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 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] }
|