It finds what you forgot to look for.
nightshift.haplab.com · Docs · Quick Start · CLI Reference
Your tokens get reset every week, you might as well use them. Nightshift runs overnight to find dead code, doc drift, test gaps, security issues, and 20+ other things silently accumulating while you ship features. Like a Roomba for your codebase — runs overnight, worst case you close the PR.
Everything lands as a branch or PR. It never writes directly to your primary branch. Don't like something? Close it. That's the whole rollback plan.
- Budget-aware: Uses remaining daily allotment, never exceeds configurable max (default 75%)
- Multi-project: Point it at your repos, it already knows what to look for
- Zero risk: Everything is a PR — merge what surprises you, close the rest
- Great DX: Thoughtful CLI defaults with clear output and reports
Full guide: Installation docs
brew install marcus/tap/nightshiftBinary downloads are available on the GitHub releases page.
Manual install:
go install github.com/marcus/nightshift/cmd/nightshift@latestFull guide: Quick Start docs
After installing, run the guided setup:
nightshift setupThis walks you through provider configuration, project selection, budget calibration, and daemon setup. Once complete you can preview what nightshift will do:
nightshift preview
nightshift budgetOr kick off a run immediately:
nightshift runFull reference: CLI Reference docs
# Preview next scheduled runs with prompt previews
nightshift preview -n 3
nightshift preview --long
nightshift preview --explain
nightshift preview --plain
nightshift preview --json
nightshift preview --write ./nightshift-prompts
# Guided global setup
nightshift setup
# Check environment and config health
nightshift doctor
# Budget status and calibration
nightshift budget --provider claude
nightshift budget snapshot --local-only
nightshift budget history -n 10
nightshift budget calibrate
# Browse and inspect available tasks
nightshift task list
nightshift task list --category pr
nightshift task list --cost low --json
# Show task details and planning prompt
nightshift task show lint-fix
nightshift task show skill-groom
nightshift task show lint-fix --prompt-only
# Run a task immediately
nightshift task run lint-fix --provider claude
nightshift task run skill-groom --provider codex --dry-run
nightshift task run lint-fix --provider codex --dry-runIf gum is available, preview output is shown through the gum pager. Use --plain to disable.
Before executing, nightshift run displays a preflight summary showing the
selected provider, budget status, projects, and planned tasks. In interactive
terminals you are prompted for confirmation; in non-TTY environments (cron,
daemon, CI) confirmation is auto-skipped.
| Flag | Default | Description |
|---|---|---|
--dry-run |
false |
Show preflight summary and exit without executing |
--project, -p |
(all configured) | Target a single project directory |
--task, -t |
(auto-select) | Run a specific task by name |
--max-projects |
1 |
Max projects to process (ignored when --project is set) |
--max-tasks |
1 |
Max tasks per project (ignored when --task is set) |
--random-task |
false |
Pick a random task from eligible tasks instead of the highest-scored one |
--ignore-budget |
false |
Bypass budget checks (use with caution) |
--yes, -y |
false |
Skip the confirmation prompt |
# Interactive run with preflight summary + confirmation prompt
nightshift run
# Non-interactive: skip confirmation
nightshift run --yes
# Dry-run: show preflight summary and exit
nightshift run --dry-run
# Process up to 3 projects, 2 tasks each
nightshift run --max-projects 3 --max-tasks 2
# Pick a random eligible task
nightshift run --random-task
# Bypass budget limits (shows warning)
nightshift run --ignore-budget
# Target a specific project and task directly
nightshift run -p ./my-project -t lint-fixOther useful flags:
nightshift status --todayto see today's activity summarynightshift daemon start --foregroundfor debug--category— filter tasks by category (pr, analysis, options, safe, map, emergency)--cost— filter by cost tier (low, medium, high, veryhigh)--prompt-only— output just the raw prompt text for piping--provider— required fortask run, choose claude or codex--dry-run— preview the prompt without executing--timeout— execution timeout (default 30m)
Nightshift relies on the local Claude Code and Codex CLIs. If you have subscriptions, you can sign in via the CLIs without API keys.
# Claude Code
claude
/login
# Codex
codex --loginClaude Code login supports Claude.ai subscriptions or Anthropic Console credentials. Codex CLI supports signing in with ChatGPT or an API key.
If you prefer API-based usage, you can authenticate those CLIs with API keys instead.
Full guide: Configuration docs · Budget docs · Scheduling docs · Tasks docs
Nightshift uses YAML config files to define:
- Token budget limits
- Target repositories
- Task priorities
- Schedule preferences
Run nightshift setup to create/update the global config at ~/.config/nightshift/config.yaml.
See the full configuration docs or SPEC.md for detailed options.
Minimal example:
schedule:
cron: "0 2 * * *"
budget:
mode: daily
max_percent: 75
reserve_percent: 5
billing_mode: subscription
calibrate_enabled: true
snapshot_interval: 30m
providers:
preference:
- claude
- codex
claude:
enabled: true
data_path: "~/.claude"
dangerously_skip_permissions: true
codex:
enabled: true
data_path: "~/.codex"
dangerously_bypass_approvals_and_sandbox: true
projects:
- path: ~/code/sidecar
- path: ~/code/tdTask selection:
tasks:
enabled:
- lint-fix
- docs-backfill
- bug-finder
priorities:
lint-fix: 1
skill-groom: 2
bug-finder: 2
intervals:
lint-fix: "24h"
skill-groom: "168h"
docs-backfill: "168h"Each task has a default cooldown interval to prevent the same task from running too frequently on a project (e.g., 24h for lint-fix, 7d for docs-backfill). Override per-task with tasks.intervals.
skill-groom is enabled by default. Add it to tasks.disabled if you want to opt out. It updates project-local skills under .claude/skills and .codex/skills using README.md as project context and starts Agent Skills docs lookup from https://agentskills.io/llms.txt.
# Remove the system service
nightshift uninstall
# Remove configs and data (optional)
rm -rf ~/.config/nightshift ~/.local/share/nightshift
# Remove the binary
rm "$(which nightshift)"MIT - see LICENSE for details.
