From d6a6b4ff3a681dd72508aad21eb8ebe34147bc5e Mon Sep 17 00:00:00 2001 From: Oliver Kiddle Date: Tue, 27 Sep 2016 21:32:01 +0200 Subject: 39369 (tweaked cf 39371): when calling an internal widget, set bindk because some widgets use it to determine how they should act --- Src/Zle/zle_thingy.c | 4 ++++ 1 file changed, 4 insertions(+) (limited to 'Src/Zle') diff --git a/Src/Zle/zle_thingy.c b/Src/Zle/zle_thingy.c index 910715491..505aea065 100644 --- a/Src/Zle/zle_thingy.c +++ b/Src/Zle/zle_thingy.c @@ -756,6 +756,10 @@ bin_zle_call(char *name, char **args, UNUSED(Options ops), UNUSED(char func)) } t = rthingy(wname); + /* for internal widgets we set bindk except for when getting + * a vi range to detect a repeated key */ + setbindk = setbindk || + (t->widget && (t->widget->flags & (WIDGET_INT | ZLE_VIOPER)) == WIDGET_INT)); ret = execzlefunc(t, args, setbindk); unrefthingy(t); if (saveflag) -- cgit 1.4.1