summaryrefslogtreecommitdiff
path: root/Common/Option.lean
blob: 275f83f994ef14d69b11d0226fe99de4ce888fb5 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
namespace Option

def zip (a : Option α) (b : Option β) : Option (α×β) := a >>= λ a  b >>= λ b  (a,b)

def unzip : (a : Option (α×β))  (Option α) × (Option β)
| none => (none, none)
| some (a, b) => (some a, some b)

def toExcept {α : Type u0} {ε : Type u1} { m : Type u0  Type u2} [Pure m] [MonadExcept m (ε := ε)] (error : ε) : Option α  m α
| none => throw error
| some a => pure a