Page
Library
Module
Module type
Parameter
Class
Class type
Source
An OCaml library to create beautiful interactive CLIs.
opam install inquireesy add @opam/inquirePrompt the user to answer the given message with "y" or "n".
Inquire.confirm "Are you sure?"Prompt the user to chose a value from the given options.
Inquire.raw_list "What's your favorite movie?" ~options:[ "Choice 1" ; "Choice 2" ]Prompt the user to enter a password that will be hidden with stars (*).
Inquire.password "Enter your password:"Prompt the user to input a string.
Inquire.input "Enter a value:"Create a custom implementation to style Inquire's prompts.
module CustomInquire = Inquire.Make (struct
  open Inquire
  let prompt_prefix = "❓  "
  let prompt_style = Style.make [ Style.bold; Style.color White ]
  let error_prefix = "❌  "
  let error_style = Style.make [ Style.bold; Style.color Red ]
  let selected_style = Style.make [ Style.bold; Style.color Blue ]
end)
let _ =
  let result = CustomInquire.confirm "Are you sure?" ~default:true in
  Lwt_main.run resultYou need Opam, you can install it by following Opam's documentation.
With Opam installed, you can install the dependencies with:
opam install --deps-only --with-test -y .Then, build the project with:
makeAfter building the project, you can run the example binaries with:
dune exec examples/<example>.exeFor instance, to run the confirm.ml example, you can type:
dune exec examples/confirm.exeYou can test compiled executable with:
make testDocumentation for the libraries in the project can be generated with:
make doc
open-cli $(make doc-path)This assumes you have a command like open-cli installed on your system.
To create a release and publish it on Opam, you can run the script scripts/release.sh. It will create a tag with the version found in inquire.opam, and push it on your repository.
From there, the CI/CD will take care of publishing your documentation, create a github release, and open a PR with your version on opam-repository.
The following snippet describes Inquire's repository structure.
.
├── examples/
|   Source for inquire's examples. This links to the library defined in `lib/`.
│
├── lib/
|   Source for Inquire's library. Contains Inquire's core functionnalities.
│
├── test/
|   Unit tests and integration tests for Inquire.
│
├── dune-project
|   Dune file used to mark the root of the project and define project-wide parameters.
|   For the documentation of the syntax, see https://dune.readthedocs.io/en/stable/dune-files.html#dune-project
│
├── LICENSE
│
├── README.md
│
└── inquire.opam
    Opam package definition.
    To know more about creating and publishing opam packages, see https://opam.ocaml.org/doc/Packaging.html.