Module type Monads.State_indexed'

type ('a, +'i, -'j) t
include State_generalised with type ('a, 'i, 'j) t := ('a'i'j) t and type 'a s := 'a
include Monad_indexed' with type ('a, 'i, 'j) t := ('a'i'j) t
include Monad_generalised with type ('a, 'i, 'j, _) t := ('a'i'j) t
val return : 'a -> ('a'i'i) t
val bind : ('a'i'j) t -> ('a -> ('b'j'k) t) -> ('b'i'k) t
val get : ('a'a'a) t
val put : 'j -> (unit, 'i'j) t