about summary refs log tree commit diff
path: root/Src
diff options
context:
space:
mode:
authorPeter Stephenson <p.w.stephenson@ntlworld.com>2013-09-25 18:42:59 +0100
committerPeter Stephenson <p.w.stephenson@ntlworld.com>2013-09-25 18:42:59 +0100
commit0ed3c5ccd0caef397eae0cce9529cda65bf31be5 (patch)
treefa0830d1b613bcde9721c0e2e190d449f28b308a /Src
parent60debf388f65849fc31b92982274cc984da74052 (diff)
downloadzsh-0ed3c5ccd0caef397eae0cce9529cda65bf31be5.tar.gz
zsh-0ed3c5ccd0caef397eae0cce9529cda65bf31be5.tar.xz
zsh-0ed3c5ccd0caef397eae0cce9529cda65bf31be5.zip
31765: If zle starts in viins mark as insertion.
This allows undo to work on everything entered.
Diffstat (limited to 'Src')
-rw-r--r--Src/Zle/zle_main.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/Src/Zle/zle_main.c b/Src/Zle/zle_main.c
index 756ff111a..5798e74b4 100644
--- a/Src/Zle/zle_main.c
+++ b/Src/Zle/zle_main.c
@@ -1188,6 +1188,13 @@ zleread(char **lp, char **rp, int flags, int context, char *init, char *finish)
     viinsbegin = 0;
     statusline = NULL;
     selectkeymap("main", 1);
+    /*
+     * If main is linked to the viins keymap, we need to register
+     * explicitly that we're now in vi insert mode as there's
+     * no user operation to indicate this.
+     */
+    if (openkeymap("main") == openkeymap("viins"))
+	viinsert(NULL);
     selectlocalmap(NULL);
     fixsuffix();
     if ((s = getlinknode(bufstack))) {