about summary refs log tree commit diff
path: root/src/lib/either.rs
blob: 12ccbb2bbfbdc37f9901244a427b21f7e55525db (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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
import option;
import option::some;
import option::none;

tag t[T, U] {
    left(T);
    right(U);
}

type operator[T, U] = fn(&T) -> U;

fn either[T, U, V](&operator[T, V] f_left,
                   &operator[U, V] f_right,
                   &t[T, U] value) -> V {
    alt (value) {
        case (left(?l)) { f_left(l) }
        case (right(?r)) { f_right(r) }
    }
}

fn lefts[T, U](&vec[t[T, U]] eithers) -> vec[T] {
    let vec[T] result = [];
    for (t[T, U] elt in eithers) {
        alt (elt) {
            case (left(?l)) { result += [l] }
            case (_) { /* fallthrough */ }
        }
    }
    ret result;
}

fn rights[T, U](&vec[t[T, U]] eithers) -> vec[U] {
    let vec[U] result = [];
    for (t[T, U] elt in eithers) {
        alt (elt) {
            case (right(?r)) { result += [r] }
            case (_) { /* fallthrough */ }
        }
    }
    ret result;
}

fn partition[T, U](&vec[t[T, U]] eithers) -> tup(vec[T], vec[U]) {
    let vec[T] lefts = [];
    let vec[U] rights = [];
    for (t[T, U] elt in eithers) {
        alt (elt) {
            case (left(?l)) { lefts += [l] }
            case (right(?r)) { rights += [r] }
        }
    }
    ret tup(lefts, rights);
}

//
// Local Variables:
// mode: rust
// fill-column: 78;
// indent-tabs-mode: nil
// c-basic-offset: 4
// buffer-file-coding-system: utf-8-unix
// compile-command: "make -k -C $RBUILD 2>&1 | sed -e 's/\\/x\\//x:\\//g'";
// End:
//