feat(autocmd): populate v:event in RecordingLeave (#16828)

This commit is contained in:
Axel Dahlberg 2022-01-05 02:55:29 +01:00 committed by GitHub
parent a45b578dbe
commit f65b0d4236
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 46 additions and 8 deletions

View File

@ -840,6 +840,9 @@ RecordingLeave When a macro stops recording.
register.
|reg_recorded()| is only updated after this
event.
Sets these |v:event| keys:
regcontents
regname
*SessionLoadPost*
SessionLoadPost After loading the session file created using
the |:mksession| command.

View File

@ -915,10 +915,29 @@ int do_record(int c)
apply_autocmds(EVENT_RECORDINGENTER, NULL, NULL, false, curbuf);
}
} else { // stop recording
save_v_event_T save_v_event;
// Set the v:event dictionary with information about the recording.
dict_T *dict = get_v_event(&save_v_event);
// The recorded text contents.
p = get_recorded();
if (p != NULL) {
// Remove escaping for CSI and K_SPECIAL in multi-byte chars.
vim_unescape_csi(p);
(void)tv_dict_add_str(dict, S_LEN("regcontents"), (const char *)p);
}
// Name of requested register, or empty string for unnamed operation.
char buf[NUMBUFLEN+2];
buf[0] = (char)regname;
buf[1] = NUL;
(void)tv_dict_add_str(dict, S_LEN("regname"), buf);
// Get the recorded key hits. K_SPECIAL and CSI will be escaped, this
// needs to be removed again to put it in a register. exec_reg then
// adds the escaping back later.
apply_autocmds(EVENT_RECORDINGLEAVE, NULL, NULL, false, curbuf);
restore_v_event(dict, &save_v_event);
reg_recorded = reg_recording;
reg_recording = 0;
if (ui_has(kUIMessages)) {
@ -926,13 +945,9 @@ int do_record(int c)
} else {
msg("");
}
p = get_recorded();
if (p == NULL) {
retval = FAIL;
} else {
// Remove escaping for CSI and K_SPECIAL in multi-byte chars.
vim_unescape_csi(p);
// We don't want to change the default register here, so save and
// restore the current register name.
old_y_previous = y_previous;

View File

@ -11,7 +11,7 @@ describe('RecordingEnter', function()
source_vim [[
let g:recorded = 0
autocmd RecordingEnter * let g:recorded += 1
execute "normal! qqyyq"
call feedkeys("qqyyq", 'xt')
]]
eq(1, eval('g:recorded'))
end)
@ -20,7 +20,7 @@ describe('RecordingEnter', function()
source_vim [[
let g:recording = ''
autocmd RecordingEnter * let g:recording = reg_recording()
execute "normal! qqyyq"
call feedkeys("qqyyq", 'xt')
]]
eq('q', eval('g:recording'))
end)
@ -32,7 +32,7 @@ describe('RecordingLeave', function()
source_vim [[
let g:recorded = 0
autocmd RecordingLeave * let g:recorded += 1
execute "normal! qqyyq"
call feedkeys("qqyyq", 'xt')
]]
eq(1, eval('g:recorded'))
end)
@ -43,10 +43,30 @@ describe('RecordingLeave', function()
let g:recording = ''
autocmd RecordingLeave * let g:recording = reg_recording()
autocmd RecordingLeave * let g:recorded = reg_recorded()
execute "normal! qqyyq"
call feedkeys("qqyyq", 'xt')
]]
eq('q', eval 'g:recording')
eq('', eval 'g:recorded')
eq('q', eval 'reg_recorded()')
end)
it('populates v:event', function()
source_vim [[
let g:regname = ''
let g:regcontents = ''
autocmd RecordingLeave * let g:regname = v:event.regname
autocmd RecordingLeave * let g:regcontents = v:event.regcontents
call feedkeys("qqyyq", 'xt')
]]
eq('q', eval 'g:regname')
eq('yy', eval 'g:regcontents')
end)
it('resets v:event', function()
source_vim [[
autocmd RecordingLeave * let g:event = v:event
call feedkeys("qqyyq", 'xt')
]]
eq(0, eval 'len(v:event)')
end)
end)