1
0
mirror of https://git.savannah.gnu.org/git/emacs.git synced 2025-01-06 11:55:48 +00:00

Fix missing undo-boundary on revert-buffer.

* lisp/simple.el (undo-auto--undoable-change-no-timer): New function.
* src/fileio.c (insert-buffer-contents): Call
  undo-auto--undoably-changed-buffers before changes.

Addresses Bug#23785.

Do not merge to master as c98bc98 also addresses the same bug.
This commit is contained in:
Phillip Lord 2016-06-28 08:02:51 +01:00
parent 6f285d963d
commit 8f9c1eda93
2 changed files with 14 additions and 1 deletions

View File

@ -2940,9 +2940,17 @@ behavior."
(cdr buffer-undo-list))))))
(setq undo-auto--last-boundary-cause 0)))))
;; This function is called also from one place in fileio.c. We call
;; this function, rather than undoable-change because it reduces the
;; number of lisp functions we have to use fboundp for to avoid
;; bootstrap issues.
(defun undo-auto--undoable-change-no-timer ()
"Record `current-buffer' as changed."
(add-to-list 'undo-auto--undoably-changed-buffers (current-buffer)))
(defun undo-auto--undoable-change ()
"Called after every undoable buffer change."
(add-to-list 'undo-auto--undoably-changed-buffers (current-buffer))
(undo-auto--undoable-change-no-timer)
(undo-auto--boundary-ensure-timer))
;; End auto-boundary section

View File

@ -3436,6 +3436,9 @@ by calling `format-decode', which see. */)
if (!NILP (BVAR (current_buffer, read_only)))
Fbarf_if_buffer_read_only (Qnil);
if (!NILP (Ffboundp (Qundo_auto__undoable_change_no_timer)))
call0 (Qundo_auto__undoable_change_no_timer);
val = Qnil;
p = Qnil;
orig_filename = Qnil;
@ -5797,6 +5800,8 @@ syms_of_fileio (void)
which gives a list of operations it handles. */
DEFSYM (Qoperations, "operations");
DEFSYM (Qundo_auto__undoable_change_no_timer, "undo-auto--undoable-change-no-timer");
DEFSYM (Qexpand_file_name, "expand-file-name");
DEFSYM (Qsubstitute_in_file_name, "substitute-in-file-name");
DEFSYM (Qdirectory_file_name, "directory-file-name");