package octez-libs
- Overview
- No Docs
You can search for identifiers within the package.
in-package search v0.2.0
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
sha256=aa2f5bc99cc4ca2217c52a1af2a2cdfd3b383208cb859ca2e79ca0903396ca1d
    
    
  sha512=d68bb3eb615e3dcccc845fddfc9901c95b3c6dc8e105e39522ce97637b1308a7fa7aa1d271351d5933febd7476b2819e1694f31198f1f0919681f1f9cc97cb3a
    
    
  doc/octez-libs.tezos-workers/Tezos_workers/Worker/MakeSingle/index.html
Module Worker.MakeSingleSource
MakeSingle (Name) (Request) (Types) is the same as using MakeGroup and then MakeWorker. It's a special case which you can use if you only ever need a single instantiation.
Parameters
module Name : Tezos_base.Worker_intf.NAMEmodule Request : Tezos_base.Worker_intf.REQUESTmodule Types : Tezos_base.Worker_intf.TYPESSignature
module Name = Namemodule Request = Requestmodule Types = TypesA handle to a specific worker, parameterized by the type of internal message buffer.
A handle to a table of workers.
type 'a message_error = - | Closed of Tezos_base.TzPervasives.error list option
- | Request_error of 'a
- | Any of exn
An error returned when waiting for a message pushed to the worker. Closed errs is returned if the worker is terminated or has crashed. If the worker is terminated, errs is an empty list. Request_error err is returned if the request failed with an error. Any exn is returned if the request failed with an exception.
type _ buffer_kind = - | Queue : infinite queue buffer_kind
- | Bounded : {- } -> bounded queue buffer_kind
- | Dropbox : {- merge : dropbox t -> any_request -> any_request option -> any_request option;
 - } -> dropbox buffer_kind
Supported kinds of internal buffers.
Create a table of workers.
val launch : 
  'kind table ->
  ?timeout:Tezos_base.Time.System.Span.t ->
  Name.t ->
  Types.parameters ->
  (module HANDLERS
    with type launch_error = 'launch_error
     and type self = 'kind t) ->
  ('kind t, 'launch_error) result Lwt.tCreates a new worker instance. Parameter queue_size not passed means unlimited queue.
Triggers a worker termination and waits for its completion. Cannot be called from within the handlers.
The following interface are common elements of multiple modules below. They are used to minimize repetition.
Exports the canceler to allow cancellation of other tasks when this worker is shutdown or when it dies.
Access the internal state, once initialized.
val with_state : 
  _ t ->
  (Types.state -> (unit, 'request_error) result Lwt.t) ->
  (unit, 'request_error) result Lwt.twith_state w f calls f on the current state of worker w if it was intialized and not closed or crashed, otherwise returns immediately.
Introspect the message queue, gives the times requests were pushed.
Get the running status of a worker.
val current_request : 
  _ t ->
  (Tezos_base.Time.System.t * Tezos_base.Time.System.t * Request.view) optionGet the request being treated by a worker. Gives the time the request was pushed, and the time its treatment started.