| description | Release notes and version history for workmux |
|---|
- Respect
CLAUDE_CONFIG_DIRwhen installing skills, so custom Claude config locations are honored. (#157)
- Fix Codex status tracking so panes stay marked as working while nested subagents are still running (#154)
- Keep compact sidebar status icons aligned even when icons have different widths
- Add
WORKMUX_DISABLE_SET_WINDOW_STATUS=1to let nested agents skip status hook updates when launched from inside another agent pane. See the status tracking guide
- Allow sandbox deny-mode domains to opt in to trusted private network destinations, such as VPN-hosted package mirrors, while keeping loopback and link-local addresses blocked
- Keep sidebar tile rows stable when template fields are empty, so optional details no longer collapse and shift tile heights unexpectedly
- Add sidebar template customization, letting you choose which labels, git stats, timers, and status details appear in compact and tile layouts. See the sidebar customization guide
- Add customizable per-agent sidebar icons and colors, with built-in defaults for Claude, Codex, OpenCode, Gemini, Pi, Kiro, Vibe, and Copilot
- Support tmux-style colors and attributes inside sidebar templates
- Improve sidebar rendering for git stats, elapsed time, row highlighting, and synchronized width across windows
- Fix pi agents lingering in the dashboard after exit (#143)
- Support
{project}placeholder and~(tilde) expansion inworktree_dir, letting you use config likeworktree_dir = "~/worktrees/{project}"(#148)
- Add
--config <path>flag toworkmux addandworkmux opento use an alternate config file for a single invocation
- Show a progress overlay when sweeping multiple worktrees in the dashboard, instead of freezing silently for several seconds
- Truncate long worktree names in the dashboard so they no longer overflow the panel
- Fix panics caused by Unicode characters in worktree names being truncated at non-character boundaries
- Install via
cargo binstall workmuxis now supported (#137)
- Add
--mode <window|session>flag toworkmux addandworkmux openfor per-command multiplexer mode overrides. Use--mode windowto temporarily reopen a session-mode worktree as a window, or--mode sessionto create a one-off session without changing config. The existing--sessionflag is now shorthand for--mode session(#139) - Add
sandbox.container.excluded_filesconfig to hide sensitive worktree files from sandboxed containers by shadowing them with/dev/null(e.g..env,.env.local). Configurable only in your global config for security (#134) - Restrict
excluded_filesto global config only, preventing malicious projects from disabling file masking via their own.workmux.yaml - Skip
excluded_filesgracefully with a clear warning on runtimes that do not support file-level bind mounts (Apple Container) - Fix sandbox relative gitdir path resolution and improve warning messages for directory entries
- Add
workmux rename [old-name] <new-name>command to rename a worktree, its tmux window or session, agent state, and sandbox container marker. Pass--branchto also rename the underlying git branch (#138) - Add status tracking support for Gemini CLI, so Gemini agents now report
working, waiting, and done states in the dashboard like Claude Code, Codex,
and OpenCode.
workmux setupauto-detects Gemini and installs the required hooks
- Add
container.devicesconfig to expose host device nodes (e.g./dev/kvm,/dev/ttyUSB0) to sandboxed containers - Add
container.group_addconfig to add supplementary groups (e.g.dialout,video) to the sandboxed process
- Fix OpenCode status tracking plugin distribution by moving shipped plugin
files into
resources/opencode/and updatingworkmux setupand manual install instructions to install bothpackage.jsonand the plugin file to OpenCode's global config directory - Fix duplicate OpenCode busy and idle status events causing stale window status transitions
- Fix dashboard agent title prefixes
- Add command palette to the dashboard, accessible via
:. Provides a fuzzy-searchable list of available actions for the current context with their key hints
- Add custom theme color overrides in config. Define custom colors under
theme.customto override any built-in theme's palette, using hex colors, named colors, or terminal color indices (#128) - Render tmux style codes in status icons. Icons configured with tmux styles
like
#[fg=#da8548]●now display with proper colors instead of raw style strings (#130) - Add
--tabflag to dashboard command to open directly on a specific tab (e.g.workmux dashboard --tab agents) (#127)
- Respect the XDG Base Directory Specification for config, cache, and state
paths. Custom
XDG_CONFIG_HOME,XDG_CACHE_HOME, andXDG_STATE_HOMEvalues are now honored, with automatic fallback to defaults. Existing setups continue to work without changes. (#126) - Fix dashboard ignoring
mode: sessionconfig when creating, opening, or checking out worktrees (#129)
- Add
--forkflag toworkmux addfor forking an existing Claude Code conversation into a new worktree, allowing the new agent to resume with full context from a previous session. Currently Claude Code only.
- Fix OpenCode sandbox passing unnecessary OPENCODE_CONFIG environment variable to containers
- Fix pi agent exiting immediately after prompt injection instead of staying in interactive mode (#118
- Clean up worktree-not-found error messages
- Mount OpenCode's global config directory (
~/.config/opencode/) into the sandbox, providing access toopencode.json, plugins, and global MCP definitions (#117)
- Fix concurrent
workmux addcommands failing with "could not lock config file" errors when creating multiple worktrees in parallel (#116)
- Add
--sessionflag toworkmux sidebarto scope the sidebar to a single tmux session instead of all sessions - Add sandbox image freshness checking for Apple Container runtime, notifying when a newer image is available (#115)
- Automatically pull sandbox images when missing or stale, removing the need for
manual
workmux sandbox pull(#115) - Fix
sandbox.host_commandsshims not available in agents that use login shells (e.g. Codex, OpenCode) (#114)
- Fix sidebar daemon dropping all clients after 30s, causing sidebar panes to stop updating
- Fix sidebar width being too narrow in some windows when the sidebar was first opened from a smaller terminal
- Make project name more readable in sidebar tiles
- Fail early with a clear error when the sandbox image is missing from the selected runtime's store (#111)
- Allow
sandbox.imagein project config (.workmux.yaml), so custom container images are no longer silently ignored when set per-project - Fix Codex sandbox warnings about helper binaries in temporary directories and missing bubblewrap (#110)
- Fix high CPU usage on Linux caused by inotify recursive watches when running multiple worktrees with active agents
- Add manual sleeping toggle (
zkey) in the sidebar to deprioritize agents you don't need to monitor, regardless of their actual status - Fix stale indicator incorrectly overriding working or waiting status icons in the sidebar, hiding statuses that require attention
- Fix git diff stats permanently freezing in linked worktrees when filesystem events originated from the shared gitdir
- Fix relative
worktree_dirpaths (e.g.../wm/) being passed literally to sandbox commands instead of resolving..segments (#105) - Fix sidebar daemon signal error appearing in tmux panes on window/session changes (#107)
- Fix Codex binary not found in Apple Container sandbox (#106)
- Improve worktree name detection in the dashboard and sidebar, especially when running in generic tmux sessions (#103)
- Add
zoom: truepane option to maximize a pane to fullscreen after creation, useful for giving an agent pane the full window while keeping other panes available in the background (#102)
- Add named layouts: define reusable pane layout presets in your config and
apply them with
workmux add -l/--layout <name>(#101) - Add
sandbox.envconfig option for setting explicit environment variables inside sandboxed agents, with values redacted in debug logs (#100) - Detect interrupted agents via pane inactivity and show interruption status in the sidebar and dashboard with elapsed time since interruption
- Fix sidebar incorrectly showing all agents as done when only one finishes
- Add named agents: define short names for agent commands in your global config and use them anywhere you'd specify an agent. Useful for multiple accounts, wrapper scripts, or commands with long environment variable overrides
- Add
sidebar: an always-visible agent status panel in a tmux side pane, showing live status, git diff stats, and elapsed timers for all agents across windows. Toggle withworkmux sidebar. See the sidebar guide- Two layout modes: tiles (default) and compact, switchable with
vor viasidebar.layoutin config - Click, scroll, or use keyboard navigation (
j/k/Enter) to jump between agents - Width adapts to terminal size and reflows on resize
- Two layout modes: tiles (default) and compact, switchable with
- Show a rebase indicator icon when a git rebase is in progress
- Fix
last-donesometimes navigating to the wrong agent when multiple agents finish close together last-donecycling is now reliable across repeated invocations, persisting state so the cycle survives even if the sorted order shifts
- Dashboard now uses configured
main_branchfor diff base detection (#97) - Fix PR status fetch being delayed 30 seconds on dashboard open
workmux last-donenow includes waiting agents
- Add Codex status tracking support, showing working/done states in the tmux window list
- Fix incorrect guest home directory with Lima 2.1.0, which changed the path
from
.linuxto.guest(#92) - Dashboard: add
rhotkey to remove worktree from the agents tab - Dashboard: show spinner on PR column header while fetching
- Fix Nix build by adding missing output hashes for crossterm git dependency
- Add
workmux resurrectcommand to restore worktree windows after a tmux or computer crash, automatically resuming agent conversations from where they left off - Dashboard: add worktree creation modal with fzf-style branch picker, fuzzy search, tab completion, and the ability to checkout open pull requests directly via Ctrl+p or by typing a PR number
- Dashboard: dim background behind modal overlays for better visual focus
- Dashboard: fix immediate exit on startup caused by a stray Enter keypress from launching the command being processed before the UI was ready
- Add
--continueflag toworkmux opento resume the last agent conversation when opening a worktree - List: show worktree age in
wm lsoutput as a new AGE column with human-friendly relative time (e.g., 2h, 3d, 1w)
- Dashboard: show elapsed time for pending PR checks and the name of failing checks across all views (PR column, agents pane, worktree info panel)
- Dashboard: add base branch picker (
b) to change a worktree's base branch from either the worktrees or agents tab - Dashboard: open PR checks page in browser with
O(shift-o) to quickly see why checks failed - Dashboard: agent task descriptions now stay up to date in real time instead of showing the initial title
- Fix a crash caused by mouse coordinate overflow when using tmux 3.6a
- Dashboard: open a worktree's pull request in the browser with
o
- Dashboard: add project picker (
p) to switch between projects' worktrees - Dashboard: show PR status and CI checks in worktree table and preview panel
- Dashboard: add worktree sort modes (
s) to cycle between natural and newest-first ordering - Dashboard: add age column to worktree table
- Dashboard: add close mux window action (
c) to stop an agent while keeping the worktree - Dashboard: redesigned worktree preview with info panel and styled git log
- Dashboard: add worktree view as a second tab (press Tab to switch between Agents and Worktrees)
- Dashboard: add bulk sweep (R) to identify and remove worktrees ready for cleanup based on merged/closed PRs, deleted remote branches, or locally merged branches
- Dashboard: add X hotkey to kill an agent directly
- Dashboard: add worktree remove (r) with a context-aware confirmation modal that warns about uncommitted changes or unmerged commits
- Add
workmux list --jsonflag for machine-readable output
- Add
sync-filescommand to re-apply file operations (copy/symlink) to existing worktrees, with--allflag to sync all worktrees at once
- Fix
focus: truenot switching to the correct pane in session mode (#86)
- Add automatic worktree naming support for the pi agent (#84)
- Add
--prompt-file-onlyflag for editors with embedded agents (e.g., neovim with an agent plugin) that consume prompts from the filesystem instead of pane injection (#82) workmux opennow accepts multiple worktree names in a single command (e.g.,workmux open foo bar)
- Add pi agent support for status tracking and setup (#81)
- Add configurable theme for dashboard
- Auto-detect dark/light mode from terminal background
- Press
T(shift+t) in the dashboard to cycle through color schemes; selection persists to config - Redesign dashboard footer
- Add
/hotkey in the dashboard to filter agents by project and worktree name - Add
config referencesubcommand to display the full annotated default config with all available options - Add
/workmuxskill that teaches agents how to use workmux
- Fix multiline paste not being submitted automatically because the Enter keystroke arrived before the application finished processing the pasted content
- Add
base_branchconfig option to set a default base branch for new worktrees, so they always branch off a specific branch (e.g. main) instead of whatever is currently checked out. The--baseCLI flag takes precedence over config (#78)
- Fix auto-generated branch names containing garbage characters with kiro-cli
- Apple Container sandboxes now default to 16 GB memory limit, preventing OOM
kills during heavy workloads. Memory and CPU limits are configurable via
container.memoryandcontainer.cpusin your config (#77) - Fork PRs checked out with
--prnow automatically prefix the local branch name with the fork owner (e.g.,forkowner-main), preventing conflicts when the fork's branch name matches an existing local branch
- Fixed OpenCode plugin's waiting (💬) status not triggering when the agent requests permission or asks a multiple-choice question, caused by event name changes in OpenCode v2 (#75)
- Added logging for branch name auto-generation
- Added support for Kiro CLI (
kiro-cli) as a recognized agent - Added support for Mistral Vibe (
vibe) as a recognized agent (#76)
- New
--sessionflag forworkmux openlets you open worktrees in a dedicated tmux session instead of a window. Session mode is persisted, so reopening the same worktree remembers the preference (#73) - Dashboard now has a scope filter (toggle with
F) to show only agents in the current session or all agents across sessions (#74) workmux setupnow offers to install bundled skills (merge, rebase, worktree, coordinator) during the first-run wizard- Agents can now communicate across projects using the coordinator skill
- Fixed session mode not being detected correctly when reopening a worktree after a tmux restart
- Window names are now automatically suffixed with the project directory name
when a name collision is detected across different repositories, avoiding
errors when multiple repos use the same worktree name. Explicit names set via
--nameare not modified (#70)
- Branch name generation now automatically uses your configured AI agent
(Claude, Gemini, Codex, or OpenCode) instead of requiring the
llmCLI to be installed (#68)- Note: This is a breaking change. If you were previously using
llmto generate branch names. Addauto_name.command: 'llm'to your global config.
- Note: This is a breaking change. If you were previously using
- New
auto_name.commandconfig option lets you specify a custom command for branch name generation workmux rmno longer fails with "cannot delete branch used by worktree" when a previousworkmux addwas interrupted mid-creation- Fixed zsh completions not working when installed via fpath autoloading (#65)
- Fixed zsh tab completion suggesting file paths for commands that only accept worktree handles or branch names (#65)
- Fixed phantom whitespace appearing in zsh completions when no candidates exist (#65)
- Dashboard now renders colored status icons correctly instead of showing raw tmux color codes as literal text (#66)
- Sandbox: Images copied to the host clipboard can now be pasted into sandboxed agents (Ctrl+V), enabling workflows like sharing screenshots with Claude Code running inside a container or VM
- Merge skill: Added
--no-verify(-n) flag to skip pre-merge hooks, and-kas a shorthand alias for--keep
- Added
workmux updatecommand for self-updating workmux directly from GitHub releases. Downloads the latest version, verifies checksums, and replaces the binary in place. Homebrew-managed installs are detected and directed to usebrew upgradeinstead - workmux now automatically checks for updates in the background and shows a
notification when a newer version is available. Checks happen at most once per
day during
workmux add. Disable withauto_update_check: falsein config or by setting theWORKMUX_NO_UPDATE_CHECKenvironment variable
- Added Apple Container as a sandbox runtime alongside Docker and Podman,
enabling sandboxing on macOS using Apple's native container technology (macOS
26+, Apple Silicon). Auto-detected when the
containerbinary is available. Configure withruntime: apple-containeror let workmux detect it automatically - Fixed
closecommand not finding the correct worktree when using a branch name that differs from the worktree handle (e.g., when created with--name)
- Added experimental Zellij backend support. Zellij is auto-detected when running inside a Zellij session. Requires Zellij built from source (uses unreleased features). See the Zellij guide for details and known limitations (contributed by @Infonautica)
- Add GitHub Copilot CLI as a supported agent for status tracking. Copilot hooks
are installed per-repository via
workmux setup. Note: the waiting state is not supported due to Copilot CLI hooks API limitations
- Fork branch references (e.g.,
someuser:feature) now prefix the local branch name with the fork owner (someuser-feature), preventing conflicts with existing branches likemain
- Built-in agents (
claude,gemini,codex,opencode) are now auto-detected in pane commands, so prompt injection works without the<agent>placeholder or a matchingagentconfig. Just use the agent name directly as the pane command (e.g.,command: "codex --yolo") and prompts are delivered automatically. (#57)
- Added session mode: worktrees can now be created as their own tmux sessions
instead of windows, giving each worktree a separate window list, history, and
layout. Enable with
--sessionflag ormode: sessionin config. - Added multi-window sessions: use the
windowsconfig to create multiple windows per session, each with its own pane layout - useful for setups like an editor window alongside a test runner
- Added
workmux setupcommand to automatically detect installed agents and configure status tracking hooks, with a guided install prompt and a tmux status bar preview showing what the icons look like - Fixed sandbox failing to start with Colima (Docker Desktop alternative for macOS) due to shim directories being created in system temp paths that Colima's VM cannot access
- Fixed backend detection for nested multiplexers (e.g., tmux inside kitty or wezterm) so workmux correctly targets the innermost multiplexer (#53)
- Added
WORKMUX_BACKENDenvironment variable to explicitly override backend auto-detection (acceptstmux,wezterm, orkitty)
- Fixed hooks and run commands failing when they use bash-specific syntax (e.g., arrays, process substitution), by using bash instead of sh for execution (#52)
- Sandbox: Host git identity (user.name, user.email) is now automatically available inside sandbox environments, so git commits from sandboxed agents use the correct author
- Added sandbox support for running agents in isolated environments. Two backends: containers (Docker/Podman) for ephemeral sessions, and Lima VMs for persistent machines with built-in Nix/Devbox toolchain support. See the sandbox guide for setup.
- Dashboard: Added Ctrl+N/Ctrl+P as alternative keybindings for navigating between rows
- Fixed bash completion panic when generating completions (#51)
- Added kitty as an alternative terminal backend -- detected automatically when running inside kitty
- Improved window cleanup handling for non-tmux backends
- Added coordinator commands for scripting multi-agent workflows:
sendsends text or file contents to a worktree's agent panecapturereads the last N lines from a worktree's pane outputstatusshows the current state of worktree agents with elapsed time and git info (use--gitfor staged/unstaged indicators)waitblocks until agents reach a target status (working, waiting, or done)runexecutes a command in a worktree's pane and streams the output in real time.
- Dashboard now supports light theme via
theme: lightin config
- The
listcommand now shows an AGENT column displaying the status of agents running in each worktree (working, waiting, done icons) - Added positional arguments to
listfor filtering by worktree handle or branch name - When piping output, agent status icons are replaced with text labels for compatibility with scripts
- Shell autocompletion now suggests worktree names for the
closecommand (bash, zsh, fish) (#47)
- Fixed dashboard incorrectly showing the worktree directory name instead of the
project name when using a custom
worktree_dirconfiguration (#48)
- Nerdfont setup now handles read-only config files gracefully (e.g., when symlinked to a Nix store), showing a helpful message instead of failing
- Added
-o/--open-if-existsflag toworkmux addfor idempotent worktree creation: if the worktree already exists, switches to it instead of failing.
- Dashboard now shows PR status column with number and state icon (open, merged, closed, draft) for each agent's worktree
- Dashboard displays CI/CD check status alongside PRs with pass/fail/pending
icons. Enable
dashboard.show_check_countsto show pass/total counts - Added last-agent toggle (Tab key in dashboard,
workmux last-agentCLI) to quickly switch between current and previous agent - Added
auto_name.backgroundconfig option to always run--auto-nameagents in background mode - Improved dashboard startup performance
- Moved internal state management from tmux-specific mechanisms to filesystem-based JSON storage, laying the groundwork for multi-backend support
- Added experimental WezTerm backend support. workmux auto-detects the backend from environment variables. See the WezTerm guide for setup instructions. (contributed by @JeremyBYU)
- New worktrees now automatically get a symlink to a gitignored
CLAUDE.local.mdfrom your main worktree, so your local Claude Code instructions are available without manual setup
- Fixed status icons breaking tmux themes that use padding spaces in window format strings (#45)
- Added nested config support for monorepos: place a
.workmux.yamlin any subdirectory to configure that project independently. When you run workmux from a subdirectory, it finds the nearest config. Working directory, file operations, and hooks are all scoped to the config directory. (#39) - Added
WM_CONFIG_DIRenvironment variable for hooks, pointing to the directory containing the.workmux.yamlthat was used
- Dashboard: Detect and clear working agents that have stalled, for example due to being interrupted
- Fixed
last-donecommand intermittently failing when switching to recently completed agents
- Tmux window names now use a nerdfont git branch icon as the default prefix
when nerdfonts are available, replacing the previous "wm-" prefix. This can be
overridden with
window_prefix - Fixed cleanup commands outputting noise to the terminal after merging or removing worktrees
- Added bash installer script for easier installation (
curl -fsSL ... | bash) - Added automatic nerdfont detection with fallback icons for users without nerdfonts installed
- Added
last-donecommand to quickly switch to recently completed agents - Fixed race condition when running merge from inside a worktree agent
- Reduced crate download size by excluding unnecessary files from the published package
- Fixed prompts failing when branch names contain slashes (#37)
- Fixed dashboard commit and merge commands not working in Claude Code when
using bash command prefix (
!) - Fixed dashboard commands including a literal newline that caused issues with OpenCode (#35)
- Dashboard: Added
--diffflag to open diff view directly for the current worktree, skipping the agent list
- Added Nix flake (https://workmux.raine.dev/guide/nix)
- Fixed bash completion not passing arguments to the fallback completion function
- Duplicate windows created with
open --neware now placed immediately after the original window instead of at the end of the window list open --newcan now be run without a name argument when inside a worktree, inferring the current worktree automatically
- Fixed
mergecommand failing with bare repo setups that use linked worktrees (#31)
- Fixed false "unmerged commits" warning when local main branch is ahead of the remote (#30)
- The
mergecommand now works when the target branch is checked out in a linked worktree (#29)
- Fixed
workmux add user/featureincorrectly treatinguseras a remote name instead of creating a local branch nameduser/feature(#28) - Fixed worktree cleanup failing to run process stop hooks by deferring directory deletion
- Dashboard: Preview pane size is now configurable via config file, CLI flag
(
--preview-size/-P), or interactively with+/-keys
- Dashboard: Selection now stays on the same agent when the list reorders due to status changes or sorting
- Dashboard: Improved file list layout with full paths and right-aligned stats
- Dashboard: Added file list sidebar to diff and patch views
- Dashboard: Added Ctrl+D/U scrolling in patch mode
- Dashboard: Improved diff coloring fallback when delta is not available
- Dashboard: Added help screen accessible with
?key, showing keybindings for each view (dashboard, diff, patch mode) - Dashboard: Added mouse scroll support in diff views
- Dashboard: The active worktree is now highlighted with a subtle background and white text for easier identification
- Dashboard: Git column header shows a spinner while refreshing
- Fixed agent status not showing "working" when launching with a prompt (works around Claude Code v2.0.77 regression)
- Dashboard: Commit and merge actions are now configurable via
dashboard.commitanddashboard.mergein your config file
- Dashboard: Fixed patch mode showing already-staged hunks
- Dashboard: Uncommitted changes are now shown for the main worktree
- Dashboard: Added patch mode for interactive hunk-by-hunk staging with
pkey - Dashboard: Added hunk splitting to stage partial changes within a hunk
- Dashboard: Added ability to undo staged changes in patch mode
- Dashboard: Added hunk commenting for review workflows
- Dashboard: Added diff browsing with
dto view uncommitted changes andDfor committed changes (toggle between WIP/review views with Tab) - Dashboard: Diffs now use delta for syntax highlighting when available, with fallback coloring
- Dashboard: Added filter to hide stale agents with
fkey (persists across sessions) - Dashboard: Added
cto commit andmto merge directly from the main view - Dashboard: Working agents now show an animated spinner
- Dashboard: Added git status column showing diff stats (+/- lines), conflict indicator, dirty state, and ahead/behind counts for each worktree
- Dashboard: Non-default base branches (not main/master) are now displayed in the git column
- Added
--notificationflag tomergecommand to show a system notification on successful merge
- Dashboard: Renamed "Agent" column to "Worktree" for clarity; non-workmux agents now display "main" instead of their window name
- The
mergecommand now auto-detects the base branch from when the worktree was created, instead of always defaulting to main - Window status icons for "waiting" and "done" again auto-clear when returning to the pane
- Added OpenCode support for agent status tracking in tmux window names
- Fixed passing prompt to OpenCode
- Dashboard: Stale agents (inactive for over an hour) now show a timer icon instead of "stale"
- Dashboard: Preview updates are now faster in input mode
- Renamed "status popup" to "dashboard"
- Added pane preview to the status dashboard, showing live terminal output from the selected agent
- Added input mode: press
ito send keystrokes directly to the selected agent's pane without switching windows, press Escape to exit - Added preview scrolling with Ctrl+U/D
- Agents are now automatically removed from the status list when they exit
- Priority sorting now uses elapsed time as a tiebreaker
- Added smart sorting to the status dashboard with four modes: Priority (by
status importance), Project (grouped by project), Recency (newest first), and
Natural (tmux order). Press
sto cycle through modes; it is saved across sessions.
- Added
statuscommand: a TUI dashboard for monitoring all active agents across tmux sessions, with quick-jump keys (1-9), peek mode, and keyboard navigation - The "done" (✅) status no longer gets replaced by "waiting" (💬) when Claude sends idle prompts, so completed sessions stay marked as done
- Added
docscommand to view the README
- Improved compatibility with non-POSIX shells like nushell
- Commands for starting agent with a prompt no longer pollute shell history
- Added
--no-verify(-n) flag tomergecommand to skip pre-merge hooks - The
mergecommand now works when run from subdirectories within a worktree
- The
opencommand now switches to an existing window by default instead of erroring when a window already exists - Added
--new(-n) flag toopencommand to force opening a duplicate window (creates suffix like-2,-3) - The
opencommand now supports prompts via-p,-P, and-eflags, matching theaddcommand
- Linux binaries now use musl for better compatibility across different Linux distributions
- The
mergecommand with--keepno longer requires a clean worktree, since the worktree won't be deleted anyway
- Log files are now stored in the XDG state directory
(
~/.local/state/workmux/)
- Added
closecommand to close a worktree's tmux window while keeping the worktree on disk. It's basically an alias for tmux'skill-window
- Added
pre_mergehook to run commands (like tests or linters) before merging, allowing you to catch issues before they land in your main branch - Added
pre_removehook that runs before worktree removal, with environment variables (WM_HANDLE,WM_WORKTREE_PATH,WM_PROJECT_ROOT) for backup or cleanup workflows - The
post_createhook now receivesWM_WORKTREE_PATHandWM_PROJECT_ROOTenvironment variables, matching the other hooks
- Fixed terminal input not being displayed after creating a worktree with
workmux addon bash (#17)
- The
mergecommand now allows untracked files in the target worktree, only blocking when there are uncommitted changes to tracked files
- The
removecommand now accepts multiple worktree names, allowing you to clean up several worktrees in a single command (e.g.,workmux rm feature-a feature-b)
- Added JSON lines support for stdin input: pipe JSON objects to
workmux addand each key automatically becomes a template variable, making it easy to use structured data from tools likejqin prompts and branch names - Template errors now show which variables are missing and list available ones, helping catch typos in branch name templates or prompts before worktrees are created
- Fixed "directory already exists" errors when creating worktrees after a previous cleanup was interrupted by background processes recreating files
- Added
--max-concurrentflag to limit how many worktrees run simultaneously, useful for creating worker pools that process items without overwhelming system resources or hitting API rate limits - Added
{{ index }}template variable for branch names and prompts in multi-worktree modes, providing a 1-indexed counter across all generated worktrees
- Added
--wait(-W) flag toaddcommand to block until the created tmux window is closed, useful for scripting workflows - Added stdin input support for multi-worktree generation: pipe lines to
workmux addto create multiple worktrees, with each line available as{{ input }}in prompts - Fixed duplicate remote fetch when using
--pror fork branch syntax (user:branch)
- Fixed a crash in
workmux completions bash(#14)
- Added
--allflag toremovecommand to remove all worktrees at once (except the main worktree), with safety checks for uncommitted changes and unmerged commits - Now shows an error when using
-p/--promptwithout an agent pane configured, instead of silently ignoring the prompt
- Removed automatic
node_modulessymlink default for Node.js projects
- Added
--goneflag tormcommand to clean up worktrees whose remote branches have been deleted (e.g., after PRs are merged)
- Added
--prflag tolistcommand to show PR status alongside worktrees, displaying PR numbers and state icons (open, draft, merged, closed) - Added spinner feedback for slow operations like GitHub API calls
- Shell completions now suggest proper values for
--base,--into, and--prompt-fileflags (bash, zsh) - Fixed an error with the
pre_deletehook when removing worktrees that were manually deleted from the filesystem
- In agent status tracking, the "waiting" (💬) status icon now auto-clears window is focused, matching the behavior of the "done" (✅️) status.
- Improved the default config template generated by
workmux init
- Added pre-built binaries for Linux ARM64 (aarch64) architecture
- Commands
open,path,remove, andmergenow accept worktree names (the directory name shown in tmux) in addition to branch names, making it easier to work with worktrees when the directory name differs from the branch
- Added
--auto-name(-A) flag to automatically generate branch names from your prompt using an LLM (uses thellmtool), so you can skip naming branches yourself - Added
auto_name.modelandauto_name.system_promptconfig options to customize the LLM model and prompt used for branch name generation
- New worktree windows are now inserted after the last workmux window instead of at the end of the window list, keeping your worktree windows grouped together
- Fixed branches created with
--basenot having upstream tracking configuration properly unset from the base branch
- Fixed panes not loading shell profiles, which broke tools like nvm etc. that depend on login shell initialization
- Added
--intoflag tomergecommand for merging into branches other than main (e.g.,workmux merge feature --into develop) - Fixed config loading and file operations when running commands from inside a worktree
- Removed
--delete-remoteflag frommergeandremovecommands
- Added agent status tracking in tmux window names, showing icons for different Claude Code states (🤖 working, 💬 waiting, ✅ done). The "done" status auto-clears when you focus the window.
- Fixed worktree path calculation when running
addfrom inside an existing worktree, which previously created nested paths instead of sibling worktrees
- Added support for GitHub fork branch format (
user:branch) inaddcommand, allowing direct checkout of fork branches copied from GitHub's UI
- Added OpenCode agent support: prompts are now automatically passed using the
-pflag when using--prompt-fileor--prompt-editorwith--agent opencode
- Added
pathcommand to get the filesystem path of a worktree by branch name - Added
--nameflag toaddcommand for explicit worktree directory and tmux window naming - Added
worktree_namingconfig option to control how worktree names are derived from branches (fullorbasename) - Added
worktree_prefixconfig option to add a prefix to all worktree directory names - Added
merge_strategyconfig option to set default merge behavior (merge, rebase, or squash)
- Added nushell support for pane startup commands
- Improved reliability of pane command execution across different shells
- Shell completions now suggest git branch names when using the
addcommand
- Shell completions now dynamically suggest branch names when pressing TAB for
open,merge, andremovecommands (bash, zsh, fish)
- Added
--prflag to checkout a GitHub pull request directly into a new worktree - Fixed version managers (nvm, pnpm, mise, etc.) being shadowed by stale PATH entries when running pane commands
- Improved list output with cleaner table formatting and relative paths
- Fixed duplicate command announcement when running merge workflow
- Fixed "can't find pane: 0" errors when using
pane-base-index 1in tmux configuration - Merge conflicts now abort cleanly, keeping your main worktree in a usable state with guidance on how to resolve
- Added
--keepflag to merge command to merge without cleaning up the worktree, useful for verifying the merge before removing the branch - Fixed a bug where multi-agent worktrees had incorrect agent configuration for worktrees after the first one
- After closing a worktree (merge or remove), the terminal now navigates back to the main worktree instead of staying in the deleted directory
- Added YAML frontmatter support in prompt files for defining variable matrices
(
foreach), making it easier to specify multi-worktree generation without CLI flags - Added
sizeandpercentageoptions for pane configuration to control pane dimensions when splitting - Fixed prompt editor temporary file now using
.mdextension for better editor syntax highlighting - Fixed Gemini agent startup issues
- Switched templating engine from Tera to MiniJinja (Jinja2-compatible) for branch names and prompts. Existing templates should work unchanged.
- Fixed prompts starting with a dash (e.g. "- foo") being incorrectly interpreted as CLI flags
- The
rmcommand now automatically uses the correct base branch that was used when the worktree was created, instead of defaulting to the main branch
- Added
--with-changesflag toaddcommand: move uncommitted changes from your current worktree to a new one, useful when you've started working on the wrong branch - Added
--patchflag: interactively select which changes to move when using--with-changes - Added
--include-untracked(-u) flag: include untracked files when moving changes
- New branches now default to branching from your currently checked out branch instead of the main branch's remote tracking branch
- Removed the
--from-currentflag (no longer needed since this is now the default behavior)
- Added multi-agent workflows: create multiple worktrees from a single command
using
-a agent1 -a agent2,-n count, or--foreachmatrix options - Added background mode (
-b,--background) to create worktrees without switching to them - Added support for prompt templating with variables like
{{ agent }},{{ num }}, and custom--foreachvariables - Added
--branch-templateoption to customize generated branch names
- Added
--prompt-editor(-e) flag to write prompts using your$EDITOR - Added configurable agent support with
--agent(-a) flag and config option - Added flags to skip setup steps:
--no-hooks,--no-file-ops,--no-pane-cmds - Defaulted to current branch as base for
workmux add(errors on detached HEAD without explicit--base) - Fixed aliases containing
<agent>placeholder not resolving correctly
- Added
--prompt(-p) and--prompt-file(-P) options toworkmux addfor attaching a prompt to new worktrees - Added
--keep-branch(-k) option toworkmux removeto preserve the local branch while removing the worktree and tmux window
- Added
--baseoption to specify a base branch, commit, or tag when creating a new worktree - Added
--from-current(-c) flag to use the current branch as the base, useful for stacking feature branches - Added support for creating worktrees from remote branches (e.g.,
workmux add origin/feature-branch) - Added support for copying directories (not just files) in file operations
- Fixed
mergeandremovecommands failing when run from within the worktree being deleted - Added safety check to prevent accidentally deleting a branch that's checked out in the main worktree
- Fixed pane startup commands not loading shell environment tools (like direnv, nvm, rbenv) before running
- Added
pre_deletehooks that run before worktree deletion, with automatic detection of Node.js projects to fast-deletenode_modulesdirectories in the background - Pane commands now keep an interactive shell open after completion, and panes can be created without a command (just a shell)
- Added
targetoption for panes to split from any existing pane, not just the most recent one - Tmux panes now use login shells for consistent environment across all panes
- The
createcommand now displays which base branch was used - Improved validation for pane configurations with helpful error messages
- Post-create hooks now run before the tmux window opens, so the new window appears ready to use instead of showing setup commands running
- Fixed cleanup when removing a worktree from within its own tmux window
- Fixed a race condition where cleaning up a worktree could fail if the tmux window hadn't fully closed yet
- Automatically run
pnpm installwhen creating worktrees in pnpm projects
- Fixed global config to always load from
~/.config/workmux/instead of platform-specific locations (e.g.,~/Library/Application Support/on macOS)
- Added
--fromflag toaddcommand to specify which branch, commit, or tag to branch from - Fixed
rmcommand failing when run from within the worktree being removed - New worktree branches no longer track a remote upstream by default
- Added global configuration support with XDG compliance—you can now set shared
defaults in
~/.config/workmux/config.yamlthat apply across all projects - Project configs can inherit from global settings using
<global>placeholder in lists - After merging or removing a worktree, automatically switches to the main branch tmux window if it exists
- Fixed an issue where removing a worktree could fail if the current directory was inside that worktree
- Fixed
prunecommand to correctly parse Claude Code's config file structure
Initial release.
- Added
opencommand to switch to an existing worktree's tmux window - Added
--rebaseand--squashmerge strategies to themergecommand - Added
claude prunecommand to clean up stale worktree entries from Claude's config - Added configurable window name prefix via
window_prefixsetting - Allowed
removecommand to work without arguments to remove the current branch - Shell completion now works with command aliases
- Fixed merge command not cleaning up worktrees after merging
- Fixed worktree deletion issues when running from within the worktree
- Fixed new branches being incorrectly flagged as unmerged