# Bash Completion

Bashly comes with built-in bash completions generator, provided by the completely gem.

By running any of the bashly add comp commands, you can add this functionality to your script in one of three ways:

Creates a standalone completion script that can be sourced or copied to the system's bash completions directory.

Creates a function in your ./src/lib directory that echoes a completion script. You can then call this function from any command (for example yourcli completions) and your users will be able to install the completions by running eval "$(yourcli completions)".

Creates the raw data YAML file. This is intended mainly for development purposes.

The bash completions generation is completely automatic, but you will have to regenerate the completion function whenever you make changes to your bashly.yml file.

In addition to suggesting sub-commands and flags, you can instruct bashly to also suggest files, directories, users, git branches and more. To do this, add another option in your bashly.yml on the command you wish to alter:

- name: upload
  help: Upload a file
  - <directory>
  - <user>
  - $(git branch 2> /dev/null)
  • Anything between <...> will be added using the compgen -A action flag.
  • Anything else, will be appended to the compgen -W flag.

For more information about these custom completions, see the documentation for the completely gem.

Bash Completions Example