Tmux
Verified@steipete
npx machina-cli add skill @steipete/tmux --openclawtmux Skill (Clawdbot)
Use tmux only when you need an interactive TTY. Prefer bash background mode for long-running, non-interactive tasks.
Quickstart (isolated socket, bash tool)
SOCKET_DIR="${CLAWDBOT_TMUX_SOCKET_DIR:-${TMPDIR:-/tmp}/clawdbot-tmux-sockets}"
mkdir -p "$SOCKET_DIR"
SOCKET="$SOCKET_DIR/clawdbot.sock"
SESSION=clawdbot-python
tmux -S "$SOCKET" new -d -s "$SESSION" -n shell
tmux -S "$SOCKET" send-keys -t "$SESSION":0.0 -- 'PYTHON_BASIC_REPL=1 python3 -q' Enter
tmux -S "$SOCKET" capture-pane -p -J -t "$SESSION":0.0 -S -200
After starting a session, always print monitor commands:
To monitor:
tmux -S "$SOCKET" attach -t "$SESSION"
tmux -S "$SOCKET" capture-pane -p -J -t "$SESSION":0.0 -S -200
Socket convention
- Use
CLAWDBOT_TMUX_SOCKET_DIR(default${TMPDIR:-/tmp}/clawdbot-tmux-sockets). - Default socket path:
"$CLAWDBOT_TMUX_SOCKET_DIR/clawdbot.sock".
Targeting panes and naming
- Target format:
session:window.pane(defaults to:0.0). - Keep names short; avoid spaces.
- Inspect:
tmux -S "$SOCKET" list-sessions,tmux -S "$SOCKET" list-panes -a.
Finding sessions
- List sessions on your socket:
{baseDir}/scripts/find-sessions.sh -S "$SOCKET". - Scan all sockets:
{baseDir}/scripts/find-sessions.sh --all(usesCLAWDBOT_TMUX_SOCKET_DIR).
Sending input safely
- Prefer literal sends:
tmux -S "$SOCKET" send-keys -t target -l -- "$cmd". - Control keys:
tmux -S "$SOCKET" send-keys -t target C-c.
Watching output
- Capture recent history:
tmux -S "$SOCKET" capture-pane -p -J -t target -S -200. - Wait for prompts:
{baseDir}/scripts/wait-for-text.sh -t session:0.0 -p 'pattern'. - Attaching is OK; detach with
Ctrl+b d.
Spawning processes
- For python REPLs, set
PYTHON_BASIC_REPL=1(non-basic REPL breaks send-keys flows).
Windows / WSL
- tmux is supported on macOS/Linux. On Windows, use WSL and install tmux inside WSL.
- This skill is gated to
darwin/linuxand requirestmuxon PATH.
Orchestrating Coding Agents (Codex, Claude Code)
tmux excels at running multiple coding agents in parallel:
SOCKET="${TMPDIR:-/tmp}/codex-army.sock"
# Create multiple sessions
for i in 1 2 3 4 5; do
tmux -S "$SOCKET" new-session -d -s "agent-$i"
done
# Launch agents in different workdirs
tmux -S "$SOCKET" send-keys -t agent-1 "cd /tmp/project1 && codex --yolo 'Fix bug X'" Enter
tmux -S "$SOCKET" send-keys -t agent-2 "cd /tmp/project2 && codex --yolo 'Fix bug Y'" Enter
# Poll for completion (check if prompt returned)
for sess in agent-1 agent-2; do
if tmux -S "$SOCKET" capture-pane -p -t "$sess" -S -3 | grep -q "❯"; then
echo "$sess: DONE"
else
echo "$sess: Running..."
fi
done
# Get full output from completed session
tmux -S "$SOCKET" capture-pane -p -t agent-1 -S -500
Tips:
- Use separate git worktrees for parallel fixes (no branch conflicts)
pnpm installfirst before running codex in fresh clones- Check for shell prompt (
❯or$) to detect completion - Codex needs
--yoloor--full-autofor non-interactive fixes
Cleanup
- Kill a session:
tmux -S "$SOCKET" kill-session -t "$SESSION". - Kill all sessions on a socket:
tmux -S "$SOCKET" list-sessions -F '#{session_name}' | xargs -r -n1 tmux -S "$SOCKET" kill-session -t. - Remove everything on the private socket:
tmux -S "$SOCKET" kill-server.
Helper: wait-for-text.sh
{baseDir}/scripts/wait-for-text.sh polls a pane for a regex (or fixed string) with a timeout.
{baseDir}/scripts/wait-for-text.sh -t session:0.0 -p 'pattern' [-F] [-T 20] [-i 0.5] [-l 2000]
-t/--targetpane target (required)-p/--patternregex to match (required); add-Ffor fixed string-Ttimeout seconds (integer, default 15)-ipoll interval seconds (default 0.5)-lhistory lines to search (integer, default 1000)
Overview
tmux lets you remotely drive interactive CLIs by sending keystrokes and reading pane output through a private socket. It shines when automating interactive prompts, coordinating multiple coding agents, or orchestrating parallel tasks. Use bash background mode for long-running non-interactive tasks.
How This Skill Works
tmux creates an isolated session via a private socket and uses commands like tmux -S ... new, send-keys, and capture-pane to drive the session and fetch output. You can attach to monitor live progress or detach, and utilities like wait-for-text help synchronize actions with prompts.
When to Use It
- When you need to automate an interactive CLI or REPL (prompts, confirmations, dynamic input).
- When coordinating multiple coding agents in parallel (e.g., running separate sessions for different tasks).
- When you require real-time monitoring of a session's output via capture-pane and periodic checks.
- When debugging or automating prompts that depend on specific text patterns (using wait-for-text).
- When you want to attach/detach sessions to observe live workflows across a private tmux socket.
Quick Start
- Step 1: SOCKET_DIR="${CLAWDBOT_TMUX_SOCKET_DIR:-${TMPDIR:-/tmp}/clawdbot-tmux-sockets}"; mkdir -p "$SOCKET_DIR"; SOCKET="$SOCKET_DIR/clawdbot.sock"; SESSION=clawdbot-python
- Step 2: tmux -S "$SOCKET" new -d -s "$SESSION" -n shell
- Step 3: tmux -S "$SOCKET" send-keys -t "$SESSION":0.0 -- 'PYTHON_BASIC_REPL=1 python3 -q' Enter; tmux -S "$SOCKET" capture-pane -p -J -t "$SESSION":0.0 -S -200
Best Practices
- Use an isolated socket directory and unique, short session names to avoid collisions.
- Target panes with session:window.pane and avoid spaces in names for reliability.
- Send inputs with literal sends (-l) where appropriate and clear keyboard sequences (Enter, C-c).
- Regularly capture pane output and wait-for-text to synchronize on prompts or results.
- For Python work, set PYTHON_BASIC_REPL=1 to ensure stable send-keys interactions.
Example Use Cases
- Orchestrate multiple coding agents in parallel: create several sessions (agent-1, agent-2, etc.), launch commands in each, and poll for completion by inspecting pane text.
- Run an interactive Python REPL inside tmux with PYTHON_BASIC_REPL=1 and feed commands via send-keys, capturing results periodically.
- Automate a long-running bash task by sending inputs and using capture-pane to fetch logs for auditing.
- Debug an interactive CLI tool by programmatically sending commands and waiting for specific prompts to appear.
- Coordinate a multi-session workflow by attaching to a session for live monitoring and detaching when not needed.