Skip to content

OSC 633;E set commandline

Category: extensions · Baseline: rich · Tags: Operating System Commands (OSC), VS Code Extensions · Specification ↗

ESC ] 633 ; E ; commandline ; nonce BEL

OSC 633;E reports the explicit command line text along with a verification nonce. The format is OSC 633 ; E ; commandline ; nonce BEL. The nonce is a per-session secret known only to the shell integration script and VS Code, preventing replay attacks where malicious output could spoof a command.

This is unique to OSC 633OSC 133 has no equivalent. It exists because VS Code's run-recent-command and command-line history features need to know exactly what the user typed, not what the terminal can infer from cell contents (which loses information about quoting, escapes, and multi-line input). The nonce makes the protocol safe to use even when running untrusted commands that might emit arbitrary escape sequences.

How this is testedpartial
Send OSC 633 ; E ; ls -la ; nonce123 BEL and verify the terminal consumes the sequence (cursor doesn't advance, terminal remains responsive).

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 all 9 tested terminals — universal adoption. Part of the Rich TUI baseline.

Supported by 11 of 14 backends (79%)

Terminal Applications

TerminalVersionSupportNotes
iTerm23.6.9✓ yes
Ghostty1.3.1✓ yes
Terminal.app2.15✓ yes
Kitty0.46.2✓ yes
VS Code1.113.0? unknown
Warp0.2026.03.18.08.24.03? unknown
Cursor2.6.21? unknown

Headless Backends

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

BackendVersionSupportNotes
Alacritty0.26.0✓ yes
vt100.js0.2.1✓ yes
vterm0.2.0✓ yes
WezTerm0.1.0-fork.5✓ yes
xterm.js5.5.0✓ yes