]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.1.0890: %! item not allowed for 'rulerformat' v9.1.0890
authorYegappan Lakshmanan <yegappan@yahoo.com>
Wed, 27 Nov 2024 19:55:45 +0000 (20:55 +0100)
committerChristian Brabandt <cb@256bit.org>
Wed, 27 Nov 2024 19:55:45 +0000 (20:55 +0100)
Problem:  %! item not allowed for 'rulerformat'
          (yatinlala)
Solution: also allow to use %! for rulerformat option
          (Yegappan Lakshmanan)

fixes: #16091
closes: #16118

Signed-off-by: Yegappan Lakshmanan <yegappan@yahoo.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
runtime/doc/options.txt
runtime/doc/tags
runtime/doc/version9.txt
src/optionstr.c
src/testdir/dumps/Test_rulerformat_function.dump [new file with mode: 0644]
src/testdir/test_cmdline.vim
src/version.c

index 57d4af882f44a08f839e894ac24f370bddf2a632..e9f35e4f31ba619e2f52861cb24930a83c9800ab 100644 (file)
@@ -1,4 +1,4 @@
-*options.txt*  For Vim version 9.1.  Last change: 2024 Nov 24
+*options.txt*  For Vim version 9.1.  Last change: 2024 Nov 27
 
 
                  VIM REFERENCE MANUAL    by Bram Moolenaar
@@ -7870,6 +7870,7 @@ A jump table for the options with a short description can be found at |Q_op|.
        All fields except the {item} are optional.  A single percent sign can
        be given as "%%".
 
+                                                       *stl-%!*
        When the option starts with "%!" then it is used as an expression,
        evaluated and the result is used as the option value.  Example: >
                :set statusline=%!MyStatusLine()
index f33988020841ddc2e575bee6e14144a38592a333..68465cc091e542325a9d252d57a61fb5c1079af7 100644 (file)
@@ -10222,6 +10222,7 @@ state() builtin.txt     /*state()*
 static-tag     tagsrch.txt     /*static-tag*
 status-line    windows.txt     /*status-line*
 statusmsg-variable     eval.txt        /*statusmsg-variable*
+stl-%! options.txt     /*stl-%!*
 stl-%{ options.txt     /*stl-%{*
 str2float()    builtin.txt     /*str2float()*
 str2list()     builtin.txt     /*str2list()*
index 10e13f846ac24b29412e47d70ea8a570952f93b4..04d1a92bda642d10065ea4330a67a13608704586 100644 (file)
@@ -1,4 +1,4 @@
-*version9.txt*  For Vim version 9.1.  Last change: 2024 Nov 14
+*version9.txt*  For Vim version 9.1.  Last change: 2024 Nov 27
 
 
                  VIM REFERENCE MANUAL    by Bram Moolenaar
@@ -41607,6 +41607,8 @@ Changed~
   started via |:Tutor|
 - improve the |vimtutor| and add a second chapter for more advanced tips
 - allow to pass local Vim script variables to python interpreter |py3eval()|
+- |getwininfo()| now also returns the "leftcol" property for a window
+- 'rulerformat' now supports the |stl-%!| item
 
                                                        *added-9.2*
 Added ~
index 7c589e9173cfd66077482bb2c73972a30b78a151..d7cb38a3aad21a76c7e02da8e89352789406a411 100644 (file)
@@ -3330,7 +3330,12 @@ parse_statustabline_rulerformat(optset_T *args, int rulerformat)
        if (wid && *s == '(' && (errmsg = check_stl_option(p_ruf)) == NULL)
            ru_wid = wid;
        else
-           errmsg = check_stl_option(p_ruf);
+       {
+           // Validate the flags in 'rulerformat' only if it doesn't point to
+           // a custom function ("%!" flag).
+           if ((*varp)[1] != '!')
+               errmsg = check_stl_option(p_ruf);
+       }
     }
     // check 'statusline' or 'tabline' only if it doesn't start with "%!"
     else if (rulerformat || s[0] != '%' || s[1] != '!')
diff --git a/src/testdir/dumps/Test_rulerformat_function.dump b/src/testdir/dumps/Test_rulerformat_function.dump
new file mode 100644 (file)
index 0000000..a93fd32
--- /dev/null
@@ -0,0 +1,2 @@
+> +0&#ffffff0@39
+@22|1|0|,|2|0| @8|3|0|%| 
index 9aec012ed869dc8690f9f52ce0e9aefb3886a105..2fbce74ce0f210c443f1bec95edfa61715b065a7 100644 (file)
@@ -3867,6 +3867,27 @@ func Test_rulerformat_position()
   call StopVimInTerminal(buf)
 endfunc
 
+" Test for using "%!" in 'rulerformat' to use a function
+func Test_rulerformat_function()
+  CheckScreendump
+
+  let lines =<< trim END
+    func TestRulerFn()
+      return '10,20%=30%%'
+    endfunc
+  END
+  call writefile(lines, 'Xrulerformat_function', 'D')
+
+  let buf = RunVimInTerminal('-S Xrulerformat_function', #{rows: 2, cols: 40})
+  call term_sendkeys(buf, ":set ruler rulerformat=%!TestRulerFn()\<CR>")
+  call term_sendkeys(buf, ":redraw!\<CR>")
+  call term_wait(buf)
+  call VerifyScreenDump(buf, 'Test_rulerformat_function', {})
+
+  " clean up
+  call StopVimInTerminal(buf)
+endfunc
+
 func Test_getcompletion_usercmd()
   command! -nargs=* -complete=command TestCompletion echo <q-args>
 
index 2416ad19d6c106f41db5e7f4a61dae3c0ae1b790..243e348e9530fa26b0fb0899922f50dd6ffd2505 100644 (file)
@@ -704,6 +704,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    890,
 /**/
     889,
 /**/