(progn (undo-start)
(undo-more 1)))
(undo-more (or arg 1))
+ ;; Don't specify a position in the undo record for the undo command.
+ ;; Instead, undoing this should move point to where the change is.
+ (let ((tail buffer-undo-list)
+ done)
+ (while (and tail (not done) (not (null (car tail))))
+ (if (integerp (car tail))
+ (progn
+ (setq done t)
+ (setq buffer-undo-list (delq (car tail) buffer-undo-list))))
+ (setq tail (cdr tail))))
(and modified (not (buffer-modified-p))
(delete-auto-save-file-if-necessary recent-save)))
;; If we do get all the way thru, make this-command indicate that.