mirror of
https://github.com/neovim/neovim.git
synced 2025-02-25 18:55:25 -06:00
Merge PR #5651 from mhinz/vv/exitval
This commit is contained in:
commit
d2e8c76dc2
@ -1383,6 +1383,9 @@ v:dying Normally zero. When a deadly signal is caught it's set to
|
|||||||
< Note: if another deadly signal is caught when v:dying is one,
|
< Note: if another deadly signal is caught when v:dying is one,
|
||||||
VimLeave autocommands will not be executed.
|
VimLeave autocommands will not be executed.
|
||||||
|
|
||||||
|
*v:exiting* *exiting-variable*
|
||||||
|
v:exiting The exit value Nvim will use. Before exiting, it is |v:null|.
|
||||||
|
|
||||||
*v:errmsg* *errmsg-variable*
|
*v:errmsg* *errmsg-variable*
|
||||||
v:errmsg Last given error message. It's allowed to set this variable.
|
v:errmsg Last given error message. It's allowed to set this variable.
|
||||||
Example: >
|
Example: >
|
||||||
|
@ -394,6 +394,7 @@ static struct vimvar {
|
|||||||
VV(VV_TYPE_DICT, "t_dict", VAR_NUMBER, VV_RO),
|
VV(VV_TYPE_DICT, "t_dict", VAR_NUMBER, VV_RO),
|
||||||
VV(VV_TYPE_FLOAT, "t_float", VAR_NUMBER, VV_RO),
|
VV(VV_TYPE_FLOAT, "t_float", VAR_NUMBER, VV_RO),
|
||||||
VV(VV_TYPE_BOOL, "t_bool", VAR_NUMBER, VV_RO),
|
VV(VV_TYPE_BOOL, "t_bool", VAR_NUMBER, VV_RO),
|
||||||
|
VV(VV_EXITING, "exiting", VAR_NUMBER, VV_RO),
|
||||||
};
|
};
|
||||||
#undef VV
|
#undef VV
|
||||||
|
|
||||||
@ -581,6 +582,7 @@ void eval_init(void)
|
|||||||
set_vim_var_special(VV_FALSE, kSpecialVarFalse);
|
set_vim_var_special(VV_FALSE, kSpecialVarFalse);
|
||||||
set_vim_var_special(VV_TRUE, kSpecialVarTrue);
|
set_vim_var_special(VV_TRUE, kSpecialVarTrue);
|
||||||
set_vim_var_special(VV_NULL, kSpecialVarNull);
|
set_vim_var_special(VV_NULL, kSpecialVarNull);
|
||||||
|
set_vim_var_special(VV_EXITING, kSpecialVarNull);
|
||||||
|
|
||||||
set_reg_var(0); // default for v:register is not 0 but '"'
|
set_reg_var(0); // default for v:register is not 0 but '"'
|
||||||
}
|
}
|
||||||
@ -17763,6 +17765,8 @@ void set_vcount(long count, long count1, int set_prevcount)
|
|||||||
/// @param[in] val Value to set to.
|
/// @param[in] val Value to set to.
|
||||||
void set_vim_var_nr(const VimVarIndex idx, const varnumber_T val)
|
void set_vim_var_nr(const VimVarIndex idx, const varnumber_T val)
|
||||||
{
|
{
|
||||||
|
clear_tv(&vimvars[idx].vv_tv);
|
||||||
|
vimvars[idx].vv_type = VAR_NUMBER;
|
||||||
vimvars[idx].vv_nr = val;
|
vimvars[idx].vv_nr = val;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -17772,6 +17776,8 @@ void set_vim_var_nr(const VimVarIndex idx, const varnumber_T val)
|
|||||||
/// @param[in] val Value to set to.
|
/// @param[in] val Value to set to.
|
||||||
void set_vim_var_special(const VimVarIndex idx, const SpecialVarValue val)
|
void set_vim_var_special(const VimVarIndex idx, const SpecialVarValue val)
|
||||||
{
|
{
|
||||||
|
clear_tv(&vimvars[idx].vv_tv);
|
||||||
|
vimvars[idx].vv_type = VAR_SPECIAL;
|
||||||
vimvars[idx].vv_special = val;
|
vimvars[idx].vv_special = val;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -134,6 +134,7 @@ typedef enum {
|
|||||||
VV_TYPE_DICT,
|
VV_TYPE_DICT,
|
||||||
VV_TYPE_FLOAT,
|
VV_TYPE_FLOAT,
|
||||||
VV_TYPE_BOOL,
|
VV_TYPE_BOOL,
|
||||||
|
VV_EXITING,
|
||||||
} VimVarIndex;
|
} VimVarIndex;
|
||||||
|
|
||||||
/// All recognized msgpack types
|
/// All recognized msgpack types
|
||||||
|
@ -557,6 +557,8 @@ void getout(int exitval)
|
|||||||
if (exmode_active)
|
if (exmode_active)
|
||||||
exitval += ex_exitval;
|
exitval += ex_exitval;
|
||||||
|
|
||||||
|
set_vim_var_nr(VV_EXITING, exitval);
|
||||||
|
|
||||||
/* Position the cursor on the last screen line, below all the text */
|
/* Position the cursor on the last screen line, below all the text */
|
||||||
ui_cursor_goto((int)Rows - 1, 0);
|
ui_cursor_goto((int)Rows - 1, 0);
|
||||||
|
|
||||||
|
46
test/functional/core/exit_spec.lua
Normal file
46
test/functional/core/exit_spec.lua
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
local helpers = require('test.functional.helpers')(after_each)
|
||||||
|
|
||||||
|
local command = helpers.command
|
||||||
|
local eval = helpers.eval
|
||||||
|
local eq, neq = helpers.eq, helpers.neq
|
||||||
|
local run = helpers.run
|
||||||
|
|
||||||
|
describe('v:exiting', function()
|
||||||
|
local cid
|
||||||
|
|
||||||
|
before_each(function()
|
||||||
|
helpers.clear()
|
||||||
|
cid = helpers.nvim('get_api_info')[1]
|
||||||
|
end)
|
||||||
|
|
||||||
|
it('defaults to v:null', function()
|
||||||
|
eq(1, eval('v:exiting is v:null'))
|
||||||
|
end)
|
||||||
|
|
||||||
|
it('is 0 on normal exit', function()
|
||||||
|
local function on_setup()
|
||||||
|
command('autocmd VimLeavePre * call rpcrequest('..cid..', "")')
|
||||||
|
command('autocmd VimLeave * call rpcrequest('..cid..', "")')
|
||||||
|
command('quit')
|
||||||
|
end
|
||||||
|
local function on_request()
|
||||||
|
eq(0, eval('v:exiting'))
|
||||||
|
return ''
|
||||||
|
end
|
||||||
|
run(on_request, nil, on_setup)
|
||||||
|
end)
|
||||||
|
|
||||||
|
it('is non-zero after :cquit', function()
|
||||||
|
local function on_setup()
|
||||||
|
command('autocmd VimLeavePre * call rpcrequest('..cid..', "")')
|
||||||
|
command('autocmd VimLeave * call rpcrequest('..cid..', "")')
|
||||||
|
command('cquit')
|
||||||
|
end
|
||||||
|
local function on_request()
|
||||||
|
neq(0, eval('v:exiting'))
|
||||||
|
return ''
|
||||||
|
end
|
||||||
|
run(on_request, nil, on_setup)
|
||||||
|
end)
|
||||||
|
|
||||||
|
end)
|
Loading…
Reference in New Issue
Block a user