Mercurial > vim
comparison src/eval.c @ 27199:d4f254d02d7c v8.2.4128
patch 8.2.4128: crash when method cannot be found
Commit: https://github.com/vim/vim/commit/64283d5e1f5487e2dbaa17d478e6eae040daa064
Author: Bram Moolenaar <Bram@vim.org>
Date: Tue Jan 18 10:37:29 2022 +0000
patch 8.2.4128: crash when method cannot be found
Problem: Crash when method cannot be found. (Christian J. Robinson)
Solution: Don't mix up pointer names.
author | Bram Moolenaar <Bram@vim.org> |
---|---|
date | Tue, 18 Jan 2022 11:45:04 +0100 |
parents | fe3da8b63dfa |
children | 73232ed49cf2 |
comparison
equal
deleted
inserted
replaced
27198:ebfde3a7b387 | 27199:d4f254d02d7c |
---|---|
4048 *arg = skipwhite(*arg); | 4048 *arg = skipwhite(*arg); |
4049 | 4049 |
4050 if (**arg != '(' && alias == NULL | 4050 if (**arg != '(' && alias == NULL |
4051 && (paren = vim_strchr(*arg, '(')) != NULL) | 4051 && (paren = vim_strchr(*arg, '(')) != NULL) |
4052 { | 4052 { |
4053 char_u *deref; | |
4054 | |
4053 *arg = name; | 4055 *arg = name; |
4054 *paren = NUL; | 4056 *paren = NUL; |
4055 name = deref_function_name(arg, &tofree, evalarg, verbose); | 4057 deref = deref_function_name(arg, &tofree, evalarg, verbose); |
4056 if (name == NULL) | 4058 if (deref == NULL) |
4057 { | 4059 { |
4058 *arg = name + len; | 4060 *arg = name + len; |
4059 ret = FAIL; | 4061 ret = FAIL; |
4060 } | 4062 } |
4061 else | 4063 else |
4064 { | |
4065 name = deref; | |
4062 len = STRLEN(name); | 4066 len = STRLEN(name); |
4067 } | |
4063 *paren = '('; | 4068 *paren = '('; |
4064 } | 4069 } |
4065 | 4070 |
4066 if (ret == OK) | 4071 if (ret == OK) |
4067 { | 4072 { |