mirror of
https://git.savannah.gnu.org/git/emacs.git
synced 2025-01-13 16:38:14 +00:00
Rectify allout-widgets region undecoration so item at start is not missed.
* lisp/allout-widgets.el (allout-widgets-undecorate-region): Reorganize the loop so an item at the start is not skipped.
This commit is contained in:
parent
dd7c191291
commit
33d85cb768
@ -2060,19 +2060,22 @@ Optional FORCE means force reassignment of the region property."
|
||||
;;;_ > allout-widgets-undecorate-region (start end)
|
||||
(defun allout-widgets-undecorate-region (start end)
|
||||
"Eliminate widgets and decorations for all items in region from START to END."
|
||||
(let ((next start)
|
||||
widget)
|
||||
(let (done next widget
|
||||
(end (or end (point-max))))
|
||||
(save-excursion
|
||||
(goto-char start)
|
||||
(while (< (setq next (next-single-char-property-change next
|
||||
'display
|
||||
(current-buffer)
|
||||
end))
|
||||
end)
|
||||
(goto-char next)
|
||||
(when (setq widget (allout-get-item-widget))
|
||||
;; if the next-property/overly progression got us to a widget:
|
||||
(allout-widgets-undecorate-item widget t))))))
|
||||
(while (not done)
|
||||
(when (and (allout-on-current-heading-p)
|
||||
(setq widget (allout-get-item-widget)))
|
||||
(if widget
|
||||
(allout-widgets-undecorate-item widget t)))
|
||||
(goto-char (setq next
|
||||
(next-single-char-property-change (point)
|
||||
'display
|
||||
(current-buffer)
|
||||
end)))
|
||||
(if (>= next end)
|
||||
(setq done t))))))
|
||||
;;;_ > allout-widgets-undecorate-text (text)
|
||||
(defun allout-widgets-undecorate-text (text)
|
||||
"Eliminate widgets and decorations for all items in TEXT."
|
||||
|
Loading…
Reference in New Issue
Block a user