f6b9747f11
Renombra la funcion entrypoint y su comando a fleetclaude. Ademas, sobre el .sh: - atajos nuevos: alt+0 (= alt+n), alt+k (kill), alt+r (resume picker), alt+flecha-izquierda (volver atras), alt+q (cerrar toda la flota con confirmacion). - mouse on, remain-on-exit off (cierra window al salir el Claude). - estetica neutra de tmux: status bar y bordes de pane en gris (sin verde fosforo), borde activo igual que inactivo (separacion simple sin resaltado de foco). Docs (INDEX, claude-fleet.md) actualizadas al nuevo nombre. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
69 lines
3.9 KiB
Markdown
69 lines
3.9 KiB
Markdown
# Capability group: claude-fleet
|
|
|
|
Operar la **flota de procesos Claude Code** vivos en la máquina como una sola
|
|
unidad: descubrirlos, listarlos en un panel TUI y centralizarlos en una ventana
|
|
kitty con tmux donde se conmuta cuál está embebido a la derecha. Reemplaza el
|
|
caos de N ventanas kitty dispersas por un único punto de entrada.
|
|
|
|
Pieza visible: la app `fleetview` (TUI). Entrypoint: el comando `fleetclaude`.
|
|
|
|
## Funciones
|
|
|
|
| ID | Firma | Qué hace |
|
|
|---|---|---|
|
|
| `list_claude_fleet_go_infra` | `ListClaudeFleet() ([]ClaudeFleet, error)` | Escanea `~/.claude/sessions/*.json` + `goals/`, valida procesos vivos (anti-PID-reciclado), join por `sessionId` → lista tipada con status/objetivo/cwd/target. |
|
|
| `launch_fleetclaude_bash_infra` | `launch_fleetclaude [--cwd <d>] [--bin <p>] [--session <n>] [--cols <n>]` | Entrypoint: abre kitty con sesión tmux (socket aislado `-L fleet`) de dos panes (TUI izq + Claude der). Instala atajos `alt+*` e hijos del sidebar. |
|
|
| `tmux_new_claude_window_go_infra` | `TmuxNewClaudeWindow(socket, session, cwd string) (string, error)` | Crea una window tmux nueva con `claude --dangerously-skip-permissions`. Devuelve el `window_id`. |
|
|
| `tmux_swap_window_into_console_go_infra` | `TmuxSwapWindowIntoConsole(socket, session, windowID string) error` | Trae el Claude de `windowID` al pane derecho de `console` (junto a la TUI), parkea el anterior, re-fija el ancho del sidebar. |
|
|
| `tmux_map_claude_panes_go_infra` | `TmuxMapClaudePanes(socket string) (map[int]string, error)` | Mapa `claudePID → window_id` de los Claude que viven en la sesión (vía `list-panes` + descendencia `/proc`). Permite a la TUI saber cuáles son conmutables. |
|
|
|
|
App relacionada: `fleetview_go_infra` (`apps/fleetview/`) — la TUI Bubble Tea que consume `list_claude_fleet` y orquesta los wrappers tmux.
|
|
|
|
## Ejemplo canónico (end-to-end)
|
|
|
|
```bash
|
|
# 1. Compilar la TUI una vez.
|
|
cd ~/fn_registry/apps/fleetview && go build -o fleetview .
|
|
|
|
# 2. Abrir la flota (una ventana kitty: panel izq + Claude der).
|
|
fn run launch_fleetclaude
|
|
|
|
# 3. Dentro de la ventana, desde CUALQUIER pane (incluido escribiendo en Claude):
|
|
# alt+↑/↓ mueve el cursor de la lista
|
|
# alt+enter conmuta el pane derecho al Claude seleccionado
|
|
# alt+n abre un Claude nuevo (window en fleet) y conmuta a él
|
|
|
|
# Inspección headless de la flota sin abrir nada:
|
|
fn run list_claude_fleet | jq '.[] | {rename, status, goal}'
|
|
```
|
|
|
|
Bajo el capó de `alt+enter`/`alt+n`: tmux redirige la tecla al pane de la TUI
|
|
(`bind -n M-Enter send-keys -t console.0 Enter`); la TUI resuelve el Claude
|
|
seleccionado con `TmuxMapClaudePanes` y lo trae con `TmuxSwapWindowIntoConsole`
|
|
(o crea uno con `TmuxNewClaudeWindow`).
|
|
|
|
## Fronteras (qué NO cubre)
|
|
|
|
- **No gestiona Claudes remotos** (ej. los de una sesión tmux del móvil): se
|
|
listan como contexto pero no se embeben localmente (no son panes de fleet).
|
|
- **Adopción de Claudes sueltos pendiente**: un Claude vivo en otra ventana kitty
|
|
(fuera de fleet) se lista, pero `alt+enter` sobre él aún no lo trae —
|
|
requerirá relaunch `claude --resume <sessionId>` dentro de fleet (patrón de
|
|
`reboot_all_claudes_bash_infra`).
|
|
- **No reinicia ni mata Claudes** (todavía): `resume`/`kill` desde el panel son
|
|
fase posterior. Para reiniciar toda la flota existe `reboot_all_claudes_bash_infra`.
|
|
- **Linux + kitty + tmux** únicamente (build tag `!windows`, usa `/proc`).
|
|
|
|
## Prerequisitos
|
|
|
|
- `kitty` y `tmux` en el PATH. La sesión vive en un server tmux aislado (`-L fleet`).
|
|
- La TUI `fleetview` compilada (`apps/fleetview/fleetview`).
|
|
- Claude Code ≥ 2.1.x (escribe `~/.claude/sessions/<PID>.json` con `status`).
|
|
|
|
## Notas
|
|
|
|
- Toda la sesión usa el socket `-L fleet`: los atajos `bind -n` no afectan al
|
|
tmux por defecto del usuario; `tmux -L fleet kill-server` lo limpia entero.
|
|
- `reboot_all_claudes_bash_infra` comparte la misma fuente de verdad
|
|
(`~/.claude/sessions/<PID>.json`) y es el complemento para reiniciar la flota.
|