2017-11-08 20:38:31 +03:00
|
|
|
|
= Execute-keys and Evaluate-commands
|
2016-02-03 20:15:35 +03:00
|
|
|
|
|
2017-11-02 05:03:24 +03:00
|
|
|
|
== Description
|
2016-02-03 20:15:35 +03:00
|
|
|
|
|
2017-11-08 20:38:31 +03:00
|
|
|
|
The *execute-keys* and *evaluate-commands* commands can be used to run
|
2018-03-27 09:21:31 +03:00
|
|
|
|
Kakoune commands:
|
2016-02-03 20:15:35 +03:00
|
|
|
|
|
|
|
|
|
----------------------------
|
2018-03-27 09:21:31 +03:00
|
|
|
|
execute-keys [<switches>] <key> ...
|
|
|
|
|
evaluate-commands [<switches>] <command> ...
|
2016-02-03 20:15:35 +03:00
|
|
|
|
----------------------------
|
|
|
|
|
|
2017-11-08 20:38:31 +03:00
|
|
|
|
*execute-keys* runs keys as if they were pressed, whereas *evaluate-commands*
|
|
|
|
|
evaluates its given parameters as if they were entered in the command prompt.
|
|
|
|
|
By default, their execution happens within the context of the current client,
|
|
|
|
|
and stops when the last key/command is reached, or an error is raised.
|
2016-02-03 20:15:35 +03:00
|
|
|
|
|
2016-02-18 15:57:23 +03:00
|
|
|
|
These two commands also save the following registers, who are then restored
|
|
|
|
|
when the commands have been executed: */*, *"*, *|*, *^*, *@*.
|
2017-11-08 20:38:31 +03:00
|
|
|
|
(See <<registers#,`:doc registers`>>)
|
2016-02-18 15:57:23 +03:00
|
|
|
|
|
2018-03-27 09:21:31 +03:00
|
|
|
|
== Optional switches
|
2017-11-02 05:03:24 +03:00
|
|
|
|
|
2016-02-03 20:15:35 +03:00
|
|
|
|
*-client* <name>::
|
2017-11-02 12:37:39 +03:00
|
|
|
|
execute in the context of the client named *name*
|
2016-02-03 20:15:35 +03:00
|
|
|
|
|
|
|
|
|
*-try-client* <name>::
|
2017-11-02 12:37:39 +03:00
|
|
|
|
execute in the context of the client named *name* if such client
|
|
|
|
|
exists, or else in the current context
|
2016-02-03 20:15:35 +03:00
|
|
|
|
|
|
|
|
|
*-draft*::
|
2017-11-02 12:37:39 +03:00
|
|
|
|
execute in a copy of the context of the selected client. Modifications
|
|
|
|
|
to the selections or input state will not affect the client. This
|
|
|
|
|
permits to make some modification to the buffer without modifying
|
|
|
|
|
the user’s selection
|
2016-02-03 20:15:35 +03:00
|
|
|
|
|
2017-10-03 15:22:15 +03:00
|
|
|
|
*-itersel*::
|
2017-11-02 12:37:39 +03:00
|
|
|
|
execute once per selection, in a context with only the considered
|
|
|
|
|
selection. This permits avoiding cases where the selections may
|
|
|
|
|
get merged
|
2016-02-03 20:15:35 +03:00
|
|
|
|
|
|
|
|
|
*-buffer* <names>::
|
2017-11-02 12:37:39 +03:00
|
|
|
|
execute in the context of each buffers in the comma separated list
|
2018-03-27 09:21:31 +03:00
|
|
|
|
*names*. `*` as a name can be used to iterate on all buffers
|
2016-02-03 20:15:35 +03:00
|
|
|
|
|
|
|
|
|
*-no-hooks*::
|
2017-11-02 12:37:39 +03:00
|
|
|
|
disable hook execution while executing the keys/commands
|
2017-11-08 20:38:31 +03:00
|
|
|
|
(See <<hooks#,`:doc hooks`>>)
|
2016-02-03 20:15:35 +03:00
|
|
|
|
|
|
|
|
|
*-with-maps*::
|
2017-11-08 20:38:31 +03:00
|
|
|
|
use user key mapping in instead of built in keys (*execute-keys* only)
|
|
|
|
|
(See <<mapping#,`:doc mapping`>>)
|
2016-02-03 20:15:35 +03:00
|
|
|
|
|
|
|
|
|
*-save-regs* <regs>::
|
2017-11-02 12:37:39 +03:00
|
|
|
|
regs is a string of registers to be restored after execution (overwrites
|
|
|
|
|
the list of registers saved by default, c.f. description)
|