mirror of
https://github.com/neovim/neovim.git
synced 2025-02-25 18:55:25 -06:00
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.
346418c624
This commit is contained in:
parent
66922d89cc
commit
f90551b0e6
@ -9428,12 +9428,16 @@ static void f_function(typval_T *argvars, typval_T *rettv, FunPtr fptr)
|
|||||||
char_u *name;
|
char_u *name;
|
||||||
|
|
||||||
s = get_tv_string(&argvars[0]);
|
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);
|
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);
|
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) {
|
if (STRNCMP(s, "s:", 2) == 0 || STRNCMP(s, "<SID>", 5) == 0) {
|
||||||
char sid_buf[25];
|
char sid_buf[25];
|
||||||
int off = *s == 's' ? 2 : 5;
|
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) {
|
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) {
|
if (argvars[2].v_type != VAR_UNKNOWN) {
|
||||||
// function(name, [args], dict)
|
// function(name, [args], dict)
|
||||||
arg_idx = 1;
|
arg_idx = 1;
|
||||||
@ -9469,23 +9469,34 @@ static void f_function(typval_T *argvars, typval_T *rettv, FunPtr fptr)
|
|||||||
// function(name, [args])
|
// function(name, [args])
|
||||||
arg_idx = 1;
|
arg_idx = 1;
|
||||||
}
|
}
|
||||||
if (dict_idx > 0 && (argvars[dict_idx].v_type != VAR_DICT
|
if (dict_idx > 0) {
|
||||||
|| argvars[dict_idx].vval.v_dict == NULL)) {
|
if (argvars[dict_idx].v_type != VAR_DICT) {
|
||||||
EMSG(_("E922: expected a dict"));
|
EMSG(_("E922: expected a dict"));
|
||||||
xfree(name);
|
xfree(name);
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
if (argvars[dict_idx].vval.v_dict == NULL) {
|
||||||
|
dict_idx = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (arg_idx > 0 && (argvars[arg_idx].v_type != VAR_LIST
|
if (arg_idx > 0) {
|
||||||
|| argvars[arg_idx].vval.v_list == NULL)) {
|
if (argvars[arg_idx].v_type != VAR_LIST) {
|
||||||
EMSG(_("E923: Second argument of function() must be a list or a dict"));
|
EMSG(_("E923: Second argument of function() must be"
|
||||||
xfree(name);
|
"a list or a dict"));
|
||||||
return;
|
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 (pt != NULL) {
|
||||||
if (arg_idx > 0) {
|
if (arg_idx > 0) {
|
||||||
list_T *list = argvars[arg_idx].vval.v_list;
|
|
||||||
listitem_T *li;
|
listitem_T *li;
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
||||||
|
@ -19,6 +19,9 @@ func Test_partial_args()
|
|||||||
call assert_equal("foo/bar/xxx", Cb("xxx"))
|
call assert_equal("foo/bar/xxx", Cb("xxx"))
|
||||||
call assert_equal("foo/bar/yyy", call(Cb, ["yyy"]))
|
call assert_equal("foo/bar/yyy", call(Cb, ["yyy"]))
|
||||||
|
|
||||||
|
let Cb = function('MyFunc', [])
|
||||||
|
call assert_equal("a/b/c", Cb("a", "b", "c"))
|
||||||
|
|
||||||
let Sort = function('MySort', [1])
|
let Sort = function('MySort', [1])
|
||||||
call assert_equal([1, 2, 3], sort([3, 1, 2], Sort))
|
call assert_equal([1, 2, 3], sort([3, 1, 2], Sort))
|
||||||
let Sort = function('MySort', [0])
|
let Sort = function('MySort', [0])
|
||||||
@ -34,10 +37,15 @@ func Test_partial_dict()
|
|||||||
let Cb = function('MyDictFunc', ["foo", "bar"], dict)
|
let Cb = function('MyDictFunc', ["foo", "bar"], dict)
|
||||||
call assert_equal("hello/foo/bar", Cb())
|
call assert_equal("hello/foo/bar", Cb())
|
||||||
call assert_fails('Cb("xxx")', 'E492:')
|
call assert_fails('Cb("xxx")', 'E492:')
|
||||||
|
|
||||||
|
let Cb = function('MyDictFunc', [], dict)
|
||||||
|
call assert_equal("hello/ttt/xxx", Cb("ttt", "xxx"))
|
||||||
|
call assert_fails('Cb("yyy")', 'E492:')
|
||||||
|
|
||||||
let Cb = function('MyDictFunc', ["foo"], dict)
|
let Cb = function('MyDictFunc', ["foo"], dict)
|
||||||
call assert_equal("hello/foo/xxx", Cb("xxx"))
|
call assert_equal("hello/foo/xxx", Cb("xxx"))
|
||||||
call assert_fails('Cb()', 'E492:')
|
call assert_fails('Cb()', 'E492:')
|
||||||
let Cb = function('MyDictFunc', dict)
|
let Cb = function('MyDictFunc', dict)
|
||||||
call assert_equal("hello/xxx/yyy", Cb("xxx", "yyy"))
|
call assert_equal("hello/xxx/yyy", Cb("xxx", "yyy"))
|
||||||
call assert_fails('Cb()', 'E492:')
|
call assert_fails('Cb("fff")', 'E492:')
|
||||||
endfunc
|
endfunc
|
||||||
|
@ -878,7 +878,7 @@ static int included_patches[] = {
|
|||||||
1567,
|
1567,
|
||||||
// 1566 NA
|
// 1566 NA
|
||||||
1565,
|
1565,
|
||||||
// 1564,
|
1564,
|
||||||
1563,
|
1563,
|
||||||
// 1562 NA
|
// 1562 NA
|
||||||
// 1561 NA
|
// 1561 NA
|
||||||
|
Loading…
Reference in New Issue
Block a user