summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog2
-rw-r--r--Completion/Redhat/Command/_scl38
2 files changed, 40 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index 9068f13a0..86510979c 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,7 @@
2015-10-31 Oliver Kiddle <opk@zsh.org>
+ * 37028: Completion/Redhat/Command/_scl: new completion
+
* 36993: Eric Cook: Functions/Misc/zed: fix argument parsing
2015-10-31 Barton E. Schaefer <schaefer@zsh.org>
diff --git a/Completion/Redhat/Command/_scl b/Completion/Redhat/Command/_scl
new file mode 100644
index 000000000..e1a4b69db
--- /dev/null
+++ b/Completion/Redhat/Command/_scl
@@ -0,0 +1,38 @@
+#compdef scl
+
+local curcontext="$curcontext" dashes ret=1
+local -a state line force alts cmd
+
+[[ $words[2] = deregister ]] &&
+ force=( '--force[deregister even SCL installed as packages]' )
+
+_arguments -C $force \
+ '(- 1)'{-l,--list}'[list installed software collections or packages within a collection]' \
+ '(-l --list)1:action:(enable register deregister)' \
+ '(-)*:collections:->collections' && ret=0
+
+if [[ -n $state ]]; then
+ (( $#line > 1 )) && curcontext="${curcontext%:*}-$line[1]:"
+ if [[ $line[1] = register ]]; then
+ _directories -P / -W /
+ return
+ fi
+ if (( ${dashes:=$words[(I)--]} )); then
+ shift dashes words
+ (( CURRENT -= dashes ))
+ _normal
+ return
+ fi
+ if [[ $CURRENT -gt 3 && $words[CURRENT] = - ]]; then
+ compadd - --
+ return
+ fi
+ [[ $line[1] = enable && $CURRENT -gt 3 ]] &&
+ cmd='command:command:_cmdstring'
+
+ _alternative 'collections:collection:compadd
+ $(_call_program collections ${words[1]} -l)' \
+ $cmd && ret=0
+fi
+
+return ret