package pplumbing-log-cli
Install
dune-project
Dependency
Authors
Maintainers
Sources
sha256=8ae0c09fec9088bc7af60582717a9e9d8bb7703e2fbf0a1b90b82e5962ed7039
sha512=ddd1d5a3d47e7c5ebfb2898f0810156dfca4e10df500ce8f39238cfe02b51fd12ea6d7796914bd02e9ad8e615da1ed7067c9f712bdbbfb884cab08d57bba3564
Description
[pplumbing] defines a set of utility libraries to use with pp. It is compatible with logs and inspired by design choices used by dune for user messages.
These libraries are meant to combine nicely into a small ecosystem of useful helpers to build CLIs in OCaml.
[Pplumbing_log_cli] contains functions to work with [Err] on the side of end programs (such as a command line tool). It defines cmdlang command line helpers to configure the [Err] library, while taking care of setting the logs and fmt style rendering.
README
pplumbing
pplumbing defines a set of utility libraries to use with pp. It is compatible with logs and inspired by design choices used by Dune for user messages. These libraries are meant to combine nicely into a small ecosystem of useful helpers to build CLIs in OCaml.
Pp_ttyextendsppto build colored documents in the user's terminal using ANSI escape codes.Erris an abstraction to report located errors and warnings to the user.Logis an interface tologsusingPp_ttyrather thanFormat.Log_clicontains functions to work withErron the side of end programs (such as a command line tools). It defines command line helpers to configure theErrlibrary, while taking care of setting thelogsandfmtstyle rendering.Cmdlang_cmdliner_err_runneris a library for running command line programs specified withcmdlangwithcmdlineras a backend and making opinionated choices, assuming your dependencies are usingErr.Cmdlang_climate_err_runneris a library for running command line programs specified withcmdlangwithclimateas a backend and making opinionated choices, assuming your dependencies are usingErr.
Links to plumbed projects
Experimental Status
:construction: pplumbing is currently under construction. During this initial 0.0.X experimental phase, the interfaces and behavior are subject to breaking changes.
Acknowledgements
- We are thankful to the authors and contributors of the projects we use as dependencies.
- We would like to thank the Dune developers for the user-facing error handling of Dune (
Stdune.User_message), on which we based the error handling scheme used inErr. By adopting a similar approach, we aim to provide a consistent and unified user experience for OCaml users across different tools and libraries.
Dependencies (9)
-
pplumbing-pp-tty
= version -
pplumbing-log
= version -
pplumbing-err
= version -
pp
>= "2.0.0" -
logs
>= "0.7.0" -
fmt
>= "0.9.0" -
cmdlang
>= "0.0.9" -
ocaml
>= "4.14" -
dune
>= "3.17"
Dev Dependencies (1)
-
odoc
with-doc
Conflicts
None