scilib documentation

core / init.control.monad

@[class]
structure has_bind (m : Type u Type v) :
Type (max (u+1) v)
  • bind : Π {α β : Type ?}, m α m β) m β
Instances of this typeclass
Instances of other typeclasses for has_bind
  • has_bind.has_sizeof_inst
def has_bind.and_then {α β : Type u} {m : Type u Type v} [has_bind m] (x : m α) (y : m β) :
m β
Equations
  • x >> y = x >>= λ (_x : α), y
@[reducible]
def return {m : Type u Type v} [monad m] {α : Type u} :
α m α
Equations
def has_bind.seq {α β : Type u} {m : Type u Type v} [has_bind m] (x : m α) (y : m β) :
m β

Identical to has_bind.and_then, but it is not inlined.

Equations