summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2022-11-12 23:12:55 +0000
committerBram Moolenaar <Bram@vim.org>2022-11-12 23:12:55 +0000
commit28c56d501352bd98472d23667bade683877cadcc (patch)
treeed33b5fb6bfe7cda3db747824872ccf247afb6dd
parent1140b51e8369fed2321ce16bd4530a0952362126 (diff)
patch 9.0.0869: bogus error when string used after :elseifv9.0.0869
Problem: Bogus error when string used after :elseif. Solution: Do not consider a double quote the start of a comment. (closes #11534)
-rw-r--r--src/ex_eval.c3
-rw-r--r--src/testdir/test_vimscript.vim10
-rw-r--r--src/version.c2
3 files changed, 14 insertions, 1 deletions
diff --git a/src/ex_eval.c b/src/ex_eval.c
index e1c28899e1..68dc6d78ca 100644
--- a/src/ex_eval.c
+++ b/src/ex_eval.c
@@ -1173,7 +1173,8 @@ ex_else(exarg_T *eap)
{
// When skipping we ignore most errors, but a missing expression is
// wrong, perhaps it should have been "else".
- if (skip && ends_excmd(*eap->arg))
+ // A double quote here is the start of a string, not a comment.
+ if (skip && *eap->arg != '"' && ends_excmd(*eap->arg))
semsg(_(e_invalid_expression_str), eap->arg);
else
result = eval_to_bool(eap->arg, &error, eap, skip, FALSE);
diff --git a/src/testdir/test_vimscript.vim b/src/testdir/test_vimscript.vim
index 4aa6bca926..a23bac3d3e 100644
--- a/src/testdir/test_vimscript.vim
+++ b/src/testdir/test_vimscript.vim
@@ -192,6 +192,16 @@ func Test_if_while()
call assert_equal('ab3j3b2c2b1f1h1km', g:Xpath)
endfunc
+" Check double quote after skipped "elseif" does not give error E15
+func Test_skipped_elseif()
+ if "foo" ==? "foo"
+ let result = "first"
+ elseif "foo" ==? "foo"
+ let result = "second"
+ endif
+ call assert_equal('first', result)
+endfunc
+
"-------------------------------------------------------------------------------
" Test 4: :return {{{1
"-------------------------------------------------------------------------------
diff --git a/src/version.c b/src/version.c
index b16f86040a..10aa6dedcc 100644
--- a/src/version.c
+++ b/src/version.c
@@ -696,6 +696,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 869,
+/**/
868,
/**/
867,