feat: Update gt nudge to accept rig/polecat format

Now accepts ergonomic rig/polecat addresses:
  gt nudge gastown/furiosa "Check your mail"

Still supports raw session names for legacy use.
Reuses parseAddress and getSessionManager from session.go.

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
Steve Yegge
2025-12-22 12:28:14 -08:00
parent 8699b7b3fd
commit 514bcb7e96

View File

@@ -2,8 +2,10 @@ package cmd
import ( import (
"fmt" "fmt"
"strings"
"github.com/spf13/cobra" "github.com/spf13/cobra"
"github.com/steveyegge/gastown/internal/style"
"github.com/steveyegge/gastown/internal/tmux" "github.com/steveyegge/gastown/internal/tmux"
) )
@@ -12,9 +14,9 @@ func init() {
} }
var nudgeCmd = &cobra.Command{ var nudgeCmd = &cobra.Command{
Use: "nudge <session> <message>", Use: "nudge <rig/polecat> <message>",
Short: "Send a message to a Claude session reliably", Short: "Send a message to a polecat session reliably",
Long: `Sends a message to a tmux session running Claude Code. Long: `Sends a message to a polecat's Claude Code session.
Uses a reliable delivery pattern: Uses a reliable delivery pattern:
1. Sends text in literal mode (-l flag) 1. Sends text in literal mode (-l flag)
@@ -22,31 +24,57 @@ Uses a reliable delivery pattern:
3. Sends Enter as a separate command 3. Sends Enter as a separate command
This is the ONLY way to send messages to Claude sessions. This is the ONLY way to send messages to Claude sessions.
Do not use raw tmux send-keys elsewhere.`, Do not use raw tmux send-keys elsewhere.
Examples:
gt nudge gastown/furiosa "Check your mail and start working"
gt nudge gastown/alpha "What's your status?"`,
Args: cobra.ExactArgs(2), Args: cobra.ExactArgs(2),
RunE: runNudge, RunE: runNudge,
} }
func runNudge(cmd *cobra.Command, args []string) error { func runNudge(cmd *cobra.Command, args []string) error {
session := args[0] target := args[0]
message := args[1] message := args[1]
t := tmux.NewTmux() t := tmux.NewTmux()
// Verify session exists // Check if target is rig/polecat format or raw session name
exists, err := t.HasSession(session) if strings.Contains(target, "/") {
if err != nil { // Parse rig/polecat format
return fmt.Errorf("checking session: %w", err) rigName, polecatName, err := parseAddress(target)
} if err != nil {
if !exists { return err
return fmt.Errorf("session %q not found", session) }
mgr, _, err := getSessionManager(rigName)
if err != nil {
return err
}
// Get session name and send nudge using the reliable NudgeSession
sessionName := mgr.SessionName(polecatName)
if err := t.NudgeSession(sessionName, message); err != nil {
return fmt.Errorf("nudging session: %w", err)
}
fmt.Printf("%s Nudged %s/%s\n", style.Bold.Render("✓"), rigName, polecatName)
} else {
// Raw session name (legacy)
exists, err := t.HasSession(target)
if err != nil {
return fmt.Errorf("checking session: %w", err)
}
if !exists {
return fmt.Errorf("session %q not found", target)
}
if err := t.NudgeSession(target, message); err != nil {
return fmt.Errorf("nudging session: %w", err)
}
fmt.Printf("✓ Nudged %s\n", target)
} }
// Send message with reliable pattern
if err := t.NudgeSession(session, message); err != nil {
return fmt.Errorf("nudging session: %w", err)
}
fmt.Printf("✓ Nudged %s\n", session)
return nil return nil
} }