1
0
mirror of https://github.com/systemd/systemd.git synced 2024-12-25 01:34:28 +03:00

shell-completion: fix completion of localectl set-locale

https://bugs.freedesktop.org/show_bug.cgi?id=74157
This commit is contained in:
Zbigniew Jędrzejewski-Szmek 2014-02-06 11:59:33 -05:00
parent 5d63309cf5
commit 627a98d398
2 changed files with 27 additions and 6 deletions

View File

@ -24,8 +24,14 @@ __contains_word () {
done done
} }
__locale_fields=( LANG LANGUAGE LC_CTYPE LC_NUMERIC LC_TIME \
LC_COLLATE LC_MONETARY LC_MESSAGES LC_PAPER \
LC_NAME LC_ADDRESS LC_TELEPHONE \
LC_MEASUREMENT LC_IDENTIFICATION )
# LC_ALL is omitted on purpose
_localectl() { _localectl() {
local i verb comps local i verb comps locale_vals
local cur=${COMP_WORDS[COMP_CWORD]} prev=${COMP_WORDS[COMP_CWORD-1]} local cur=${COMP_WORDS[COMP_CWORD]} prev=${COMP_WORDS[COMP_CWORD-1]}
local OPTS='-h --help --version --no-convert --no-pager --no-ask-password local OPTS='-h --help --version --no-convert --no-pager --no-ask-password
-H --host' -H --host'
@ -62,7 +68,17 @@ _localectl() {
if [[ -z $verb ]]; then if [[ -z $verb ]]; then
comps=${VERBS[*]} comps=${VERBS[*]}
elif __contains_word "$verb" ${VERBS[LOCALES]}; then elif __contains_word "$verb" ${VERBS[LOCALES]}; then
comps=$(command localectl list-locales) if [[ $cur = *=* ]]; then
mapfile -t locale_vals < <(command localectl list-locales 2>/dev/null)
COMPREPLY=( $(compgen -W '${locale_vals[*]}' -- "${cur#=}") )
elif [[ $prev = "=" ]]; then
mapfile -t locale_vals < <(command localectl list-locales 2>/dev/null)
COMPREPLY=( $(compgen -W '${locale_vals[*]}' -- "$cur") )
else
compopt -o nospace
COMPREPLY=( $(compgen -W '${__locale_fields[*]}' -S= -- "$cur") )
fi
return 0
elif __contains_word "$verb" ${VERBS[KEYMAPS]}; then elif __contains_word "$verb" ${VERBS[KEYMAPS]}; then
comps=$(command localectl list-keymaps) comps=$(command localectl list-keymaps)
elif __contains_word "$verb" ${VERBS[STANDALONE]} ${VERBS[X11]}; then elif __contains_word "$verb" ${VERBS[STANDALONE]} ${VERBS[X11]}; then

View File

@ -1,17 +1,22 @@
#compdef localectl #compdef localectl
_localectl_set-locale() { _localectl_set-locale() {
local -a _confs _locales local -a _locales locale_fields
locale_fields=(LANG LANGUAGE LC_CTYPE LC_NUMERIC LC_TIME \
LC_COLLATE LC_MONETARY LC_MESSAGES LC_PAPER \
LC_NAME LC_ADDRESS LC_TELEPHONE \
LC_MEASUREMENT LC_IDENTIFICATION)
# LC_ALL is omitted on purpose
local expl suf local expl suf
_locales=( ${(f)"$(_call_program locales "$service" list-locales)"} ) _locales=( ${(f)"$(_call_program locales "$service" list-locales)"} )
_confs=( ${${(f)"$(_call_program confs "locale 2>/dev/null")"}%\=*} ) compset -P1 '*='
if [[ -prefix 1 *\= ]]; then if [[ -prefix 1 *\= ]]; then
local conf=${PREFIX%%\=*} local conf=${PREFIX%%\=*}
compset -P1 '*='
_wanted locales expl "locales configs" \ _wanted locales expl "locales configs" \
_combination localeconfs confs=$conf locales "$@" - _combination localeconfs confs=$conf locales "$@" -
else else
compadd -S '=' $_confs compadd -S '=' $locale_fields
fi fi
} }