2018-02-23 14:31:28 +01:00
|
|
|
= Modes
|
|
|
|
|
|
|
|
== Description
|
|
|
|
|
|
|
|
Kakoune is a modal editor which means that keys have different effects depending
|
|
|
|
on the current mode. Therefore, modes can be conceptualized as a way to group
|
|
|
|
related behaviors together during a text editing workflow.
|
|
|
|
|
2018-03-01 04:38:41 +01:00
|
|
|
Kakoune starts in Normal mode. A few keys let users enter other modes
|
|
|
|
where they can focus on a specific task before going back to Normal mode.
|
2018-02-23 14:31:28 +01:00
|
|
|
|
|
|
|
Modes are stored in a stack with the top of the stack being the active mode.
|
|
|
|
So in some scenarios, the Normal mode may feel *nested* in another one.
|
|
|
|
The `ModeChange` hook is triggered each time a mode is popped or pushed
|
|
|
|
on this stack. See <<hooks#,`:doc hooks`>>
|
|
|
|
|
2018-03-01 04:38:41 +01:00
|
|
|
To get a comprehensive list of commands available for each modes, see
|
|
|
|
<<keys#,`:doc keys`>>. Most of them are described in *info* boxes in
|
|
|
|
real-time if the `autoinfo` option is set.
|
2018-02-23 14:31:28 +01:00
|
|
|
|
|
|
|
To customize key mappings in various modes, refer to <<mapping#,`:doc mapping`>>.
|
|
|
|
|
|
|
|
== Builtin modes
|
|
|
|
|
|
|
|
=== Normal mode
|
|
|
|
|
2018-03-01 04:38:41 +01:00
|
|
|
Normal mode is the default mode. It provides commands to manipulate
|
|
|
|
selections, such as general movement, text object selection, searching,
|
|
|
|
splitting, and commands to manipulate the text underlying the current
|
|
|
|
selections, such as yanking, pasting, deleting…
|
|
|
|
|
|
|
|
It also provides commands to enter other modes.
|
2018-02-23 14:31:28 +01:00
|
|
|
|
|
|
|
See normal commands <<keys#movement,`:doc keys movement`>>.
|
|
|
|
|
|
|
|
=== Insert mode
|
|
|
|
|
2018-03-01 04:38:41 +01:00
|
|
|
Insert mode provides an efficient way to interactively write text into
|
|
|
|
the buffer. Most keys will insert their corresponding characters before
|
|
|
|
every selections cursors. It also provides completion support for inserted
|
|
|
|
text along with some commands for basic movement.
|
|
|
|
|
|
|
|
Insert mode can be entered from Normal modes through a set of commands
|
|
|
|
such as `i` to insert before selection, `a` to insert after selection,
|
|
|
|
`o` to insert in a new line below selections… It can then be exited with
|
|
|
|
`<esc>` to return to Normal mode.
|
|
|
|
|
2018-02-23 14:31:28 +01:00
|
|
|
See changes <<keys#changes,`:doc keys changes`>>.
|
|
|
|
|
2018-03-01 04:38:41 +01:00
|
|
|
From Insert mode, `<a-;>` provides a way to temporarily enter a new
|
|
|
|
Normal mode for a single command, before returning to Insert mode.
|
2018-02-23 14:31:28 +01:00
|
|
|
|
|
|
|
See insert commands <<keys#insert-mode,`:doc keys insert-mode`>>.
|
|
|
|
|
|
|
|
=== Goto mode
|
|
|
|
|
2018-03-01 04:38:41 +01:00
|
|
|
Goto mode provides commands dedicated to jumping either inside a buffer
|
2020-05-02 17:36:58 +02:00
|
|
|
(such as jumping to buffer start/end, window top/bottom) or to another
|
2018-03-01 04:38:41 +01:00
|
|
|
(such as jumping to the file whose path is currently selected).
|
|
|
|
|
2018-02-23 14:31:28 +01:00
|
|
|
See goto commands <<keys#goto-commands,`:doc keys goto-commands`>>.
|
|
|
|
|
|
|
|
=== View mode
|
|
|
|
|
2018-03-01 04:38:41 +01:00
|
|
|
View mode provides commands dedicated to controlling the window, such
|
|
|
|
as scrolling or centering the main selection cursor.
|
|
|
|
|
2018-02-23 14:31:28 +01:00
|
|
|
See view commands <<keys#view-commands,`:doc keys view-commands`>>.
|
|
|
|
|
|
|
|
=== Menu mode
|
|
|
|
|
2020-10-04 13:34:57 +02:00
|
|
|
Menu mode is entered when a menu is displayed with the `menu` command.
|
2018-03-01 04:38:41 +01:00
|
|
|
Mappings are used to filter and select intended items.
|
2018-02-23 14:31:28 +01:00
|
|
|
|
|
|
|
=== Prompt mode
|
|
|
|
|
2020-10-04 13:34:57 +02:00
|
|
|
Mode entered with `:`, `/` or the `prompt` command. During prompt mode a
|
2018-03-01 04:38:41 +01:00
|
|
|
line of text is edited and then validated with `<ret>` or abandoned with
|
|
|
|
`<esc>`.
|
|
|
|
|
2018-02-23 14:31:28 +01:00
|
|
|
See prompt commands <<keys#prompt-commands,`:doc keys prompt-commands`>>.
|
|
|
|
|
|
|
|
=== Object mode
|
|
|
|
|
|
|
|
Mode entered with `<a-i>`, `<a-a>` and various combinations of `[]{}` keys.
|
|
|
|
It aims at crafting semantic selections, often called *text-objects*.
|
2018-03-01 04:38:41 +01:00
|
|
|
|
2018-02-23 14:31:28 +01:00
|
|
|
See object commands <<keys#object-commands,`:doc keys object-commands`>>.
|
|
|
|
|
|
|
|
=== User mode
|
|
|
|
|
2020-10-04 13:34:57 +02:00
|
|
|
Mode entered with `,` (comma key). The user mode is empty by default and is
|
|
|
|
the opportunity to store custom mappings with no risk to shadow builtin ones.
|
|
|
|
The context of execution is always the Normal mode.
|
2018-02-23 14:31:28 +01:00
|
|
|
|
|
|
|
== User modes
|
|
|
|
|
2018-03-01 04:38:41 +01:00
|
|
|
The following two commands are useful in advanced use cases, when the
|
|
|
|
builtin User mode gets too crowded by mappings competing for the same
|
|
|
|
key that deserves to be split in more meaningful collections. It's
|
|
|
|
mostly useful for plugin authors who want to bind their new commands in
|
|
|
|
extensible menus.
|
2018-02-23 14:31:28 +01:00
|
|
|
|
|
|
|
--------------------------------
|
2018-03-02 07:45:04 +01:00
|
|
|
declare-user-mode <name>
|
2018-02-23 14:31:28 +01:00
|
|
|
--------------------------------
|
|
|
|
|
|
|
|
Declare a new custom mode that can later be referred by the *map* command.
|
|
|
|
For example a `grep` custom mode to attach keys like `n` or `p` to skim
|
|
|
|
through the output results.
|
|
|
|
|
|
|
|
-------------------------------
|
2018-03-02 07:45:04 +01:00
|
|
|
enter-user-mode <name>
|
2018-02-23 14:31:28 +01:00
|
|
|
-------------------------------
|
|
|
|
|
2018-03-01 04:38:41 +01:00
|
|
|
Enable the designated mode for the next key. Docstrings are shown in the
|
|
|
|
automatic info box to increase discoverability. To keep illustrating
|
|
|
|
the aforementioned fictional `grep` mode, a normal mapping on `<a-g>`
|
|
|
|
could be used to enter this mode.
|