1
0
Fork 0
mirror of git://git.code.sf.net/p/zsh/code synced 2025-09-29 06:51:03 +02:00

zsh-workers/9787

This commit is contained in:
Tanaka Akira 2000-02-18 09:37:17 +00:00
parent 680a2161a4
commit a76b8ea1a5
2 changed files with 41 additions and 7 deletions

View file

@ -34,9 +34,9 @@ zstyle -s ":completion:${curcontext}:" substitute expr &&
# If the array is empty, store the original string again.
[[ -z "$exp" ]] && exp=("$word")
(( $#exp )) || exp=("$word")
subd="$exp"
subd=("$exp[@]")
# Now try globbing.
@ -47,14 +47,15 @@ zstyle -s ":completion:${curcontext}:" glob expr &&
# If we don't have any expansions or only one and that is the same
# as the original string, we let other completers run.
[[ $#exp -eq 0 ||
( $#exp -eq 1 && "$exp[1]" = "$word"(|\(N\)) ) ]] && return 1
(( $#exp )) || exp=("$subd[@]")
[[ $#exp -eq 1 && "$exp[1]" = "$word"(|\(N\)) ]] && return 1
# With subst-globs-only we bail out if there were no glob expansions,
# regardless of any substitutions
zstyle -s ":completion:${curcontext}:" subst-globs-only expr &&
[[ "${(e):-\$[$expr]}" -eq 1 ]] &&
[[ "$subd" = "$exp"(|\(N\)) ]] && return 1
[[ "${(e):-\$[$expr]}" -eq 1 && "$subd" = "$exp"(|\(N\)) ]] && return 1
# Now add as matches whatever the user requested.
@ -76,7 +77,7 @@ else
_requested all-expansions expl 'all expansions' "o:$word" &&
compadd "$expl[@]" -UQ -qS "$suf" - "$exp"
if _requested expansions; then
if [[ $#exp -gt 1 ]] && _requested expansions; then
if [[ "$sort" = menu ]]; then
_description expansions expl expansions "o:$word"
else

View file

@ -2819,6 +2819,39 @@ bslashquote(const char *s, char **e, int instring)
}
continue;
}
else if (*u == Tick || *u == Qtick) {
char c = *u++;
*v++ = c;
while (*u && *u != c)
*v++ = *u++;
*v++ = c;
if (!*u)
u--;
continue;
}
else if ((*u == String || *u == Qstring) &&
(u[1] == Inpar || u[1] == Inbrack || u[1] == Inbrace)) {
char c = (u[1] == Inpar ? Outpar : (u[1] == Inbrace ?
Outbrace : Outbrack));
char beg = *u;
int level = 0;
*v++ = *u++;
*v++ = *u++;
while (*u && (*u != c || level)) {
if (*u == beg)
level++;
else if (*u == c)
level--;
*v++ = *u++;
}
if (*u)
*v++ = *u;
else
u--;
continue;
}
else if (ispecial(*u) &&
((*u != '=' && *u != '~') ||
u == s ||