Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/oxidecomputer/helios-bash-completion
bash tab completion for Helios systems
https://github.com/oxidecomputer/helios-bash-completion
Last synced: about 2 months ago
JSON representation
bash tab completion for Helios systems
- Host: GitHub
- URL: https://github.com/oxidecomputer/helios-bash-completion
- Owner: oxidecomputer
- License: mpl-2.0
- Created: 2024-04-28T04:41:53.000Z (9 months ago)
- Default Branch: main
- Last Pushed: 2024-04-28T04:42:04.000Z (9 months ago)
- Last Synced: 2024-08-17T08:06:31.055Z (5 months ago)
- Language: Rust
- Size: 10.7 KB
- Stars: 2
- Watchers: 23
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# helios-bash-completion
This program is intended to ship as `/usr/lib/helios-bash-completion` on a
Helios system. It will generate bash shell source that should be evaluated
from within `.bashrc` to enable the use of bash tab completion for some system
commands; e.g.,```
$ /usr/lib/helios-bash-completion -g
function _helios_bash_completion {
eval $('/usr/lib/helios-bash-completion' "$COMP_CWORD" "${COMP_WORDS[@]}");
};complete -F _helios_bash_completion 'zlogin';
complete -F _helios_bash_completion 'allocate';
complete -F _helios_bash_completion 'deallocate';
complete -F _helios_bash_completion 'ipfs';
complete -F _helios_bash_completion 'ipfstat';
complete -F _helios_bash_completion 'ipmon';
complete -F _helios_bash_completion 'ipnat';
complete -F _helios_bash_completion 'ippool';
complete -F _helios_bash_completion 'pgrep';
complete -F _helios_bash_completion 'pkill';
complete -F _helios_bash_completion 'ps';
complete -F _helios_bash_completion 'psrset';
complete -F _helios_bash_completion 'ptree';
complete -F _helios_bash_completion 'svccfg';
complete -F _helios_bash_completion 'svcadm';
complete -F _helios_bash_completion 'svcprop';
complete -F _helios_bash_completion 'svcs';
complete -F _helios_bash_completion 'zoneadm';
complete -F _helios_bash_completion 'zonecfg';$ eval $(/usr/lib/helios-bash-completion -g)
$ complete
complete -F _helios_bash_completion deallocate
complete -F _helios_bash_completion allocate
complete -F _helios_bash_completion svcadm
complete -F _helios_bash_completion ipnat
complete -F _helios_bash_completion pgrep
complete -F _helios_bash_completion psrset
complete -F _helios_bash_completion pkill
complete -F _helios_bash_completion ippool
complete -F _helios_bash_completion zlogin
complete -F _helios_bash_completion zonecfg
complete -F _helios_bash_completion ipmon
complete -F _helios_bash_completion ipfstat
complete -F _helios_bash_completion svccfg
complete -F _helios_bash_completion svcs
complete -F _helios_bash_completion ipfs
complete -F _helios_bash_completion zoneadm
complete -F _helios_bash_completion ps
complete -F _helios_bash_completion svcprop
complete -F _helios_bash_completion ptree
```The program attempts to be as unobtrusive as possible when it cannot guarantee
a useful match. It is also somewhat context sensitive; i.e., it ideally will
not offer completions that don't make sense at the point where the user is
requesting them with the tab key.## Testing
A limited facility for tinkering is available. If you do not have any zones
available on your system, you can feed a set of test zone names to
the program through the environment. For example:```
$ export COMPLETE_TEST_ZONENAMES='samuel taylor coleridge'$ ./target/release/helios-bash-completion 2 'zonecfg' '-z' ''
COMPREPLY=(
'coleridge'
'samuel'
'taylor'
)$ ./target/release/helios-bash-completion 1 'zlogin' ''
COMPREPLY=(
'-C'
'-E'
'-Q'
'-S'
'-d'
'-e'
'-l'
'-n'
'coleridge'
'samuel'
'taylor'
)
```Bash appears to invoke the command for actual completion with the current
environment as well, so you can test interactively with the same overrides.## Licence
Unless otherwise noted, all components are licenced under the [Mozilla Public
License Version 2.0](./LICENSE).