2011-09-15 15:46:07 +00:00
|
|
|
// A bunch of tests for syntactic forms involving blocks that were
|
|
|
|
// previously ambiguous (e.g. 'if true { } *val;' gets parsed as a
|
|
|
|
// binop)
|
|
|
|
|
|
|
|
fn test1() { let val = @0; { } *val; }
|
|
|
|
|
|
|
|
fn test2() -> int { let val = @0; { } *val }
|
|
|
|
|
|
|
|
fn test3() {
|
2012-03-27 01:35:18 +00:00
|
|
|
let regs = @{mut eax: 0};
|
2012-08-06 19:34:08 +00:00
|
|
|
match check true { true => { } }
|
2011-09-15 15:46:07 +00:00
|
|
|
(*regs).eax = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
fn test4() -> bool { let regs = @true; if true { } *regs || false }
|
|
|
|
|
|
|
|
fn test5() -> (int, int) { { } (0, 1) }
|
|
|
|
|
|
|
|
fn test6() -> bool { { } (true || false) && true }
|
|
|
|
|
|
|
|
fn test7() -> uint {
|
|
|
|
let regs = @0;
|
2012-08-06 19:34:08 +00:00
|
|
|
match check true { true => { } }
|
2011-09-15 15:46:07 +00:00
|
|
|
(*regs < 2) as uint
|
|
|
|
}
|
|
|
|
|
2012-01-30 02:33:08 +00:00
|
|
|
fn test8() -> int {
|
|
|
|
let val = @0;
|
2012-08-06 19:34:08 +00:00
|
|
|
match check true {
|
2012-08-04 02:59:04 +00:00
|
|
|
true => { }
|
2012-01-30 02:33:08 +00:00
|
|
|
}
|
|
|
|
if *val < 1 {
|
|
|
|
0
|
|
|
|
} else {
|
|
|
|
1
|
|
|
|
}
|
|
|
|
}
|
2011-09-15 15:46:07 +00:00
|
|
|
|
2012-08-06 19:34:08 +00:00
|
|
|
fn test9() { let regs = @mut 0; match check true { true => { } } *regs += 1; }
|
2011-09-15 15:46:07 +00:00
|
|
|
|
|
|
|
fn test10() -> int {
|
2012-06-29 23:26:56 +00:00
|
|
|
let regs = @mut ~[0];
|
2012-08-06 19:34:08 +00:00
|
|
|
match check true { true => { } }
|
2011-09-15 15:46:07 +00:00
|
|
|
(*regs)[0]
|
|
|
|
}
|
|
|
|
|
2012-06-29 23:26:56 +00:00
|
|
|
fn test11() -> ~[int] { if true { } ~[1, 2] }
|