12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273(*****************************************************************************)(* *)(* Open Source License *)(* Copyright (c) 2020 Nomadic Labs <contact@nomadic-labs.com> *)(* *)(* Permission is hereby granted, free of charge, to any person obtaining a *)(* copy of this software and associated documentation files (the "Software"),*)(* to deal in the Software without restriction, including without limitation *)(* the rights to use, copy, modify, merge, publish, distribute, sublicense, *)(* and/or sell copies of the Software, and to permit persons to whom the *)(* Software is furnished to do so, subject to the following conditions: *)(* *)(* The above copyright notice and this permission notice shall be included *)(* in all copies or substantial portions of the Software. *)(* *)(* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR*)(* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, *)(* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL *)(* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER*)(* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING *)(* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER *)(* DEALINGS IN THE SOFTWARE. *)(* *)(*****************************************************************************)(** [S] is the signature for a Lwt, result and Lwt-result combined monad. It is
similar to {!Bare_sigs.Monad} with the addition of traces. Specifically:
- The type ['error trace] is meant to be substituted by a type provided by a
[Trace] module ([with type 'error trace := 'error Trace.trace]).
- The functions [error_trace] and [fail_trace] allow failing immediately
with a trace-wrapped error.
- [{join,all,both}_{e,ep}] return ['error trace] rather than ['error list].
*)moduletypeS=sigincludeBare_sigs.Monad.S(** ['error trace] is intended to be substituted by a type provided by a
[Trace] module ([with type 'error trace := 'error Trace.trace]) *)type'errortrace(** [error_trace e] is [Error (Trace.make e)] where [Trace] is the
{!Traced_sigs.Trace} module that provides the trace type and functions.
*)valerror_trace:'error->('a,'errortrace)result(** [fail_trace e] is [Lwt.return (Error (Trace.make e))] where [Trace] is the
{!Traced_sigs.Trace} module that provides the trace type and functions.
*)valfail_trace:'error->('a,'errortrace)resultLwt.t(** [join], [all], and [both] all return traces rather than lists of errors.
This applies to both result-only and Lwt-result monads. *)valjoin_e:(unit,'errortrace)resultlist->(unit,'errortrace)resultvalall_e:('a,'errortrace)resultlist->('alist,'errortrace)resultvalboth_e:('a,'errortrace)result->('b,'errortrace)result->('a*'b,'errortrace)resultvaljoin_ep:(unit,'errortrace)resultLwt.tlist->(unit,'errortrace)resultLwt.tvalall_ep:('a,'errortrace)resultLwt.tlist->('alist,'errortrace)resultLwt.tvalboth_ep:('a,'errortrace)resultLwt.t->('b,'errortrace)resultLwt.t->('a*'b,'errortrace)resultLwt.tend