From 8d2de4beaf79ab2273e2121d3209dd6825efabe6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Andr=C3=A9=20Tanner?= Date: Tue, 11 Jul 2017 23:19:22 +0200 Subject: Revert "vis: process aliased key sequences individually" This reverts commit 54ca598fcccff8844bfbe494cd3b325b2fea487f. The key handling functions are called too often. This for example causes problems for `r` (replace char) in combination with :langmap. --- vis.c | 14 ++------------ 1 file changed, 2 insertions(+), 12 deletions(-) (limited to 'vis.c') diff --git a/vis.c b/vis.c index 7596097..c8229dd 100644 --- a/vis.c +++ b/vis.c @@ -1159,22 +1159,12 @@ static void vis_keys_process(Vis *vis, size_t pos) { strcpy(vis->key_prev, vis->key_current); strncpy(vis->key_current, start, len); vis->key_current[len] = '\0'; - char *params_end = binding_end; - while (params_end) { - tmp = *params_end; - *params_end = '\0'; - end = (char*)binding->action->func(vis, binding_end, &binding->action->arg); - *params_end = tmp; - if (end) { - start = cur = end; - break; - } - params_end = (char*)vis_keys_next(vis, params_end); - } + end = (char*)binding->action->func(vis, binding_end, &binding->action->arg); if (!end) { end = start; break; } + start = cur = end; } else if (binding->alias) { buffer_remove(buf, start - buf->data, binding_end - start); buffer_insert0(buf, start - buf->data, binding->alias); -- cgit v1.2.3