README.md 3.36 KB
Newer Older
1
2
# vi-mode plugin

3
4
This plugin increase `vi-like` zsh functionality.

5
To use it, add `vi-mode` to the plugins array in your zshrc file:
6

7
8
9
```zsh
plugins=(... vi-mode)
```
10

11
## Settings
12

13
14
15
16
- `VI_MODE_RESET_PROMPT_ON_MODE_CHANGE`: controls whether the prompt is redrawn when
  switching to a different input mode. If this is unset, the mode indicator will not
  be updated when changing to a different mode.
  Set it to `true` to enable it. For example:
17

18
19
20
  ```zsh
  VI_MODE_RESET_PROMPT_ON_MODE_CHANGE=true
  ```
21

22
23
  The default value is unset, unless `vi_mode_prompt_info` is used, in which case it'll
  automatically be set to `true`.
24

25
26
- `MODE_INDICATOR`: controls the string displayed when the shell is in normal mode.
  See [Mode indicator](#mode-indicator) for details.
27

28
## Mode indicator
29

30
31
*Normal mode* is indicated with a red `<<<` mark at the right prompt, when it
hasn't been defined by theme.
32

33
34
35
36
37
38
39
40
41
42
43
44
45
You can change this indicator by setting the `MODE_INDICATOR` variable. This setting
supports Prompt Expansion sequences. For example:

```zsh
MODE_INDICATOR="%F{yellow}+%f"
```

You can also use the `vi_mode_prompt_info` function in your prompt, which will display
this mode indicator.

## Key bindings

Use `ESC` or `CTRL-[` to enter `Normal mode`.
46

47
NOTE: some of these key bindings are set by zsh by default when using a vi-mode keymap.
48

49
50
51
52
53
54
55
56
### History

- `ctrl-p` : Previous command in history
- `ctrl-n` : Next command in history
- `/`      : Search backward in history
- `n`      : Repeat the last `/`

### Movement
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73

- `$`   : To the end of the line
- `^`   : To the first non-blank character of the line
- `0`   : To the first character of the line
- `w`   : [count] words forward
- `W`   : [count] WORDS forward
- `e`   : Forward to the end of word [count] inclusive
- `E`   : Forward to the end of WORD [count] inclusive
- `b`   : [count] words backward
- `B`   : [count] WORDS backward
- `t{char}`   : Till before [count]'th occurrence of {char} to the right
- `T{char}`   : Till before [count]'th occurrence of {char} to the left
- `f{char}`   : To [count]'th occurrence of {char} to the right
- `F{char}`   : To [count]'th occurrence of {char} to the left
- `;`   : Repeat latest f, t, F or T [count] times
- `,`   : Repeat latest f, t, F or T in opposite direction

74
### Insertion
75
76
77
78
79
80
81
82

- `i`   : Insert text before the cursor
- `I`   : Insert text before the first character in the line
- `a`   : Append text after the cursor
- `A`   : Append text at the end of the line
- `o`   : Insert new command line below the current one
- `O`   : Insert new command line above the current one

83
### Delete and Insert
84

Alexander Frolov's avatar
Alexander Frolov committed
85
86
- `ctrl-h`      : While in *Insert mode*: delete character before the cursor
- `ctrl-w`      : While in *Insert mode*: delete word before the cursor
87
88
89
90
91
92
93
94
95
96
- `d{motion}`   : Delete text that {motion} moves over
- `dd`          : Delete line
- `D`           : Delete characters under the cursor until the end of the line
- `c{motion}`   : Delete {motion} text and start insert
- `cc`          : Delete line and start insert
- `C`           : Delete to the end of the line and start insert
- `r{char}`     : Replace the character under the cursor with {char}
- `R`           : Enter replace mode: Each character replaces existing one
- `x`           : Delete [count] characters under and after the cursor
- `X`           : Delete [count] characters before the cursor
97
98
99
100

### Removed key bindings

- `v`   : Edit current command line in Vim