From 2244a5d40c83d477839f91cb6d6a4aeb02446a97 Mon Sep 17 00:00:00 2001 From: omentic Date: Wed, 1 May 2024 23:29:52 +0000 Subject: deploy: 12eec890240a05d1e090114f7f4fdd7c1ee8ff88 --- master/usage.html | 407 ------------------------------------------------------ 1 file changed, 407 deletions(-) delete mode 100644 master/usage.html (limited to 'master/usage.html') diff --git a/master/usage.html b/master/usage.html deleted file mode 100644 index d95e5993..00000000 --- a/master/usage.html +++ /dev/null @@ -1,407 +0,0 @@ - - - - - - Usage - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - - - - - - - - - - - - - - - - - - -
- -
- - - - - - - - -
-
-

Using Helix

- - - -

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 register a.
  • -
  • "op - Paste the text in register o 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 register h and then change it (delete and enter insert mode).
  • -
  • "md - Store the selection in register m 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 characterContains
/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 characterWhen readWhen written
_No values are returnedAll values are discarded
#Selection indices (first selection is 1, second is 2, etc.)This register is not writable
.Contents of the current selectionsThis register is not writable
%Name of the current fileThis register is not writable
+Reads from the system clipboardJoins and yanks to the system clipboard
*Reads from the primary clipboardJoins 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:

-

Surround demo

-
- - - -
Key SequenceAction
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]:

-
    -
  1. % to select the whole file
  2. -
  3. s to split the selections on a search term
  4. -
  5. Input use and hit Enter
  6. -
  7. mr([ to replace the parentheses with square brackets
  8. -
-

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.

-

Textobject demo -Textobject tree-sitter demo

-
    -
  • 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 maTextobject selected
wWord
WWORD
pParagraph
(, [, ', etc.Specified surround pairs
mThe closest surround pair
fFunction
tType (or Class)
aArgument/parameter
cComment
TTest
gChange
-
-
-

πŸ’‘ 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 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.

-

Tree-sitter-nav-demo

-

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.

- -
- - -
-
- - - -
- - - - - - - - - - - - - - - - - - -
- - -- cgit v1.2.3-70-g09d2