Carefully manage save/restore of point in `notmuch-wash-toggle-invisible-action'.

Before the change, save-excursion was used to save the point.  But the
marker saved by save-excursion was inside a region that was deleted,
so that approach is unreliable, (leading to point jumping to a new
position past the button). This patch instead saves point in an
integer variable, and when restoring, carefully avoids moving point
past the button, (in case the new button label is shorter than the old
button label).
This commit is contained in:
Dmitry Kurochkin 2011-05-25 03:02:43 +04:00 committed by Carl Worth
parent 31b7c04ae1
commit b6862c7eb9

View file

@ -82,13 +82,14 @@ collapse the remaining lines into a button.")
(let* ((new-start (button-start cite-button)) (let* ((new-start (button-start cite-button))
(overlay (button-get cite-button 'overlay)) (overlay (button-get cite-button 'overlay))
(button-label (notmuch-wash-button-label overlay)) (button-label (notmuch-wash-button-label overlay))
(old-point (point))
(inhibit-read-only t)) (inhibit-read-only t))
(save-excursion
(goto-char new-start) (goto-char new-start)
(insert button-label) (insert button-label)
(let ((old-end (button-end cite-button))) (let ((old-end (button-end cite-button)))
(move-overlay cite-button new-start (point)) (move-overlay cite-button new-start (point))
(delete-region (point) old-end)))) (delete-region (point) old-end))
(goto-char (min old-point (1- (button-end cite-button)))))
(force-window-update) (force-window-update)
(redisplay t)) (redisplay t))