Skip to main content

Lightweight tmux automation wrapper and renderer.

Project description

tmux-wrapper

tmux-wrapper is a Python module and CLI for driving a tmux session like a human: type text, press key chords, inspect what changed, and scroll through history.

It is aimed at agent workflows, test automation, and other situations where tmux should be treated as an interactive device instead of a bag of ad-hoc tmux CLI commands.

Installation

pip install tmux-wrapper

After installation, the CLI command is:

tmux-c

To print the bundled inline skill/help text:

tmux-c skill

Requirements

  • Python 3.9+
  • tmux installed and available on PATH

Core Model

Treat one tmux session as a serialized device.

For a given session:

  • send one action
  • wait briefly or inspect
  • then send the next action

Do not overlap wrapper actions against the same session.

The most important mental model is:

  • tmux-wrapper is not a screenshot reader
  • it is an incremental observer whose output depends on the previous capture

Once you treat it that way, the workflow becomes much more predictable.

Main API

from tmux_wrapper import Keys, TMUXWrapper
  • type(text) sends literal text only.
  • press(chords) sends one or more key chords.
  • glance() is the default inspection method.
  • view() is the fallback inspection method when glance() is too compressed.
  • scroll_up(lines=3) / scroll_down(lines=3) provide line-based history scrolling.
  • snapshot() is intentionally disabled.

Inspection Semantics

glance()

glance() is the default inspection method.

It returns:

  • newly added lines as !!...
  • unchanged regions as ...[N unchanged line(s)]
  • [Nothing Changed] when no new additions appeared

Example:

...[12 unchanged lines]
!!new output line
...[3 unchanged lines]

view()

view() is the fallback when you need more context.

Compared with glance():

  • it keeps unchanged context lines
  • it is better when you want the precise current screen region
  • it is noisier than glance()

Recommended Workflow

Default to glance(). Use view() only when glance() does not provide enough context.

Python

from tmux_wrapper import Keys, TMUXWrapper

tmux = TMUXWrapper(session="demo")

tmux.glance()
tmux.type("echo hello")
tmux.glance()
tmux.press([(Keys.Enter,)])
print(tmux.glance())
print(tmux.view())

CLI

tmux-c demo glance
tmux-c demo type "echo hello"
tmux-c demo glance
tmux-c demo press Enter
tmux-c demo glance
tmux-c demo view

Command Entry Safety

  • Before typing into an existing shell, inspect first.
  • If the pane may still be running something, use press Ctrl+C, then inspect again until you see a stable prompt.
  • If a shell line may already contain partial input, clear it before retyping.
  • Prefer press Ctrl+C for interrupting a running process.
  • Use press Ctrl+U only when you specifically want to clear the current shell line.
  • Do not send type "..." and press Enter in the same parallel batch.
  • For long commands, prefer:
    • glance
    • type
    • glance or a short wait
    • press Enter
    • glance
  • If the command text is visible at the prompt but did not execute, press Enter once and inspect. Do not retype until you know the line is clean.

Recommended shared-shell pattern:

tmux-c demo glance
tmux-c demo press Ctrl+C
tmux-c demo glance
tmux-c demo type "python your_long_running_command.py ..."
tmux-c demo glance
tmux-c demo press Enter
tmux-c demo glance

Common Patterns

Run a command

tmux-c demo type "pytest -q"
tmux-c demo press Enter
tmux-c demo glance

Interrupt

tmux-c demo press Ctrl+C

Pane navigation

tmux-c demo press Ctrl+B Left
tmux-c demo press Ctrl+B Right

Zoom toggle

tmux-c demo press Ctrl+B Z

Scroll through output

tmux-c demo scroll_up 20
tmux-c demo glance
tmux-c demo scroll_down 20
tmux-c demo glance

Practical Usage Notes

  • glance() is best for “what was added?”
  • view() is better when you want the exact visible screen region
  • scroll_up() enters tmux history; it does not rerun the command
  • scroll_down 9999 is a practical way to return to the bottom and usually exits copy mode too
  • When reading the top of a big file, the most reliable flow is:
    • print the whole file once
    • scroll up in small steps
    • inspect with glance()
  • If you scroll too far in one jump, you may end up in older terminal history instead of the output you just produced
  • The diff baseline persists per session, so always keep track of what the last capture was
  • If the session becomes messy, the usual recovery pattern is:
    • press Ctrl+C
    • scroll_down 9999
    • inspect
    • rerun the command

Session Behavior

  • TMUXWrapper(session="name") creates the session if it does not already exist.
  • If the wrapper created the session, object cleanup deletes it by default.
  • Calling delete() always deletes the session immediately.
  • view() and glance() are stateful because they update the stored baseline.
  • CLI baseline state is persisted per session so separate tmux-c invocations can still diff correctly.

Development

Install development dependencies with uv:

uv sync --dev

Run tests:

env -u VIRTUAL_ENV uv run pytest -q

Build distributions:

env -u VIRTUAL_ENV uv build

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tmux_wrapper-0.1.3.tar.gz (17.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

tmux_wrapper-0.1.3-py3-none-any.whl (16.1 kB view details)

Uploaded Python 3

File details

Details for the file tmux_wrapper-0.1.3.tar.gz.

File metadata

  • Download URL: tmux_wrapper-0.1.3.tar.gz
  • Upload date:
  • Size: 17.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for tmux_wrapper-0.1.3.tar.gz
Algorithm Hash digest
SHA256 adac144fa05bba3c03d6200faf289698471a3c998f83300a262d2903ff98ba48
MD5 37c5115aeb4d75a8ed9774420c65aaa2
BLAKE2b-256 74f1608734d2550a9e4b927a7547814bce0b40b7d8ca2a32521c82b44c6b5694

See more details on using hashes here.

Provenance

The following attestation bundles were made for tmux_wrapper-0.1.3.tar.gz:

Publisher: python-publish.yml on Randomizez/TmuxWrapper

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file tmux_wrapper-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: tmux_wrapper-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 16.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for tmux_wrapper-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 fa4c1e0f3702b6563ee6c7c00ed9e7952973f2cccdff85e555b99184ceb529d6
MD5 de914fa657ef7c8eaca95b2d22ebe19e
BLAKE2b-256 b6035a1f2e796631962f3da6283c5a4cb32a4d098ca37d4ae8e3fe531fb3ab9b

See more details on using hashes here.

Provenance

The following attestation bundles were made for tmux_wrapper-0.1.3-py3-none-any.whl:

Publisher: python-publish.yml on Randomizez/TmuxWrapper

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page