package sihl
Install
Dune Dependency
Authors
Maintainers
Sources
sha256=77f0813d75a88edd14b3396e8b848d94c31c28803299b4b1bd4b78b1de4a2e80
sha512=a8907bc35ea14b7c3a7d638979a2a274860202b2de58b84b5621a4908db001ace493d8aa2e5383f4c8b1847efd256938592f63ef75a41521284b3640d3a7442a
doc/sihl.core/Sihl_core/App/index.html
Module Sihl_core.App
Source
A module to create Sihl apps.
An app is a thin convenience layer on top of the service container. It provides hooks that are executed at different stages in the app lifecycle.
with_services services app
adds services
to an app
.
before_start f app
registers a callback f with app
. The callback is executed before any service is started. This means you must not use any services here!
after_stop f app
registers a callback f with app
. The callback is executed before after services are stopped. This means you must not use any services here!
val run :
?commands:Command.t list ->
?log_reporter:(unit -> Logs.reporter) ->
?args:string list ->
t ->
unit
run ?commands ?log_reporter app
is the main entry point to a Sihl app and starts the command line interface with commands
merged with the commands provided by services.
An optional log_reporter
can be provided to change the logging behavior. The default log reporter logs to stdout.
val run' :
?commands:Command.t list ->
?log_reporter:(unit -> Logs.reporter) ->
?args:string list ->
t ->
unit Lwt.t
run' ?commands ?log_reporter app
is analogous to run
. It is a helper to be used in tests that need Lwt.t
.