]> granicus.if.org Git - vim/commitdiff
updated for version 7.3.111 v7.3.111
authorBram Moolenaar <Bram@vim.org>
Tue, 1 Feb 2011 17:01:11 +0000 (18:01 +0100)
committerBram Moolenaar <Bram@vim.org>
Tue, 1 Feb 2011 17:01:11 +0000 (18:01 +0100)
Problem:    Executing a :normal command in 'statusline' evaluation causes the
            cursor to move. (Dominique Pelle)
Solution:   When updating the cursor for 'cursorbind' allow the cursor beyond
            the end of the line.  When evaluating 'statusline' temporarily
            reset 'cursorbind'.

src/move.c
src/screen.c
src/version.c

index 447445b4612b28371fc4ea7ca57c7ea2662cd457..79df9285ada9b4cfde458ba44c1488d270e38586 100644 (file)
@@ -2846,6 +2846,7 @@ do_check_cursorbind()
     colnr_T    col =  curwin->w_cursor.col;
     win_T      *old_curwin = curwin;
     buf_T      *old_curbuf = curbuf;
+    int                restart_edit_save;
 # ifdef FEAT_VISUAL
     int                old_VIsual_select = VIsual_select;
     int                old_VIsual_active = VIsual_active;
@@ -2875,8 +2876,12 @@ do_check_cursorbind()
                curwin->w_cursor.lnum = line;
            curwin->w_cursor.col = col;
 
-           /* Make sure the cursor is in a valid position. */
+           /* Make sure the cursor is in a valid position.  Temporarily set
+            * "restart_edit" to allow the cursor to be beyond the EOL. */
+           restart_edit_save = restart_edit;
+           restart_edit = TRUE;
            check_cursor();
+           restart_edit = restart_edit_save;
 # ifdef FEAT_MBYTE
            /* Correct cursor for multi-byte character. */
            if (has_mbyte)
index 340dfd02feb2447b46d97b57fc0ef6c42929238c..1726fac82a36cb68d8c919ec441e11c35c4a6207 100644 (file)
@@ -6435,6 +6435,8 @@ win_redr_custom(wp, draw_ruler)
     struct     stl_hlrec hltab[STL_MAX_ITEM];
     struct     stl_hlrec tabtab[STL_MAX_ITEM];
     int                use_sandbox = FALSE;
+    win_T      *ewp;
+    int                p_crb_save;
 
     /* setup environment for the task at hand */
     if (wp == NULL)
@@ -6513,14 +6515,20 @@ win_redr_custom(wp, draw_ruler)
     if (maxwidth <= 0)
        return;
 
+    /* Temporarily reset 'cursorbind', we don't want a side effect from moving
+     * the cursor away and back. */
+    ewp = wp == NULL ? curwin : wp;
+    p_crb_save = ewp->w_p_crb;
+    ewp->w_p_crb = FALSE;
+
     /* Make a copy, because the statusline may include a function call that
      * might change the option value and free the memory. */
     stl = vim_strsave(stl);
-    width = build_stl_str_hl(wp == NULL ? curwin : wp,
-                               buf, sizeof(buf),
+    width = build_stl_str_hl(ewp, buf, sizeof(buf),
                                stl, use_sandbox,
                                fillchar, maxwidth, hltab, tabtab);
     vim_free(stl);
+    ewp->w_p_crb = p_crb_save;
 
     /* Make all characters printable. */
     p = transstr(buf);
index d635dfee90f4f9515d38d1d6baaaa9444c47cc1a..cc3174f3127af8b0c60fc8ca25e9ed083095529a 100644 (file)
@@ -714,6 +714,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    111,
 /**/
     110,
 /**/