]> granicus.if.org Git - vim/commitdiff
updated for version 7.3.481 v7.3.481
authorBram Moolenaar <Bram@vim.org>
Wed, 28 Mar 2012 10:59:57 +0000 (12:59 +0200)
committerBram Moolenaar <Bram@vim.org>
Wed, 28 Mar 2012 10:59:57 +0000 (12:59 +0200)
Problem:    Changing 'virtualedit' in an operator function to "all" does not
            have the desired effect. (Aaron Bohannon)
Solution:   Save, reset and restore virtual_op when executing an operator
            function.

src/normal.c
src/version.c

index aa470e4f7577bd318a4d7f33ff4e77b68b0e3c24..a7301162bd2accf6b88c3b0c0f21bcf3c1430005 100644 (file)
@@ -2279,6 +2279,7 @@ op_function(oap)
 {
 #ifdef FEAT_EVAL
     char_u     *(argv[1]);
+    int                save_virtual_op = virtual_op;
 
     if (*p_opfunc == NUL)
        EMSG(_("E774: 'operatorfunc' is empty"));
@@ -2297,7 +2298,14 @@ op_function(oap)
            argv[0] = (char_u *)"line";
        else
            argv[0] = (char_u *)"char";
+
+       /* Reset virtual_op so that 'virtualedit' can be changed in the
+        * function. */
+       virtual_op = MAYBE;
+
        (void)call_func_retnr(p_opfunc, 1, argv, FALSE);
+
+       virtual_op = save_virtual_op;
     }
 #else
     EMSG(_("E775: Eval feature not available"));
index 2598aeba9ec19d24ddd45857871a9adaf64d8cc9..a1bd77c9336f5686ae95e081942c598679fc664f 100644 (file)
@@ -714,6 +714,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    481,
 /**/
     480,
 /**/