rust/src/lib/either.rs
2011-07-27 15:54:33 +02:00

50 lines
1.2 KiB
Rust

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](f_left: &operator[T, V], f_right: &operator[U, V],
value: &t[T, U]) -> V {
alt value { left(l) { f_left(l) } right(r) { f_right(r) } }
}
fn lefts[T, U](eithers: &(t[T, U])[]) -> T[] {
let result: T[] = ~[];
for elt: t[T, U] in eithers {
alt elt { left(l) { result += ~[l] } _ {/* fallthrough */ } }
}
ret result;
}
fn rights[T, U](eithers: &(t[T, U])[]) -> U[] {
let result: U[] = ~[];
for elt: t[T, U] in eithers {
alt elt { right(r) { result += ~[r] } _ {/* fallthrough */ } }
}
ret result;
}
fn partition[T, U](eithers: &(t[T, U])[]) -> {lefts: T[], rights: U[]} {
let lefts: T[] = ~[];
let rights: U[] = ~[];
for elt: t[T, U] in eithers {
alt elt { left(l) { lefts += ~[l] } right(r) { rights += ~[r] } }
}
ret {lefts: lefts, rights: 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:
//