aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJames McCoy <jamessan@jamessan.com>2016-09-30 08:25:15 -0400
committerJames McCoy <jamessan@jamessan.com>2016-09-30 08:25:15 -0400
commitc8b6ec2e6a8599203b4cff762f148f62464d9725 (patch)
tree484c01f263fbeb2fc27b032c771fa1223cc039e7 /src
parent724675061c32ce8eaf658f9633e32510a5f23b5d (diff)
parent3a59b04c1997a697c3428bcfcf4fa9e875e718dd (diff)
downloadrneovim-c8b6ec2e6a8599203b4cff762f148f62464d9725.tar.gz
rneovim-c8b6ec2e6a8599203b4cff762f148f62464d9725.tar.bz2
rneovim-c8b6ec2e6a8599203b4cff762f148f62464d9725.zip
Merge pull request #5409 from jamessan/toplevel-state
Correct logic for setting NormalState.toplevel
Diffstat (limited to 'src')
-rw-r--r--src/nvim/normal.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/src/nvim/normal.c b/src/nvim/normal.c
index d0a9d3aca7..c7c112200a 100644
--- a/src/nvim/normal.c
+++ b/src/nvim/normal.c
@@ -459,7 +459,7 @@ void normal_enter(bool cmdwin, bool noexmode)
normal_state_init(&state);
state.cmdwin = cmdwin;
state.noexmode = noexmode;
- state.toplevel = !cmdwin && !noexmode;
+ state.toplevel = (!cmdwin || cmdwin_result == 0) && !noexmode;
state_enter(&state.state);
}
@@ -1360,7 +1360,7 @@ static int normal_check(VimState *state)
// Dict internally somewhere.
// "may_garbage_collect" is reset in vgetc() which is invoked through
// do_exmode() and normal_cmd().
- may_garbage_collect = s->toplevel;
+ may_garbage_collect = !s->cmdwin && !s->noexmode;
// Update w_curswant if w_set_curswant has been set.
// Postponed until here to avoid computing w_virtcol too often.