zellij

Remote-control zellij sessions for interactive CLIs by sending keystrokes and scraping pane output.

Safety Notice

This listing is from the official public ClawHub registry. Review SKILL.md and referenced scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "zellij" with this command: npx skills add jivvei/zellij

zellij Skill (Moltbot)

Use zellij only when you need an interactive TTY. Prefer exec background mode for long-running, non-interactive tasks.

Quickstart (data dir, exec tool)

DATA_DIR="${CLAWDBOT_ZELLIJ_DATA_DIR:-${TMPDIR:-/tmp}/moltbot-zellij-data}"
mkdir -p "$DATA_DIR"
SESSION=moltbot-python

zellij --data-dir "$DATA_DIR" new-session --session "$SESSION" --layout "default" --detach
zellij --data-dir "$DATA_DIR" run --session "$SESSION" --name repl -- python3 -q
zellij --data-dir "$DATA_DIR" pipe --session "$SESSION" --pane-id 0

After starting a session, always print monitor commands:

To monitor:
  zellij --data-dir "$DATA_DIR" attach --session "$SESSION"
  zellij --data-dir "$DATA_DIR" pipe --session "$SESSION" --pane-id 0

Data directory convention

  • Use CLAWDBOT_ZELLIJ_DATA_DIR (default ${TMPDIR:-/tmp}/moltbot-zellij-data).
  • Zellij stores state (sessions, plugins, etc.) in this directory.

Targeting panes and naming

  • Zellij uses pane-id (numeric) to target specific panes.
  • Find pane IDs: zellij --data-dir "$DATA_DIR" list-sessions --long or use list-panes.sh.
  • Keep session names short; avoid spaces.

Finding sessions

  • List sessions on your data dir: zellij --data-dir "$DATA_DIR" list-sessions.
  • List sessions across all data dirs: {baseDir}/scripts/find-sessions.sh --all (uses CLAWDBOT_ZELLIJ_DATA_DIR).

Sending input safely

  • Use zellij action to send keystrokes: zellij --data-dir "$DATA_DIR" action --session "$SESSION" write-chars --chars "$cmd".
  • Control keys: zellij --data-dir "$DATA_DIR" action --session "$SESSION" write 2 (Ctrl+C).

Watching output

  • Capture pane output: zellij --data-dir "$DATA_DIR" pipe --session "$SESSION" --pane-id 0.
  • Wait for prompts: {baseDir}/scripts/wait-for-text.sh -s "$SESSION" -p 0 -p 'pattern'.
  • Attaching is OK; detach with Ctrl+p d (zellij default detach).

Spawning processes

  • For python REPLs, zellij works well with standard python3 -q.
  • No special flags needed like tmux's PYTHON_BASIC_REPL=1.

Windows / WSL

  • zellij is supported on macOS/Linux. On Windows, use WSL and install zellij inside WSL.
  • This skill is gated to darwin/linux and requires zellij on PATH.

Orchestrating Coding Agents (Codex, Claude Code)

zellij excels at running multiple coding agents in parallel:

DATA_DIR="${TMPDIR:-/tmp}/codex-army-data"

# Create multiple sessions
for i in 1 2 3 4 5; do
  zellij --data-dir "$DATA_DIR" new-session --session "agent-$i" --layout "compact" --detach
done

# Launch agents in different workdirs
zellij --data-dir "$DATA_DIR" action --session "agent-1" write-chars --chars "cd /tmp/project1 && codex --yolo 'Fix bug X'\n"
zellij --data-dir "$DATA_DIR" action --session "agent-2" write-chars --chars "cd /tmp/project2 && codex --yolo 'Fix bug Y'\n"

# Poll for completion (check if prompt returned)
for sess in agent-1 agent-2; do
  pane_id=$(zellij --data-dir "$DATA_DIR" list-sessions --long | grep "\"$sess\"" | jq -r '.tabs[0].panes[0].id')
  if zellij --data-dir "$DATA_DIR" pipe --session "$sess" --pane-id "$pane_id" | grep -q "❯"; then
    echo "$sess: DONE"
  else
    echo "$sess: Running..."
  fi
done

# Get full output from completed session
zellij --data-dir "$DATA_DIR" pipe --session "agent-1" --pane-id 0

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: zellij --data-dir "$DATA_DIR" delete-session --session "$SESSION".
  • Kill all sessions on a data dir: use {baseDir}/scripts/cleanup-sessions.sh "$DATA_DIR".

Zellij vs Tmux Quick Reference

Tasktmuxzellij
List sessionslist-sessionslist-sessions
Create sessionnew-session -dnew-session --detach
Attachattach -tattach --session
Send keyssend-keysaction write-chars
Capture panecapture-panepipe
Kill sessionkill-sessiondelete-session
DetachCtrl+b dCtrl+p d

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 -s session -p pane-id -r 'pattern' [-F] [-T 20] [-i 0.5]
  • -s/--session session name (required)
  • -p/--pane-id pane ID (required)
  • -r/--pattern regex to match (required); add -F for fixed string
  • -T timeout seconds (integer, default 15)
  • -i poll interval seconds (default 0.5)

Helper: find-panes.sh

{baseDir}/scripts/find-panes.sh lists panes for a given session.

{baseDir}/scripts/find-panes.sh -s session [-d data-dir]
  • -s/--session session name (required)
  • -d/--data-dir zellij data dir (uses CLAWDBOT_ZELLIJ_DATA_DIR if not specified)

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Coding

Lucky Tmux Controller

Remote-control tmux sessions for interactive CLIs by sending keystrokes and scraping pane output.

Registry SourceRecently Updated
1310Profile unavailable
Automation

Agent Kanban

OpenClaw Agent Dashboard - A Bloomberg Terminal-style web interface for real-time monitoring of all Agent status, session history, and session file sizes. Us...

Registry SourceRecently Updated
3390Profile unavailable
Automation

Agent Hand

Manage and monitor all your AI agent sessions from a unified terminal with smart sorting, instant switching, and multi-profile support.

Registry SourceRecently Updated
2900Profile unavailable
General

OCT 助手

提供 OpenClaw Terminal (OCT) 的配置模板和使用指南,支持智能对话、系统控制和开发辅助功能。

Registry SourceRecently Updated
2390Profile unavailable