]> granicus.if.org Git - vim/commitdiff
patch 8.2.3091: Vim9: default argument expr. cannot use previous argument v8.2.3091
authorBram Moolenaar <Bram@vim.org>
Sat, 3 Jul 2021 16:56:53 +0000 (18:56 +0200)
committerBram Moolenaar <Bram@vim.org>
Sat, 3 Jul 2021 16:56:53 +0000 (18:56 +0200)
Problem:    Vim9: default argument expression cannot use previous argument
Solution:   Correct argument index. (closes #8496)

src/structs.h
src/testdir/test_vim9_func.vim
src/version.c
src/vim9compile.c

index d6f4988e7243969df64b582d1f23a7b140773124..be4082b93524a2f8139890ee495e29ba14674786 100644 (file)
@@ -1610,6 +1610,8 @@ typedef struct
     int                uf_dfunc_idx;   // only valid if uf_def_status is UF_COMPILED
     garray_T   uf_args;        // arguments, including optional arguments
     garray_T   uf_def_args;    // default argument expressions
+    int                uf_args_visible; // normally uf_args.ga_len, less when
+                                // compiling default argument expression.
 
     // for :def (for :function uf_ret_type is NULL)
     type_T     **uf_arg_types; // argument types (count == uf_args.ga_len)
index 4816cb6674afbc653f1840c343d78f5f9848430e..f4142ee851683424536f38a4c44f273b2b53689f 100644 (file)
@@ -452,6 +452,12 @@ def Test_call_default_args()
       MyDefaultThird('->', 'xx', v:none)->assert_equal('->xxbb')
       MyDefaultThird('->', v:none, 'yy')->assert_equal('->aayy')
       MyDefaultThird('->', 'xx', 'yy')->assert_equal('->xxyy')
+
+      def DefArg(mandatory: any, optional = mandatory): string
+        return mandatory .. optional
+      enddef
+      DefArg(1234)->assert_equal('12341234')
+      DefArg("ok")->assert_equal('okok')
   END
   CheckDefAndScriptSuccess(lines)
 
index 0cefeba32b30ea1e6362dc52b83331023ba108e1..5f07483581d1c7b89f1b4cfe42ce61430f919bdd 100644 (file)
@@ -755,6 +755,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    3091,
 /**/
     3090,
 /**/
index d07421571330ba6b58a3d6404521625cc94f5daf..88086cefd677ff8e01f79798a5b763ee177c5deb 100644 (file)
@@ -274,7 +274,7 @@ arg_exists(
 
     if (len == 0)
        return FAIL;
-    for (idx = 0; idx < cctx->ctx_ufunc->uf_args.ga_len; ++idx)
+    for (idx = 0; idx < cctx->ctx_ufunc->uf_args_visible; ++idx)
     {
        char_u *arg = FUNCARG(cctx->ctx_ufunc, idx);
 
@@ -9172,7 +9172,6 @@ compile_def_function(
     {
        int     count = ufunc->uf_def_args.ga_len;
        int     first_def_arg = ufunc->uf_args.ga_len - count;
-       int     uf_args_len = ufunc->uf_args.ga_len;
        int     i;
        char_u  *arg;
        int     off = STACK_FRAME_SIZE + (ufunc->uf_va_name != NULL ? 1 : 0);
@@ -9195,12 +9194,11 @@ compile_def_function(
                goto erret;
 
            // Make sure later arguments are not found.
-           ufunc->uf_args.ga_len = i;
+           ufunc->uf_args_visible = arg_idx;
 
            arg = ((char_u **)(ufunc->uf_def_args.ga_data))[i];
            r = compile_expr0(&arg, &cctx);
 
-           ufunc->uf_args.ga_len = uf_args_len;
            if (r == FAIL)
                goto erret;
 
@@ -9230,6 +9228,7 @@ compile_def_function(
        if (did_set_arg_type)
            set_function_type(ufunc);
     }
+    ufunc->uf_args_visible = ufunc->uf_args.ga_len;
 
     /*
      * Loop over all the lines of the function and generate instructions.