CTOP(1)

NAME

ctopCTOP - Interactive Process Viewer for AI Coding Agents

SYNOPSIS

$npm install -g ctop-claude

INFO

80 stars
8 forks
0 views

DESCRIPTION

CTOP - Interactive Process Viewer for AI Coding Agents

README

CTOP — AI Agent Terminal Operations Panel

License: MIT Platform: macOS | Linux | Windows Node.js Zero Dependencies

htop for your AI coding agents. Monitor Claude Code, Codex CLI, OpenCode, and Devin sessions — CPU, memory, tokens, context window, costs, branches — from a single terminal pane.

CTOP Demo

Features

  • Multi-agent monitoring — Claude Code + Codex CLI + OpenCode + Devin, real-time CPU/memory/status
  • Context window tracking — visual bar with input, cache, output, and free segments
  • Cost estimation — per-session and aggregate API cost (Claude + OpenAI pricing)
  • Token waveform — real-time sparkline showing token activity pulse
  • Two view modes — list view (table) and pane view (card grid), toggle with P
  • Live log tailing — stream conversation in a split pane (L)
  • Sort, filter, search — by CPU, memory, context, branch, model, or full-text (F)
  • Dashboard & history — aggregate stats (d), 24-hour usage charts (H)
  • Process control — kill sessions (graceful or force), quick-jump to project dir
  • Desktop notifications — get notified when sessions complete
  • 5 color themes — default, minimal, dracula, solarized, monokai (+ custom)
  • Plugin system — extend with custom columns via ~/.ctop/plugins/
  • Compaction & rate limit detection — flags compaction events and quota usage
  • CLI mode for agentsctop ls, ctop whoami, ctop alerts, … (see CLI mode)

CTOP Features


Installation

# Homebrew
brew tap aakashadesara/ctop && brew install ctop-claude

npm

npm install -g ctop-claude

npx (no install)

npx ctop-claude

From source

git clone https://github.com/aakashadesara/ctop.git chmod +x ctop/claude-manager ln -s "$(pwd)/ctop/claude-manager" /usr/local/bin/ctop

Then run ctop. If no agents are running, you'll see an empty state — start a Claude Code, Codex, OpenCode, or Devin session and it'll appear on the next refresh.


Keyboard shortcuts

KeyAction
j/k or /Navigate
h/l or /Navigate (pane mode)
g / GJump to first / last
PToggle list / pane view
s / SCycle sort / reverse
/Filter
FFull-text search conversations
dToggle dashboard
LToggle log pane
HToggle 24-hour history
WTimeline view
TCycle color theme
x / XKill (SIGTERM / SIGKILL)
KKill ALL agents
o / e / tOpen dir in Finder / editor / terminal
nToggle notifications
?Help
qQuit

Mouse: click to select, scroll to navigate.


Agent skill

A self-contained ctop skill ships in this repo. Drop it into Claude Code so any agent learns when and how to call ctop:

# Per-project
mkdir -p .claude/skills && cp -r skills/ctop .claude/skills/

Or user-wide

mkdir -p ~/.claude/skills && cp -r skills/ctop ~/.claude/skills/

Once installed, ask any Claude Code session things like "what other agents am I running", "how much have my sessions cost", "is my context about to compact" — the agent will reach for ctop automatically.

Skill files:

CLI mode (for agents and scripts)

ctop with no args starts the interactive TUI. ctop <subcommand> runs a one-shot query and exits, so AI agents can introspect their own sessions and sister sessions from another terminal.

ctop ls                          # Table of every running agent
ctop ls --json                   # Same, machine-parseable
ctop ls --agent claude           # Filter by backend
ctop ls --cwd ~/code/myproj      # Filter by directory

ctop get <pid> --json # Full detail on one session ctop log <pid> --tail 20 # Last 20 conversation messages ctop search "TODO" --json # Full-text search across sessions ctop diff <pid> # Git diff for the session's cwd ctop stats --json # Aggregate cost / tokens / counts

ctop whoami # Detect which session you're in ctop whoami --pid-only # PID only, for scripting ctop alerts # Low-context / idle / ghost warnings ctop alerts --severity critical # Only critical-level alerts

ctop kill <pid> # SIGTERM (must be your own user) ctop kill <pid> --force # SIGKILL ctop notify "title" "message" # Desktop notification

whoami detects the calling session via $CTOP_PID → parent-PID walk → $PWD match, with a matchConfidence label (exact | ppid | cwd-guess | none) so agents know how much to trust the answer.

Read tools surface data that the user could read off disk anyway. kill enforces uid ownership and an agent-session check before sending the signal — there is no kill-all.

Examples

# Find sessions about to compact
ctop ls --json | jq '.[] | select(.contextPct != null and .contextPct < 20)'

Self-aware compaction (hook)

[ "$(ctop whoami --json | jq -r .session.contextPct)" -lt 15 ] &&
echo "context low — consider /compact"

Clean up ghost sessions

ctop alerts --json | jq -r '.[] | select(.kind=="ghost") | .pid' |
xargs -I {} ctop kill {} --force

Configuration

CLI flags (TUI mode)

ctop --refresh 3             # Refresh every 3 seconds
ctop --context-limit 128000  # Set context window to 128k
ctop --pane                  # Start in pane view

Config file (~/.ctoprc)

{
  "refreshInterval": 5000,
  "contextLimit": 200000,
  "defaultView": "list",
  "theme": "default",
  "contextBarStyle": "block",
  "notifications": { "enabled": true, "minDuration": 30 }
}

CLI flags override config file values.


How it works

Reads process info from ps (PowerShell on Windows), resolves working directories via lsof, and enriches each process with session metadata from local JSONL files (~/.claude/projects/ for Claude, ~/.codex/sessions/ for Codex) and SQLite databases (~/.local/share/opencode/ for OpenCode, ~/.local/share/devin/cli/ for Devin). No network calls, no external dependencies.

Plugins

Extend with custom columns. Create .js files in ~/.ctop/plugins/:

module.exports = {
  name: 'my-plugin',
  column: {
    header: 'CUSTOM',
    width: 10,
    getValue: (proc) => proc.cwd ? 'yes' : 'no',
  },
};

See examples/plugins/ for more.


Requirements

  • Node.js 18+
  • macOS, Linux, or Windows — Windows uses PowerShell for process detection; CWD resolution is more limited than macOS/Linux.
  • Claude Code, Codex CLI, OpenCode, and/or Devin (terminal) running sessions
  • sqlite3 on PATH for OpenCode and Devin session reads (built-in on macOS; available via apt/brew on Linux)

Contributing

PRs welcome! Fork, clone, run ./claude-manager to develop, npm test to test. Open an issue first for large changes.

License

MIT

SEE ALSO

clihub5/22/2026CTOP(1)