Skip to content

Input editor Vim keybindings

Open in ChatGPT ↗
Ask ChatGPT about this page
Open in Claude ↗
Ask Claude about this page
Copied!

Use input editor Vim keybindings (also known as Vim mode) to edit commands quickly in Warp.

The Vi family of programs (including Vim and Neovim) are modal text editors that allow for keyboard-driven text editing. Several shells, including bash and zsh, implement vi-style keybindings. Warp’s input editor was built natively to support more modern text editing experiences, which means it replaces the shell’s editor capabilities. Warp has its implementation of Vim keybindings (also known as Vim mode) you can use.

To manually toggle Vim keybindings in Warp’s input editor:

  • Through the Command Palette, search for “Vim Keybindings”.
  • Through Settings > Features > Text Editing, toggle “Edit commands with Vim keybindings”.

As in bash and zsh’s vi mode implementations, the editor starts in insert mode. Pressing CTRL-C or ENTER clears any pending command state.

At the moment, Warp only supports default Vim keybindings.

One exception is the keyboard shortcut for exiting insert mode, which can be rebound underSettings > Keyboard shortcuts > Exit Vim Insert Mode, or through the Command Palette search for “Exit Vim Insert Mode”.

Below is a list of the vim functionality implemented in Warp so far.

See Vim docs: motion for more information.

Command(s)Description
h, j, k, lsingle-char movement
<space>, <backspace>single-char movement with line wrap
w, W, b, B, e, Eword movement
ge, gEend of previous word
$end of line
0beginning of line
^first non-whitespace character of line
%jump to matching bracket
[, ]prev/next unmatched bracket
_beginning of the current line
+first non-whitespace character of the next line
-first non-whitespace character of the previous line
Command(s)Description
gg, Gjump to first/last line
Command(s)Description
rreplace character under cursor
d, Ddelete a range or object
c, Cchange a range or object (delete, then go to insert mode)
s, Ssubstitute (like change, but can only delete at the cursor)
x, Xdelete under cursor
y, Yyank (copy) into the clipboard
p, Ppaste from the clipboard
u, ⌃rundo, redo
~toggle upper/lowercase under cursor
gulowercase under cursor (u in visual mode)
gUuppercase under cursor (U in visual mode)
Jjoin current and following lines
.repeat last edit

See Vim docs: editing for more information.

Command(s)Description
iinner (exclude delimiters in text object)
aaround (include delimiters in text object)
w, Wwhitespace-delimited string (word)
", ', ```quote-delimited string
(, {, [parenthesized/bracketed string

See Vim docs: text objects for more information.

Command(s)Description
t, T, f, Ffind next/prev matching character on line
;repeat last character search in the same direction
,repeat last character search in the opposite direction

See Vim docs: left-right motions for more information.

Unlike Vim, general search commands don’t search within the buffer. Instead, they open Warp’s native command search.

Command(s)Description
/, ?, *, #open Warp command search
Command(s)Description
iinsert text before the cursor
Iinsert text before the first non-whitespace character in the line
aappend text after the cursor
Aappend text at the end of the line
obegin new line below the cursor and insert text
Obegin new line above the cursor and insert text
vvisual character mode
Vvisual line mode

See Vim docs: insert and Vim docs: visual mode for more information.

Command(s)Description
"register prefix

Warp currently supports the following registers:

Register nameDescription
az, AZnamed registers
+system clipboard
*system clipboard
"unnamed register, containing the text of the last delete or yank

See Vim docs: registers for more information.

The best way to report bugs and request features is through Warp’s GitHub Issues page. Please note that the issue or request is for Vim Keybindings.