πΉ Usage
π¨ Valet commands
Valet is a CLI tool that exposes usable commands (e.g. valet help
) or sub commands (e.g. valet self update
).
Each command can accept options (e.g. --help
or -v
) and/or arguments (e.g. in valet self extend my-extension
, my-extension
is an argument of the valet self extend
command).
Each command has properties that enable Valet to:
- Display its usage (e.g. a description, some examples…),
- parse the options and arguments of that command.
You can access the help of a command by either typing valet help my-command
or valet my-command --help
.
Commands can be nested under another parent command which is what we call sub commands. E.g. the self update
command is a sub command of the self
command. There is no limit to the level of nesting for sub commands.
mcmd
can match the command mycommand
if it exists. You can opt-out of this behavior through configuration.Behind the scene, a command refers to a bash function written in a bash script file which is source’d before calling the function. Commands are indexed ahead of time in a process called build (the valet self build
command) in order to not waste time searching for the command script during execution.
π€ About options and arguments
Options
Options can have multiple long name (--my-option
is long name) and up to one short name (-v
is a short composed of a single letter).
Short names can be grouped together, e.g. -fsL
is equivalent to -f -s -L
or equivalent to the long name options --force --silent --follow
.
- Options can be simple flags (i.e. we check if the option is present or not).
- Or can have a value, in which case they are represented as such:
--my-option <value>
and the user is expected to provide a value.
Each option can be set using a environment variable matching the option long name in UPPER_SNAKE_CASE
(e.g. –my-option can be set using export MY_OPTION="value"
).
Arguments
Arguments are always mandatory and must be provided by the user.
An argument that starts with a -
character can be wrongly interpreted as an option. You can use --
to mark the separation between options and commands. E.g. valet my-command -- -my-argument-
allows to interpret -my-argument-
as the first and only argument of my-command
instead of an option.
π Command menu
Calling valet
without any arguments (you can pass options) will open the interactive search for commands.
Type your query (fuzzy matching is active so you can skip some letters), press β¬οΈ/β¬οΈ to select the command and hit enter to run it. Press β¬
οΈ/β‘οΈ (or [PAGE_DOWN]/[PAGE_UP]
and [HOME]/[END]
) to navigate a command help. Press ESC
to leave without selecting a command.
The command property hideInMenu
can prevent a command from being displayed in the menu. These commands are still executable by passing the command name directly to Valet (i.e. you can call valet self setup
even if it is hidden in the menu).
Similarly, you can execute a parent command (e.g. valet self
) to open an interactive menu with only the commands that are nested under it.
π³ Environments variables
Almost all options in Valet are configurable with environment variables. Even options that you can pass to your custom commands can be set through variables (check the --help
)!
This makes Valet particularly suitable for automation (in CI/CD pipelines for instance).
Additionally, at the beginning of its execution, Valet will source
a file named .env
located in the current directory, which enables you to set up command options (this file name can be changed if needed).
βοΈ Adding your own commands and libraries
Valet is pre-configured with some example commands so you can try it immediately and see how it feels.
However, the main goal is to extend Valet and create your own commands. Valet takes care of the boilerplate stuff (parsing arguments, proper log functions, help, testing your command…) so you can focus on the feature of your command.
To create a new command, follow this documentation.
To create a new library, follow this documentation.
πͺ Use Valet library functions directly in bash
Thanks to the self export
command, you can export Valet functions so they are usable directly in your bash session:
eval "$(valet self export -a)"
log::info "Cool logs!"
if interactive::promptYesNo "Do you want to continue?"; then echo "Yes."; else echo "No."; fi