summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog3
-rw-r--r--Completion/Redhat/Command/_yum285
2 files changed, 156 insertions, 132 deletions
diff --git a/ChangeLog b/ChangeLog
index 8a36017e9..d133b8da1 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,8 @@
2016-11-24 Oliver Kiddle <opk@zsh.org>
+ * 40004 (tweaked): Completion/Redhat/Command/_yum: fix cache
+ mechanism, complete groups and other minor improvements
+
* unposted: Src/Zle/zle_params.c: fix to compile on Solaris where
curses.h has a #define for reg to register
diff --git a/Completion/Redhat/Command/_yum b/Completion/Redhat/Command/_yum
index 69a8de9a2..4698a3159 100644
--- a/Completion/Redhat/Command/_yum
+++ b/Completion/Redhat/Command/_yum
@@ -9,19 +9,40 @@ _yum() {
'(-t --tolerant)'{-t,--tolerant}'[be tolerant of errors]' \
'(-C --cacheonly)'{-C,--cacheonly}'[run entirely from cache]' \
'(-c --config)'{-c,--config=}'[config file location]:Yum conf file:_files' \
- '(-R --randomwait)'{-R,--randomwait=}'[maximum command wait time (in minutes)]:max wait time' \
+ '(-R --randomwait)'{-R,--randomwait=}'[specify maximum command wait time]:max wait time (minutes)' \
'(-d --debuglevel)'{-d,--debuglevel=}'[debug level (0-10)]:debug level' \
+ '--showduplicates[show duplicates, in repos, in list/search commands]' \
'(-e --errorlevel)'{-e,--errorlevel=}'[error level (0-10)]:error level' \
- '(-y --assumeyes)'{-y,--assumeyes}'[answer yes for all questions]' \
+ '--rpmverbosity=[specify rpm debug level]:debug level' \
+ '(-q --quiet -v --verbose)'{-q,--quiet}'[quiet operation]' \
+ '(-q --quiet -v --verbose)'{-v,--verbose}'[verbose operation]' \
+ '(-y --assumeyes --assumeno)'{-y,--assumeyes}'[answer yes to all questions]' \
+ '(-y --assumeyes --assumeno)--assumeno[answer no to all questions]' \
+ '(- *)--version[display version information]' \
'--installroot=[set install root]:install root:_files -/' \
- '*--enablerepo=[enable or or more repositories]:repos to enable:_yum_disabled_repos_list' \
- '*--disablerepo=[disable one or more repositories]:disable repos:_yum_enabled_repos_list' \
- {*-x,*--exclude=}'[exclude package(s) by name or glob]:exclude packages' \
- '--version[show yum version]' \
+ '*--enablerepo=[enable or or more repositories]:repository:_sequence _yum_disabled_repos' \
+ '*--disablerepo=[disable one or more repositories]:repository:_sequence _yum_enabled_repos' \
+ \*{-x,--exclude=}'[exclude package by name or glob]:package:_yum_all_pkgs' \
+ '--disableexcludes=[disable exclude]:exclude:(all main)' \
+ '--disableincludes=[disable include]:include' \
'--obsoletes[enable obsoletes processing during updates]' \
- '--nogpgcheck[disable gpg signature checking]' \
'--noplugins[disable yum plugins]' \
- '--disablepresto[disable Presto plugin and don''''t download any deltarpms]' \
+ '--nogpgcheck[disable gpg signature checking]' \
+ '--disableplugin=[disable plugin]:plugin' \
+ '--enableplugin=[enable plugin]:plugin' \
+ '--skip-broken[skip packages with depsolving problems]' \
+ '--color=[control whether color is used]:(always auto never)' \
+ '--releasever=[set value of $releasever in yum config and repo files]:value' \
+ "--downloadonly[don't update, just download]" \
+ '--downloaddir=[specify alternate directory to store packages]:directort:_directories' \
+ '--setopt=[set arbitrary config and repo options]:option' \
+ '--bugfix[include bugfix relevant packages in updates]' \
+ '--security[include security relevant packages in updates]' \
+ '--advisory=[include packages needed to fix the given advisory]:advisory' \
+ '--bzs=[include packages needed to fix the given BZ]:BZ' \
+ '--cves=[include packages needed to fix the given CVE]:CVE' \
+ '--sec-severity=[include security relevant packages matching specific severity]:severity' \
+ {*-x,*--exclude=}'[exclude package(s) by name or glob]:exclude packages' \
'*::yum command:_yum_command'
}
@@ -58,7 +79,7 @@ _yum() {
"help:produce help for all or given command"
"load-transaction:load a saved transaction from a textfile"
"load-ts:load a saved transaction from a textfile"
- "check:Check for problems in the rpmdb"
+ "check:check for problems in the rpmdb"
"reinstall:reinstall a package"
"downgrade:downgrade a package"
"repolist:display the configured software repositories"
@@ -67,9 +88,9 @@ _yum() {
)
if (( CURRENT == 1 )); then
- _describe -t commands 'yum command' _yum_cmds || compadd "$@"
+ _describe -t commands 'yum command' _yum_cmds
else
- local curcontext="$curcontext"
+ local curcontext="$curcontext" ret=1
cmd="${${_yum_cmds[(r)$words[1]:*]%%:*}}"
# Deal with any aliases
@@ -94,45 +115,36 @@ _yum() {
if [ "$cmd" = "help" ]; then
if (( CURRENT == 2 )); then
- local -a _yum_cmd_names
- _yum_cmd_names=(${_yum_cmds%%:*})
- _describe -t commands 'commands' _yum_cmd_names
+ _describe -t commands 'yum commands' _yum_cmds && ret=0
else
# help takes one argument
_message 'no more arguments'
fi
- else
- _call_function ret _yum_$cmd || _message 'no more arguments'
+ elif ! _call_function ret _yum-$cmd; then
+ _default && ret=0
fi
else
- _message "unknown yum command: $words[1]"
+ # fallback to default completion for unknown commands
+ _default && ret=0
fi
return ret
fi
}
# Expand next argument after 'yum check'
-_yum_check() {
- if (( CURRENT == 2 )); then
+_yum-check() {
##chkargs=("dependencies" "duplicates" "obsoletes" "provides" "all") # according to man page
##chkargs=("dependencies" "duplicates" "all") # according to help
#chkargs=("dependencies" "duplicates" "provides" "all") # what works for me
- local expl
- _wanted arguments expl 'check argument' compadd dependencies \
- duplicates provides all
- else
- return 1
- fi
+ _values -w 'check argument' dependencies duplicates provides all
}
# Expand next argument after 'yum repolist'
-_yum_repolist() {
- if (( CURRENT == 2 )); then
- local expl
- _wanted arguments expl 'repolist arguments' compadd all enabled disabled
- else
- return 1
- fi
+_yum-repolist() {
+ _yum_get_repos
+ _alternative \
+ 'filters:filter:(all enabled disabled)' \
+ 'repositories:repository:compadd -a yum_enabled_repos yum_disabled_repos'
}
_yum_ids() {
@@ -140,35 +152,32 @@ _yum_ids() {
# all other arguments are forwarded to compadd
#
# maxid is the last transaction ID known to yum
- # minusone is the number of arguments provided to _yum_ids minus one
local maxid
- local minusone
-
- maxid=$(yum history stats | grep Transactions | sed "s/.*: //")
- # `$#' is the number of arguments
- ((minusone=$#-1))
+ maxid=${${(M)${(f)"$(_call_program transactions yum history stats)"}:#Transactions:*}##* }
# `$@' are the arguments
# `${(@)@[...]}' selects a subrange from $@
- # `${(@)@[1,$minusone]}' are all except the last argument
+ # `${(@)@[1,-2]}' are all except the last argument
# `$@[$#]' is the last argument, e.g. the first suggestable ID
- compadd "${(@)@[1,$minusone]}" {$@[$#]..$maxid}
+ compadd "${(@)@[1,-2]:/-J/-V}" -M "B:0=" {$@[$#]..$maxid}
}
_yum_ranges() {
- if compset -P '*..'; then
- _yum_ids $@ ${(S)IPREFIX#..}
+ if compset -P 1 '*..'; then
+ _yum_ids "$@" ${(S)IPREFIX#..}
+ elif compset -S '..*'; then
+ _yum_ids "$@" 1
else
- _yum_ids $@ -S '..' 1
+ _yum_ids "$@" -S '..' 1
fi
}
# Expand next argument after 'yum history'
-_yum_history() {
+_yum-history() {
local expl
if (( CURRENT == 2 )); then
- _wanted arguments expl "yum history command" compadd info list \
+ _wanted commands expl "yum history command" compadd info list \
packages-list packages-info summary addon-info redo undo \
roll-back new sync stats
elif (( CURRENT == 3 )); then
@@ -209,49 +218,45 @@ _yum_history() {
# Fills the all pkg cache
_yum_all_pkgs()
{
- if ( [[ ${+_all_pkgs} -eq 0 ]] || _cache_invalid ALL ) &&
- ! _retrieve_cache ALL;
-then
- _all_pkgs=( $(yum -C list all | sed 's/\s.*//' | grep '\.' 2>/dev/null) )
- _store_cache ALL _all_pkgs
-fi
+ (( $+_yum_all_pkgs[1] )) && return
+ if _cache_invalid yum-all-packages || ! _retrieve_cache yum-all-packages; then
+ _yum_all_pkgs=( ${(M)${${(f)"$(_call_program packages yum -C list all)"}// *}:#*.*} )
+ _store_cache yum-all-packages _yum_all_pkgs
+ fi
}
# Fills the installed pkg cache
_yum_installed_pkgs()
{
- if ( [[ ${+_installed_pkgs} -eq 0 ]] || _cache_invalid INSTALLED ) &&
- ! _retrieve_cache INSTALLED;
-then
- _installed_pkgs=( $(yum -C list installed | sed 's/\s.*//' | grep '\.' 2>/dev/null) )
- _store_cache INSTALLED _installed_pkgs
-fi
+ (( $+_yum_installed_pkgs[1] )) && return
+ if _cache_invalid yum-installed || ! _retrieve_cache yum-installed; then
+ _yum_installed_pkgs=( ${(M)${${(f)"$(_call_program packages yum -C list installed)"}// *}:#*.*} )
+ _store_cache yum-installed _yum_installed_pkgs
+ fi
}
# Fills the available pkg cache
_yum_available_pkgs()
{
- if ( [[ ${+_available_pkgs} -eq 0 ]] || _cache_invalid AVAILABLE ) &&
- ! _retrieve_cache AVAILABLE;
-then
- _available_pkgs=( $(yum -C list available | sed 's/\s.*//' | grep '\.' 2>/dev/null) )
- _store_cache AVAILABLE _available_pkgs
-fi
+ (( $+_yum_available_pkgs[1] )) && return
+ if _cache_invalid yum-available || ! _retrieve_cache yum-available; then
+ _yum_available_pkgs=( ${(M)${${(f)"$(_call_program packages yum -C list available)"}// *}:#*.*} )
+ _store_cache yum-available _yum_available_pkgs
+ fi
}
# Fills the upgrade pkg cache
_yum_upgrade_pkgs()
{
- if ( [[ ${+_upgrade_pkgs} -eq 0 ]] || _cache_invalid UPGRADE ) &&
- ! _retrieve_cache UPGRADE;
-then
- _upgrade_pkgs=( $(yum -C list upgrade | sed 's/\s.*//' | grep '\.' 2>/dev/null) )
- _store_cache UPGRADE _upgrade_pkgs
-fi
+ (( $+_yum_upgrade_pkgs[1] )) && return
+ if _cache_invalid yum-upgrade || ! _retrieve_cache yum-upgrade; then
+ _yum_upgrade_pkgs=( ${(M)${${(f)"$(_call_program packages yum -C list upgrade)"}// *}:#*.*} )
+ _store_cache yum-upgrade _yum_upgrade_pkgs
+ fi
}
# Gets the list of defined repos
-yum_repos() {
+_yum_get_repos() {
local trepo
local -a tarray
tarray=( $(egrep -h '(^\[.*\]|^enabled.*=)' /etc/yum.repos.d/*.repo /etc/yum.conf | sed -e 's/ //g' | sed -e 's/\[//g' | sed -e 's/\].*$//g' 2>/dev/null) )
@@ -259,63 +264,86 @@ yum_repos() {
local -i dindex=0
for line in $tarray; do
if [[ "$line" = "enabled=1" ]]; then
- enabled_yum_repos=($enabled_yum_repos $trepo)
+ yum_enabled_repos=($enabled_yum_repos $trepo)
elif [[ "$line" = "enabled=0" ]]; then
- disabled_yum_repos=($disabled_yum_repos $trepo)
+ yum_disabled_repos=($yum_disabled_repos $trepo)
elif [[ "$line" != "main" ]]; then
trepo=$line
fi
done
}
-(( $+functions[_yum_disabled_repos_list] )) || _yum_disabled_repos_list()
-{
- compset -P '*,'
- compset -S ',*'
- yum_repos
- compadd "$@" -a -- disabled_yum_repos
+_yum_disabled_repos() {
+ _yum_get_repos
+ compadd "$@" -a -- yum_disabled_repos
}
-(( $+functions[_yum_enabled_repos_list] )) || _yum_enabled_repos_list()
-{
- compset -P '*,'
- compset -S ',*'
- yum_repos
- compadd "$@" -a -- enabled_yum_repos
+_yum_enabled_repos() {
+ _yum_get_repos
+ compadd "$@" -a -- yum_enabled_repos
}
# Suggest installed packages
_yum_act_on_installed_pkgs() {
+ local expl
_yum_installed_pkgs
- compadd "$@" -a -- _installed_pkgs
+ _wanted packages expl 'package' compadd "$@" -a -- _yum_installed_pkgs
}
# Completion function for distribution-synchronization|distro-sync
-(( $+functions[_yum_distribution-synchronization] )) || _yum_distribution-synchronization()
+(( $+functions[_yum-distribution-synchronization] )) || _yum-distribution-synchronization()
{
_yum_act_on_installed_pkgs "$@"
}
# Completion function for erase|remove
-(( $+functions[_yum_erase] )) || _yum_erase()
+(( $+functions[_yum-erase] )) || _yum-erase()
{
_yum_act_on_installed_pkgs "$@"
}
# Completion function for downgrade
-(( $+functions[_yum_downgrade] )) || _yum_downgrade()
+(( $+functions[_yum-downgrade] )) || _yum-downgrade()
{
_yum_act_on_installed_pkgs "$@"
}
# Completion function for reinstall
-(( $+functions[_yum_reinstall] )) || _yum_reinstall()
+(( $+functions[_yum-reinstall] )) || _yum-reinstall()
{
_yum_act_on_installed_pkgs "$@"
}
+(( $+functions[_yum-groupinfo] )) || _yum-groupinfo()
+{
+ local expl
+ _wanted groups expl group compadd \
+ ${${(M)${(f)"$(_call_program groups yum grouplist -C)"}:# *}# }
+}
+
+(( $+functions[_yum-groupinstall] )) || _yum-groupinstall()
+{
+ local expl
+ _wanted groups expl group compadd \
+ ${${(M)${(f)"$(_call_program groups yum grouplist -C)"}:# *}# }
+}
+
+(( $+functions[_yum-groupremove] )) || _yum-groupremove()
+{
+ local expl
+ _wanted groups expl group compadd \
+ ${${(M)${(f)"$(_call_program groups yum grouplist -C installed)"}:# *}# }
+}
+
+(( $+functions[_yum-groupupdate] )) || _yum-groupupdate()
+{
+ local expl
+ _wanted groups expl group compadd \
+ ${${(M)${(f)"$(_call_program groups yum grouplist -C installed)"}:# *}# }
+}
+
# Completion function for install
-(( $+functions[_yum_install] )) || _yum_install()
+(( $+functions[_yum-install] )) || _yum-install()
{
if ! [[ $PREFIX == */* ]]; then
_yum_available_pkgs
@@ -325,7 +353,7 @@ _yum_act_on_installed_pkgs() {
_tags files packages
while _tags; do
if _requested files; then
- compadd "$@" -a -- _available_pkgs
+ compadd "$@" -a -- _yum_available_pkgs
fi
if _requested packages; then
_call_function - _yum_localinstall
@@ -336,42 +364,45 @@ _yum_act_on_installed_pkgs() {
}
# Completion function for load-transaction
-(( $+functions[_yum_load-transaction] )) || _yum_load-transaction()
+(( $+functions[_yum-load-transaction] )) || _yum-load-transaction()
{
_files
}
# Completion function for localinstall
-(( $+functions[_yum_localinstall] )) || _yum_localinstall()
+(( $+functions[_yum-localinstall] )) || _yum-localinstall()
{
_files -/ -g '(#i)*.rpm(-.)'
}
# Completion function for localupdate
-(( $+functions[_yum_localupdate] )) || _yum_localupdate()
+(( $+functions[_yum-localupdate] )) || _yum-localupdate()
{
_files -/ -g '(#i)*.rpm(-.)'
}
# Completion function for update/upgrade
-(( $+functions[_yum_update] )) || _yum_update()
+(( $+functions[_yum-update] )) || _yum-update()
{
+ local expl
_yum_upgrade_pkgs
- compadd "$@" -a -- _upgrade_pkgs
+ _wanted packages expl package compadd "$@" -a _yum_upgrade_pkgs
}
# Completion function for deplist
-(( $+functions[_yum_deplist] )) || _yum_deplist()
+(( $+functions[_yum-deplist] )) || _yum-deplist()
{
+ local expl
_yum_available_pkgs
- compadd "$@" -a -- _available_pkgs
+ _wanted packages expl package compadd "$@" -a _yum_available_pkgs
}
_yum_all()
{
_yum_all_pkgs
- compadd "$@" -a -- _all_pkgs
+ compadd "$@" -a -- _yum_all_pkgs
}
+
_yum_list_or_info()
{
local -a listlist
@@ -386,60 +417,50 @@ _yum_list_or_info()
)
if (( CURRENT == 2 )); then
- _describe -t yum-list-subcmds "Yum info/list sub-commands" listlist || _yum_all
+ _describe -t filters "filter" listlist || _yum_all
else
- local subcmd
- subcmd="${${listlist[(r)$words[2]:*]%%:*}}"
# offer packages selected by the subcommand
- case $subcmd in
- all) _yum_all;;
- installed) _yum_erase;;
- available) _yum_install;;
- updates) _yum_update;;
+ case $words[2] in
+ installed) _yum-erase;;
+ available) _yum-install;;
+ updates) _yum-update;;
+ *extras|obsoletes|recent)
+ _wanted packages expl package compadd \
+ ${(M)${${(f)"$(_call_program packages yum -C list $words[2])"}// *}:#*.*}
+ ;;
+ *) _yum_all;;
esac
fi
}
# Completion function for list
-(( $+functions[_yum_list] )) || _yum_list()
+(( $+functions[_yum-list] )) || _yum-list()
{
_yum_list_or_info
}
# Completion function for info
-(( $+functions[_yum_info] )) || _yum_info()
+(( $+functions[_yum-info] )) || _yum-info()
{
_yum_list_or_info
}
# Completion function for provides|whatprovides
-(( $+functions[_yum_provides] )) || _yum_provides()
-{
- _files
-}
-
-# Completion function for resolvedep
-(( $+functions[_yum_resolvedep] )) || _yum_resolvedep()
+(( $+functions[_yum-provides] )) || _yum-provides()
{
_files
}
# Completion function for clean
-(( $+functions[_yum_clean] )) || _yum_clean()
+(( $+functions[_yum-clean] )) || _yum-clean()
{
- local -a cleanlist
- cleanlist=(
- "all:all cache"
- "cache:all cache"
- "dbcache:DB cache"
- "headers:cache headers"
- "packages:cache packages"
- "metadata:cache meta-data"
- )
-
- if (( CURRENT == 2 )); then
- _describe -t yum-clean-subcmds "Yum clean sub-commands" cleanlist
- fi
+ _values -w "Yum clean sub-commands" \
+ "all[all cache]" \
+ "cache[all cache]" \
+ "dbcache[DB cache]" \
+ "headers[cache headers]" \
+ "packages[cache packages]" \
+ "metadata[cache meta-data]"
}
_yum_caching_policy() {
@@ -447,8 +468,8 @@ _yum_caching_policy() {
local -a oldp
# rebuild if cache is more than a week old
- oldp=( "$1"(mw+1) )
- (( $#oldp )) && return 0
+ oldp=( "$1"(mw-1) )
+ (( $#oldp )) || return 0
_yumrepomds=( /var/cache/yum/**/repomd.xml )