Integration
Attyx exposes a full IPC interface over sockets. Scripts, AI agents, and external tools can create tabs, split panes, send keystrokes, read screen content, and more — all from the command line.
How it works
Section titled “How it works”Every running Attyx instance listens on a socket:
| Platform | Path |
|---|---|
| macOS / Linux | ~/.local/state/attyx/ctl-<pid>.sock (Unix domain socket) |
| Windows | Named pipe \\.\pipe\attyx-ctl-<pid> |
The attyx binary doubles as both the terminal and the IPC client. When you run a subcommand like attyx tab create, it connects to the socket of the most recently active instance and sends the command.
Global options
Section titled “Global options”All IPC commands accept these flags:
| Flag | Description |
|---|---|
--target <pid> | Send to a specific Attyx instance by PID |
-s, --session <id> | Route the command to a specific session |
--json | Output in JSON format for programmatic use |
--help, -h | Show help for any command |
Pane targeting
Section titled “Pane targeting”Every pane has a stable numeric ID that never changes once assigned. IDs are monotonically increasing integers (1, 2, 3, …) — they don’t get reused when other panes close. Use attyx list to see them.
Almost all commands accept --pane (-p) to target a specific pane without changing focus:
attyx send-keys -p 3 "ls -la\n" # send to pane 3attyx get-text -p 3 # read from pane 3attyx split close -p 5 # close pane 5attyx split zoom -p 5 # toggle zoom on pane 5attyx split rotate -p 3 # rotate splits in pane 3's tabTab commands accept a positional tab number instead:
attyx tab close 3 # close tab 3attyx tab rename 2 "build logs" # rename tab 2Tracking new pane IDs
Section titled “Tracking new pane IDs”When you create a tab or split, the command returns the new pane’s ID:
id=$(attyx tab create) # returns e.g. "4"id=$(attyx split v --cmd htop) # returns e.g. "5"Capture this output to target the pane later without guessing:
id=$(attyx split v --cmd python3)attyx send-keys -p "$id" "print('hello')\r"attyx get-text -p "$id"attyx split close -p "$id"Session-targeted commands
Section titled “Session-targeted commands”Use -s/--session <id> to route any command to a specific session:
attyx -s 2 tab create # create tab in session 2attyx -s 2 send-keys -p 3 "ls\n" # send to pane 3 in session 2attyx -s 2 get-text -p 5 # read from pane 5 in session 2attyx -s 2 list # list tabs/panes in session 2When -s is omitted, commands target the currently attached session.
attyx tab create # new shell tabattyx tab create --cmd htop # new tab running htopattyx tab create --cmd "make test" --wait # wait for exit codeattyx tab close # close active tabattyx tab close 3 # close tab 3attyx tab next # switch to next tabattyx tab prev # switch to previous tabattyx tab select 3 # jump to tab 3 (1-indexed)attyx tab move left # reorder tab leftattyx tab move right # reorder tab rightattyx tab rename "build logs" # set active tab titleattyx tab rename 2 "build logs" # set tab 2 titleOptions for tab create
Section titled “Options for tab create”| Option | Description |
|---|---|
--cmd <command> | Run a command instead of a bare shell. Runs inside a full interactive shell with your PATH and config. The shell stays open after the command exits. |
--wait, -w | Wait for the command to exit and return its exit code. Requires --cmd. |
Splits
Section titled “Splits”attyx split vertical # new pane to the rightattyx split horizontal # new pane belowattyx split v --cmd claude # vertical split running claudeattyx split h --cmd htop --wait # horizontal split, wait for exitattyx split close # close focused paneattyx split close -p 3 # close pane 3 (no focus change)attyx split rotate # rotate layout in active tabattyx split rotate -p 3 # rotate layout in pane 3's tabattyx split zoom # toggle zoom on focused paneattyx split zoom -p 5 # toggle zoom on pane 5v and h are aliases for vertical and horizontal. The --cmd and --wait options work the same as tab create.
Move focus between panes. Focus determines which pane receives input from send-keys and send-text.
attyx focus upattyx focus downattyx focus leftattyx focus rightSending input
Section titled “Sending input”send-keys
Section titled “send-keys”Send keystrokes to a pane with C-style escape sequence support. Targets the focused pane by default, or use -p to target a specific pane.
attyx send-keys "ls -la\n" # type ls -la and press Enterattyx send-keys -p 3 "ls\n" # send to pane 3 (no focus change)attyx send-keys "\x03" # Ctrl-C (interrupt)attyx send-keys -p 5 "\x03" # Ctrl-C to pane 5attyx send-keys "\x04" # Ctrl-D (EOF)attyx send-keys "\x1b" # Escapeattyx send-keys "\x1b[A\n" # Arrow up then Enterattyx send-keys "q" # press q (e.g. quit less)attyx send-keys "y\n" # confirm a promptOptions for send-keys
Section titled “Options for send-keys”| Option | Description |
|---|---|
-p, --pane <id> | Target a specific pane by ID |
--wait-stable [ms] | Wait for pane output to stabilize before returning. Optional timeout in milliseconds. |
Escape sequences
Section titled “Escape sequences”| Sequence | Key |
|---|---|
\n | Enter / newline |
\t | Tab |
\x03 | Ctrl-C |
\x04 | Ctrl-D |
\x1a | Ctrl-Z |
\x1b | Escape |
\x1b[A | Arrow up |
\x1b[B | Arrow down |
\x1b[C | Arrow right |
\x1b[D | Arrow left |
\x7f | Backspace |
Named keys
Section titled “Named keys”You can also use named key tokens in curly braces:
attyx send-keys "{Up}{Enter}" # arrow up then Enterattyx send-keys "{Ctrl-c}" # Ctrl-Cattyx send-keys "{Shift-Tab}" # Shift-Tabattyx send-keys "{Ctrl-Shift-Up}" # combined modifiersattyx send-keys "{F1}" # function key| Token | Key |
|---|---|
{Up}, {Down}, {Left}, {Right} | Arrow keys |
{Home}, {End}, {PgUp}, {PgDn} | Navigation |
{Enter}, {Tab}, {Escape} | Common keys |
{Backspace}, {Delete}, {Insert} | Editing keys |
{F1}–{F12} | Function keys |
{Ctrl-c}, {Alt-a}, {Shift-Tab} | Modifier combos |
send-text
Section titled “send-text”Send raw text to a pane. Supports the same escape sequences as send-keys.
attyx send-text "hello" # write "hello" (no newline)attyx send-text -p 3 "hello" # write to pane 3attyx send-text "echo hello\n" # write "echo hello" + EnterReading screen content
Section titled “Reading screen content”Read the visible text from a pane (focused pane by default).
attyx get-text # plain text, one line per rowattyx get-text -p 3 # read from pane 3attyx get-text --json # { "lines": ["row1", "row2", ...] }attyx get-text -p 5 --json # pane 5 as JSONTrailing whitespace is trimmed per row. Empty trailing rows are omitted.
Querying state
Section titled “Querying state”attyx list # full tab/pane treeattyx list tabs # tab names and indicesattyx list splits # panes in active tabattyx list sessions # daemon sessionsattyx list --json # any of the above as JSONpanes is an alias for splits.
Configuration
Section titled “Configuration”attyx reload # hot-reload config from diskattyx theme dracula # switch themeattyx theme "catppuccin-mocha"Scrolling
Section titled “Scrolling”attyx scroll-to topattyx scroll-to bottomattyx scroll-to page-upattyx scroll-to page-downPopups
Section titled “Popups”Open a floating terminal overlay. Closes when the command exits.
attyx popup lazygitattyx popup htop --width 90 --height 90attyx popup fzf --width 60 --height 40 --border noneattyx popup "k9s" --border heavy| Option | Default | Description |
|---|---|---|
--width, -w | 80 | Width as % of terminal (1-100) |
--height | 80 | Height as % of terminal (1-100) |
--border, -b | rounded | Border style: single, double, rounded, heavy, none |
Sessions
Section titled “Sessions”attyx session list # list all sessionsattyx session create # create new sessionattyx session switch 2 # switch to session 2attyx session rename "dev server" # rename current sessionattyx session rename 1 "dev server" # rename session 1attyx session kill 3 # kill session 3Run (shorthand)
Section titled “Run (shorthand)”attyx run is shorthand for attyx tab create --cmd:
attyx run htop # open tab running htopattyx run "make test" --wait # run and wait for exit codeattyx run claude # open tab running claudeTargeting instances
Section titled “Targeting instances”By default, IPC commands target the most recently active Attyx instance. To target a specific one:
attyx --target 12345 tab createYou can also set the ATTYX_PID environment variable. Socket discovery scans ~/.local/state/attyx/ for ctl-*.sock files and picks the most recently modified one.
JSON output
Section titled “JSON output”All query commands support --json for structured output:
attyx list --jsonattyx list tabs --jsonattyx get-text --jsonattyx session list --jsonErrors are returned as {"error": "message"}.
Wait mode
Section titled “Wait mode”The --wait flag on tab create, split vertical, and split horizontal blocks until the command exits and returns its exit code:
attyx run "make test" --wait && echo "Tests passed"attyx split v --cmd "cargo build" --waitThis is useful for scripting workflows where you need to know if a command succeeded.
Agent workflow
Section titled “Agent workflow”A typical AI agent or automation script interacts with Attyx using pane targeting — capture the ID on creation, then use -p for all subsequent commands. This avoids focus juggling entirely.
# 1. Open a pane and capture its stable IDid=$(attyx split v --cmd "your-tool")
# 2. Read the output (by pane ID, no focus change)attyx get-text -p "$id"
# 3. Send inputattyx send-keys -p "$id" "some input\n"
# 4. Read the resultattyx get-text -p "$id"
# 5. Clean upattyx split close -p "$id"For commands that take time to produce output, poll instead of guessing with sleep:
# Wait for output to stabilize (poll every 2s, 2 stable reads = done)stable=0; prev=""; for i in $(seq 1 15); do sleep 2 curr=$(attyx get-text -p "$id" 2>/dev/null) if [ "$curr" = "$prev" ] && [ -n "$curr" ]; then stable=$((stable + 1)) [ $stable -ge 2 ] && break else stable=0 fi prev="$curr"doneecho "$curr"For quick commands (ls, cat, etc.) a simple sleep 1 is fine. Use polling for anything interactive or slow (builds, installs, AI responses).
All commands
Section titled “All commands”| Command | Description |
|---|---|
tab create [--cmd] [--wait] | Create a new tab (returns pane ID) |
tab close [N] | Close tab N (default: active tab) |
tab next / tab prev | Switch tabs |
tab select <N> | Jump to tab N |
tab move left|right | Reorder tab |
tab rename [N] <name> | Set tab title (default: active tab) |
split vertical|horizontal [--cmd] [--wait] | Split pane (returns pane ID) |
split close [-p <id>] | Close pane (default: focused) |
split rotate [-p <id>] | Rotate layout |
split zoom [-p <id>] | Toggle pane zoom |
focus up|down|left|right | Move focus |
send-keys [-p <id>] [--wait-stable] <keys> | Send keystrokes (with escapes) |
send-text [-p <id>] <text> | Send raw text |
get-text [-p <id>] | Read screen content |
list [tabs|splits|sessions] | Query state |
reload | Hot-reload config |
theme <name> | Switch theme |
scroll-to top|bottom|page-up|page-down | Scroll viewport |
popup <cmd> [--width] [--height] [--border] | Open popup |
session list|create|kill|switch|rename | Manage sessions |
run <cmd> [--wait] | Shorthand for tab create --cmd |