Module Async_smtp.Smtp_monad
type 'a t
= ('a, Async_smtp__.Reject_or_error.t) Async.Deferred.Result.t
include Core.Monad.S with type 'a t := 'a t
include Base__.Monad_intf.S_without_syntax with type 'a t := 'a t
module Monad_infix : Base__.Monad_intf.Infix with type 'a t := 'a t
val return : 'a -> 'a t
return v
returns the (trivial) computation that returns v.
val exn : (Core.Exn.t -> _ t) Async_smtp__.With_info.with_reject
val error : (Core.Error.t -> _ t) Async_smtp__.With_info.with_reject
val error_string : (string -> _ t) Async_smtp__.With_info.with_reject
val errorf : (('a, unit, string, _ t) Core.format4 -> 'a) Async_smtp__.With_info.with_reject
val reject : (Smtp_reply.t -> _ t) Async_smtp__.With_info.with_here
val tag : tag:string -> ('a t -> 'a t) Async_smtp__.With_info.with_maybe_here
val tag' : ?tag:string -> ('a t -> 'a t) Async_smtp__.With_info.with_maybe_here
val ok : 'a Async.Deferred.t -> 'a t
Helpers to convert to an
'a t
. Unliketry_with*
below, these will not capture raised exceptions.
val of_or_error : ('a Async.Deferred.Or_error.t -> 'a t) Async_smtp__.With_info.with_tag
val return_or_error : ('a Core.Or_error.t -> 'a t) Async_smtp__.With_info.with_tag
val try_with : ((unit -> 'a Async.Deferred.t) -> 'a t) Async_smtp__.With_info.with_tag
Capture any raised exceptions as
Error
s.
val try_with_join : ((unit -> 'a t) -> 'a t) Async_smtp__.With_info.with_tag
val try_with_or_error : ((unit -> 'a Async.Deferred.Or_error.t) -> 'a t) Async_smtp__.With_info.with_tag