From: Chong Yidong Date: Tue, 30 Dec 2008 15:03:08 +0000 (+0000) Subject: (Fvertical_motion): Don't advance iterator if we have reseated to the X-Git-Tag: emacs-pretest-23.0.90~804 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=af2be00218e0daf21cde4c041f49df63b2e69460;p=emacs.git (Fvertical_motion): Don't advance iterator if we have reseated to the desired position. --- diff --git a/src/indent.c b/src/indent.c index d30d2dc7293..aea60c3ce48 100644 --- a/src/indent.c +++ b/src/indent.c @@ -2063,7 +2063,7 @@ whether or not it is currently displayed in some window. */) } else { - int it_start, oselective, first_x, it_overshoot_expected; + int it_start, first_x, it_overshoot_expected; SET_TEXT_POS (pt, PT, PT_BYTE); start_display (&it, w, pt); @@ -2093,11 +2093,15 @@ whether or not it is currently displayed in some window. */) really at some x > 0. */ reseat_at_previous_visible_line_start (&it); it.current_x = it.hpos = 0; - /* Temporarily disable selective display so we don't move too far */ - oselective = it.selective; - it.selective = 0; - move_it_to (&it, PT, -1, -1, -1, MOVE_TO_POS); - it.selective = oselective; + if (IT_CHARPOS (it) != PT) + { + int oselective = it.selective; + /* Temporarily disable selective display so we don't move + too far */ + it.selective = 0; + move_it_to (&it, PT, -1, -1, -1, MOVE_TO_POS); + it.selective = oselective; + } if (XINT (lines) <= 0) {