]> granicus.if.org Git - vim/commitdiff
patch 8.2.4614: redrawing too much when 'cursorline' is set v8.2.4614
authorzeertzjq <zeertzjq@outlook.com>
Wed, 23 Mar 2022 14:55:23 +0000 (14:55 +0000)
committerBram Moolenaar <Bram@vim.org>
Wed, 23 Mar 2022 14:55:23 +0000 (14:55 +0000)
Problem:    Redrawing too much when 'cursorline' is set and jumping around.
Solution:   Rely on win_update() to redraw the current and previous cursor
            line, do not mark lines as modified. (closes #9996)

src/drawline.c
src/drawscreen.c
src/move.c
src/option.c
src/proto/move.pro
src/version.c

index 747a1e33b05febca6b5e51e7e7938f7f5cc08c66..679e4cae4e3e9261d6b4fce83468c48179a9e7ba 100644 (file)
@@ -945,8 +945,7 @@ win_line(
     if (wp->w_p_cul && lnum == wp->w_cursor.lnum)
     {
        // Do not show the cursor line in the text when Visual mode is active,
-       // because it's not clear what is selected then.  Do update
-       // w_last_cursorline.
+       // because it's not clear what is selected then.
        if (!(wp == curwin && VIsual_active)
                                         && wp->w_p_culopt_flags != CULOPT_NBR)
        {
@@ -971,18 +970,14 @@ win_line(
                else
 # endif
                    line_attr = cul_attr;
-               wp->w_last_cursorline = wp->w_cursor.lnum;
            }
            else
            {
                line_attr_save = line_attr;
-               wp->w_last_cursorline = 0;
                margin_columns_win(wp, &left_curline_col, &right_curline_col);
            }
            area_highlighting = TRUE;
        }
-       else
-           wp->w_last_cursorline = wp->w_cursor.lnum;
     }
 #endif
 
index a562c4d84a221f96da618db1316d5fa2ce1db773..a902397cd7ff14da71f8dd15c18498fddf2b5860 100644 (file)
@@ -1468,9 +1468,6 @@ win_update(win_T *wp)
 # define DID_FOLD 3    // updated a folded line
     int                did_update = DID_NONE;
     linenr_T   syntax_last_parsed = 0;         // last parsed text line
-    // remember the current w_last_cursorline, it changes when drawing the new
-    // cursor line
-    linenr_T   last_cursorline = wp->w_last_cursorline;
 #endif
     linenr_T   mod_top = 0;
     linenr_T   mod_bot = 0;
@@ -2245,8 +2242,8 @@ win_update(win_T *wp)
 #endif
                                ))))
 #ifdef FEAT_SYN_HL
-               || (wp->w_p_cul && (lnum == wp->w_cursor.lnum
-                                                  || lnum == last_cursorline))
+               || (wp->w_p_cul && lnum == wp->w_cursor.lnum)
+               || lnum == wp->w_last_cursorline
 #endif
                                )
        {
@@ -2551,6 +2548,12 @@ win_update(win_T *wp)
 
     // End of loop over all window lines.
 
+#ifdef FEAT_SYN_HL
+    // Now that the window has been redrawn with the old and new cursor line,
+    // update w_last_cursorline.
+    wp->w_last_cursorline = wp->w_p_cul ? wp->w_cursor.lnum : 0;
+#endif
+
 #ifdef FEAT_VTP
     // Rewrite the character at the end of the screen line.
     // See the version that was fixed.
index 1c88e6ebcc5959a55707b44ad27fd34e147b1758..571ec8c3174fcb5bb46782f92845bbd0379c0bde 100644 (file)
@@ -115,14 +115,6 @@ comp_botline(win_T *wp)
     set_empty_rows(wp, done);
 }
 
-#ifdef FEAT_SYN_HL
-    void
-reset_cursorline(void)
-{
-    curwin->w_last_cursorline = 0;
-}
-#endif
-
 /*
  * Redraw when w_cline_row changes and 'relativenumber' or 'cursorline' is
  * set.
@@ -138,24 +130,8 @@ redraw_for_cursorline(win_T *wp)
            && (wp->w_valid & VALID_CROW) == 0
            && !pum_visible())
     {
-       if (wp->w_p_rnu)
-           // win_line() will redraw the number column only.
-           redraw_win_later(wp, VALID);
-#ifdef FEAT_SYN_HL
-       if (wp->w_p_cul)
-       {
-           if (wp->w_redr_type <= VALID && wp->w_last_cursorline != 0)
-           {
-               // "w_last_cursorline" may be outdated, worst case we redraw
-               // too much.  This is optimized for moving the cursor around in
-               // the current window.
-               redrawWinline(wp, wp->w_last_cursorline);
-               redrawWinline(wp, wp->w_cursor.lnum);
-           }
-           else
-               redraw_win_later(wp, SOME_VALID);
-       }
-#endif
+       // win_line() will redraw the number column and cursorline only.
+       redraw_win_later(wp, VALID);
     }
 }
 
index 936906649dde0b8e1ecb898cd4407633054206ac..71b71ba53c5f99ee357624fc68a64e9b860f5794 100644 (file)
@@ -2782,11 +2782,6 @@ set_bool_option(
        p_lrm = !p_lnr;
 #endif
 
-#ifdef FEAT_SYN_HL
-    else if ((int *)varp == &curwin->w_p_cul && !value && old_value)
-       reset_cursorline();
-#endif
-
 #ifdef FEAT_PERSISTENT_UNDO
     // 'undofile'
     else if ((int *)varp == &curbuf->b_p_udf || (int *)varp == &p_udf)
index d78623acc5c17f0a09c028837c033759227452f9..e6a06011c47767e061f25a0bb797bb1ddedd84f5 100644 (file)
@@ -1,5 +1,4 @@
 /* move.c */
-void reset_cursorline(void);
 void redraw_for_cursorline(win_T *wp);
 void update_topline_redraw(void);
 void update_topline(void);
index 695ddaf0c7a3481eac0fdadd1ac365e8ed113c62..ad4f3c81396f7886712f96873edb39b8f546fb21 100644 (file)
@@ -750,6 +750,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    4614,
 /**/
     4613,
 /**/