Merge pull request #5409 from jamessan/toplevel-state

Correct logic for setting NormalState.toplevel
This commit is contained in:
James McCoy 2016-09-30 08:25:15 -04:00
commit c8b6ec2e6a
No known key found for this signature in database
GPG Key ID: DFE691AE331BA3DB
2 changed files with 41 additions and 2 deletions

View File

@ -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.

View File

@ -0,0 +1,39 @@
local helpers = require('test.functional.helpers')(after_each)
local eq = helpers.eq
local eval = helpers.eval
local feed = helpers.feed
local clear = helpers.clear
local execute = helpers.execute
describe('v:count/v:count1', function()
before_each(function()
clear()
execute('map <silent> _x :<C-u>let g:count = "v:count=". v:count .", v:count1=". v:count1<CR>')
end)
describe('in cmdwin', function()
it('equal 0/1 when no count is given', function()
feed('q:_x')
eq('v:count=0, v:count1=1', eval('g:count'))
end)
it('equal 2/2 when count of 2 is given', function()
feed('q:2_x')
eq('v:count=2, v:count1=2', eval('g:count'))
end)
end)
describe('in normal mode', function()
it('equal 0/1 when no count is given', function()
feed('_x')
eq('v:count=0, v:count1=1', eval('g:count'))
end)
it('equal 2/2 when count of 2 is given', function()
feed('2_x')
eq('v:count=2, v:count1=2', eval('g:count'))
end)
end)
end)