vim-patch:9.0.0786: user command does not get number from :tab modifier

Problem:    User command does not get number from :tab modifier.
Solution:   Include the number. (closes vim/vim#11393, closes vim/vim#6901)
208567e9d7
(cherry picked from commit a43a46f1e6)
This commit is contained in:
zeertzjq 2022-10-18 20:13:11 +08:00 committed by github-actions[bot]
parent 6fe00190f0
commit 24769cf1b5
2 changed files with 25 additions and 2 deletions

View File

@ -79,6 +79,19 @@ function Test_cmdmods()
call assert_equal('silent!', g:mods) call assert_equal('silent!', g:mods)
tab MyCmd tab MyCmd
call assert_equal('tab', g:mods) call assert_equal('tab', g:mods)
0tab MyCmd
call assert_equal('0tab', g:mods)
tab split
tab MyCmd
call assert_equal('tab', g:mods)
1tab MyCmd
call assert_equal('1tab', g:mods)
tabprev
tab MyCmd
call assert_equal('tab', g:mods)
2tab MyCmd
call assert_equal('2tab', g:mods)
2tabclose
topleft MyCmd topleft MyCmd
call assert_equal('topleft', g:mods) call assert_equal('topleft', g:mods)
to MyCmd to MyCmd

View File

@ -1237,8 +1237,18 @@ size_t add_win_cmd_modifers(char *buf, const cmdmod_T *cmod, bool *multi_mods)
// :tab // :tab
if (cmod->cmod_tab > 0) { if (cmod->cmod_tab > 0) {
result += add_cmd_modifier(buf, "tab", multi_mods); int tabnr = cmod->cmod_tab - 1;
if (tabnr == tabpage_index(curtab)) {
// For compatibility, don't add a tabpage number if it is the same
// as the default number for :tab.
result += add_cmd_modifier(buf, "tab", multi_mods);
} else {
char tab_buf[NUMBUFLEN + 3];
snprintf(tab_buf, sizeof(tab_buf), "%dtab", tabnr);
result += add_cmd_modifier(buf, tab_buf, multi_mods);
}
} }
// :topleft // :topleft
if (cmod->cmod_split & WSP_TOP) { if (cmod->cmod_split & WSP_TOP) {
result += add_cmd_modifier(buf, "topleft", multi_mods); result += add_cmd_modifier(buf, "topleft", multi_mods);
@ -1308,7 +1318,7 @@ size_t uc_mods(char *buf, const cmdmod_T *cmod, bool quote)
result += add_cmd_modifier(buf, "verbose", &multi_mods); result += add_cmd_modifier(buf, "verbose", &multi_mods);
} else { } else {
char verbose_buf[NUMBUFLEN]; char verbose_buf[NUMBUFLEN];
snprintf(verbose_buf, NUMBUFLEN, "%dverbose", verbose_value); snprintf(verbose_buf, sizeof(verbose_buf), "%dverbose", verbose_value);
result += add_cmd_modifier(buf, verbose_buf, &multi_mods); result += add_cmd_modifier(buf, verbose_buf, &multi_mods);
} }
} }