From d58c1780fd6c528ee953a44f7739ce0021ac26b5 Mon Sep 17 00:00:00 2001 From: Bart Schaefer Date: Sun, 6 May 2001 22:35:08 +0000 Subject: Improve handling of b/n/s subscript flags. --- Completion/Zsh/Context/_subscript | 26 +++++++++++++++++++++++++- 1 file changed, 25 insertions(+), 1 deletion(-) diff --git a/Completion/Zsh/Context/_subscript b/Completion/Zsh/Context/_subscript index 83cacc9af..bca521714 100644 --- a/Completion/Zsh/Context/_subscript +++ b/Completion/Zsh/Context/_subscript @@ -8,15 +8,39 @@ if [[ "$1" = -q ]]; then shift fi -compset -P '\([^\)]##\)' # remove subscript flags +compset -P '\(([^\(\)]|*\(*\)*)##\)' # remove subscript flags if [[ "$PREFIX" = :* ]]; then _wanted characters expl 'character class' \ compadd -p: -S ':]' alnum alpha blank cntrl digit graph \ lower print punct space upper xdigit elif compset -P '\('; then + local match compset -S '\)*' + if [[ $PREFIX = (#b)*([bns])(?|)(*) ]]; then + local f=$match[1] d=$match[2] e=$match[2] v=$match[3] + [[ $f = s && ${(Pt)${compstate[parameter]}} != scalar ]] && return 1 + if [[ -z $d ]]; then + _message 'delimiter' + return + else + case $d in + (\() e=\);; + (\[) e=\];; + (\{) e=\};; + esac + if [[ $v != *$e* ]]; then + case $f in + (s) _message 'separator string';; + (b|n) [[ $v = <-># ]] && _message 'number' || return 1;; + esac + [[ -n $v && $SUFFIX$ISUFFIX != *$e* ]] && _message 'delimiter' + return 0 + fi + fi + fi + case ${(Pt)${compstate[parameter]}} in assoc*) flags=( '(R k K i I)r[any one value matched by subscript as pattern]' -- cgit 1.4.1