mirror of
				https://github.com/neovim/neovim.git
				synced 2025-10-25 20:07:09 +00:00 
			
		
		
		
	Merge pull request #20718 from neovim/backport-20716-to-release-0.8
[Backport release-0.8] vim-patch:9.0.0786: user command does not get number from :tab modifier
This commit is contained in:
		| @@ -79,6 +79,19 @@ function Test_cmdmods() | ||||
|   call assert_equal('silent!', g:mods) | ||||
|   tab MyCmd | ||||
|   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 | ||||
|   call assert_equal('topleft', g:mods) | ||||
|   to MyCmd | ||||
|   | ||||
| @@ -1237,8 +1237,18 @@ size_t add_win_cmd_modifers(char *buf, const cmdmod_T *cmod, bool *multi_mods) | ||||
|  | ||||
|   // :tab | ||||
|   if (cmod->cmod_tab > 0) { | ||||
|     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 | ||||
|   if (cmod->cmod_split & WSP_TOP) { | ||||
|     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); | ||||
|     } else { | ||||
|       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); | ||||
|     } | ||||
|   } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 zeertzjq
					zeertzjq