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 23 by Vim Project (add :[23]match commands)
|
||||||
" 2024 Jan 25 by Vim Project (WinNewPre autocommand)
|
" 2024 Jan 25 by Vim Project (WinNewPre autocommand)
|
||||||
" 2024 Jan 27 by Vim Project (add foreach() function)
|
" 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
|
" Version: 9.0-25
|
||||||
" URL: http://www.drchip.org/astronaut/vim/index.html#SYNTAX_VIM
|
" URL: http://www.drchip.org/astronaut/vim/index.html#SYNTAX_VIM
|
||||||
" Automatically generated keyword lists: {{{1
|
" Automatically generated keyword lists: {{{1
|
||||||
|
@@ -1339,12 +1339,12 @@ gotchars(char_u *chars, int len)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Record a <Nop> key.
|
* Record an <Ignore> key.
|
||||||
*/
|
*/
|
||||||
void
|
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);
|
gotchars(nop_buf, 3);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -3666,9 +3666,9 @@ vgetorpeek(int advance)
|
|||||||
#endif
|
#endif
|
||||||
if (timedout && c == ESC)
|
if (timedout && c == ESC)
|
||||||
{
|
{
|
||||||
// When recording there will be no timeout. Add a <Nop> after the ESC
|
// When recording there will be no timeout. Add an <Ignore> after the
|
||||||
// to avoid that it forms a key code with following characters.
|
// ESC to avoid that it forms a key code with following characters.
|
||||||
gotchars_nop();
|
gotchars_ignore();
|
||||||
}
|
}
|
||||||
|
|
||||||
--vgetc_busy;
|
--vgetc_busy;
|
||||||
|
@@ -568,10 +568,10 @@ normal_cmd_get_more_chars(
|
|||||||
++no_mapping;
|
++no_mapping;
|
||||||
// Vim may be in a different mode when the user types the next key,
|
// 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
|
// but when replaying a recording the next key is already in the
|
||||||
// typeahead buffer, so record a <Nop> before that to prevent the
|
// typeahead buffer, so record an <Ignore> before that to prevent
|
||||||
// vpeekc() above from applying wrong mappings when replaying.
|
// the vpeekc() above from applying wrong mappings when replaying.
|
||||||
++no_u_sync;
|
++no_u_sync;
|
||||||
gotchars_nop();
|
gotchars_ignore();
|
||||||
--no_u_sync;
|
--no_u_sync;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -30,7 +30,7 @@ int typebuf_changed(int tb_change_cnt);
|
|||||||
int typebuf_typed(void);
|
int typebuf_typed(void);
|
||||||
int typebuf_maplen(void);
|
int typebuf_maplen(void);
|
||||||
void del_typebuf(int len, int offset);
|
void del_typebuf(int len, int offset);
|
||||||
void gotchars_nop(void);
|
void gotchars_ignore(void);
|
||||||
void ungetchars(int len);
|
void ungetchars(int len);
|
||||||
int save_typebuf(void);
|
int save_typebuf(void);
|
||||||
void save_typeahead(tasave_T *tp);
|
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 timer_start(10, {-> feedkeys(",bar\<Esc>q", 't')})
|
||||||
call feedkeys('qrct[', 'xt!')
|
call feedkeys('qrct[', 'xt!')
|
||||||
call assert_equal(',bar[blah]', getline(1))
|
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
|
undo
|
||||||
call assert_equal('foo[blah]', getline(1))
|
call assert_equal('foo[blah]', getline(1))
|
||||||
call feedkeys('@r', 'xt!')
|
call feedkeys('@r', 'xt!')
|
||||||
|
@@ -704,6 +704,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
60,
|
||||||
/**/
|
/**/
|
||||||
59,
|
59,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user