GitHub Heads-Up Display — terminal dashboard for your portfolio repos
Project description
ghud
GitHub Heads-Up Display — a terminal dashboard for your portfolio repos.
ghud gives you quick, formatted access to your GitHub activity without verbose gh field specifications or opening a browser.
- Global dashboard — notifications, open PRs, merged PRs, issues, other activity
- Issue views —
ghud i 42for a rich issue display,ghud ifor a list - PR views —
ghud pr 15with check status, reviews, and comments - Repo dashboard —
ghud rfor issues + PRs in the current repo - Repo discovery — find repos missing from your portfolio config
Example
$ ghud
╭───────────────────────── New Issues From Others (3) ─────────────────────────╮
│ plinking_duck Faster BCF/VCF reader for 'Free' 23d ago │
│ duckdb_markdown Would it be possible to add option to 50d ago │
│ write markdown with frontmatter data? │
│ duckdb_scalarfs Curious about the extension usage 80d ago │
╰──────────────────────────────────────────────────────────────────────────────╯
╭───────────────────────────── Your Open PRs (5) ──────────────────────────────╮
│ community-ext Update sitting_duck to v1.4.0 0d │
│ fledgling Extract conversation tools into MCP server 13d 1c │
│ fledgling Fix ReadLines returning empty table 18d 1c │
│ community-ext Update plinking_duck to v0.1.2 21d │
│ duckdb_tarfs Port to DuckDB v1.4-andium 40d 3c │
╰──────────────────────────────────────────────────────────────────────────────╯
Installation
pip install ghud
Requires the GitHub CLI (gh) to be installed and authenticated.
Quick Start
# Global dashboard
ghud
# View issue #42 in the current repo
ghud i 42
# View PR #15 with full detail
ghud pr 15 --detail full
# List open issues across all portfolio repos
ghud i --repo all
# Repo dashboard for the current directory
ghud r
# Find repos not yet in your portfolio config
ghud discover --dry-run
Commands
| Command | Alias | Description |
|---|---|---|
ghud / ghud overview |
ghud o |
Global dashboard |
ghud issue [N] |
ghud i |
List issues or view detail |
ghud pr [N] |
List PRs or view detail | |
ghud repo |
ghud r |
Repo-level dashboard |
ghud discover |
Find untracked repos | |
ghud serve |
Start MCP server |
Key Options
--repo owner/repo— target a specific repo (--repo allfor cross-repo)--detail brief|summary|standard|full— control detail level on issue/PR views--comments N— show last N comments (default: 3, or--comments all)--no-pager— disable pager--state open|closed|all— filter list views--limit N— max items in list views (default: 30)
Configuration
ghud reads a projects.yaml file that lists your portfolio repos. It checks these locations:
$XDG_CONFIG_HOME/ghud/projects.yaml(default:~/.config/ghud/projects.yaml)~/Projects/pages/src/_data/projects.yaml
The YAML uses a nested category/subcategory/project structure. Repos in the ignored category are excluded from the dashboard.
Features
Multi-View CLI
Browse issues, PRs, and repos with detail levels from brief (one-line summary) to full (body, all comments, timeline events, expanded CI checks).
Check Status Indicators
PR views show CI and review status at a glance: ✓ passing, ✗ failing, ● pending, — no checks.
Auto Repo Detection
When run inside a git repo, ghud detects the repo from your origin remote. Override with --repo or use --repo all for cross-repo views.
Responsive Layout
On wide terminals (>=120 columns), the dashboard uses a two-column layout. Narrow terminals get a single-column stack.
MCP Server
ghud serve starts an MCP server exposing dashboard tools for AI agents, enabling integration with tools like Claude Code.
Performance
ghud fetches all data in ~2 seconds using concurrent API calls and GraphQL batching for per-repo issue queries.
Development
git clone https://github.com/teaguesterling/ghud.git
cd ghud
pip install -e ".[dev]"
pytest
License
MIT
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ghud-0.2.1.tar.gz.
File metadata
- Download URL: ghud-0.2.1.tar.gz
- Upload date:
- Size: 49.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9a1e016fa528dbf22838008469892f789c77eaa80617e6eb2e158d0458bdf5e6
|
|
| MD5 |
eb4439dd075a36ce431f3fe0001cfe68
|
|
| BLAKE2b-256 |
e6706d94e54434faa8bfb6bbca78276f288071e87595ee24826f85000718a023
|
Provenance
The following attestation bundles were made for ghud-0.2.1.tar.gz:
Publisher:
publish.yml on teaguesterling/ghud
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ghud-0.2.1.tar.gz -
Subject digest:
9a1e016fa528dbf22838008469892f789c77eaa80617e6eb2e158d0458bdf5e6 - Sigstore transparency entry: 1191489417
- Sigstore integration time:
-
Permalink:
teaguesterling/ghud@44c6554110933da042884bb80d8d607d1d4dd779 -
Branch / Tag:
refs/tags/v0.2.1 - Owner: https://github.com/teaguesterling
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@44c6554110933da042884bb80d8d607d1d4dd779 -
Trigger Event:
release
-
Statement type:
File details
Details for the file ghud-0.2.1-py3-none-any.whl.
File metadata
- Download URL: ghud-0.2.1-py3-none-any.whl
- Upload date:
- Size: 23.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
758c3cc53e8bc471796f6a2b33efdd78caa80c4825ba47f3c89a93895d5b9e2f
|
|
| MD5 |
a1df42c7831b3f837747d47cb85a741b
|
|
| BLAKE2b-256 |
f66bdec32aece4179b386ec7750b35eee9589ffc779f1bd9057d9cc52bbe22cf
|
Provenance
The following attestation bundles were made for ghud-0.2.1-py3-none-any.whl:
Publisher:
publish.yml on teaguesterling/ghud
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ghud-0.2.1-py3-none-any.whl -
Subject digest:
758c3cc53e8bc471796f6a2b33efdd78caa80c4825ba47f3c89a93895d5b9e2f - Sigstore transparency entry: 1191489418
- Sigstore integration time:
-
Permalink:
teaguesterling/ghud@44c6554110933da042884bb80d8d607d1d4dd779 -
Branch / Tag:
refs/tags/v0.2.1 - Owner: https://github.com/teaguesterling
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@44c6554110933da042884bb80d8d607d1d4dd779 -
Trigger Event:
release
-
Statement type: