]> granicus.if.org Git - vim/commitdiff
patch 8.2.1290: Vim9: cannot replace a global function v8.2.1290
authorBram Moolenaar <Bram@vim.org>
Sat, 25 Jul 2020 13:41:11 +0000 (15:41 +0200)
committerBram Moolenaar <Bram@vim.org>
Sat, 25 Jul 2020 13:41:11 +0000 (15:41 +0200)
Problem:    Vim9: cannot replace a global function.
Solution:   Allow for "!" on a global function. (closes #6524)  Also fix that
            :delfunc on a :def function only made it empty.

src/testdir/test_vim9_script.vim
src/userfunc.c
src/version.c

index 3e2ced0a93f3b152135534748e1451e93628727b..f7d195ea834c43b3f862cf23247607e9556ee775 100644 (file)
@@ -468,6 +468,54 @@ def Test_delfunction()
       'enddef',
       'DoThat()',
       ], 'E1084:')
+
+  # Check that global :def function can be replaced and deleted
+  let lines =<< trim END
+      vim9script
+      def g:Global(): string
+        return "yes"
+      enddef
+      assert_equal("yes", g:Global())
+      def! g:Global(): string
+        return "no"
+      enddef
+      assert_equal("no", g:Global())
+      delfunc g:Global
+      assert_false(exists('*g:Global'))
+  END
+  CheckScriptSuccess(lines)
+
+  # Check that global function can be replaced by a :def function and deleted
+  lines =<< trim END
+      vim9script
+      func g:Global()
+        return "yes"
+      endfunc
+      assert_equal("yes", g:Global())
+      def! g:Global(): string
+        return "no"
+      enddef
+      assert_equal("no", g:Global())
+      delfunc g:Global
+      assert_false(exists('*g:Global'))
+  END
+  CheckScriptSuccess(lines)
+
+  # Check that global :def function can be replaced by a function and deleted
+  lines =<< trim END
+      vim9script
+      def g:Global(): string
+        return "yes"
+      enddef
+      assert_equal("yes", g:Global())
+      func! g:Global()
+        return "no"
+      endfunc
+      assert_equal("no", g:Global())
+      delfunc g:Global
+      assert_false(exists('*g:Global'))
+  END
+  CheckScriptSuccess(lines)
 enddef
 
 func Test_wrong_type()
index bf026d85792802d8603fea00f70e264e690a8229..3e566f334a741304a33181d1b92101e15a838358 100644 (file)
@@ -1148,6 +1148,8 @@ func_clear_free(ufunc_T *fp, int force)
     func_clear(fp, force);
     if (force || fp->uf_dfunc_idx == 0)
        func_free(fp, force);
+    else
+       fp->uf_flags |= FC_DEAD;
 }
 
 
@@ -2557,12 +2559,6 @@ def_function(exarg_T *eap, char_u *name_arg)
     char_u     *heredoc_trimmed = NULL;
     int                vim9script = in_vim9script();
 
-    if (vim9script && eap->forceit)
-    {
-       emsg(_(e_nobang));
-       return NULL;
-    }
-
     /*
      * ":function" without argument: list functions.
      */
@@ -2732,6 +2728,13 @@ def_function(exarg_T *eap, char_u *name_arg)
     }
     p = skipwhite(p + 1);
 
+    // In Vim9 script only global functions can be redefined.
+    if (vim9script && eap->forceit && !is_global)
+    {
+       emsg(_(e_nobang));
+       goto ret_free;
+    }
+
     ga_init2(&newlines, (int)sizeof(char_u *), 3);
 
     if (!eap->skip && name_arg == NULL)
index 0bd3cb20a3184e76e995e0c4ec00ec90e6c51251..20365a0a4530f37ce6dbd94850dae02862fd523a 100644 (file)
@@ -754,6 +754,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1290,
 /**/
     1289,
 /**/