package lwt
Install
Dune Dependency
Authors
Maintainers
Sources
md5=ba3659a8918d8e7cb0f4ef9a83945f90
sha512=9f46fb2e56dc7bd57a12d5ab4dc68719947a1462f336087a95e991d087bb9b5b8dee2592d0f7d35abc507d9a641dd221c44c949c81d00e26c673a067d94ba3f4
doc/lwt/Lwt_switch/index.html
Module Lwt_switch
Source
Lwt switches
Switch has two goals:
- being able to free multiple resources at the same time,
- offer a better alternative than always returning an id to free some resource.
For example, consider the following interface:
type id
val free : id -> unit Lwt.t
val f : unit -> id Lwt.t
val g : unit -> id Lwt.t
val h : unit -> id Lwt.t
Now you want to call f
, g
and h
in parallel. You can simply do:
lwt idf = f () and idg = g () and idh = h () in
...
However, one may want to handle possible failures of f ()
, g ()
and h ()
, and disable all allocated resources if one of these three threads fails. This may be hard since you have to remember which one failed and which one returned correctly.
Now if we change the interface a little bit:
val f : ?switch : Lwt_switch.t -> unit -> id Lwt.t
val g : ?switch : Lwt_switch.t -> unit -> id Lwt.t
val h : ?switch : Lwt_switch.t -> unit -> id Lwt.t
the code becomes:
Lwt_switch.with_switch (fun switch ->
lwt idf = f ~switch ()
and idg = g ~switch ()
and idh = h ~switch () in
...
)
Type of switches.
with_switch fn
is fn switch
, where switch
is a fresh switch that is turned off when the callback thread finishes (whether it succeeds or fails).
is_on switch
returns true
if the switch is currently on, and false
otherwise.
turn_off switch
turns off the switch. It calls all registered hooks, waits for all of them to terminate, then returns. If one of the hooks failed, it will fail with the exception raised by the hook. If the switch is already off, it does nothing.
Exception raised when trying to add a hook to a switch that is already off.
check switch
does nothing if switch
is None
or contains an switch that is currently on, and raises Off
otherwise.