diff options
author | Bram Moolenaar <Bram@vim.org> | 2022-01-18 10:37:29 +0000 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2022-01-18 10:37:29 +0000 |
commit | 64283d5e1f5487e2dbaa17d478e6eae040daa064 (patch) | |
tree | 16ed445ad7f02151bf9b6bc19e64c7434169d511 /src/eval.c | |
parent | 78f60322f70ab91a32e572fbf3d97c792acbc83a (diff) |
patch 8.2.4128: crash when method cannot be foundv8.2.4128
Problem: Crash when method cannot be found. (Christian J. Robinson)
Solution: Don't mix up pointer names.
Diffstat (limited to 'src/eval.c')
-rw-r--r-- | src/eval.c | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/src/eval.c b/src/eval.c index bf65082e27..2b145e1a2a 100644 --- a/src/eval.c +++ b/src/eval.c @@ -4050,16 +4050,21 @@ eval_method( if (**arg != '(' && alias == NULL && (paren = vim_strchr(*arg, '(')) != NULL) { + char_u *deref; + *arg = name; *paren = NUL; - name = deref_function_name(arg, &tofree, evalarg, verbose); - if (name == NULL) + deref = deref_function_name(arg, &tofree, evalarg, verbose); + if (deref == NULL) { *arg = name + len; ret = FAIL; } else + { + name = deref; len = STRLEN(name); + } *paren = '('; } |