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.2.tar.gz (17.3 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.2-py3-none-any.whl (16.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: tmux_wrapper-0.1.2.tar.gz
  • Upload date:
  • Size: 17.3 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.2.tar.gz
Algorithm Hash digest
SHA256 e689fa75b170bba32d9fd1238bdfe3c9c2db55e7f873bbf0ff79a2dc826d8f36
MD5 f761c68906734e55661560c11d700e0c
BLAKE2b-256 ad5b272b7432d5386724d96cd339602cbe97d9b62ad51c4818305601e5373ee0

See more details on using hashes here.

Provenance

The following attestation bundles were made for tmux_wrapper-0.1.2.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.2-py3-none-any.whl.

File metadata

  • Download URL: tmux_wrapper-0.1.2-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.2-py3-none-any.whl
Algorithm Hash digest
SHA256 61da46ff5501d18bdd56b04a4641658d3c59062f6570449f221d86f0b51f6edb
MD5 0f6f7cd0ec1e13443b0250535f60ec0c
BLAKE2b-256 3cf2df36074d23a3a63da2f7acd4164cb92ac85273732b69788e24c62e1b49e0

See more details on using hashes here.

Provenance

The following attestation bundles were made for tmux_wrapper-0.1.2-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