// 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. // 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_eq!(w, y); assert_eq!(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); }