Foxcli is an interactive AI coding assistant in the terminal, built upon the leaked code of Claude Code .
Therefore, the way to use Foxcli is exactly the same as that of standard Claude Code. Even more exciting is that Foxcli is deeply integrated with LangRouter ,
allowing you to friendly use and switch between mainstream LLM models (including claude opus 4.6, claude sonnet 4.6, kimi k2.5, minimax M2.5, deepseek v3.2, etc.) within an ongoing session as needed, without interrupting your context.
Why not integrate with OpenRouter? OpenRouter's API for Claude models is too expensive! Moreover, OpenRouter's Anthropic API interface is not as compatible with the official Claude Code API interface.
LangRouter API Key Preparation
Go to LangRouter , register an account, save your API key, and ensure your account has sufficient balance (you can deposit $2 for testing)
Compile from source code yourself (optional)
Environmental requirements
# Development mode
bun run dev
# Build and run
bun run build && bun dist/cli.js
The built version can be started with both bun and node. You can publish to a private registry and start directly.
If you encounter any bugs, please open an issue and we will prioritize fixing them.
✅ = Implemented ⚠️ = Partial / Conditional ❌ = stub / Removed / Feature flag off
Capability
Status
Description
REPL Interactive UI (Ink Terminal Rendering)
✅
Main screen 5000+ lines, full interaction
API Communication — Anthropic Direct
✅
Supports API Key + OAuth
API Communication — AWS Bedrock
✅
Supports credential refresh, Bearer Token
API Communication — Google Vertex
✅
Supports GCP credential refresh
API Communication — Azure Foundry
✅
Supports API Key + Azure AD
Streaming Conversation & Tool Call Loop (query.ts)
✅
1700+ lines, includes auto-compaction, token tracking
Session Engine (QueryEngine.ts)
✅
1300+ lines, manages conversation state and attribution
Context Building (git status / CLAUDE.md / memory)
✅
context.ts fully implemented
Permission System (plan/auto/manual modes)
✅
6300+ lines, includes YOLO classifier, path validation, rule matching
Hook System (pre/post tool use)
✅
Supports settings.json configuration
Session Resume (/resume)
✅
Separate ResumeConversation screen
Doctor Diagnostics (/doctor)
✅
Version, API, plugin, sandbox checks
Auto Compaction
✅
auto-compact / micro-compact / API compact
Tool
Status
Description
BashTool
✅
Shell execution, sandbox, permission checking
FileReadTool
✅
File / PDF / image / Notebook reading
FileEditTool
✅
String replacement editing + diff tracking
FileWriteTool
✅
File creation / overwrite + diff generation
NotebookEditTool
✅
Jupyter Notebook cell editing
AgentTool
✅
Sub-agent spawning (fork / async / background / remote)
WebFetchTool
✅
URL fetch → Markdown → AI summary
WebSearchTool
✅
Web search + domain filtering
AskUserQuestionTool
✅
Multi-question interactive prompts + preview
SendMessageTool
✅
Message sending (peers / teammates / mailbox)
SkillTool
✅
Slash command / Skill invocation
EnterPlanModeTool
✅
Enter plan mode
ExitPlanModeTool (V2)
✅
Exit plan mode
TodoWriteTool
✅
Todo list v1
BriefTool
✅
Short message + attachment sending
TaskOutputTool
✅
Background task output reading
TaskStopTool
✅
Background task stop
ListMcpResourcesTool
⚠️
MCP resource list (filtered by specialTools, added under specific conditions)
ReadMcpResourceTool
⚠️
MCP resource reading (same as above)
SyntheticOutputTool
⚠️
Only created in non-interactive sessions (SDK/pipe mode)
CronCreateTool
✅
Scheduled task creation (AGENT_TRIGGERS gate removed)
CronDeleteTool
✅
Scheduled task deletion
CronListTool
✅
Scheduled task list
EnterWorktreeTool
✅
Enter Git Worktree (isWorktreeModeEnabled() hardcoded to true)
ExitWorktreeTool
✅
Exit Git Worktree
Tools — Conditionally Enabled
Tool
Status
Enable Condition
GlobTool
✅
Enabled when not embedded bfs/ugrep (enabled by default)
GrepTool
✅
Same as above
TaskCreateTool
⚠️
When isTodoV2Enabled() is true
TaskGetTool
⚠️
Same as above
TaskUpdateTool
⚠️
Same as above
TaskListTool
⚠️
Same as above
TeamCreateTool
⚠️
When isAgentSwarmsEnabled()
TeamDeleteTool
⚠️
Same as above
ToolSearchTool
⚠️
When isToolSearchEnabledOptimistic()
PowerShellTool
⚠️
Windows platform detection
LSPTool
⚠️
When ENABLE_LSP_TOOL environment variable
ConfigTool
❌
USER_TYPE === 'ant' (always false)
Tools — Feature Flag Off (All Unavailable)
Tool
Feature Flag
SleepTool
PROACTIVE / KAIROS
RemoteTriggerTool
AGENT_TRIGGERS_REMOTE
MonitorTool
MONITOR_TOOL
SendUserFileTool
KAIROS
OverflowTestTool
OVERFLOW_TEST_TOOL
TerminalCaptureTool
TERMINAL_PANEL
WebBrowserTool
WEB_BROWSER_TOOL
SnipTool
HISTORY_SNIP
WorkflowTool
WORKFLOW_SCRIPTS
PushNotificationTool
KAIROS / KAIROS_PUSH_NOTIFICATION
SubscribePRTool
KAIROS_GITHUB_WEBHOOKS
ListPeersTool
UDS_INBOX
CtxInspectTool
CONTEXT_COLLAPSE
Tools — Stub / Unavailable
Tool
Description
TungstenTool
ANT-ONLY stub
REPLTool
ANT-ONLY, isEnabled: () => false
SuggestBackgroundPRTool
ANT-ONLY, isEnabled: () => false
VerifyPlanExecutionTool
Requires CLAUDE_CODE_VERIFY_PLAN=true env var, and is stub
ReviewArtifactTool
stub, not registered in tools.ts
DiscoverSkillsTool
stub, not registered in tools.ts
Slash Commands — Available
Command
Status
Description
/add-dir
✅
Add directory
/advisor
✅
Advisor configuration
/agents
✅
Agent list/management
/branch
✅
Branch management
/btw
✅
Quick note
/chrome
✅
Chrome integration
/clear
✅
Clear screen
/color
✅
Agent color
/compact
✅
Compact conversation
/config (/settings)
✅
Configuration management
/context
✅
Context information
/copy
✅
Copy last message
/cost
✅
Session cost
/desktop
✅
Claude Desktop integration
/diff
✅
Show diff
/doctor
✅
Health check
/effort
✅
Set effort level
/exit
✅
Exit
/export
✅
Export conversation
/extra-usage
✅
Extra usage information
/fast
✅
Toggle fast mode
/feedback
✅
Feedback
/loop
✅
Scheduled loop execution (bundled skill, can be disabled via CLAUDE_CODE_DISABLE_CRON)
/heapdump
✅
Heap dump (debugging)
/help
✅
Help
/hooks
✅
Hook management
/ide
✅
IDE connection
/init
✅
Initialize project
/install-github-app
✅
Install GitHub App
/install-slack-app
✅
Install Slack App
/keybindings
✅
Keybindings management
/login / /logout
✅
Login / Logout
/mcp
✅
MCP service management
/memory
✅
Memory / CLAUDE.md management
/mobile
✅
Mobile QR code
/model
✅
Model selection
/output-style
✅
Output style
/passes
✅
Referral codes
/permissions
✅
Permission management
/plan
✅
Plan mode
/plugin
✅
Plugin management
/pr-comments
✅
PR comments
/privacy-settings
✅
Privacy settings
/rate-limit-options
✅
Rate limit options
/release-notes
✅
Release notes
/reload-plugins
✅
Reload plugins
/remote-env
✅
Remote environment configuration
/rename
✅
Rename session
/resume
✅
Resume session
/review
✅
Code review (local)
/ultrareview
✅
Cloud review
/rewind
✅
Rewind conversation
/sandbox-toggle
✅
Toggle sandbox
/security-review
✅
Security review
/session
✅
Session information
/skills
✅
Skill management
/stats
✅
Session statistics
/status
✅
Status information
/statusline
✅
Status bar UI
/stickers
✅
Stickers
/tasks
✅
Task management
/theme
✅
Terminal theme
/think-back
✅
Year in review
/upgrade
✅
Upgrade CLI
/usage
✅
Usage information
/insights
✅
Usage analytics report
/vim
✅
Vim mode
Slash Commands — Feature Flag Off
Command
Feature Flag
/voice
VOICE_MODE
/proactive
PROACTIVE / KAIROS
/brief
KAIROS / KAIROS_BRIEF
/assistant
KAIROS
/remote-control (alias rc)
BRIDGE_MODE
/remote-control-server
DAEMON + BRIDGE_MODE
/force-snip
HISTORY_SNIP
/workflows
WORKFLOW_SCRIPTS
/web-setup
CCR_REMOTE_SETUP
/subscribe-pr
KAIROS_GITHUB_WEBHOOKS
/ultraplan
ULTRAPLAN
/torch
TORCH
/peers
UDS_INBOX
/fork
FORK_SUBAGENT
/buddy
BUDDY
Slash Commands — ANT-ONLY (Unavailable)
/files /tag /backfill-sessions /break-cache /bughunter /commit /commit-push-pr /ctx_viz /good-claude /issue /init-verifiers /mock-limits /bridge-kick /version /reset-limits /onboarding /share /summary /teleport /ant-trace /perf-issue /env /oauth-refresh /debug-tool-call /agents-platform /autofix-pr
Subcommand
Status
Description
claude (default)
✅
Main REPL / interactive / print mode
claude mcp serve/add/remove/list/get/...
✅
MCP service management (7 subcommands)
claude auth login/status/logout
✅
Authentication management
claude plugin validate/list/install/...
✅
Plugin management (7 subcommands)
claude setup-token
✅
Long-lived token configuration
claude agents
✅
Agent list
claude doctor
✅
Health check
claude update / upgrade
✅
Auto-update
claude install [target]
✅
Native installation
claude server
❌
DIRECT_CONNECT flag
claude ssh <host>
❌
SSH_REMOTE flag
claude open <cc-url>
❌
DIRECT_CONNECT flag
claude auto-mode
❌
TRANSCRIPT_CLASSIFIER flag
claude remote-control
❌
BRIDGE_MODE + DAEMON flag
claude assistant
❌
KAIROS flag
claude up/rollback/log/error/export/task/completion
❌
ANT-ONLY
Service
Status
Description
API Client (services/api/)
✅
3400+ lines, 4 providers
MCP (services/mcp/)
✅
34 files, 12000+ lines
OAuth (services/oauth/)
✅
Full OAuth flow
Plugins (services/plugins/)
✅
Complete infrastructure, no built-in plugins
LSP (services/lsp/)
⚠️
Implementation exists, disabled by default
Compaction (services/compact/)
✅
auto / micro / API compaction
Hook System (services/tools/toolHooks.ts)
✅
pre/post tool use hooks
Session Memory (services/SessionMemory/)
✅
Session memory management
Memory Extraction (services/extractMemories/)
✅
Automatic memory extraction
Skill Search (services/skillSearch/)
✅
Local/remote skill search
Policy Limits (services/policyLimits/)
✅
Policy limit enforcement
Analytics / GrowthBook / Sentry
⚠️
Framework exists, actual sink is empty
Voice (services/voice.ts)
❌
VOICE_MODE flag off
Internal Packages (packages/)
Package
Status
Description
color-diff-napi
✅
1006 lines complete TypeScript implementation (syntax highlighting diff)
audio-capture-napi
✅
151 lines complete implementation (cross-platform audio recording, using SoX/arecord)
image-processor-napi
✅
125 lines complete implementation (macOS clipboard image reading, using osascript + sharp)
modifiers-napi
✅
67 lines complete implementation (macOS modifier key detection, bun:ffi + CoreGraphics)
url-handler-napi
❌
stub, waitForUrlEvent() returns null
@ant/claude-for-chrome-mcp
❌
stub, createServer() returns null
@ant/computer-use-mcp
⚠️
Type-safe stub (265 lines, complete type definitions but functions return empty values)
@ant/computer-use-input
✅
183 lines complete implementation (macOS keyboard/mouse simulation, AppleScript/JXA/CGEvent)
@ant/computer-use-swift
✅
388 lines complete implementation (macOS display/app management/screenshot, JXA/screencapture)
Feature Flags (31, all return false)
ABLATION_BASELINE AGENT_MEMORY_SNAPSHOT BG_SESSIONS BRIDGE_MODE BUDDY CCR_MIRROR CCR_REMOTE_SETUP CHICAGO_MCP COORDINATOR_MODE DAEMON DIRECT_CONNECT EXPERIMENTAL_SKILL_SEARCH FORK_SUBAGENT HARD_FAIL HISTORY_SNIP KAIROS KAIROS_BRIEF KAIROS_CHANNELS KAIROS_GITHUB_WEBHOOKS LODESTONE MCP_SKILLS PROACTIVE SSH_REMOTE TORCH TRANSCRIPT_CLASSIFIER UDS_INBOX ULTRAPLAN UPLOAD_USER_SETTINGS VOICE_MODE WEB_BROWSER_TOOL WORKFLOW_SCRIPTS
foxcli/
├── src/
│ ├── entrypoints/
│ │ ├── cli.tsx # Entry file (includes MACRO/feature polyfill)
│ │ └── sdk/ # SDK submodule stub
│ ├── main.tsx # Main CLI logic (Commander definition)
│ └── types/
│ ├── global.d.ts # Global variable/macro declarations
│ └── internal-modules.d.ts # Internal npm package type declarations
├── packages/ # Monorepo workspace packages
│ ├── color-diff-napi/ # Complete implementation (terminal color diff)
│ ├── modifiers-napi/ # stub (macOS modifier key detection)
│ ├── audio-capture-napi/ # stub
│ ├── image-processor-napi/# stub
│ ├── url-handler-napi/ # stub
│ └── @ant/ # Anthropic internal package stubs
│ ├── claude-for-chrome-mcp/
│ ├── computer-use-mcp/
│ ├── computer-use-input/
│ └── computer-use-swift/
├── scripts/ # Automation stub generation scripts
├── build.ts # Build script (Bun.build + code splitting + Node.js compatibility post-processing)
├── dist/ # Build output (entry cli.js + ~450 chunk files)
└── package.json # Bun workspaces monorepo configuration
The entry file src/entrypoints/cli.tsx injects necessary polyfills at the top:
feature() — All feature flags return false, skipping unimplemented branches
globalThis.MACRO — Simulates build-time macro injection (VERSION, etc.)
The project uses Bun workspaces to manage internal packages. Stubs that were manually placed in node_modules/ have been migrated to packages/, resolved via workspace:*.
The original Claude Code uses feature() from bun:bundle to inject feature flags at build time, controlled by A/B testing platforms like GrowthBook for gradual rollout. In this project, feature() is polyfilled to always return false, so all 30 flags below are disabled.
Flag
Purpose
KAIROS
Assistant mode — Long-running autonomous agent (includes brief, push notifications, file sending)
KAIROS_BRIEF
Kairos Brief — Send briefing summaries to users
KAIROS_CHANNELS
Kairos Channels — Multi-channel communication
KAIROS_GITHUB_WEBHOOKS
GitHub Webhook subscription — Real-time PR events pushed to Agent
PROACTIVE
Proactive mode — Agent actively executes tasks, includes SleepTool scheduled wakeup
COORDINATOR_MODE
Coordinator mode — Multi-agent orchestration and scheduling
BUDDY
Buddy pair programming feature
FORK_SUBAGENT
Fork sub-agent — Spawn independent sub-agent from current session
Flag
Purpose
BRIDGE_MODE
Remote control bridge — Allows external clients to remotely control Claude Code
DAEMON
Daemon — Background persistent service, supports worker and supervisor
BG_SESSIONS
Background sessions — Background process management like ps/logs/attach/kill/--bg
SSH_REMOTE
SSH remote — claude ssh <host> to connect to remote host
DIRECT_CONNECT
Direct connect mode — cc:// URL protocol, server command, open command
CCR_REMOTE_SETUP
Web-based remote setup — Configure Claude Code via browser
CCR_MIRROR
Claude Code Runtime mirror — Session state sync/replication
Flag
Purpose
UDS_INBOX
Unix Domain Socket inbox — Local agent-to-agent communication (/peers)
Flag
Purpose
CHICAGO_MCP
Computer Use MCP — Computer operations (screen capture, mouse/keyboard control)
WEB_BROWSER_TOOL
Web browser tool — Embedded browser interaction in terminal
VOICE_MODE
Voice mode — Voice input/output, microphone push-to-talk
WORKFLOW_SCRIPTS
Workflow scripts — User-defined automation workflows
MCP_SKILLS
MCP-based Skill loading mechanism
Flag
Purpose
HISTORY_SNIP
History snip — Manually snip segments from conversation history (/force-snip)
ULTRAPLAN
Ultra-plan — Large-scale planning for remote Agent collaboration
AGENT_MEMORY_SNAPSHOT
Agent memory snapshot — Memory snapshot during Agent runtime
Infrastructure / Experimental
Flag
Purpose
ABLATION_BASELINE
Scientific experiment — Baseline ablation testing, used for A/B experiment control group
HARD_FAIL
Hard fail mode — Abort on errors instead of graceful degradation
TRANSCRIPT_CLASSIFIER
Transcript classifier — auto-mode command, automatically analyzes and classifies conversation records
UPLOAD_USER_SETTINGS
Settings sync upload — Sync local configuration to cloud
LODESTONE
Deep link protocol handler — Jump to specific locations in Claude Code from external apps
EXPERIMENTAL_SKILL_SEARCH
Experimental skill search index
TORCH
Torch feature (specific purpose unknown, possibly some highlighting/tracking mechanism)
This project is for educational and research purposes only. All rights to Claude Code belong to Anthropic .