Skip to content

Insert/replace mode (IRM)

Category: modes · Baseline: modern · Tags: ECMA-48 Standard · Specification ↗

ESC [ 4 h
IRM (Insert/Replace Mode) controls whether new characters insert (shifting existing content right) or replace (overwriting) at the cursor. Enable insert mode with ESC [ 4 h, disable (replace mode) with ESC [ 4 l. Replace mode is the default. Most modern TUI applications use explicit ICH/DCH sequences rather than IRM.
How this is testedautomated
Write "ABC", move to col 1, send \x1b[4h (IRM), write "X", verify X is at col 0 and A shifted to col 1.

The same probe runs against headless backends (via Termless) and real terminal apps (via a daemon launched in each terminal). This lets us distinguish parser correctness from rendering correctness.

Analysis2026-04-06

Supported by 11 of 12 terminals (92%). Not supported by: vt100.js. Part of the Modern TUI baseline. Notes: vt100.js: IRM (insert/replace mode) not implemented in vt100.js baseline emulator.

Supported by 12 of 14 backends (86%)

Terminal Applications

TerminalVersionSupportNotes
iTerm23.6.9✓ yes
Ghostty1.3.1✓ yes
VS Code✓ yes
Warp✓ yes
Cursor✓ yes
Terminal.app✓ yes

Headless Backends

Parser correctness only — a means the parser accepts the sequence.

BackendVersionSupportNotes
Alacritty0.26.0✓ yes
vterm0.2.0✓ yes
WezTerm0.1.0-fork.5✓ yes
xterm.js5.5.0✓ yes
Kitty0.40.0~ partialNot exposed via Python batch bridge
vt100.js0.2.1✗ noIRM (insert/replace mode) not implemented in vt100.js baseline emulator