]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.1.1949: :stag does not use 'swichtbuf' option v9.1.1949
authorYegappan Lakshmanan <yegappan@yahoo.com>
Wed, 3 Dec 2025 19:22:13 +0000 (19:22 +0000)
committerChristian Brabandt <cb@256bit.org>
Wed, 3 Dec 2025 19:22:13 +0000 (19:22 +0000)
Problem:  :stag does not use 'swichtbuf' option, though the
          documentation states differently
          (Christian Brabandt)
Solution: Respect 'switchbuf' option (Yegappan Lakshmanan).

related: #18845
closes: #18856

Signed-off-by: Yegappan Lakshmanan <yegappan@yahoo.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
runtime/doc/windows.txt
src/tag.c
src/testdir/test_tagjump.vim
src/version.c

index 5b77055a65d63780ec55b7a48ad96325cddbf1d0..7b82486558dc4fb73c57716bddc94145bc62756f 100644 (file)
@@ -1,4 +1,4 @@
-*windows.txt*  For Vim version 9.1.  Last change: 2025 Nov 11
+*windows.txt*  For Vim version 9.1.  Last change: 2025 Dec 03
 
 
                  VIM REFERENCE MANUAL    by Bram Moolenaar
@@ -878,13 +878,15 @@ the buffer.  The result is that all buffers will use the 'encoding' encoding
                                                        *:sta* *:stag*
 :sta[g][!] [tagname]
                Does ":tag[!] [tagname]" and splits the window for the found
-               tag.  See also |:tag|.
+               tag.  Refer to 'switchbuf' to jump to a tag in a vertically
+               split window or a new tab page.  See also |:tag|.
 
 CTRL-W ]                                       *CTRL-W_]* *CTRL-W_CTRL-]*
 CTRL-W CTRL-]  Split current window in two.  Use identifier under cursor as a
                tag and jump to it in the new upper window.
                In Visual mode uses the Visually selected text as a tag.
-               Make new window N high.
+               Make new window N high.  Refer to 'switchbuf' to jump to a tag
+               in a vertically split window or a new tab page.
 
                                                        *CTRL-W_g]*
 CTRL-W g ]     Split current window in two.  Use identifier under cursor as a
index 23573fe88d29945a48047cbc409fa3a7ebba23de..60b38d156d2fb66e60123c3b959576e1cba073d7 100644 (file)
--- a/src/tag.c
+++ b/src/tag.c
@@ -3850,6 +3850,15 @@ jumpto_tag(
     if (getfile_result == GETFILE_UNUSED
                                  && (postponed_split || cmdmod.cmod_tab != 0))
     {
+       if (swb_flags & SWB_VSPLIT)
+           // If 'switchbuf' contains 'vsplit', then use a new vertically
+           // split window.
+           cmdmod.cmod_split |= WSP_VERT;
+
+       if (swb_flags & SWB_NEWTAB)
+           // If 'switchbuf' contains 'newtab', then use a new tabpage
+           cmdmod.cmod_tab = tabpage_index(curtab) + 1;
+
        if (win_split(postponed_split > 0 ? postponed_split : 0,
                                                postponed_split_flags) == FAIL)
        {
index 47618d077450696935a9ba51f3ff4c7aeb42532d..5ddaaadc27bdffacd1d7d6ff8070cafdb20aefa1 100644 (file)
@@ -144,6 +144,24 @@ func Test_tagjump_switchbuf()
   1tabnext | stag third
   call assert_equal(2, tabpagenr('$'))
   call assert_equal(3, line('.'))
+  tabonly
+
+  " use a vertically split window
+  enew | only
+  set switchbuf=vsplit
+  stag third
+  call assert_equal(2, winnr('$'))
+  call assert_equal(1, winnr())
+  call assert_equal(3, line('.'))
+  call assert_equal(['row', [['leaf', win_getid(1)], ['leaf', win_getid(2)]]], winlayout())
+
+  " jump to a tag in a new tabpage
+  enew | only
+  set switchbuf=newtab
+  stag second
+  call assert_equal(2, tabpagenr('$'))
+  call assert_equal(2, tabpagenr())
+  call assert_equal(2, line('.'))
 
   tabclose!
   enew | only
index b9c5409dc6e8bd53d4accc6108d74a7f3a2ddeec..186cddf80ef8c0e2efe7d3d340e5b3b8173333b5 100644 (file)
@@ -729,6 +729,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1949,
 /**/
     1948,
 /**/