Metadata-Version: 2.4
Name: erk-statusline
Version: 0.7.2
Summary: Custom status line for Claude Code with robbyrussell theme style
Requires-Python: >=3.11
Requires-Dist: erk-shared
Description-Content-Type: text/markdown

# erk-statusline

Custom status line for Claude Code with robbyrussell theme style.

![Screenshot](screenshots/statusline.png)

## 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

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

Or for development:

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

## Usage

Add to `~/.claude/settings.json`:

```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:**

```bash
# 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

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

# Run individual checks
make lint
make typecheck
make test

# Run tests with coverage
make test-coverage
```
