* kmacro.el (kmacro-call-macro): Fix bug#14135.
authorLeo Liu <sdl.web@gmail.com>
Fri, 5 Apr 2013 08:38:06 +0000 (16:38 +0800)
committerLeo Liu <sdl.web@gmail.com>
Fri, 5 Apr 2013 08:38:06 +0000 (16:38 +0800)
lisp/ChangeLog
lisp/kmacro.el

index 015ce23..6da3acf 100644 (file)
@@ -1,3 +1,7 @@
+2013-04-05  Leo Liu  <sdl.web@gmail.com>
+
+       * kmacro.el (kmacro-call-macro): Fix bug#14135.
+
 2013-04-05  Jay Belanger  <jay.p.belanger@gmail.com>
 
        * calc/calc-units.el (calc-convert-units): Rewrite conditional.
index c08f49d..d6de2fe 100644 (file)
@@ -631,11 +631,11 @@ others, use \\[kmacro-name-last-macro]."
                                   (> (length (this-single-command-keys)) 1))
                              ;; Used when we're in the process of repeating.
                              (eq no-repeat 'repeating))
-                        last-input-event))
-       (last-kbd-macro (or macro last-kbd-macro)))
+                        last-input-event)))
     (if end-macro
-       (kmacro-end-macro arg)
-      (call-last-kbd-macro arg #'kmacro-loop-setup-function))
+       (kmacro-end-macro arg)          ; modifies last-kbd-macro
+      (let ((last-kbd-macro (or macro last-kbd-macro)))
+       (call-last-kbd-macro arg #'kmacro-loop-setup-function)))
     (when (consp arg)
       (setq arg (car arg)))
     (when (and (or (null arg) (> arg 0))
@@ -658,7 +658,9 @@ others, use \\[kmacro-name-last-macro]."
          (define-key map (vector repeat-key)
            `(lambda () (interactive)
               (kmacro-call-macro ,(and kmacro-call-repeat-with-arg arg)
-                                 'repeating nil ,last-kbd-macro)))
+                                 'repeating nil ,(if end-macro
+                                                    last-kbd-macro
+                                                  (or macro last-kbd-macro)))))
          map)))))