]> granicus.if.org Git - vim/commitdiff
patch 7.4.1564 v7.4.1564
authorBram Moolenaar <Bram@vim.org>
Tue, 15 Mar 2016 11:36:08 +0000 (12:36 +0100)
committerBram Moolenaar <Bram@vim.org>
Tue, 15 Mar 2016 11:36:08 +0000 (12:36 +0100)
Problem:    An empty list in function() causes an error.
Solution:   Handle an empty list like there is no list of arguments.

src/eval.c
src/testdir/test_partial.vim
src/version.c

index 3040e93d01a41d24bfd2d06bf852ef5245ad7d71..eadb802b3046ec263fd63d7bfd77c5377870f26d 100644 (file)
@@ -11786,6 +11786,10 @@ f_function(typval_T *argvars, typval_T *rettv)
        EMSG2(_("E700: Unknown function: %s"), s);
     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];
@@ -11808,10 +11812,6 @@ f_function(typval_T *argvars, typval_T *rettv)
 
        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) */
@@ -11824,27 +11824,38 @@ f_function(typval_T *argvars, typval_T *rettv)
            else
                /* function(name, [args]) */
                arg_idx = 1;
-           if (dict_idx > 0 && (argvars[dict_idx].v_type != VAR_DICT
-                                    || argvars[dict_idx].vval.v_dict == NULL))
+           if (dict_idx > 0)
            {
-               EMSG(_("E922: expected a dict"));
-               vim_free(name);
-               return;
+               if (argvars[dict_idx].v_type != VAR_DICT)
+               {
+                   EMSG(_("E922: expected a dict"));
+                   vim_free(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))
+           if (arg_idx > 0)
            {
-               EMSG(_("E923: Second argument of function() must be a list or a dict"));
-               vim_free(name);
-               return;
+               if (argvars[arg_idx].v_type != VAR_LIST)
+               {
+                   EMSG(_("E923: Second argument of function() must be a list or a dict"));
+                   vim_free(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 *)alloc_clear(sizeof(partial_T));
 
-           pt = (partial_T *)alloc_clear(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;
 
index 998b232206b1c037e1be71e0a5429f0524a1c2ca..b1a52db03ba64bc68319fc21ee24fdeb850a8012 100644 (file)
@@ -19,6 +19,9 @@ func Test_partial_args()
   call assert_equal("foo/bar/xxx", Cb("xxx"))
   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])
   call assert_equal([1, 2, 3], sort([3, 1, 2], Sort))
   let Sort = function('MySort', [0])
@@ -34,10 +37,16 @@ func Test_partial_dict()
   let Cb = function('MyDictFunc', ["foo", "bar"], dict)
   call assert_equal("hello/foo/bar", Cb())
   call assert_fails('Cb("xxx")', 'E492:')
+
   let Cb = function('MyDictFunc', ["foo"], dict)
   call assert_equal("hello/foo/xxx", Cb("xxx"))
   call assert_fails('Cb()', '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', dict)
   call assert_equal("hello/xxx/yyy", Cb("xxx", "yyy"))
-  call assert_fails('Cb()', 'E492:')
+  call assert_fails('Cb("fff")', 'E492:')
 endfunc
index 50d20f10034639839c5332c2fc6f33a240ce76d2..3cab68979451f272ce46d0f3d9efaddd5b036cf7 100644 (file)
@@ -743,6 +743,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1564,
 /**/
     1563,
 /**/