aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorzeertzjq <zeertzjq@outlook.com>2024-11-28 09:02:10 +0800
committerGitHub <noreply@github.com>2024-11-28 09:02:10 +0800
commit5897994cb75b5b64a34017873119c87a75c42375 (patch)
tree7f579a1eebcd3e3487ebe5e58f33a94dc803b80d /src
parent76dcc7029b200e1d85024d7ba4a34c602e730dbe (diff)
downloadrneovim-5897994cb75b5b64a34017873119c87a75c42375.tar.gz
rneovim-5897994cb75b5b64a34017873119c87a75c42375.tar.bz2
rneovim-5897994cb75b5b64a34017873119c87a75c42375.zip
vim-patch:9.1.0890: %! item not allowed for 'rulerformat' (#31369)
Problem: %! item not allowed for 'rulerformat' (yatinlala) Solution: also allow to use %! for rulerformat option (Yegappan Lakshmanan) fixes: vim/vim#16091 closes: vim/vim#16118 https://github.com/vim/vim/commit/ac023e8baae65584537aa3c11494dad6f71770af Co-authored-by: Yegappan Lakshmanan <yegappan@yahoo.com>
Diffstat (limited to 'src')
-rw-r--r--src/nvim/options.lua1
-rw-r--r--src/nvim/optionstr.c6
2 files changed, 6 insertions, 1 deletions
diff --git a/src/nvim/options.lua b/src/nvim/options.lua
index bcb05b107b..84c90e44a7 100644
--- a/src/nvim/options.lua
+++ b/src/nvim/options.lua
@@ -8407,6 +8407,7 @@ return {
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: >vim
set statusline=%!MyStatusLine()
diff --git a/src/nvim/optionstr.c b/src/nvim/optionstr.c
index b47517b1a2..918443db9f 100644
--- a/src/nvim/optionstr.c
+++ b/src/nvim/optionstr.c
@@ -2191,7 +2191,11 @@ static const char *did_set_statustabline_rulerformat(optset_T *args, bool rulerf
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);
+ }
}
} else if (rulerformat || s[0] != '%' || s[1] != '!') {
// check 'statusline', 'winbar', 'tabline' or 'statuscolumn'