summary refs log tree commit diff
path: root/src/rustdoc/par.rs
blob: d15caffd46fd4008ba1b12e1232dccaae73e7440 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
export anymap, seqmap, parmap;

fn anymap<T:send, U:send>(v: [T], f: fn~(T) -> U) -> [U] {
    seqmap(v, f)
}

fn seqmap<T, U>(v: [T], f: fn(T) -> U) -> [U] {
    vec::map(v, f)
}

fn parmap<T:send, U:send>(v: [T], f: fn~(T) -> U) -> [U] unsafe {
    let futures = vec::map(v) {|elt|
        let po = comm::port();
        let ch = comm::chan(po);
        let addr = ptr::addr_of(elt);
        task::spawn {||
            comm::send(ch, f(*addr));
        }
        po
    };
    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];
}