summaryrefslogtreecommitdiffstats
path: root/completions/modinfo
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 09:14:42 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 09:14:42 +0000
commit0bc58b66a4850cdb8458a86c3d9a2fc81de82aa3 (patch)
treeea0fe36eb5e6f40e0a1f765d44c4b0c0b2bfb089 /completions/modinfo
parentInitial commit. (diff)
downloadbash-completion-0bc58b66a4850cdb8458a86c3d9a2fc81de82aa3.tar.xz
bash-completion-0bc58b66a4850cdb8458a86c3d9a2fc81de82aa3.zip
Adding upstream version 1:2.11.upstream/1%2.11upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'completions/modinfo')
-rw-r--r--completions/modinfo47
1 files changed, 47 insertions, 0 deletions
diff --git a/completions/modinfo b/completions/modinfo
new file mode 100644
index 0000000..009bcf3
--- /dev/null
+++ b/completions/modinfo
@@ -0,0 +1,47 @@
+# Linux modinfo(8) completion -*- shell-script -*-
+
+_modinfo()
+{
+ local cur prev words cword split
+ _init_completion -s || return
+
+ case "$prev" in
+ --field | -!(-*)F)
+ COMPREPLY=($(compgen -W 'alias author depends description
+ filename firmware license parm srcversion staging vermagic
+ version' -- "${cur,,}"))
+ return
+ ;;
+ --set-version | -!(-*)k)
+ _kernel_versions
+ return
+ ;;
+ esac
+
+ $split && return
+
+ if [[ $cur == -* ]]; then
+ local opts=$(_parse_help "$1")
+ COMPREPLY=($(compgen -W '${opts:-$(_parse_usage "$1")}' -- "$cur"))
+ [[ ${COMPREPLY-} == *= ]] && compopt -o nospace
+ return
+ fi
+
+ local i version=$(uname -r)
+ for ((i = ${#words[@]} - 1; i > 0; i--)); do
+ if [[ ${words[i]} == -@(!(-*)k*|-set-version) ]]; then
+ version=${words[i + 1]}
+ break
+ fi
+ done
+
+ # do filename completion if we're giving a path to a module
+ if [[ $cur == @(*/|[.~])* ]]; then
+ _filedir '@(?(k)o?(.[gx]z))'
+ else
+ _modules $version
+ fi
+} &&
+ complete -F _modinfo modinfo
+
+# ex: filetype=sh