summaryrefslogtreecommitdiff
path: root/src/grp-boot/kernel-install/kernel-install.completion.zsh
diff options
context:
space:
mode:
authorLuke Shumaker <lukeshu@sbcglobal.net>2016-09-10 17:26:37 -0400
committerLuke Shumaker <lukeshu@sbcglobal.net>2016-09-10 17:26:37 -0400
commitbcbdba00c1641217b488dcdb13abd22ace4733ad (patch)
tree3730b7009ba8423b636f27c39af2e9f1781e7099 /src/grp-boot/kernel-install/kernel-install.completion.zsh
parent660cbff7f8a7c27e2d3f7e0ea175ffb7e7a2b749 (diff)
./tools/move.sh
Diffstat (limited to 'src/grp-boot/kernel-install/kernel-install.completion.zsh')
-rw-r--r--src/grp-boot/kernel-install/kernel-install.completion.zsh26
1 files changed, 26 insertions, 0 deletions
diff --git a/src/grp-boot/kernel-install/kernel-install.completion.zsh b/src/grp-boot/kernel-install/kernel-install.completion.zsh
new file mode 100644
index 0000000000..4fdd3a4ae7
--- /dev/null
+++ b/src/grp-boot/kernel-install/kernel-install.completion.zsh
@@ -0,0 +1,26 @@
+#compdef kernel-install
+
+_images(){
+ if [[ "$words[2]" == "remove" ]]; then
+ _message 'No more options'
+ else
+ _path_files -W /boot/ -P /boot/ -g "vmlinuz-*"
+ fi
+}
+
+_kernels(){
+ read _MACHINE_ID < /etc/machine-id
+ _kernel=( /lib/modules/[0-9]* )
+ if [[ "$cmd" == "remove" && -n "$_MACHINE_ID" ]]; then
+ _kernel=( "/boot/$_MACHINE_ID"/[0-9]* )
+ fi
+ _kernel=( ${_kernel##*/} )
+ _describe "installed kernels" _kernel
+}
+
+_arguments \
+ '1::add or remove:(add remove)' \
+ '2::kernel versions:_kernels' \
+ '3::kernel images:_images'
+
+#vim: set ft=zsh sw=4 ts=4 et