Small tmux session controller with recurring sends
Project description
tmuxctl
tmuxctl is a small tmux workflow helper for three things:
- finding the session you want
- jumping to it quickly
- sending recurring follow-ups to long-running agent or worker sessions
It installs two executables:
tmuxctlt
t is just the shorter alias for the same CLI.
Install
Primary install:
uv tool install tmuxctl
Then use either:
tmuxctl --help
t --help
Run without arguments to see the 10 most recent sessions plus shortcut hints:
tmuxctl
t
Core Workflow
1. Find the session you want
Show all sessions, sorted by recency, with numeric IDs:
t list
Short form:
t l
tl
Typical output:
IDX SESSION CREATED
1 codex 2026-04-03 15:56:59
2 backend-worker 2026-04-03 15:22:10
3 docs 2026-04-03 14:10:31
If you just want the recent view:
t
t r
t recent --limit 10
2. Jump into a session
Attach by name:
t codex
That is equivalent to:
t attach codex
Attach by recency index:
t 1
t 2
t 10
Those resolve to attach-recent N.
Attach to the newest session directly:
t attach-last
3. Create a session if it does not exist
Use a leading colon when you want create-or-attach behavior:
t :codex
That resolves to:
t create-or-attach codex
Rule of thumb:
t codexmeans attach onlyt :codexmeans create or attach
Use t - to derive the session name from the current directory and create-or-attach it:
cd ~/git/workshops
t -
That resolves to:
t create-or-attach git-workshops
If you want another session for the same folder, add any suffix:
cd ~/git/workshops
t -asd
That resolves to:
t create-or-attach git-workshops-asd
4. Send a one-off message
Send text directly:
t send codex --message "check status and continue"
Or send from a file:
t send rk-codex --message-file prompts/rk-codex-progress.txt
By default, send waits 200ms before pressing Enter. You can change that:
t send codex --message "status?" --enter-delay-ms 500
t send codex --message "status?" --no-enter
Automation Workflow
1. Add a recurring job
Inline message:
t jobs add codex --every 15m --message "check status and continue"
If you are already inside tmux, use :current to target the active session without typing its name:
t jobs add :current --every 15m --message \
"Check project status and continue. Help any blocked agents, review CI, and \
keep the pipeline moving. If nothing in the current batch needs attention, \
pick the next two ready issues per _docs/PROCESS.md and run the full workflow."
Shared prompt file:
t jobs add rk-codex --every 30m --message-file prompts/rk-codex-progress.txt
When a job uses --message-file, tmuxctl stores the file path and reads the file at send time. Updating the file updates future scheduled runs.
2. Run the scheduler
t jobs daemon
Recurring jobs only run while the daemon is running.
3. Inspect and edit jobs
t jobs
t jobs list
t jobs show 2
t jobs logs --limit 20
t jobs edit 2 --every 45m
t jobs edit 2 --message "check status and continue"
t jobs edit 2 --session :current
t jobs edit 3 --message-file prompts/rk-codex-progress.txt
Useful job controls:
t jobs pause 3
t jobs pause-current
t jobs resume 3
t jobs resume-current
t jobs remove 3
If a scheduled job fails 3 runs in a row, tmuxctl jobs daemon removes it automatically.
Session Cleanup
Kill a session by name:
t kill codex
Kill a session by the numeric ID shown in t list:
t kill 2
Skip confirmation:
t k 2 --yes
Rename a session and retarget any scheduled jobs bound to it:
t rename codex codex-main
t rename 2 archived-worker
Shell Setup
Bash completion
Install completion:
t --install-completion
Preview the script:
t --show-completion bash
Completion works for:
- commands
- plain session names
:sessionshortcuts
Local checkout helper
If you are working from this repository and want its virtualenv binaries on your PATH, run:
./install.sh
That appends this repo's .venv/bin and alias tl='t l' to ~/.bashrc, skipping any line that is already present.
How Scheduling Works
Recurring jobs are stored in:
~/.config/tmuxctl/tmuxctl.db
The scheduler is database-driven:
jobs addcreates jobsjobs edit,jobs pause,jobs resume, andjobs removemodify jobsjobs daemonpolls for due jobs and runs them
If you want recurring jobs to survive logout or reboot, keep t jobs daemon running with something like:
systemd --userlaunchdcron @reboot
Running as a systemd user service (Linux)
Create ~/.config/systemd/user/tmuxctl.service:
[Unit]
Description=tmuxctl scheduler daemon
After=default.target
[Service]
Type=simple
ExecStart=%h/.local/bin/tmuxctl jobs daemon
Restart=on-failure
RestartSec=5
[Install]
WantedBy=default.target
Adjust ExecStart to wherever tmuxctl is installed (for a local editable checkout, point at .venv/bin/tmuxctl). Then enable and start it:
systemctl --user daemon-reload
systemctl --user enable --now tmuxctl.service
systemctl --user status tmuxctl.service
To keep the daemon running after you log out, enable lingering for your user (needs sudo, one-time):
sudo loginctl enable-linger "$USER"
Logs are available via journalctl --user -u tmuxctl -f.
Alternatives
Install with pip:
pip install tmuxctl
Install directly from GitHub:
uv tool install git+https://github.com/alexeygrigorev/tmuxctl.git
Install from a local checkout in editable mode:
git clone https://github.com/alexeygrigorev/tmuxctl.git
cd tmuxctl
uv tool install -e .
If you use the local checkout install, also run:
./install.sh
Reinstall the local checkout after updates:
uv tool install -e . --force
For development:
uv sync --dev
uv run pytest
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file tmuxctl-0.1.4.tar.gz.
File metadata
- Download URL: tmuxctl-0.1.4.tar.gz
- Upload date:
- Size: 21.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b6a8a4e2def678b5dfa5ca94a3196494356863fd1175bdd8bf606d2fcf93e958
|
|
| MD5 |
334f326f9cf1f6f175850ca85a8b4bd0
|
|
| BLAKE2b-256 |
bfd52343ea209829d19c3f8bfad01d0d237d17d6e19eee44aa9cded066b320ee
|
File details
Details for the file tmuxctl-0.1.4-py3-none-any.whl.
File metadata
- Download URL: tmuxctl-0.1.4-py3-none-any.whl
- Upload date:
- Size: 16.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cabf1f3728d634cceeb6b0ff436a760954d32baedb57a505418df2a9275802e5
|
|
| MD5 |
e952391fde29644db0a86b369a25c549
|
|
| BLAKE2b-256 |
8c0cb82a96309fa7f766f1ac0d2c9539489bcd911b25159f0d90472bd6fba02e
|