;; This file is part of GNU Emacs.
-;; This program is free software; you can redistribute it and/or modify
+;; GNU Emacs is free software; you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation; either version 2, or (at your option)
;; any later version.
-;; This program is distributed in the hope that it will be useful,
+;; GNU Emacs is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
;; GNU General Public License for more details.
;; includes that many copies of the same character.
;; So use just the first character
;; and repeat it the right number of times.
- (setq insertion (substring insertion 0 1))
+ (setq insertion (substring insertion -1))
(let ((count (prefix-numeric-value repeat-arg))
(i 0))
(while (< i count)
(repeat-self-insert insertion)
(setq i (1+ i)))))
- (if (or (stringp real-last-command)
- (vectorp real-last-command))
- (execute-kbd-macro real-last-command)
- (call-interactively real-last-command))))
+ (let ((indirect (indirect-function real-last-command)))
+ (if (or (stringp indirect)
+ (vectorp indirect))
+ ;; Bind real-last-command so that executing the macro
+ ;; does not alter it.
+ (let ((real-last-command real-last-command))
+ (execute-kbd-macro real-last-command))
+ (call-interactively real-last-command)))))
(when repeat-repeat-char
;; A simple recursion here gets into trouble with max-lisp-eval-depth
;; on long sequences of repetitions of a command like `forward-word'