From bb0bc511a69077b362d948f577bde9af546d30f9 Mon Sep 17 00:00:00 2001 From: "Kenneth Benzie (Benie)" Date: Thu, 29 Jan 2026 11:22:22 +0000 Subject: [PATCH] Add A binding to display-popup with agent.sh Enables the use of AI agents (claude, gemini) in a persistent display-popup, backed by a tmux session, via the A binding. --- agent.sh | 53 +++++++++++++++++++++++++++++++++++++++++ hooks/session-create.sh | 2 +- tmux.conf | 2 ++ 3 files changed, 56 insertions(+), 1 deletion(-) create mode 100755 agent.sh diff --git a/agent.sh b/agent.sh new file mode 100755 index 0000000..279aedb --- /dev/null +++ b/agent.sh @@ -0,0 +1,53 @@ +#!/usr/bin/env bash + +set -e + +# Check which agent commands are available +agents=() +command -v claude &>/dev/null && agents+=(claude) +command -v gemini &>/dev/null && agents+=(gemini) + +if [ ${#agents[@]} -eq 0 ]; then + echo "No agent commands found (claude, gemini)" + exit 1 +fi + +# Use the current directory (set via display-popup -d) +dir="${PWD:-$HOME}" +# Use the directory basename as window name +window_name=$dir + +# Create the agent session if it doesn't exist +if ! tmux has-session -t agent; then + tmux new-session -ds agent -c "$dir" -n "$window_name" "${agents[0]}" + [ ${#agents[@]} -gt 1 ] && tmux split-window -h -t agent:0 "${agents[1]}" + # Store the directory in a window option for later matching + tmux set-window-option -t agent @agent_dir "$dir" + tmux set-option -t agent status off + tmux attach-session -t agent + exit 0 +fi + +# Search for an existing window with matching directory +target_window="" +for window_id in $(tmux list-windows -t agent -F '#{window_id}'); do + window_dir=$(tmux show-window-option -t "$window_id" -v @agent_dir 2>/dev/null || true) + if [ "$window_dir" = "$dir" ]; then + target_window="$window_id" + break + fi +done + +if [ -n "$target_window" ]; then + # Select the existing window + tmux select-window -t "$target_window" +else + # Create a new window with agents + tmux new-window -t agent -c "$dir" -n "$window_name" "${agents[0]}" + [ ${#agents[@]} -gt 1 ] && tmux split-window -h -t agent -c "$dir" "${agents[1]}" + # Store the directory in a window option for later matching + tmux set-window-option -t agent @agent_dir "$dir" +fi + +# Attach to the session +tmux attach-session -t agent diff --git a/hooks/session-create.sh b/hooks/session-create.sh index 4b7705c..23ac58a 100755 --- a/hooks/session-create.sh +++ b/hooks/session-create.sh @@ -4,6 +4,6 @@ session_name=$(tmux display-message -p '#S') session_layout=~/.local/share/tmux/layouts/session-$session_name if [ -f $session_layout ]; then $session_layout -else +elif [ "$session_name" != "agent" ]; then tmux rename-window home fi diff --git a/tmux.conf b/tmux.conf index 856a8b0..f3ffd29 100644 --- a/tmux.conf +++ b/tmux.conf @@ -67,12 +67,14 @@ if -b '[ "`uname`" = "Darwin" ]' \ 'set -g default-command "reattach-to-user-namespace -l $SHELL"' if -b '~/.config/tmux/check-version.sh ">=" 3.2 && ~/.config/tmux/check-version.sh "<" 3.3' { + bind A display-popup -d '#{pane_current_path}' -w 75% -h 90% -E ~/.config/tmux/agent.sh bind I display-popup -d '#{pane_current_path}' -E '$SHELL -i ~/.config/tmux/interpreter.sh' bind P display-popup -w 60 -h 10 -E '~/.config/tmux/project.sh' bind S display-popup -w 60 -h 10 -E '~/.config/tmux/session.sh' bind T display-popup -d '#{pane_current_path}' -E $SHELL } if -b '~/.config/tmux/check-version.sh ">=" 3.3' { + bind A display-popup -S fg=#54546D -b rounded -d '#{pane_current_path}' -w 75% -h 90% -E ~/.config/tmux/agent.sh bind I display-popup -S fg=#54546D -b rounded -d '#{pane_current_path}' -E '$SHELL -i ~/.config/tmux/interpreter.sh' bind P display-popup -B -w 60 -h 10 -E '~/.config/tmux/project.sh' bind S display-popup -B -w 60 -h 10 -E '~/.config/tmux/session.sh'