summaryrefslogtreecommitdiff
path: root/Src/Zle/zle_hist.c
diff options
context:
space:
mode:
authorPeter Stephenson <pws@users.sourceforge.net>2009-01-19 17:57:43 +0000
committerPeter Stephenson <pws@users.sourceforge.net>2009-01-19 17:57:43 +0000
commit46cdeb71b7c8dae7517ef832130049dc1e821cb6 (patch)
treec11b0fc3b9fef873d86fcfff1455d27b4dab295e /Src/Zle/zle_hist.c
parent8541ccb842c27c8e8ff14e4e0718f7b14efee0b2 (diff)
downloadzsh-46cdeb71b7c8dae7517ef832130049dc1e821cb6.tar.gz
zsh-46cdeb71b7c8dae7517ef832130049dc1e821cb6.zip
26366: add "isearch" keymap and "accept-search" functino
Diffstat (limited to 'Src/Zle/zle_hist.c')
-rw-r--r--Src/Zle/zle_hist.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/Src/Zle/zle_hist.c b/Src/Zle/zle_hist.c
index c4dad7617..aec847ec6 100644
--- a/Src/Zle/zle_hist.c
+++ b/Src/Zle/zle_hist.c
@@ -49,6 +49,10 @@ ZLE_STRING_T previous_search = NULL;
/**/
int previous_search_len = 0;
+/* Local keymap in isearch mode */
+
+/**/
+Keymap isearch_keymap;
/*** History text manipulation utilities ***/
@@ -1141,6 +1145,8 @@ doisearch(char **args, int dir, int pattern)
if (!(he = quietgethist(hl)))
return;
+ selectlocalmap(isearch_keymap);
+
clearlist = 1;
if (*args) {
@@ -1572,6 +1578,8 @@ doisearch(char **args, int dir, int pattern)
feep = 1;
else
goto ins;
+ } else if (cmd == Th(z_acceptsearch)) {
+ break;
} else {
if(cmd == Th(z_selfinsertunmeta)) {
fixunmeta();
@@ -1640,6 +1648,8 @@ doisearch(char **args, int dir, int pattern)
*/
if (savekeys >= 0 && kungetct > savekeys)
kungetct = savekeys;
+
+ selectlocalmap(NULL);
}
static Histent