rust/src/test/pretty/block-disambig.rs

69 lines
1.6 KiB
Rust
Raw Normal View History

// 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 <LICENSE-APACHE or
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, 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)
#![feature(managed_boxes)]
2013-12-12 02:02:26 -06:00
2013-12-31 17:46:27 -06:00
use std::cell::Cell;
use std::gc::GC;
2013-12-31 17:46:27 -06:00
fn test1() { let val = box(GC) 0; { } *val; }
fn test2() -> int { let val = box(GC) 0; { } *val }
struct S { eax: int }
2013-01-28 20:55:29 -06:00
fn test3() {
let regs = box(GC) Cell::new(S {eax: 0});
2012-08-23 16:44:58 -05:00
match true { true => { } _ => { } }
2013-12-31 17:46:27 -06:00
regs.set(S {eax: 1});
}
fn test4() -> bool { let regs = box(GC) true; if true { } *regs || false }
fn test5() -> (int, int) { { } (0, 1) }
fn test6() -> bool { { } (true || false) && true }
fn test7() -> uint {
let regs = box(GC) 0;
2012-08-23 16:44:58 -05:00
match true { true => { } _ => { } }
(*regs < 2) as uint
}
fn test8() -> int {
let val = box(GC) 0;
2012-08-23 16:44:58 -05:00
match true {
2012-08-03 21:59:04 -05:00
true => { }
2012-08-23 16:44:58 -05:00
_ => { }
}
if *val < 1 {
0
} else {
1
}
}
2013-12-31 17:46:27 -06:00
fn test9() {
let regs = box(GC) Cell::new(0);
2013-12-31 17:46:27 -06:00
match true { true => { } _ => { } } regs.set(regs.get() + 1);
}
fn test10() -> int {
let regs = box(GC) vec!(0);
2012-08-23 16:44:58 -05:00
match true { true => { } _ => { } }
*(*regs).get(0)
}
fn test11() -> Vec<int> { if true { } vec!(1, 2) }