#prompt #input-validation #interactive #ask #questions #cli

oma-inquire

inquire is a library for building interactive prompts on terminals

2 releases

0.1.1 Aug 8, 2023
0.1.0 Aug 8, 2023

#219 in Value formatting

Download history 244/week @ 2024-07-20 239/week @ 2024-07-27 249/week @ 2024-08-03 365/week @ 2024-08-10 427/week @ 2024-08-17 620/week @ 2024-08-24 560/week @ 2024-08-31 676/week @ 2024-09-07 182/week @ 2024-09-14 256/week @ 2024-09-21 320/week @ 2024-09-28 230/week @ 2024-10-05 252/week @ 2024-10-12 147/week @ 2024-10-19 552/week @ 2024-10-26 543/week @ 2024-11-02

1,520 downloads per month
Used in oma-topics

MIT license

320KB
5.5K SLoC

Latest Version Build status Supported platforms License



inquire is a library for building interactive prompts on terminals.

It provides several different prompts in order to interactively ask the user for information via the CLI. With inquire, you can use:

  • Text to get text input from the user, with built-in autocompletion support;
  • Editor* to get longer text inputs by opening a text editor for the user;
  • DateSelect* to get a date input from the user, selected via an interactive calendar;
  • Select to ask the user to select one option from a given list;
  • MultiSelect to ask the user to select an arbitrary number of options from a given list;
  • Confirm for simple yes/no confirmation prompts;
  • CustomType for text prompts that you would like to parse to a custom type, such as numbers or UUIDs;
  • Password for secretive text prompts.

Demo

Animated GIF making a demonstration of a questionnaire created with this library. You can replay this recording in your terminal with asciinema play command - asciinema play ./assets/expense_tracker.cast Source

Features

  • Cross-platform, supporting UNIX and Windows terminals (thanks to crossterm);
  • Several kinds of prompts to suit your needs;
  • Standardized error handling (thanks to thiserror);
  • Support for fine-grained configuration for each prompt type, allowing you to customize:
    • Default values;
    • Input validators and formatters;
    • Help messages;
    • Autocompletion for Text prompts;
    • Custom list filters for Select and MultiSelect prompts;
    • Custom parsers for Confirm and CustomType prompts;
    • Custom extensions for files created by Editor prompts;
    • and many others!

Usage

Put this line in your Cargo.toml, under [dependencies].

inquire = "0.6.1"

* This prompt type is gated under a feature flag, e.g.:

inquire = { version = "0.6.1", features = ["date", "editor"] }

Dependencies

~3–13MB
~154K SLoC