diff options
author | Bram Moolenaar <Bram@vim.org> | 2013-02-26 19:36:15 +0100 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2013-02-26 19:36:15 +0100 |
commit | e17c2603355669a84813f454875d865f38172ff8 (patch) | |
tree | 56bebea0472c6d4a86797401e6b715775bbd4d73 /src | |
parent | f5e44a7e90a68f91da540fe9da8b62fb9e2aeea6 (diff) | |
download | vim-git-e17c2603355669a84813f454875d865f38172ff8.tar.gz |
updated for version 7.3.841v7.3.841
Problem: When a "cond ? one : two" expression has a subscript it is not
parsed correctly. (Andy Wokula)
Solution: Handle a subscript also when the type is unknown. (Christian
Brabandt)
Diffstat (limited to 'src')
-rw-r--r-- | src/eval.c | 10 | ||||
-rw-r--r-- | src/version.c | 2 |
2 files changed, 12 insertions, 0 deletions
diff --git a/src/eval.c b/src/eval.c index 480f214b4..d5a41fbce 100644 --- a/src/eval.c +++ b/src/eval.c @@ -5164,6 +5164,16 @@ eval7(arg, rettv, evaluate, want_string) ret = get_func_tv(s, len, rettv, arg, curwin->w_cursor.lnum, curwin->w_cursor.lnum, &len, evaluate, NULL); + + /* If evaluate is FALSE rettv->v_type was not set in + * get_func_tv, but it's needed in handle_subscript() to parse + * what follows. So set it here. */ + if (rettv->v_type == VAR_UNKNOWN && !evaluate && **arg == '(') + { + rettv->vval.v_string = vim_strsave(""); + rettv->v_type = VAR_FUNC; + } + /* Stop the expression evaluation when immediately * aborting on error, or when an interrupt occurred or * an exception was thrown but not caught. */ diff --git a/src/version.c b/src/version.c index 7c12188fe..6098591c0 100644 --- a/src/version.c +++ b/src/version.c @@ -729,6 +729,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 841, +/**/ 840, /**/ 839, |