]> git.eshelyaron.com Git - emacs.git/commitdiff
(move_it_vertically_backward): Change heuristic
authorGerd Moellmann <gerd@gnu.org>
Wed, 12 Dec 2001 13:42:55 +0000 (13:42 +0000)
committerGerd Moellmann <gerd@gnu.org>
Wed, 12 Dec 2001 13:42:55 +0000 (13:42 +0000)
for the case that we didn't move far enough initially.

src/xdisp.c

index 91558067d1f59d4cb12c2de6e5ad6af93a525378..4fed4ac415951c5452fce0795cf80dabb57ef748 100644 (file)
@@ -5373,7 +5373,7 @@ move_it_vertically_backward (it, dy)
       int y0 = it3.current_y;
       int y1 = line_bottom_y (&it3);
       int line_height = y1 - y0;
-      
+
       /* If we did not reach target_y, try to move further backward if
         we can.  If we moved too far backward, try to move forward.  */
       if (target_y < it->current_y
@@ -5384,13 +5384,21 @@ move_it_vertically_backward (it, dy)
          && it->current_y - target_y > line_height / 3 * 2
          && IT_CHARPOS (*it) > BEGV)
        {
+         TRACE_MOVE ((stderr, "  not far enough -> move_vert %d\n",
+                      target_y - it->current_y));
          move_it_vertically (it, target_y - it->current_y);
          xassert (IT_CHARPOS (*it) >= BEGV);
        }
       else if (target_y >= it->current_y + line_height
               && IT_CHARPOS (*it) < ZV)
        {
-         move_it_vertically (it, target_y - (it->current_y + line_height));
+         /* Should move forward by at least one line, maybe more.  */
+         do
+           {
+             move_it_by_lines (it, 1, 1);
+           }
+         while (target_y >= line_bottom_y (it) && IT_CHARPOS (*it) < ZV);
+
          xassert (IT_CHARPOS (*it) >= BEGV);
        }
     }