5 releases (2 stable)
1.1.0 | Apr 30, 2022 |
---|---|
1.0.0 | Jan 18, 2022 |
0.1.2 | Nov 25, 2020 |
0.1.1 | Nov 25, 2020 |
0.1.0 | Nov 24, 2020 |
#561 in Command-line interface
12KB
211 lines
Confirm
A simple tool for scripted confirmation. Returns zero if confirmed, non-zero otherwise.
$ confirm "Echo something?" -a 3 && echo something
Echo something? [y/n]:
Echo something? [y/n]:
Echo something? [y/n]: y
something
Installation
Currently, must be installed using cargo install confirm-rs
. Platform support is determined by the getch
crate.
You can also download the code and build from source.
User guide
The up-to-date docs are maintained in the --help
output of the tool, copied below.
confirm --help
output:
confirm-rs 1.1.0
A simple tool to obtain interactive confirmation in scripts.
USAGE:
confirm [OPTIONS] [PROMPT]
ARGS:
<PROMPT>
The prompt to display
Prompt of "Continue?" will become "Continue? [y/n]: ". Options are added and
highlighted based on given settings. Original message will NEVER be modified.
[default: Continue?]
OPTIONS:
-a, --ask-count <ASK_COUNT>
Number of times to ask
Number of total times a question should be asked. Use 0 for infinite retries.
[default: 3]
-d, --default <DEFAULT>
Choose a default answer
If no default is chosen, and the user supplies an empty answer, then a retry is
triggered. Otherwise, the default is used on an empty answer. If the retry count has
been hit, then the process assumes a negative response and exits 1. Using the keyword
"retry" is identical to omitting the option.
[default: retry]
-f, --full-words
Require explicit "yes" or "no", not single letters.
Cannot be used with --no-enter.
-h, --help
Print help information
--no
Don't ask any question, fail immediately.
Turns the tool into no-op failure. Useful when testing shell scripts built around this
tool.
--no-enter
Don't require newlines
Read the character on the terminal as it's typed, without waiting for the user to hit
enter/return.
-V, --version
Print version information
--yes
Don't ask any question, return successfully.
Turns the entire tool into a no-op, useful when building shell scripts around the tool.
Dependencies
~3.5MB
~65K SLoC