diff options
author | Zbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl> | 2014-02-06 11:59:33 -0500 |
---|---|---|
committer | Zbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl> | 2014-02-06 12:01:39 -0500 |
commit | 627a98d39844a1ac10fde1f72cf18b4f08be4990 (patch) | |
tree | 5368d72462a7bfa239577753243b87f2fa049807 /shell-completion/zsh/_localectl | |
parent | 5d63309cf5a6fc5256391fa4ddb72cf68e2e27e5 (diff) |
shell-completion: fix completion of localectl set-locale
https://bugs.freedesktop.org/show_bug.cgi?id=74157
Diffstat (limited to 'shell-completion/zsh/_localectl')
-rw-r--r-- | shell-completion/zsh/_localectl | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/shell-completion/zsh/_localectl b/shell-completion/zsh/_localectl index 3d76bb0c4d..c04f4f3109 100644 --- a/shell-completion/zsh/_localectl +++ b/shell-completion/zsh/_localectl @@ -1,17 +1,22 @@ #compdef localectl _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 _locales=( ${(f)"$(_call_program locales "$service" list-locales)"} ) - _confs=( ${${(f)"$(_call_program confs "locale 2>/dev/null")"}%\=*} ) + compset -P1 '*=' if [[ -prefix 1 *\= ]]; then local conf=${PREFIX%%\=*} - compset -P1 '*=' _wanted locales expl "locales configs" \ _combination localeconfs confs=$conf locales "$@" - else - compadd -S '=' $_confs + compadd -S '=' $locale_fields fi } |