]> granicus.if.org Git - vim/commitdiff
patch 7.4.1015 v7.4.1015
authorBram Moolenaar <Bram@vim.org>
Thu, 31 Dec 2015 21:27:55 +0000 (22:27 +0100)
committerBram Moolenaar <Bram@vim.org>
Thu, 31 Dec 2015 21:27:55 +0000 (22:27 +0100)
Problem:    The column is not restored properly when the matchparen plugin is
            used in Insert mode and the cursor is after the end of the line.
Solution:   Set the curswant flag. (Christian Brabandt).  Also fix
            highlighting the match of the character before the cursor.

runtime/plugin/matchparen.vim
src/eval.c
src/version.c

index 2a5a16a57e82b4be03e4b1775484c5cdd6220582..873302efeea1ee7e387c92dd251bd7ec3ff9bd73 100644 (file)
@@ -1,6 +1,6 @@
 " Vim plugin for showing matching parens
 " Maintainer:  Bram Moolenaar <Bram@vim.org>
-" Last Change: 2014 Jul 19
+" Last Change: 2015 Dec 31
 
 " Exit quickly when:
 " - this plugin was already loaded (or disabled)
@@ -55,7 +55,7 @@ function! s:Highlight_Matching_Pair()
   let before = 0
 
   let text = getline(c_lnum)
-  let matches = matchlist(text, '\(.\)\=\%'.c_col.'c\(.\)')
+  let matches = matchlist(text, '\(.\)\=\%'.c_col.'c\(.\=\)')
   if empty(matches)
     let [c_before, c] = ['', '']
   else
index 8b972dfe781fba9b5683186ecab98d2a123306d4..1abb62059c94237815ed79206b57085c7643b66c 100644 (file)
@@ -10183,6 +10183,7 @@ f_cursor(argvars, rettv)
 #ifdef FEAT_VIRTUALEDIT
     long       coladd = 0;
 #endif
+    int                set_curswant = TRUE;
 
     rettv->vval.v_number = -1;
     if (argvars[1].v_type == VAR_UNKNOWN)
@@ -10198,7 +10199,10 @@ f_cursor(argvars, rettv)
        coladd = pos.coladd;
 #endif
        if (curswant >= 0)
+       {
            curwin->w_curswant = curswant - 1;
+           set_curswant = FALSE;
+       }
     }
     else
     {
@@ -10231,7 +10235,7 @@ f_cursor(argvars, rettv)
        mb_adjust_cursor();
 #endif
 
-    curwin->w_set_curswant = TRUE;
+    curwin->w_set_curswant = set_curswant;
     rettv->vval.v_number = 0;
 }
 
@@ -17524,7 +17528,10 @@ f_setpos(argvars, rettv)
                {
                    curwin->w_cursor = pos;
                    if (curswant >= 0)
+                   {
                        curwin->w_curswant = curswant - 1;
+                       curwin->w_set_curswant = FALSE;
+                   }
                    check_cursor();
                    rettv->vval.v_number = 0;
                }
index 699a7f6cb387a6c6c1b9f70159a7b1eb70c049eb..1e9dabd6b3abb98af65e6043781ee8b3328e4b3f 100644 (file)
@@ -741,6 +741,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1015,
 /**/
     1014,
 /**/