Using Pi
This page collects day-to-day usage details that do not fit on the quickstart page.
Interactive Mode
Section titled “Interactive Mode”
The interface has four main areas:
- Startup header - shortcuts, loaded context files, prompt templates, skills, and extensions
- Messages - user messages, assistant responses, tool calls, tool results, notifications, errors, and extension UI
- Editor - where you type; border color indicates the current thinking level
- Footer - working directory, session name, token/cache usage, cost, context usage, and current model
The editor can be replaced temporarily by built-in UI such as /settings or by custom extension UI.
Editor Features
Section titled “Editor Features”| Feature | How |
|---|---|
| File reference | Type @ to fuzzy-search project files |
| Path completion | Press Tab to complete paths |
| Multi-line input | Shift+Enter, or Ctrl+Enter on Windows Terminal |
| Images | Paste with Ctrl+V, Alt+V on Windows, or drag into the terminal |
| Shell command | !command runs and sends output to the model |
| Hidden shell command | !!command runs without sending output to the model |
| External editor | Ctrl+G opens $VISUAL or $EDITOR |
See Keybindings for all shortcuts and customization.
Slash Commands
Section titled “Slash Commands”Type / in the editor to open command completion. Extensions can register custom commands, skills are available as /skill:name, and prompt templates expand via /templatename.
| Command | Description |
|---|---|
/login, /logout | Manage OAuth or API-key credentials |
/model | Switch models |
/scoped-models | Enable/disable models for Ctrl+P cycling |
/settings | Thinking level, theme, message delivery, transport |
/resume | Pick from previous sessions |
/new | Start a new session |
/name <name> | Set session display name |
/session | Show session file, ID, messages, tokens, and cost |
/tree | Jump to any point in the session and continue from there |
/fork | Create a new session from a previous user message |
/clone | Duplicate the current active branch into a new session |
/compact [prompt] | Manually compact context, optionally with custom instructions |
/copy | Copy last assistant message to clipboard |
/export [file] | Export session to HTML |
/share | Upload as private GitHub gist with shareable HTML link |
/reload | Reload keybindings, extensions, skills, prompts, and context files |
/hotkeys | Show all keyboard shortcuts |
/changelog | Display version history |
/quit | Quit pi |
Message Queue
Section titled “Message Queue”You can submit messages while the agent is still working:
- Enter queues a steering message, delivered after the current assistant turn finishes executing its tool calls.
- Alt+Enter queues a follow-up message, delivered after the agent finishes all work.
- Escape aborts and restores queued messages to the editor.
- Alt+Up retrieves queued messages back to the editor.
On Windows Terminal, Alt+Enter is fullscreen by default. Remap it as described in Terminal setup if you want pi to receive the shortcut.
Configure delivery in Settings with steeringMode and followUpMode.
Sessions
Section titled “Sessions”Sessions are saved automatically to ~/.pi/agent/sessions/, organized by working directory.
pi -c # Continue most recent sessionpi -r # Browse and select a sessionpi --no-session # Ephemeral mode; do not savepi --name "my task" # Set session display name at startuppi --session <path|id> # Use a specific session file or session IDpi --fork <path|id> # Fork a session into a new session fileUseful session commands:
/sessionshows the current session file and ID./treenavigates the in-file session tree and can summarize abandoned branches./forkcreates a new session from an earlier user message./cloneduplicates the current active branch into a new session file./compactsummarizes older messages to free context.
See Sessions and Compaction for details.
Context Files
Section titled “Context Files”Pi loads AGENTS.md or CLAUDE.md at startup from:
~/.pi/agent/AGENTS.mdfor global instructions- parent directories, walking up from the current working directory
- the current directory
Use context files for project conventions, commands, safety rules, and preferences. Disable loading with --no-context-files or -nc.
System Prompt Files
Section titled “System Prompt Files”Replace the default system prompt with:
.pi/SYSTEM.mdfor a project~/.pi/agent/SYSTEM.mdglobally
Append to the default prompt without replacing it with APPEND_SYSTEM.md in either location.
Project Trust
Section titled “Project Trust”On interactive startup, pi asks before trusting a project folder that contains project-local settings, resources, or project .agents/skills and has no saved decision for the folder or a parent folder in ~/.pi/agent/trust.json. Trusting a project allows pi to load .pi/settings.json and .pi resources, install missing project packages, and execute project extensions.
Before the trust decision, pi loads only context files, user/global extensions, and CLI -e extensions so they can handle the project_trust event. Project-local extensions, project package-managed extensions, and project settings are loaded only after the project is trusted. This split also applies when switching to a session from a different cwd whose trust has not been resolved in the current process.
Non-interactive modes (-p, --mode json, and --mode rpc) do not show a trust prompt. Without an applicable saved trust decision, they use defaultProjectTrust from global settings: ask (default) and never ignore those project resources, while always trusts them. Pass --approve/-a or --no-approve/-na to override project trust for one run.
If no extension or saved decision applies, defaultProjectTrust controls the fallback behavior. Set it to "ask", "always", or "never" in ~/.pi/agent/settings.json, or change it with /settings.
pi config and package commands use the same project trust flow, except pi update never prompts. Pass --approve to trust project-local settings for one command or --no-approve to ignore them.
Use /trust in interactive mode to save a project trust decision for future sessions, including trust for the immediate parent folder. It writes ~/.pi/agent/trust.json only; the current session is not reloaded, so restart pi for changes to take effect.
Exporting and Sharing Sessions
Section titled “Exporting and Sharing Sessions”Use /export [file] to write a session to HTML.
Use /share to upload a private GitHub gist with a shareable HTML link.
If you use pi for open source work and want to publish sessions for model, prompt, tool, and evaluation research, see badlogic/pi-share-hf. It publishes sessions to Hugging Face datasets.
CLI Reference
Section titled “CLI Reference”pi [options] [@files...] [messages...]Package Commands
Section titled “Package Commands”pi install <source> [-l] # Install package, -l for project-localpi remove <source> [-l] # Remove packagepi uninstall <source> [-l] # Alias for removepi update [source|self|pi] # Update pi only, or one package sourcepi update --all # Update pi and packages; reconcile pinned git refspi update --extensions # Update packages only; reconcile pinned git refspi update --self # Update pi onlypi update --extension <src> # Update one packagepi list # List installed packagespi config # Enable/disable package resourcesThese commands manage pi packages and pi update can update the pi CLI installation. To uninstall pi itself, see Quickstart. pi config and project package commands accept --approve/--no-approve to trust or ignore project-local settings for one command. pi update never prompts for project trust.
See Pi Packages for package sources and security notes.
| Flag | Description |
|---|---|
| default | Interactive mode |
-p, --print | Print response and exit |
--mode json | Output all events as JSON lines; see JSON mode |
--mode rpc | RPC mode over stdin/stdout; see RPC mode |
--export <in> [out] | Export a session to HTML |
In print mode, pi also reads piped stdin and merges it into the initial prompt:
cat README.md | pi -p "Summarize this text"Model Options
Section titled “Model Options”| Option | Description |
|---|---|
--provider <name> | Provider, such as anthropic, openai, or google |
--model <pattern> | Model pattern or ID; supports provider/id and optional :<thinking> |
--api-key <key> | API key, overriding environment variables |
--thinking <level> | off, minimal, low, medium, high, xhigh |
--models <patterns> | Comma-separated patterns for Ctrl+P cycling |
--list-models [search] | List available models |
Session Options
Section titled “Session Options”| Option | Description |
|---|---|
-c, --continue | Continue the most recent session |
-r, --resume | Browse and select a session |
--session <path|id> | Use a specific session file or partial UUID |
--fork <path|id> | Fork a session file or partial UUID into a new session |
--session-dir <dir> | Custom session storage directory |
--no-session | Ephemeral mode; do not save |
--name <name>, -n <name> | Set session display name at startup |
Tool Options
Section titled “Tool Options”| Option | Description |
|---|---|
--tools <list>, -t <list> | Allowlist specific built-in, extension, and custom tools |
--exclude-tools <list>, -xt <list> | Disable specific built-in, extension, and custom tools |
--no-builtin-tools, -nbt | Disable built-in tools but keep extension/custom tools enabled |
--no-tools, -nt | Disable all tools |
Built-in tools: read, bash, edit, write, grep, find, ls.
Resource Options
Section titled “Resource Options”| Option | Description |
|---|---|
-e, --extension <source> | Load an extension from path, npm, or git; repeatable |
--no-extensions | Disable extension discovery |
--skill <path> | Load a skill; repeatable |
--no-skills | Disable skill discovery |
--prompt-template <path> | Load a prompt template; repeatable |
--no-prompt-templates | Disable prompt template discovery |
--theme <path> | Load a theme; repeatable |
--no-themes | Disable theme discovery |
--no-context-files, -nc | Disable AGENTS.md and CLAUDE.md discovery |
Combine --no-* with explicit flags to load exactly what you need, ignoring settings. Example:
pi --no-extensions -e ./my-extension.tsOther Options
Section titled “Other Options”| Option | Description |
|---|---|
--system-prompt <text> | Replace default prompt; context files and skills are still appended |
--append-system-prompt <text> | Append to system prompt |
--verbose | Force verbose startup |
-a, --approve | Trust project-local files for this run |
-na, --no-approve | Ignore project-local files for this run |
-h, --help | Show help |
-v, --version | Show version |
File Arguments
Section titled “File Arguments”Prefix files with @ to include them in the message:
pi @prompt.md "Answer this"pi -p @screenshot.png "What's in this image?"pi @code.ts @test.ts "Review these files"Examples
Section titled “Examples”# Interactive with initial promptpi "List all .ts files in src/"
# Non-interactivepi -p "Summarize this codebase"
# Non-interactive with piped stdincat README.md | pi -p "Summarize this text"
# Named one-shot sessionpi --name "release audit" -p "Audit this repository"
# Different modelpi --provider openai --model gpt-4o "Help me refactor"
# Model with provider prefixpi --model openai/gpt-4o "Help me refactor"
# Model with thinking level shorthandpi --model sonnet:high "Solve this complex problem"
# Limit model cyclingpi --models "claude-*,gpt-4o"
# Read-only modepi --tools read,grep,find,ls -p "Review the code"
# Disable one extension or built-in tool while keeping the rest availablepi --exclude-tools ask_questionEnvironment Variables
Section titled “Environment Variables”| Variable | Description |
|---|---|
PI_CODING_AGENT_DIR | Override config directory; default is ~/.pi/agent |
PI_CODING_AGENT_SESSION_DIR | Override session storage directory; overridden by --session-dir |
PI_PACKAGE_DIR | Override package directory, useful for Nix/Guix store paths |
PI_OFFLINE | Disable startup network operations, including update checks, package update checks, and install/update telemetry |
PI_SKIP_VERSION_CHECK | Skip the Pi version update check at startup. This prevents the pi.dev latest-version request |
PI_TELEMETRY | Override install/update telemetry and provider attribution headers: 1/true/yes or 0/false/no. This does not disable update checks |
PI_CACHE_RETENTION | Set to long for extended prompt cache where supported |
VISUAL, EDITOR | External editor for Ctrl+G |
Design Principles
Section titled “Design Principles”Pi keeps the core small and pushes workflow-specific behavior into extensions, skills, prompt templates, and packages.
It intentionally does not include built-in MCP, sub-agents, permission popups, plan mode, to-dos, or background bash. You can build or install those workflows as extensions or packages, or use external tools such as containers and tmux.
For the full rationale, read the blog post.