| ▲ | pvtmert 5 hours ago | |
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. | ||