summaryrefslogtreecommitdiff
path: root/lisp/follow.el
diff options
context:
space:
mode:
authorAlan Mackenzie <acm@muc.de>2021-11-13 18:33:17 +0000
committerAlan Mackenzie <acm@muc.de>2021-11-13 18:33:17 +0000
commitd4536ff2572931b105198a85a452a777d6d3a1ff (patch)
tree1ad74f81ba1757e91d6171f528f881a659de657d /lisp/follow.el
parent480241983ea91e31ca4d757fe91df84d1d11d3c9 (diff)
downloademacs-d4536ff2572931b105198a85a452a777d6d3a1ff.tar.gz
emacs-d4536ff2572931b105198a85a452a777d6d3a1ff.tar.bz2
emacs-d4536ff2572931b105198a85a452a777d6d3a1ff.zip
Fix follow-scroll-down in a small buffer which starts slightly scrolled
This fixes bug #51814. * lisp/follow.el (follow-scroll-down): Do away with the optimization of doing vertical-motion over only one window. Instead move over all windows, to checck for being close to point-min, and setting point accordingly.
Diffstat (limited to 'lisp/follow.el')
-rw-r--r--lisp/follow.el32
1 files changed, 19 insertions, 13 deletions
diff --git a/lisp/follow.el b/lisp/follow.el
index 2ca2c1f17ba..3761275bbf6 100644
--- a/lisp/follow.el
+++ b/lisp/follow.el
@@ -669,24 +669,30 @@ Works like `scroll-down' when not in Follow mode."
(t
(let* ((orig-point (point))
(windows (follow-all-followers))
- (win (car (reverse windows)))
- (start (window-start (car windows))))
+ (start (window-start (car windows)))
+ (lines 0))
(if (eq start (point-min))
(if (or (null scroll-error-top-bottom)
(bobp))
(signal 'beginning-of-buffer nil)
(goto-char (point-min)))
- (select-window win)
- (goto-char start)
- (vertical-motion (- (- (window-height win)
- (if header-line-format 2 1) ; always mode-line
- (if tab-line-format 1 0)
- next-screen-context-lines)))
- (set-window-start win (point))
- (if (< orig-point (window-end win t))
- (goto-char orig-point)
- (goto-char start)
- (vertical-motion (- next-screen-context-lines 1)))
+ (select-window (car windows))
+ (dolist (win windows)
+ (setq lines
+ (+ lines
+ (- (window-height win)
+ (if header-line-format 2 1) ; Count mode-line, too.
+ (if tab-line-format 1 0)))))
+ (setq lines (- lines next-screen-context-lines))
+ (goto-char start)
+ (let ((at-top (> (vertical-motion (- lines)) (- lines))))
+ (set-window-start (car windows) (point))
+ (if at-top
+ (goto-char orig-point)
+ (goto-char start)
+ (vertical-motion (- next-screen-context-lines 1))
+ (if (< orig-point (point))
+ (goto-char orig-point))))
(setq follow-internal-force-redisplay t))))))
(put 'follow-scroll-down 'scroll-command t)