rust/src/test/run-pass/block-arg.rs

63 lines
1.9 KiB
Rust

// 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.
// Check usage and precedence of block arguments in expressions:
pub fn main() {
let v = ~[-1f, 0f, 1f, 2f, 3f];
// Statement form does not require parentheses:
for vec::each(v) |i| {
info!("%?", *i);
}
// Usable at all:
let mut any_negative = do vec::any(v) |e| { e.is_negative() };
assert!(any_negative);
// Higher precedence than assignments:
any_negative = do vec::any(v) |e| { e.is_negative() };
assert!(any_negative);
// Higher precedence than unary operations:
let abs_v = do vec::map(v) |e| { e.abs() };
assert!(do vec::all(abs_v) |e| { e.is_positive() });
assert!(!do vec::any(abs_v) |e| { e.is_negative() });
// Usable in funny statement-like forms:
if !do vec::any(v) |e| { e.is_positive() } {
assert!(false);
}
match do vec::all(v) |e| { e.is_negative() } {
true => { fail!(~"incorrect answer."); }
false => { }
}
match 3 {
_ if do vec::any(v) |e| { e.is_negative() } => {
}
_ => {
fail!(~"wrong answer.");
}
}
// Lower precedence than binary operations:
let w = do vec::foldl(0f, v) |x, y| { x + *y } + 10f;
let y = do vec::foldl(0f, v) |x, y| { x + *y } + 10f;
let z = 10f + do vec::foldl(0f, v) |x, y| { x + *y };
assert!(w == y);
assert!(y == z);
// In the tail of a block
let w =
if true { do vec::any(abs_v) |e| { e.is_positive() } }
else { false };
assert!(w);
}