Get the FREE Ultimate OpenClaw Setup Guide →
P

Tmux

Verified

@steipete

npx machina-cli add skill @steipete/tmux --openclaw
Files (1)
SKILL.md
4.0 KB

tmux 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 (uses CLAWDBOT_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/linux and requires tmux on 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 install first before running codex in fresh clones
  • Check for shell prompt ( or $) to detect completion
  • Codex needs --yolo or --full-auto for 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/--target pane target (required)
  • -p/--pattern regex to match (required); add -F for fixed string
  • -T timeout seconds (integer, default 15)
  • -i poll interval seconds (default 0.5)
  • -l history lines to search (integer, default 1000)

Source

git clone https://clawhub.ai/steipete/tmuxView on GitHub

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

  1. 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
  2. Step 2: tmux -S "$SOCKET" new -d -s "$SESSION" -n shell
  3. 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.

Frequently Asked Questions

Add this skill to your agents
Sponsor this space

Reach thousands of developers