]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.1.0557: moving in the buffer list doesn't work as documented v9.1.0557
authorLemonBoy <thatlemon@gmail.com>
Wed, 10 Jul 2024 18:20:48 +0000 (20:20 +0200)
committerChristian Brabandt <cb@256bit.org>
Wed, 10 Jul 2024 18:20:48 +0000 (20:20 +0200)
Problem:  moving in the buffer list doesn't work as documented
          (SenileFelineS)
Solution: Skip non-help buffers, when run from normal buffers, else
          only move from help buffers to the next help buffer (LemonBoy)

As explained in the help section for :bnext and :bprev the commands
should jump from help buffers to help buffers (and from regular ones to
regular ones).

fixes: #4478
closes: #15198

Signed-off-by: LemonBoy <thatlemon@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
runtime/doc/version9.txt
src/buffer.c
src/testdir/test_buffer.vim
src/version.c
src/vim.h

index df56215ea8e642245d64fc6b34d2e548873b3289..ed1cd4308166092afaddd8713c37532c504a5b18 100644 (file)
@@ -1,4 +1,4 @@
-*version9.txt*  For Vim version 9.1.  Last change: 2024 Jul 09
+*version9.txt*  For Vim version 9.1.  Last change: 2024 Jul 10
 
 
                  VIM REFERENCE MANUAL    by Bram Moolenaar
@@ -41580,6 +41580,9 @@ Changed~
 - provide information about function arguments using the get(func, "arity")
   function |get()-func|
 - |:bwipe| also wipes jumplist and tagstack data
+- moving in the buffer list using |:bnext| and similar commands, behaves as
+  documented and skips help buffers (if not run from a help buffer, else 
+  moves to the next/previous help buffer).
 
                                                        *added-9.2*
 Added ~
index 82957f986ab17f477d9adc43abcd79324137f43d..447ce76d49a328fd843e8408a48fa5a78e99d5c0 100644 (file)
@@ -50,6 +50,7 @@ static void   free_buffer(buf_T *);
 static void    free_buffer_stuff(buf_T *buf, int free_options);
 static int     bt_nofileread(buf_T *buf);
 static void    no_write_message_buf(buf_T *buf);
+static int     do_buffer_ext(int action, int start, int dir, int count, int flags);
 
 #ifdef UNIX
 # define dev_T dev_t
@@ -1106,13 +1107,30 @@ goto_buffer(
 {
     bufref_T   old_curbuf;
     int                save_sea = swap_exists_action;
+    int                skip_help_buf;
+
+    switch (eap->cmdidx)
+    {
+       case CMD_bnext:
+       case CMD_sbnext:
+       case CMD_bNext:
+       case CMD_bprevious:
+       case CMD_sbNext:
+       case CMD_sbprevious:
+           skip_help_buf = TRUE;
+           break;
+       default:
+           skip_help_buf = FALSE;
+           break;
+    }
 
     set_bufref(&old_curbuf, curbuf);
 
     if (swap_exists_action == SEA_NONE)
        swap_exists_action = SEA_DIALOG;
-    (void)do_buffer(*eap->cmd == 's' ? DOBUF_SPLIT : DOBUF_GOTO,
-                                            start, dir, count, eap->forceit);
+    (void)do_buffer_ext(*eap->cmd == 's' ? DOBUF_SPLIT : DOBUF_GOTO, start, dir, count,
+           (eap->forceit ? DOBUF_FORCEIT : 0) |
+           (skip_help_buf ? DOBUF_SKIPHELP : 0));
     if (swap_exists_action == SEA_QUIT && *eap->cmd == 's')
     {
 #if defined(FEAT_EVAL)
@@ -1343,8 +1361,11 @@ do_buffer_ext(
                if (buf == NULL)
                    buf = lastbuf;
            }
-           // don't count unlisted buffers
-           if (unload || buf->b_p_bl)
+           // Don't count unlisted buffers.
+           // Avoid non-help buffers if the starting point was a non-help buffer and
+           // vice-versa.
+           if (unload || (buf->b_p_bl
+                       && ((flags & DOBUF_SKIPHELP) == 0 || buf->b_help == bp->b_help)))
            {
                 --count;
                 bp = NULL;     // use this buffer as new starting point
index de088bd8efe3714ec01b8988d9c52bf99c5df1d8..757ba05784f79e72c50f0fa0e4f61e5bb7668f12 100644 (file)
@@ -126,6 +126,52 @@ func Test_buflist_browse()
   %bwipe!
 endfunc
 
+" Test for :bnext and :bprev when called from help and non-help buffers.
+func Test_bnext_bprev_help()
+  %bwipe!
+
+  e XHelp1 | set bt=help
+  let b1 = bufnr()
+  e Xbuf1
+  let b2 = bufnr()
+
+  " There's only one buffer of each type.
+  b XHelp1
+  bnext | call assert_equal(b1, bufnr())
+  bprev | call assert_equal(b1, bufnr())
+  b Xbuf1
+  bnext | call assert_equal(b2, bufnr())
+  bprev | call assert_equal(b2, bufnr())
+
+  " Add one more buffer of each type.
+  e XHelp2 | set bt=help
+  let b3 = bufnr()
+  e Xbuf2
+  let b4 = bufnr()
+
+  " Help buffer jumps to help buffer.
+  b XHelp1
+  bnext | call assert_equal(b3, bufnr())
+  bnext | call assert_equal(b1, bufnr())
+  bprev | call assert_equal(b3, bufnr())
+  bprev | call assert_equal(b1, bufnr())
+
+  " Regular buffer jumps to regular buffer.
+  b Xbuf1
+  bnext | call assert_equal(b4, bufnr())
+  bnext | call assert_equal(b2, bufnr())
+  bprev | call assert_equal(b4, bufnr())
+  bprev | call assert_equal(b2, bufnr())
+
+  " :brewind and :blast are not affected by the buffer type.
+  b Xbuf2
+  brewind | call assert_equal(b1, bufnr())
+  b XHelp1
+  blast   | call assert_equal(b4, bufnr())
+
+  %bwipe!
+endfunc
+
 " Test for :bdelete
 func Test_bdelete_cmd()
   %bwipe!
index 8a392cac651c7b2a17c2c04d9e3de9ea4fadc60c..9c076f86b069fb184b7c5325312778b6a2783ca6 100644 (file)
@@ -704,6 +704,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    557,
 /**/
     556,
 /**/
index a80f8448487d617e42392aa9d2d989b06635798f..1b64e0dd9ff9a7b75b699ce251280ae7ad534c51 100644 (file)
--- a/src/vim.h
+++ b/src/vim.h
@@ -1074,6 +1074,8 @@ extern int (*dyn_libintl_wputenv)(const wchar_t *envstring);
 // Values for flags argument of do_buffer()
 #define DOBUF_FORCEIT  1       // :cmd!
 #define DOBUF_NOPOPUP  2       // skip popup window buffers
+#define DOBUF_SKIPHELP 4       // skip or keep help buffers depending on b_help of the
+                               // starting buffer
 
 // Values for sub_cmd and which_pat argument for search_regcomp()
 // Also used for which_pat argument for searchit()