A keyboard macro is a canned sequence of input events that can be considered a command and made the definition of a key. The Lisp representation of a keyboard macro is a string or vector containing the events. Don’t confuse keyboard macros with Lisp macros (see Macros).
This function executes kbdmacro as a sequence of events. If kbdmacro is a string or vector, then the events in it are executed exactly as if they had been input by the user. The sequence is not expected to be a single key sequence; normally a keyboard macro definition consists of several key sequences concatenated.
If kbdmacro is a symbol, then its function definition is used in place of kbdmacro. If that is another symbol, this process repeats. Eventually the result should be a string or vector. If the result is not a symbol, string, or vector, an error is signaled.
The argument count is a repeat count; kbdmacro is executed that many times. If count is omitted or nil
, kbdmacro is executed once. If it is 0, kbdmacro is executed over and over until it encounters an error or a failing search.
If loopfunc is non-nil
, it is a function that is called, without arguments, prior to each iteration of the macro. If loopfunc returns nil
, then this stops execution of the macro.
See Reading One Event, for an example of using execute-kbd-macro
.
This variable contains the string or vector that defines the keyboard macro that is currently executing. It is nil
if no macro is currently executing. A command can test this variable so as to behave differently when run from an executing macro. Do not set this variable yourself.
This variable is non-nil
if and only if a keyboard macro is being defined. A command can test this variable so as to behave differently while a macro is being defined. The value is append
while appending to the definition of an existing macro. The commands start-kbd-macro
, kmacro-start-macro
and end-kbd-macro
set this variable—do not set it yourself.
The variable is always local to the current terminal and cannot be buffer-local. See Multiple Terminals.
This variable is the definition of the most recently defined keyboard macro. Its value is a string or vector, or nil
.
The variable is always local to the current terminal and cannot be buffer-local. See Multiple Terminals.
This normal hook is run when a keyboard macro terminates, regardless of what caused it to terminate (reaching the macro end or an error which ended the macro prematurely).
Copyright © 1990-1996, 1998-2019 Free Software Foundation, Inc.
Licensed under the GNU GPL license.
https://www.gnu.org/software/emacs/manual/html_node/elisp/Keyboard-Macros.html