Using Helix
- --
-
- Registers - - -
- Surround -
- Selecting and manipulating text with textobjects -
- Navigating using tree-sitter textobjects -
- Moving the selection with syntax-aware motions -
For a full interactive introduction to Helix, refer to the
-tutor which
-can be accessed via the command hx --tutor
or :tutor
.
--π‘ Currently, not all functionality is fully documented, please refer to the -key mappings list.
-
Registers
-In Helix, registers are storage locations for text and other data, such as the
-result of a search. Registers can be used to cut, copy, and paste text, similar
-to the clipboard in other text editors. Usage is similar to Vim, with "
being
-used to select a register.
User-defined registers
-Helix allows you to create your own named registers for storing text, for -example:
--
-
"ay
- Yank the current selection to registera
.
-"op
- Paste the text in registero
after the selection.
-
If a register is selected before invoking a change or delete command, the selection will be stored in the register and the action will be carried out:
--
-
"hc
- Store the selection in registerh
and then change it (delete and enter insert mode).
-"md
- Store the selection in registerm
and delete it.
-
Default registers
-Commands that use registers, like yank (y
), use a default register if none is specified.
-These registers are used as defaults:
Register character | Contains |
---|---|
/ | Last search |
: | Last executed command |
" | Last yanked text |
@ | Last recorded macro |
Special registers
-Some registers have special behavior when read from and written to.
-Register character | When read | When written |
---|---|---|
_ | No values are returned | All values are discarded |
# | Selection indices (first selection is 1 , second is 2 , etc.) | This register is not writable |
. | Contents of the current selections | This register is not writable |
% | Name of the current file | This register is not writable |
* | Reads from the system clipboard | Joins and yanks to the system clipboard |
+ | Reads from the primary clipboard | Joins and yanks to the primary clipboard |
When yanking multiple selections to the clipboard registers, the selections -are joined with newlines. Pasting from these registers will paste multiple -selections if the clipboard was last yanked to by the Helix session. Otherwise -the clipboard contents are pasted as one selection.
-Surround
-Helix includes built-in functionality similar to vim-surround. -The keymappings have been inspired from vim-sandwich:
- -Key Sequence | Action |
---|---|
ms<char> (after selecting text) | Add surround characters to selection |
mr<char_to_replace><new_char> | Replace the closest surround characters |
md<char_to_delete> | Delete the closest surround characters |
You can use counts to act on outer pairs.
-Surround can also act on multiple selections. For example, to change every occurrence of (use)
to [use]
:
-
-
%
to select the whole file
-s
to split the selections on a search term
-- Input
use
and hit Enter
- mr([
to replace the parentheses with square brackets
-
Multiple characters are currently not supported, but planned for future release.
-Selecting and manipulating text with textobjects
-In Helix, textobjects are a way to select, manipulate and operate on a piece of -text in a structured way. They allow you to refer to blocks of text based on -their structure or purpose, such as a word, sentence, paragraph, or even a -function or block of code.
--
--
-
ma
- Select around the object (va
in Vim,<alt-a>
in Kakoune)
-mi
- Select inside the object (vi
in Vim,<alt-i>
in Kakoune)
-
Key after mi or ma | Textobject selected |
---|---|
w | Word |
W | WORD |
p | Paragraph |
( , [ , ' , etc. | Specified surround pairs |
m | The closest surround pair |
f | Function |
t | Type (or Class) |
a | Argument/parameter |
c | Comment |
T | Test |
g | Change |
--π‘
-f
,t
, etc. need a tree-sitter grammar active for the current -document and a special tree-sitter query file to work properly. Only -some grammars currently have the query file implemented. -Contributions are welcome!
Navigating using tree-sitter textobjects
-Navigating between functions, classes, parameters, and other elements is
-possible using tree-sitter and textobject queries. For
-example to move to the next function use ]f
, to move to previous
-type use [t
, and so on.
For the full reference see the unimpaired section of the key bind -documentation.
---π‘ This feature relies on tree-sitter textobjects -and requires the corresponding query file to work properly.
-
Moving the selection with syntax-aware motions
-Alt-p
, Alt-o
, Alt-i
, and Alt-n
(or Alt
and arrow keys) allow you to move the
-selection according to its location in the syntax tree. For example, many languages have the
-following syntax for function calls:
func(arg1, arg2, arg3);
-
-A function call might be parsed by tree-sitter into a tree like the following.
-(call
- function: (identifier) ; func
- arguments:
- (arguments ; (arg1, arg2, arg3)
- (identifier) ; arg1
- (identifier) ; arg2
- (identifier))) ; arg3
-
-Use :tree-sitter-subtree
to view the syntax tree of the primary selection. In
-a more intuitive tree format:
ββββββ
- βcallβ
- βββββββ΄βββββ΄ββββββ
- β β
-βββββββΌβββββ ββββββΌβββββ
-βidentifierβ βargumentsβ
-β "func" β ββββββ΄ββββ¬ββββββ΄ββββ
-ββββββββββββ β β β
- β β β
- βββββββββββΌβ ββββββΌββββββ ββΌββββββββββ
- βidentifierβ βidentifierβ βidentifierβ
- β "arg1" β β "arg2" β β "arg3" β
- ββββββββββββ ββββββββββββ ββββββββββββ
-
-If you have a selection that wraps arg1
(see the tree above), and you use
-Alt-n
, it will select the next sibling in the syntax tree: arg2
.
// before
-func([arg1], arg2, arg3)
-// after
-func(arg1, [arg2], arg3);
-
-Similarly, Alt-o
will expand the selection to the parent node, in this case, the
-arguments node.
func[(arg1, arg2, arg3)];
-
-There is also some nuanced behavior that prevents you from getting stuck on a
-node with no sibling. When using Alt-p
with a selection on arg1
, the previous
-child node will be selected. In the event that arg1
does not have a previous
-sibling, the selection will move up the syntax tree and select the previous
-element. As a result, using Alt-p
with a selection on arg1
will move the
-selection to the "func" identifier
.