mirror of
https://github.com/vim/vim.git
synced 2025-09-24 03:44:06 -04:00
patch 9.1.0060: Recorded register cannot be translated using keytrans()
Problem: Recorded register cannot be translated using keytrans() when it involves character search (iddqd505) Solution: Record a K_IGNORE instead of a K_NOP (zeertzjq) related: #13916 closes: #13925 Signed-off-by: zeertzjq <zeertzjq@outlook.com> Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
committed by
Christian Brabandt
parent
cf8695d48c
commit
bf321806bf
@@ -13,7 +13,7 @@
|
||||
" 2024 Jan 23 by Vim Project (add :[23]match commands)
|
||||
" 2024 Jan 25 by Vim Project (WinNewPre autocommand)
|
||||
" 2024 Jan 27 by Vim Project (add foreach() function)
|
||||
" 2024 Jan 28 by Vim Project (improve line-continuation matching)
|
||||
" 2024 Jan 28 by Vim Project (improve line-continuation matching & string interpolation)
|
||||
" Version: 9.0-25
|
||||
" URL: http://www.drchip.org/astronaut/vim/index.html#SYNTAX_VIM
|
||||
" Automatically generated keyword lists: {{{1
|
||||
|
@@ -1339,12 +1339,12 @@ gotchars(char_u *chars, int len)
|
||||
}
|
||||
|
||||
/*
|
||||
* Record a <Nop> key.
|
||||
* Record an <Ignore> key.
|
||||
*/
|
||||
void
|
||||
gotchars_nop(void)
|
||||
gotchars_ignore(void)
|
||||
{
|
||||
char_u nop_buf[3] = { K_SPECIAL, KS_EXTRA, KE_NOP };
|
||||
char_u nop_buf[3] = { K_SPECIAL, KS_EXTRA, KE_IGNORE };
|
||||
gotchars(nop_buf, 3);
|
||||
}
|
||||
|
||||
@@ -3666,9 +3666,9 @@ vgetorpeek(int advance)
|
||||
#endif
|
||||
if (timedout && c == ESC)
|
||||
{
|
||||
// When recording there will be no timeout. Add a <Nop> after the ESC
|
||||
// to avoid that it forms a key code with following characters.
|
||||
gotchars_nop();
|
||||
// When recording there will be no timeout. Add an <Ignore> after the
|
||||
// ESC to avoid that it forms a key code with following characters.
|
||||
gotchars_ignore();
|
||||
}
|
||||
|
||||
--vgetc_busy;
|
||||
|
@@ -568,10 +568,10 @@ normal_cmd_get_more_chars(
|
||||
++no_mapping;
|
||||
// Vim may be in a different mode when the user types the next key,
|
||||
// but when replaying a recording the next key is already in the
|
||||
// typeahead buffer, so record a <Nop> before that to prevent the
|
||||
// vpeekc() above from applying wrong mappings when replaying.
|
||||
// typeahead buffer, so record an <Ignore> before that to prevent
|
||||
// the vpeekc() above from applying wrong mappings when replaying.
|
||||
++no_u_sync;
|
||||
gotchars_nop();
|
||||
gotchars_ignore();
|
||||
--no_u_sync;
|
||||
}
|
||||
}
|
||||
|
@@ -30,7 +30,7 @@ int typebuf_changed(int tb_change_cnt);
|
||||
int typebuf_typed(void);
|
||||
int typebuf_maplen(void);
|
||||
void del_typebuf(int len, int offset);
|
||||
void gotchars_nop(void);
|
||||
void gotchars_ignore(void);
|
||||
void ungetchars(int len);
|
||||
int save_typebuf(void);
|
||||
void save_typeahead(tasave_T *tp);
|
||||
|
@@ -868,6 +868,8 @@ func Test_replay_charsearch_omap()
|
||||
call timer_start(10, {-> feedkeys(",bar\<Esc>q", 't')})
|
||||
call feedkeys('qrct[', 'xt!')
|
||||
call assert_equal(',bar[blah]', getline(1))
|
||||
call assert_equal("ct[\<Ignore>,bar\<Esc>", @r)
|
||||
call assert_equal('ct[<Ignore>,bar<Esc>', keytrans(@r))
|
||||
undo
|
||||
call assert_equal('foo[blah]', getline(1))
|
||||
call feedkeys('@r', 'xt!')
|
||||
|
@@ -704,6 +704,8 @@ static char *(features[]) =
|
||||
|
||||
static int included_patches[] =
|
||||
{ /* Add new patch number below this line */
|
||||
/**/
|
||||
60,
|
||||
/**/
|
||||
59,
|
||||
/**/
|
||||
|
Reference in New Issue
Block a user