Przejdź do głównej zawartości

Mistrzostwo terminala

Masz Claude Code uruchomione w jednej zakładce terminala, serwer deweloperski w drugiej, wyjście testów w trzeciej i git log w czwartej. Ciągle przełączasz zakładki, tracąc z oczu tę, która ma potrzebne wyjście. Potem Claude kończy zadanie, a ty przegapiasz powiadomienie, bo czytałeś logi w innej zakładce.

Zaawansowani użytkownicy rozwiązują to za pomocą multiplekserów terminala. Jeden ekran, wiele paneli, Claude Code zawsze widoczny.

  • Konfigurację tmux zoptymalizowaną dla przepływów pracy z Claude Code
  • Układy wielopanelowe do developmentu, debugowania i przeglądów
  • Wzorce integracji z powłoką, które przekazują dane do Claude Code
  • Strategie powiadomień, aby nigdy nie przegapić zakończenia przez Claude

Idealny układ ma trzy lub cztery panele:

+----------------------------+------------------+
| | |
| Claude Code | Serwer dev |
| (panel główny) | (góra-prawo) |
| | |
+----------------------------+------------------+
| | |
| Edytor / Pliki | Wyjście testów |
| (dół-lewo) | (dół-prawo) |
| | |
+----------------------------+------------------+

Dodaj do ~/.tmux.conf dla szybkiego przełączania paneli:

# Użyj Alt+strzałka do przełączania paneli bez prefiksu
bind -n M-Left select-pane -L
bind -n M-Right select-pane -R
bind -n M-Up select-pane -U
bind -n M-Down select-pane -D
# Zwiększ historię dla scrollbacku
set -g history-limit 50000

Prawdziwa moc developmentu opartego na CLI to przekazywanie. Wyjście każdego polecenia powłoki może stać się wejściem dla Claude Code:

Okno terminala
# Analizuj niepowodzenia testów
npm run test 2>&1 | claude -p "Jakie są przyczyny źródłowe tych niepowodzeń testów? Pogrupuj według kategorii."
# Wyjaśnij złożoną historię git
git log --oneline --graph --since="1 week ago" | claude -p "Podsumuj aktywność rozwojową z tego tygodnia."
# Debuguj błędy budowania
npm run build 2>&1 | claude -p "Napraw te błędy budowania TypeScript. Pokaż mi dokładne potrzebne zmiany."
# Analizuj podatności zależności
npm audit --json | claude -p "Które z tych podatności są krytyczne i jakie są ścieżki aktualizacji?"

Buduj wieloetapowe pipeline’y, które używają Claude Code jako kroku przetwarzania:

Okno terminala
# Wygeneruj changelog z commitów
git log --oneline v1.2.0..HEAD | \
claude -p "Wygeneruj changelog dla użytkowników z tych commitów. Pogrupuj według: Funkcje, Naprawy błędów, Wydajność." \
--output-format text > CHANGELOG-draft.md
# Utwórz opis PR z diffa
git diff main...HEAD | \
claude -p "Napisz opis PR dla tych zmian. Dołącz: Podsumowanie, Wprowadzone zmiany, Notatki testowe." \
--output-format text

Uruchom wiele instancji Claude Code dla różnych celów:

Okno terminala
# Terminal 1: Główny development
claude -r "feature-work"
# Terminal 2: Przegląd kodu w tle (osobny panel tmux)
claude -r "review-session" --model sonnet
# Terminal 3: Debugowanie testów (kolejny panel)
claude -r "test-fixes"

Każda sesja utrzymuje własny kontekst. Sesja pracy nad funkcją zna twoje decyzje architektoniczne. Sesja przeglądu koncentruje się na jakości kodu. Sesja testowa śledzi wzorce i niepowodzenia testów.

Monitoruj proces i przekazuj jego wyjście do Claude Code, gdy coś pójdzie nie tak:

Okno terminala
# Obserwuj wyjście testów i automatycznie analizuj niepowodzenia
npm run test:watch 2>&1 | while IFS= read -r line; do
echo "$line"
if echo "$line" | grep -q "FAIL"; then
echo "$line" | claude -p "Ten test właśnie się nie powiódł. Jaka jest prawdopodobna przyczyna na podstawie komunikatu błędu?"
fi
done

Skonfiguruj Claude Code, aby odtwarzał dźwięk po zakończeniu:

{
"hooks": {
"Stop": [
{
"matcher": "",
"hooks": [
{
"type": "command",
"command": "afplay /System/Library/Sounds/Glass.aiff"
}
]
}
]
}
}

Większość emulatorów terminala może migać lub podskakiwać w docku, gdy otrzymany zostanie znak dzwonka:

{
"hooks": {
"Stop": [
{
"matcher": "",
"hooks": [
{
"type": "command",
"command": "printf '\\a'"
}
]
}
]
}
}

Scrollback tmux nie przechwytuje wyjścia Claude Code: Zwiększ limit historii za pomocą set -g history-limit 50000 w ~/.tmux.conf. Sesje Claude Code mogą produkować tysiące linii.

Przekazane wyjście jest zbyt duże dla Claude Code: Przy przekazywaniu dużych wyjść użyj head lub tail, aby ograniczyć wejście. Claude Code działa najlepiej ze skoncentrowanym kontekstem, a nie 10 000 liniami logów.

Wiele instancji Claude Code osiąga limity: Każda instancja zużywa tokeny niezależnie. Jeśli uruchamiasz trzy równoległe sesje, twoje zużycie tokenów się potraja. Obserwuj swój /cost we wszystkich sesjach.

Dźwięki powiadomień odtwarzają się podczas spotkań: Dodaj warunkowe sprawdzenie do hooka: [[ "$(osascript -e 'output muted of (get volume settings)')" != "true" ]] && afplay /System/Library/Sounds/Glass.aiff.