aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/eval.c
diff options
context:
space:
mode:
authorMichael Ennen <mike.ennen@gmail.com>2016-10-25 23:03:04 -0700
committerJames McCoy <jamessan@jamessan.com>2016-12-12 10:17:35 -0500
commitf90551b0e67c1389cb91dfedbe9a111c677e67e2 (patch)
tree78f60fc109fb4baf03dde888f1f103d500fc2f3f /src/nvim/eval.c
parent66922d89cce6ee381244d37f7c0c324cae815b45 (diff)
downloadrneovim-f90551b0e67c1389cb91dfedbe9a111c677e67e2.tar.gz
rneovim-f90551b0e67c1389cb91dfedbe9a111c677e67e2.tar.bz2
rneovim-f90551b0e67c1389cb91dfedbe9a111c677e67e2.zip
vim-patch:7.4.1564
Problem: An empty list in function() causes an error. Solution: Handle an empty list like there is no list of arguments. https://github.com/vim/vim/commit/346418c624f1bc7c04c98907134a2b284e6452dd
Diffstat (limited to 'src/nvim/eval.c')
-rw-r--r--src/nvim/eval.c51
1 files changed, 31 insertions, 20 deletions
diff --git a/src/nvim/eval.c b/src/nvim/eval.c
index 6dd0b8cb4a..36303d8313 100644
--- a/src/nvim/eval.c
+++ b/src/nvim/eval.c
@@ -9428,12 +9428,16 @@ static void f_function(typval_T *argvars, typval_T *rettv, FunPtr fptr)
char_u *name;
s = get_tv_string(&argvars[0]);
- if (s == NULL || *s == NUL || ascii_isdigit(*s))
+ if (s == NULL || *s == NUL || ascii_isdigit(*s)) {
EMSG2(_(e_invarg2), s);
- /* Don't check an autoload name for existence here. */
- else if (vim_strchr(s, AUTOLOAD_CHAR) == NULL && !function_exists(s))
+ } else if (vim_strchr(s, AUTOLOAD_CHAR) == NULL && !function_exists(s)) {
+ // Don't check an autoload name for existence here.
EMSG2(_("E700: Unknown function: %s"), s);
- else {
+ } else {
+ int dict_idx = 0;
+ int arg_idx = 0;
+ list_T *list = NULL;
+
if (STRNCMP(s, "s:", 2) == 0 || STRNCMP(s, "<SID>", 5) == 0) {
char sid_buf[25];
int off = *s == 's' ? 2 : 5;
@@ -9454,10 +9458,6 @@ static void f_function(typval_T *argvars, typval_T *rettv, FunPtr fptr)
}
if (argvars[1].v_type != VAR_UNKNOWN) {
- partial_T *pt;
- int dict_idx = 0;
- int arg_idx = 0;
-
if (argvars[2].v_type != VAR_UNKNOWN) {
// function(name, [args], dict)
arg_idx = 1;
@@ -9469,23 +9469,34 @@ static void f_function(typval_T *argvars, typval_T *rettv, FunPtr fptr)
// function(name, [args])
arg_idx = 1;
}
- if (dict_idx > 0 && (argvars[dict_idx].v_type != VAR_DICT
- || argvars[dict_idx].vval.v_dict == NULL)) {
- EMSG(_("E922: expected a dict"));
- xfree(name);
- return;
+ if (dict_idx > 0) {
+ if (argvars[dict_idx].v_type != VAR_DICT) {
+ EMSG(_("E922: expected a dict"));
+ xfree(name);
+ return;
+ }
+ if (argvars[dict_idx].vval.v_dict == NULL) {
+ dict_idx = 0;
+ }
}
- if (arg_idx > 0 && (argvars[arg_idx].v_type != VAR_LIST
- || argvars[arg_idx].vval.v_list == NULL)) {
- EMSG(_("E923: Second argument of function() must be a list or a dict"));
- xfree(name);
- return;
+ if (arg_idx > 0) {
+ if (argvars[arg_idx].v_type != VAR_LIST) {
+ EMSG(_("E923: Second argument of function() must be"
+ "a list or a dict"));
+ xfree(name);
+ return;
+ }
+ list = argvars[arg_idx].vval.v_list;
+ if (list == NULL || list->lv_len == 0) {
+ arg_idx = 0;
+ }
}
+ }
+ if (dict_idx > 0 || arg_idx > 0) {
+ partial_T *pt = (partial_T *)xcalloc(1, sizeof(partial_T));
- pt = (partial_T *)xcalloc(1, sizeof(partial_T));
if (pt != NULL) {
if (arg_idx > 0) {
- list_T *list = argvars[arg_idx].vval.v_list;
listitem_T *li;
int i = 0;