// xfail-fast #[legacy_modes]; trait vec_monad { fn bind(f: fn(A) -> ~[B]) -> ~[B]; } impl ~[A]: vec_monad { fn bind(f: fn(A) -> ~[B]) -> ~[B] { let mut r = ~[]; for self.each |elt| { r += f(*elt); } r } } trait option_monad { fn bind(f: fn(A) -> Option) -> Option; } impl Option: option_monad { fn bind(f: fn(A) -> Option) -> Option { match self { Some(a) => { f(a) } None => { None } } } } fn transform(x: Option) -> Option<~str> { x.bind(|n| Some(n + 1) ).bind(|n| Some(int::str(n)) ) } fn main() { assert transform(Some(10)) == Some(~"11"); assert transform(None) == None; assert (~[~"hi"]).bind(|x| ~[x, x + ~"!"] ).bind(|x| ~[x, x + ~"?"] ) == ~[~"hi", ~"hi?", ~"hi!", ~"hi!?"]; }