Zbigniew Jędrzejewski-Szmek ca73a2
From 827591e3b789844ec103338573cf8ed82231c0ad Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek ca73a2
From: =?UTF-8?q?Zbigniew=20J=C4=99drzejewski-Szmek?= <zbyszek@in.waw.pl>
Zbigniew Jędrzejewski-Szmek ca73a2
Date: Thu, 6 Feb 2014 11:59:33 -0500
Zbigniew Jędrzejewski-Szmek ca73a2
Subject: [PATCH] shell-completion: fix completion of localectl set-locale
Zbigniew Jędrzejewski-Szmek ca73a2
Zbigniew Jędrzejewski-Szmek ca73a2
https://bugs.freedesktop.org/show_bug.cgi?id=74157
Zbigniew Jędrzejewski-Szmek ca73a2
---
Zbigniew Jędrzejewski-Szmek ca73a2
 shell-completion/bash/localectl | 20 ++++++++++++++++++--
Zbigniew Jędrzejewski-Szmek ca73a2
 shell-completion/zsh/_localectl | 13 +++++++++----
Zbigniew Jędrzejewski-Szmek ca73a2
 2 files changed, 27 insertions(+), 6 deletions(-)
Zbigniew Jędrzejewski-Szmek ca73a2
Zbigniew Jędrzejewski-Szmek ca73a2
diff --git a/shell-completion/bash/localectl b/shell-completion/bash/localectl
Zbigniew Jędrzejewski-Szmek ca73a2
index 84e2a6b..c9e22af 100644
Zbigniew Jędrzejewski-Szmek ca73a2
--- a/shell-completion/bash/localectl
Zbigniew Jędrzejewski-Szmek ca73a2
+++ b/shell-completion/bash/localectl
Zbigniew Jędrzejewski-Szmek ca73a2
@@ -24,8 +24,14 @@ __contains_word () {
Zbigniew Jędrzejewski-Szmek ca73a2
         done
Zbigniew Jędrzejewski-Szmek ca73a2
 }
Zbigniew Jędrzejewski-Szmek ca73a2
 
Zbigniew Jędrzejewski-Szmek ca73a2
+__locale_fields=( LANG LANGUAGE LC_CTYPE LC_NUMERIC LC_TIME \
Zbigniew Jędrzejewski-Szmek ca73a2
+                  LC_COLLATE LC_MONETARY LC_MESSAGES LC_PAPER \
Zbigniew Jędrzejewski-Szmek ca73a2
+                  LC_NAME LC_ADDRESS LC_TELEPHONE \
Zbigniew Jędrzejewski-Szmek ca73a2
+                  LC_MEASUREMENT LC_IDENTIFICATION )
Zbigniew Jędrzejewski-Szmek ca73a2
+# LC_ALL is omitted on purpose
Zbigniew Jędrzejewski-Szmek ca73a2
+
Zbigniew Jędrzejewski-Szmek ca73a2
 _localectl() {
Zbigniew Jędrzejewski-Szmek ca73a2
-        local i verb comps
Zbigniew Jędrzejewski-Szmek ca73a2
+        local i verb comps locale_vals
Zbigniew Jędrzejewski-Szmek ca73a2
         local cur=${COMP_WORDS[COMP_CWORD]} prev=${COMP_WORDS[COMP_CWORD-1]}
Zbigniew Jędrzejewski-Szmek ca73a2
         local OPTS='-h --help --version --no-convert --no-pager --no-ask-password
Zbigniew Jędrzejewski-Szmek ca73a2
                     -H --host'
Zbigniew Jędrzejewski-Szmek ca73a2
@@ -62,7 +68,17 @@ _localectl() {
Zbigniew Jędrzejewski-Szmek ca73a2
         if [[ -z $verb ]]; then
Zbigniew Jędrzejewski-Szmek ca73a2
                 comps=${VERBS[*]}
Zbigniew Jędrzejewski-Szmek ca73a2
         elif __contains_word "$verb" ${VERBS[LOCALES]}; then
Zbigniew Jędrzejewski-Szmek ca73a2
-                comps=$(command localectl list-locales)
Zbigniew Jędrzejewski-Szmek ca73a2
+                if [[ $cur = *=* ]]; then
Zbigniew Jędrzejewski-Szmek ca73a2
+                        mapfile -t locale_vals < <(command localectl list-locales 2>/dev/null)
Zbigniew Jędrzejewski-Szmek ca73a2
+                        COMPREPLY=( $(compgen -W '${locale_vals[*]}' -- "${cur#=}") )
Zbigniew Jędrzejewski-Szmek ca73a2
+                elif [[ $prev = "=" ]]; then
Zbigniew Jędrzejewski-Szmek ca73a2
+                        mapfile -t locale_vals < <(command localectl list-locales 2>/dev/null)
Zbigniew Jędrzejewski-Szmek ca73a2
+                        COMPREPLY=( $(compgen -W '${locale_vals[*]}' -- "$cur") )
Zbigniew Jędrzejewski-Szmek ca73a2
+                else
Zbigniew Jędrzejewski-Szmek ca73a2
+                        compopt -o nospace
Zbigniew Jędrzejewski-Szmek ca73a2
+                        COMPREPLY=( $(compgen -W '${__locale_fields[*]}' -S= -- "$cur") )
Zbigniew Jędrzejewski-Szmek ca73a2
+                fi
Zbigniew Jędrzejewski-Szmek ca73a2
+                return 0
Zbigniew Jędrzejewski-Szmek ca73a2
         elif __contains_word "$verb" ${VERBS[KEYMAPS]}; then
Zbigniew Jędrzejewski-Szmek ca73a2
                 comps=$(command localectl list-keymaps)
Zbigniew Jędrzejewski-Szmek ca73a2
         elif __contains_word "$verb" ${VERBS[STANDALONE]} ${VERBS[X11]}; then
Zbigniew Jędrzejewski-Szmek ca73a2
diff --git a/shell-completion/zsh/_localectl b/shell-completion/zsh/_localectl
Zbigniew Jędrzejewski-Szmek ca73a2
index 3d76bb0..c04f4f3 100644
Zbigniew Jędrzejewski-Szmek ca73a2
--- a/shell-completion/zsh/_localectl
Zbigniew Jędrzejewski-Szmek ca73a2
+++ b/shell-completion/zsh/_localectl
Zbigniew Jędrzejewski-Szmek ca73a2
@@ -1,17 +1,22 @@
Zbigniew Jędrzejewski-Szmek ca73a2
 #compdef localectl
Zbigniew Jędrzejewski-Szmek ca73a2
 
Zbigniew Jędrzejewski-Szmek ca73a2
 _localectl_set-locale() {
Zbigniew Jędrzejewski-Szmek ca73a2
-    local -a _confs _locales
Zbigniew Jędrzejewski-Szmek ca73a2
+    local -a _locales locale_fields
Zbigniew Jędrzejewski-Szmek ca73a2
+    locale_fields=(LANG LANGUAGE LC_CTYPE LC_NUMERIC LC_TIME \
Zbigniew Jędrzejewski-Szmek ca73a2
+                   LC_COLLATE LC_MONETARY LC_MESSAGES LC_PAPER \
Zbigniew Jędrzejewski-Szmek ca73a2
+                   LC_NAME LC_ADDRESS LC_TELEPHONE \
Zbigniew Jędrzejewski-Szmek ca73a2
+                   LC_MEASUREMENT LC_IDENTIFICATION)
Zbigniew Jędrzejewski-Szmek ca73a2
+    # LC_ALL is omitted on purpose
Zbigniew Jędrzejewski-Szmek ca73a2
+
Zbigniew Jędrzejewski-Szmek ca73a2
     local expl suf
Zbigniew Jędrzejewski-Szmek ca73a2
     _locales=( ${(f)"$(_call_program locales "$service" list-locales)"} )
Zbigniew Jędrzejewski-Szmek ca73a2
-    _confs=( ${${(f)"$(_call_program confs "locale 2>/dev/null")"}%\=*} )
Zbigniew Jędrzejewski-Szmek ca73a2
+    compset -P1 '*='
Zbigniew Jędrzejewski-Szmek ca73a2
     if [[ -prefix 1 *\= ]]; then
Zbigniew Jędrzejewski-Szmek ca73a2
         local conf=${PREFIX%%\=*}
Zbigniew Jędrzejewski-Szmek ca73a2
-        compset -P1 '*='
Zbigniew Jędrzejewski-Szmek ca73a2
         _wanted locales expl "locales configs" \
Zbigniew Jędrzejewski-Szmek ca73a2
             _combination localeconfs  confs=$conf locales "$@" -
Zbigniew Jędrzejewski-Szmek ca73a2
     else
Zbigniew Jędrzejewski-Szmek ca73a2
-        compadd -S '='  $_confs
Zbigniew Jędrzejewski-Szmek ca73a2
+        compadd -S '=' $locale_fields
Zbigniew Jędrzejewski-Szmek ca73a2
     fi
Zbigniew Jędrzejewski-Szmek ca73a2
 }
Zbigniew Jędrzejewski-Szmek ca73a2