Idris2/tests/idris2/interface004/Do.idr

16 lines
304 B
Idris
Raw Normal View History

public export
interface Do (m : Type) where
Next : m -> Type
bind : (x : m) -> Next x
public export
Monad m => Do (m a) where
Next x = {b : Type} -> (a -> m b) -> m b
bind x k = x >>= k
foo : Maybe Int -> Maybe Int -> Maybe Int
foo x y
= bind x (\x' =>
bind y (\y' => Just (x' + y')))