shell completions consist of basically a state, and DAG (directed acyclic graph)
consider following
- git -> [ -C, <sub-commands> ]
- <sub-commands> -> [ add, branch, checkout, clone, remote, stash ]
- -C -> [ <directories> ]
- add -> [ <files>, <directories ]
...
- checkout -> [ <refs>, <files>, <directories> ]
---
obviously you could dump all these at every <tab> invocation, i usually create base+completions script considering completions for the base.
this way, i have tools & tools-completion, tools have sub-commands of fix, restart, connect, review, retrieve, etc.
each of these also have completions, like tools-restart-completions. those lists available services/daemons only
while installing, you only need to install "tools completions", that handles the redirect(s) to sub-commands and their sub-commands, making things easier to maintain, simple to operate, and independent.