Skip to main content

Custom status line for Claude Code with robbyrussell theme style

Project description

erk-statusline

Custom status line for Claude Code with robbyrussell theme style.

Screenshot

Status Line Components

The status line displays (left to right):

  • Git repo: (git:repo-name) - Current GitHub repository name
  • Worktree: ({wt, br}:name) or (wt:name) - Git worktree info ("root" for main worktree, or worktree name for linked worktrees)
  • Branch: (br:branch-name) - Current git branch (combined with worktree if names match)
  • Current directory: (cwd:path) - Relative path from git root (only shown if not at root)
  • Dirty indicator: - Shows when there are uncommitted changes
  • GitHub PR info: (gh:#123 plan:#456 st:XX chks:XX):
    • #123 - PR number
    • plan:#456 - Associated issue number from .impl/issue.json
    • st: - PR state emoji: 👀 published, 🚧 draft, 🎉 merged, closed, 💥 conflicts
    • chks: - CI checks status: passing, 🚫 failing, 🔄 pending
  • Model: (S) Sonnet, (O) Opus, or model initial

Installation

uv tool install git+https://github.com/dagster-io/erk-statusline

Or for development:

git clone https://github.com/dagster-io/erk-statusline
cd erk-statusline
uv sync

Usage

Add to ~/.claude/settings.json:

{
  "statusLine": {
    "type": "command",
    "command": "erk-statusline"
  }
}

Debugging

The statusline writes debug logs to help diagnose issues like missing chks: indicator, timeouts, or API failures.

Log location: ~/.erk/logs/statusline/<session-id>.log

To view logs for your current session:

# Find recent logs
ls -lt ~/.erk/logs/statusline/ | head

# Tail the most recent log
tail -f ~/.erk/logs/statusline/$(ls -t ~/.erk/logs/statusline/ | head -1)

Example log output:

2025-01-05 12:34:56 DEBUG Statusline invoked: session=abc123 cwd=/path/to/repo
2025-01-05 12:34:56 DEBUG Fetching GitHub data for branch=feature-branch
2025-01-05 12:34:56 DEBUG Fetching PR details: owner/repo #4225
2025-01-05 12:34:56 DEBUG Fetching check runs: owner/repo sha=abc1234
2025-01-05 12:34:57 DEBUG PR details fetched: owner/repo #4225 in 0.8s -> MERGEABLE
2025-01-05 12:34:57 DEBUG Check runs fetched: owner/repo sha=abc1234 in 0.9s -> 5 checks
2025-01-05 12:34:57 DEBUG Final result: branch=feature-branch pr=4225 checks=🔄

Common issues to look for:

  • Timeout messages - API calls taking too long (default timeout: 1.5s per call)
  • Empty checks - Final result: ... checks=(empty) means no check runs were returned
  • Cache behavior - Look for "Cache hit/miss" messages to understand caching

Development

# Run all checks (lint, typecheck, tests)
make check

# Run individual checks
make lint
make typecheck
make test

# Run tests with coverage
make test-coverage

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

erk_statusline-0.9.8.tar.gz (24.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

erk_statusline-0.9.8-py3-none-any.whl (17.7 kB view details)

Uploaded Python 3

File details

Details for the file erk_statusline-0.9.8.tar.gz.

File metadata

  • Download URL: erk_statusline-0.9.8.tar.gz
  • Upload date:
  • Size: 24.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.21 {"installer":{"name":"uv","version":"0.9.21","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for erk_statusline-0.9.8.tar.gz
Algorithm Hash digest
SHA256 f0e22879375aac010eb75316eb595df0d671e9d6830ddbcdb34d7998183dc3ea
MD5 a6989b99742f02c00148ddb9b02ea3fd
BLAKE2b-256 15d79f56301534622e65ce992390ce885bce008a825b17a1de7ec3d46b4b7851

See more details on using hashes here.

File details

Details for the file erk_statusline-0.9.8-py3-none-any.whl.

File metadata

  • Download URL: erk_statusline-0.9.8-py3-none-any.whl
  • Upload date:
  • Size: 17.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.21 {"installer":{"name":"uv","version":"0.9.21","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for erk_statusline-0.9.8-py3-none-any.whl
Algorithm Hash digest
SHA256 680896a8b1fbd7b140669f221c8234c704ed8377a79ebf718ae8f39552651d97
MD5 587b580c0c1498e9b31f5a390e438ffd
BLAKE2b-256 1b43da4e61764dff6a3b1f8e1b2a78785d2d1d0c6bb5a07559066fdab00585e2

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page