Command line completion
arduino-cli
supports command-line completion (also known as tab completion) for basic commands. Currently bash
,
zsh
, fish
, and powershell
shells are supportedBefore you start
In order to generate the file required to make the completion work you have to install Arduino CLI first.
Generate the completion file
To generate the completion file you can use
arduino-cli completion [bash|zsh|fish|powershell] [--no-descriptions]
. By
default this command will print on the standard output (the shell window) the content of the completion file. To save to
an actual file use the >
redirect symbol.Bash
Use
arduino-cli completion bash > arduino-cli.sh
to generate the completion file. At this point you can move that file
in /etc/bash_completion.d/
(root access is required) with sudo mv arduino-cli.sh /etc/bash_completion.d/
.A not recommended alternative is to source the completion file in
~/.bashrc
.Remember to open a new shell to test the functionality.
Zsh
Use
arduino-cli completion zsh > _arduino-cli
to generate the completion file. At this point you can place the file in
a directory listed in your fpath
if you have already created a directory to store your completion.Or if you want you can create a directory, add it to your
fpath
and copy the file in it:mkdir ~/completion_zsh
- add
at the beginning of yourfpath=($HOME/completion_zsh $fpath)
file~/.zshrc
mv _arduino-cli ~/completion_zsh/
Remember to open a new shell to test the functionality.
Fish
Use
arduino-cli completion fish > arduino-cli.fish
to generate the completion file. At this point you can place the
file in ~/.config/fish/completions
as stated in the
official documentation. Remember to
create the directory if it's not already there mkdir -p ~/.config/fish/completions/
and then place the completion file
in there with mv arduino-cli.fish ~/.config/fish/completions/
Remember to open a new shell to test the functionality.
Powershell
Use
arduino-cli completion powershell > arduino-cli.ps1
to generate a temporary completion file. At this point you
need to add the content of the generated file to your PowerShell profile file.
or add it by hand with your favourite text editor.Get-Content -Path arduino-cli.ps1 | Add-Content -Path $profile
- The previous command added two
lines, move them on top of theusing namespace
file.$profile
- If not already done, add the line
to yourSet-PSReadlineKeyHandler -Key Tab -Function MenuComplete
file: it is needed to enable the TAB completion in PowerShell.$profile
to remove the temporary file.del arduino-cli.ps1
Remember to open a new shell to test the functionality.
For more information on tab-completion on PowerShell, please, refer to Autocomplete in PowerShell.
Disabling command and flag descriptions
By default fish, zsh and bash completion have command and flag description enabled by default. If you want to disable this behaviour you can simply pass the
--no-descriptions
flag when calling completion
command and the generated file
will not have descriptionsN.B. This flag is not compatible with powershell
Brew
If you install the
arduino-cli
using homebrew package manager the completion should work out of
the box if you have followed the official documentation.