sig
  type ('l, 'r) t = Left of '| Right of '| Both of 'l * 'r
  val _Left : '-> ('a, 'b) These.t
  val _Right : '-> ('b, 'a) These.t
  val _Both : '-> '-> ('a, 'b) These.t
  module Make :
    functor (S : Semigroup.S->
      sig
        type 'a t = (S.t, 'a) t
        val bind : ('-> 'b t) -> 'a t -> 'b t
        val pure : '-> 'a t
        val ap : ('-> 'b) t -> (unit -> 'a t) -> 'b t
        val map : ('-> 'b) -> 'a t -> 'b t
        val ( >|= ) : 'a t -> ('-> 'b) -> 'b t
        val replace : '-> 'b t -> 'a t
        val void : 'a t -> unit t
        val ap' : ('-> 'b) t -> 'a t -> 'b t
        val ( <*> ) : ('-> 'b) t -> 'a t -> 'b t
        val ( <~> ) : ('-> 'b) t -> (unit -> 'a t) -> 'b t
        val discard_left : 'a t -> (unit -> 'b t) -> 'b t
        val discard_right : 'a t -> (unit -> 'b t) -> 'a t
        val repeat : int -> 'a t -> 'a list t
        val repeat_ : int -> 'a t -> unit t
        val forever : 'a t -> 'b t
        val ( >>= ) : 'a t -> ('-> 'b t) -> 'b t
        val join : 'a t t -> 'a t
        val mcompose : ('-> 'c t) -> ('-> 'b t) -> '-> 'c t
      end
  val bimap :
    ('-> 'b) -> ('-> 'd) -> ('a, 'c) These.t -> ('b, 'd) These.t
  val fold :
    ('-> 'b) -> ('-> 'b) -> ('-> '-> 'b) -> ('a, 'c) These.t -> 'b
  val swap : ('a, 'b) These.t -> ('b, 'a) These.t
  val maybe_left : ('a, 'b) These.t -> 'a option
  val maybe_right : ('a, 'b) These.t -> 'b option
  val maybe_both : ('a, 'b) These.t -> ('a * 'b) option
end