diff options
author | Sven Wischnowsky <wischnow@users.sourceforge.net> | 2000-10-11 10:57:40 +0000 |
---|---|---|
committer | Sven Wischnowsky <wischnow@users.sourceforge.net> | 2000-10-11 10:57:40 +0000 |
commit | 5d8adbee0753795e7903b40847e17c879766dbf7 (patch) | |
tree | 5aad6d5536a3d9d0d0131cee2ba497bb5f8e7b3f /Src/Zle/complist.c | |
parent | e1fb97ee440f41014bb621f588ac04011280ddbe (diff) | |
download | zsh-5d8adbee0753795e7903b40847e17c879766dbf7.tar.gz zsh-5d8adbee0753795e7903b40847e17c879766dbf7.tar.xz zsh-5d8adbee0753795e7903b40847e17c879766dbf7.zip |
make user defined completion widgets leave menu selection without accepting the currently selected match (12959)
Diffstat (limited to 'Src/Zle/complist.c')
-rw-r--r-- | Src/Zle/complist.c | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/Src/Zle/complist.c b/Src/Zle/complist.c index 7c2fdfe57..a7dbf6412 100644 --- a/Src/Zle/complist.c +++ b/Src/Zle/complist.c @@ -2237,7 +2237,11 @@ domenuselect(Hookdef dummy, Chdata dat) continue; } else { ungetkeycmd(); - acc = 1; + if (cmd->widget && (cmd->widget->flags & WIDGET_NCOMP)) { + acc = 0; + broken = 2; + } else + acc = 1; break; } do_single(**p); @@ -2260,6 +2264,7 @@ domenuselect(Hookdef dummy, Chdata dat) menucmp = 2; showinglist = -2; minfo.asked = 0; + zrefresh(); } if (!noselect && (!dat || acc)) { showinglist = -2; @@ -2271,7 +2276,8 @@ domenuselect(Hookdef dummy, Chdata dat) mlbeg = -1; fdat = NULL; - return ((dat && !broken) ? (acc ? 1 : 2) : (!noselect ^ acc)); + return (broken == 2 ? 3 : + ((dat && !broken) ? (acc ? 1 : 2) : (!noselect ^ acc))); } /* The widget function. */ |