export anymap, seqmap, parmap; fn anymap(v: ~[T], f: fn~(T) -> U) -> ~[U] { parmap(v, f) } fn seqmap(v: ~[T], f: fn(T) -> U) -> ~[U] { vec::map(v, f) } fn parmap(v: ~[T], f: fn~(T) -> U) -> ~[U] unsafe { let futures = do vec::map(v) |elt| { let po = comm::port(); let ch = comm::chan(po); let addr = ptr::addr_of(elt); do task::spawn |copy f| { comm::send(ch, f(*addr)); } po }; do vec::map(futures) |future| { comm::recv(future) } } #[test] fn test_parallel_map() { let i = ~[1, 2, 3, 4]; let j = parmap(i, |e| e + 1 ); assert j == ~[2, 3, 4, 5]; }