about summary refs log tree commit diff
diff options
context:
space:
mode:
authorPeter Stephenson <pws@users.sourceforge.net>2010-07-20 09:06:55 +0000
committerPeter Stephenson <pws@users.sourceforge.net>2010-07-20 09:06:55 +0000
commitbaee5347e4b099ae2306cd119cba4d5059b8b6f3 (patch)
tree5f9721c32edddc565f66ad48899284cb049a39e1
parentbb95aef24fb0228eb5dceb71e13f64de056ccc08 (diff)
downloadzsh-baee5347e4b099ae2306cd119cba4d5059b8b6f3.tar.gz
zsh-baee5347e4b099ae2306cd119cba4d5059b8b6f3.tar.xz
zsh-baee5347e4b099ae2306cd119cba4d5059b8b6f3.zip
28092: let _getconf find more configuration variables
-rw-r--r--ChangeLog6
-rw-r--r--Completion/Unix/Command/_getconf69
2 files changed, 44 insertions, 31 deletions
diff --git a/ChangeLog b/ChangeLog
index 912f0d72e..952723d9b 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+2010-07-19  Peter Stephenson  <pws@csr.com>
+
+	* Completion/Unix/Command/_getconf: generate missing keys.
+
 2010-07-19  Frank Terbeck  <ft@bewatermyfriend.org>
 
 	* 28093, based on Michel Lespinasse: 28090:
@@ -13391,5 +13395,5 @@
 
 *****************************************************
 * This is used by the shell to define $ZSH_PATCHLEVEL
-* $Revision: 1.5029 $
+* $Revision: 1.5030 $
 *****************************************************
diff --git a/Completion/Unix/Command/_getconf b/Completion/Unix/Command/_getconf
index e8f9a1b3d..76d9c7686 100644
--- a/Completion/Unix/Command/_getconf
+++ b/Completion/Unix/Command/_getconf
@@ -2,48 +2,57 @@
 
 local expl ret=1
 
+local -a syskeys posixkeys confkeys pathkeys1 pathkeys2 allkeys mykeys restkeys
+syskeys=(ARG_MAX BC_BASE_MAX BC_DIM_MAX BC_SCALE_MAX
+  BC_STRING_MAX CHILD_MAX COLL_WEIGHTS_MAX EXPR_NEST_MAX LINE_MAX
+  NGROUPS_MAX OPEN_MAX RE_DUP_MAX STREAM_MAX TZNAME_MAX)
+posixkeys=(_POSIX_CHILD_MAX _POSIX_LINK_MAX
+  _POSIX_MAX_CANON _POSIX_MAX_INPUT _POSIX_NAME_MAX _POSIX_NGROUPS_MAX
+  _POSIX_OPEN_MAX _POSIX_PATH_MAX _POSIX_PIPE_BUF _POSIX_SSIZE_MAX
+  _POSIX_STREAM_MAX _POSIX_TZNAME_MAX _POSIX_VERSION
+  POSIX2_BC_BASE_MAX POSIX2_BC_DIM_MAX POSIX2_BC_SCALE_MAX
+  POSIX2_BC_STRING_MAX POSIX2_COLL_WEIGHTS_MAX POSIX2_EXPR_NEST_MAX
+  POSIX2_LINE_MAX POSIX2_RE_DUP_MAX POSIX2_VERSION POSIX2_C_BIND
+  POSIX2_C_DEV POSIX2_FORT_DEV POSIX2_FORT_RUN POSIX2_LOCALEDEF
+  POSIX2_SW_DEV _XOPEN_VERSION)
+confkeys=(PATH GNU_LIBC_VERSION GNU_LIBPTHREAD_VERSION
+  LFS_CFLAGS LFS_LDFLAGS LFS_LIBS LFS_LINTFLAGS
+  LFS64_CFLAGS LFS64_LDFLAGS LFS64_LIBS LFS64_LINTFLAGS)
+pathkeys1=(PIPE_BUF _POSIX_CHOWN_RESTRICTED
+  _POSIX_NO_TRUNC _POSIX_VDISABLE)
+pathkeys2=(LINK_MAX MAX_CANON MAX_INPUT NAME_MAX PATH_MAX PIPE_BUF)
+mykeys=($syskeys $posixkeys $confkeys $pathkeys1 $pathkeys2)
+
 if [[ CURRENT -eq 2 ]]; then
-  _tags syswideconfig pathconfig standardsconfig confstring
+  _tags syswideconfig pathconfig standardsconfig confstring restconfig
+
+  allkeys=(${${(f)"$(getconf -a 2>/dev/null)"}%%[: ]*})
+  restkeys=(${allkeys:#(${(j.|.)~mykeys})})
 
   while _tags; do
     _requested -V syswideconfig expl 'systemwide configuration variables' \
-      compadd -S '' ARG_MAX BC_BASE_MAX BC_DIM_MAX BC_SCALE_MAX \
-          BC_STRING_MAX CHILD_MAX COLL_WEIGHTS_MAX EXPR_NEST_MAX LINE_MAX \
-	  NGROUPS_MAX OPEN_MAX RE_DUP_MAX STREAM_MAX TZNAME_MAX && ret=0
+      compadd -S '' $syskeys && ret=0
 
     _requested -V standardsconfig \
         expl 'system-standards configuration variables' \
-      compadd -S '' _POSIX_CHILD_MAX _POSIX_LINK_MAX \
-          _POSIX_MAX_CANON _POSIX_MAX_INPUT _POSIX_NAME_MAX _POSIX_NGROUPS_MAX \
-	  _POSIX_OPEN_MAX _POSIX_PATH_MAX _POSIX_PIPE_BUF _POSIX_SSIZE_MAX \
-	  _POSIX_STREAM_MAX _POSIX_TZNAME_MAX _POSIX_VERSION \
-	  POSIX2_BC_BASE_MAX POSIX2_BC_DIM_MAX POSIX2_BC_SCALE_MAX \
-	  POSIX2_BC_STRING_MAX POSIX2_COLL_WEIGHTS_MAX POSIX2_EXPR_NEST_MAX \
-	  POSIX2_LINE_MAX POSIX2_RE_DUP_MAX POSIX2_VERSION POSIX2_C_BIND \
-	  POSIX2_C_DEV POSIX2_FORT_DEV POSIX2_FORT_RUN POSIX2_LOCALEDEF \
-	  POSIX2_SW_DEV _XOPEN_VERSION && ret=0
+      compadd -S '' $posixkeys && ret=0
 
     _requested -V confstring \
         expl 'configuration-dependent string variables' \
-      compadd -S '' PATH GNU_LIBC_VERSION GNU_LIBPTHREAD_VERSION \
-          LFS_CFLAGS LFS_LDFLAGS LFS_LIBS LFS_LINTFLAGS \
-	  LFS64_CFLAGS LFS64_LDFLAGS LFS64_LIBS LFS64_LINTFLAGS \
-	  && ret=0
-
-    _requested -V confstring \
-        expl 'configuration-dependent string variables' \
-      compadd -S '' PATH GNU_LIBC_VERSION GNU_LIBPTHREAD_VERSION \
-          LFS_CFLAGS LFS_LDFLAGS LFS_LIBS LFS_LINTFLAGS \
-	  LFS64_CFLAGS LFS64_LDFLAGS LFS64_LIBS LFS64_LINTFLAGS \
-	  && ret=0
+      compadd -S '' $confkeys && ret=0
 
     _requested pathconfig &&
-        while _next_label -V pathconfig expl 'system path configuration variables'; do
-          compadd "$expl[@]" -S '' PIPE_BUF _POSIX_CHOWN_RESTRICTED \
-                                   _POSIX_NO_TRUNC _POSIX_VDISABLE && ret=0
-          compadd "$expl[@]" -S ' ' LINK_MAX MAX_CANON MAX_INPUT NAME_MAX \
-                                    PATH_MAX PIPE_BUF && ret=0
-        done
+    while _next_label -V pathconfig expl 'system path configuration variables'; do
+      compadd "$expl[@]" -S '' $pathkeys1 && ret=0
+      compadd "$expl[@]" -S ' ' $pathkeys2 && ret=0
+    done
+
+    if (( ${#restkeys} )); then
+      _requested -V restconfig \
+	expl 'remaining unclassified configuration variables' \
+	compadd -S '' $restkeys && ret=0
+    fi
+
     (( ret )) || return 0
   done
 else