0
0
mirror of https://github.com/vim/vim.git synced 2025-09-25 03:54:15 -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:
zeertzjq
2024-01-28 19:03:00 +01:00
committed by Christian Brabandt
parent cf8695d48c
commit bf321806bf
6 changed files with 15 additions and 11 deletions

View File

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

View File

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

View File

@@ -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;
} }
} }

View File

@@ -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);

View File

@@ -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!')

View File

@@ -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,
/**/ /**/