You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
58 lines
1.2 KiB
58 lines
1.2 KiB
5 years ago
|
(*
|
||
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
||
|
*
|
||
|
* This source code is licensed under the MIT license found in the
|
||
|
* LICENSE file in the root directory of this source tree.
|
||
|
*)
|
||
|
|
||
|
module type S = sig
|
||
|
type 'a t
|
||
|
|
||
|
val return : 'a -> 'a t
|
||
|
val bind : ('a -> 'b t) -> 'a t -> 'b t
|
||
|
|
||
|
module Import : sig
|
||
|
val ( >>= ) : 'a t -> ('a -> 'b t) -> 'b t
|
||
|
val ( >>| ) : 'a t -> ('a -> 'b) -> 'b t
|
||
|
val ( let* ) : 'a t -> ('a -> 'b t) -> 'b t
|
||
|
val ( and* ) : 'a t -> 'b t -> ('a * 'b) t
|
||
|
val ( let+ ) : 'a t -> ('a -> 'b) -> 'b t
|
||
|
val ( and+ ) : 'a t -> 'b t -> ('a * 'b) t
|
||
|
end
|
||
|
end
|
||
|
|
||
|
module State (State : sig
|
||
|
type t
|
||
|
end) =
|
||
|
struct
|
||
|
type state = State.t
|
||
|
type 'a t = state -> 'a * state
|
||
|
|
||
|
let return a s = (a, s)
|
||
|
|
||
|
let bind k m s =
|
||
|
let a, s = m s in
|
||
|
k a s
|
||
|
|
||
|
let run m s = m s
|
||
|
|
||
|
module Import = struct
|
||
|
let ( >>= ) m k = bind k m
|
||
|
let ( let* ) m k = bind k m
|
||
|
|
||
|
let ( and* ) : 'a t -> 'b t -> ('a * 'b) t =
|
||
|
fun m n s ->
|
||
|
let a, s = m s in
|
||
|
let b, s = n s in
|
||
|
return (a, b) s
|
||
|
|
||
|
let ( >>| ) : 'a t -> ('a -> 'b) -> 'b t =
|
||
|
fun m f ->
|
||
|
let* a = m in
|
||
|
return (f a)
|
||
|
|
||
|
let ( let+ ) = ( >>| )
|
||
|
let ( and+ ) = ( and* )
|
||
|
end
|
||
|
end
|