// Copyright 2012 The Rust Project Developers. See the COPYRIGHT // file at the top-level directory of this distribution and at // http://rust-lang.org/COPYRIGHT. // // Licensed under the Apache License, Version 2.0 or the MIT license // , at your // option. This file may not be copied, modified, or distributed // except according to those terms. // 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 } struct S { eax: int } fn test3() { let regs = @mut S {eax: 0}; match true { true => { } _ => { } } (*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; match true { true => { } _ => { } } (*regs < 2) as uint } fn test8() -> int { let val = @0; match true { true => { } _ => { } } if *val < 1 { 0 } else { 1 } } fn test9() { let regs = @mut 0; match true { true => { } _ => { } } *regs += 1; } fn test10() -> int { let regs = @mut ~[0]; match true { true => { } _ => { } } (*regs)[0] } fn test11() -> ~[int] { if true { } ~[1, 2] }