Settings
Pi uses JSON settings files with project settings overriding global settings.
| Location |
Scope |
~/.pi/agent/settings.json |
Global (all projects) |
.pi/settings.json |
Project (current directory) |
Edit directly or use /settings for common options.
All Settings
Model & Thinking
| Setting |
Type |
Default |
Description |
defaultProvider |
string |
- |
Default provider (e.g., "anthropic", "openai") |
defaultModel |
string |
- |
Default model ID |
defaultThinkingLevel |
string |
- |
"off", "minimal", "low", "medium", "high", "xhigh" |
hideThinkingBlock |
boolean |
false |
Hide thinking blocks in output |
thinkingBudgets |
object |
- |
Custom token budgets per thinking level |
thinkingBudgets
{
"thinkingBudgets": {
"minimal": 1024,
"low": 4096,
"medium": 10240,
"high": 32768
}
}
UI & Display
| Setting |
Type |
Default |
Description |
theme |
string |
"dark" |
Theme name ("dark", "light", or custom) |
quietStartup |
boolean |
false |
Hide startup header |
collapseChangelog |
boolean |
false |
Show condensed changelog after updates |
doubleEscapeAction |
string |
"tree" |
Action for double-escape: "tree", "fork", or "none" |
editorPaddingX |
number |
0 |
Horizontal padding for input editor (0-3) |
autocompleteMaxVisible |
number |
5 |
Max visible items in autocomplete dropdown (3-20) |
showHardwareCursor |
boolean |
false |
Show terminal cursor |
Compaction
| Setting |
Type |
Default |
Description |
compaction.enabled |
boolean |
true |
Enable auto-compaction |
compaction.reserveTokens |
number |
16384 |
Tokens reserved for LLM response |
compaction.keepRecentTokens |
number |
20000 |
Recent tokens to keep (not summarized) |
{
"compaction": {
"enabled": true,
"reserveTokens": 16384,
"keepRecentTokens": 20000
}
}
Branch Summary
| Setting |
Type |
Default |
Description |
branchSummary.reserveTokens |
number |
16384 |
Tokens reserved for branch summarization |
Retry
| Setting |
Type |
Default |
Description |
retry.enabled |
boolean |
true |
Enable automatic retry on transient errors |
retry.maxRetries |
number |
3 |
Maximum retry attempts |
retry.baseDelayMs |
number |
2000 |
Base delay for exponential backoff (2s, 4s, 8s) |
retry.maxDelayMs |
number |
60000 |
Max server-requested delay before failing (60s) |
When a provider requests a retry delay longer than maxDelayMs (e.g., Google's "quota will reset after 5h"), the request fails immediately with an informative error instead of waiting silently. Set to 0 to disable the cap.
{
"retry": {
"enabled": true,
"maxRetries": 3,
"baseDelayMs": 2000,
"maxDelayMs": 60000
}
}
Message Delivery
| Setting |
Type |
Default |
Description |
steeringMode |
string |
"one-at-a-time" |
How steering messages are sent: "all" or "one-at-a-time" |
followUpMode |
string |
"one-at-a-time" |
How follow-up messages are sent: "all" or "one-at-a-time" |
transport |
string |
"sse" |
Preferred transport for providers that support multiple transports: "sse", "websocket", or "auto" |
Terminal & Images
| Setting |
Type |
Default |
Description |
terminal.showImages |
boolean |
true |
Show images in terminal (if supported) |
terminal.clearOnShrink |
boolean |
false |
Clear empty rows when content shrinks (can cause flicker) |
images.autoResize |
boolean |
true |
Resize images to 2000x2000 max |
images.blockImages |
boolean |
false |
Block all images from being sent to LLM |
Shell
| Setting |
Type |
Default |
Description |
shellPath |
string |
- |
Custom shell path (e.g., for Cygwin on Windows) |
shellCommandPrefix |
string |
- |
Prefix for every bash command (e.g., "shopt -s expand_aliases") |
Model Cycling
| Setting |
Type |
Default |
Description |
enabledModels |
string[] |
- |
Model patterns for Ctrl+P cycling (same format as --models CLI flag) |
{
"enabledModels": ["claude-*", "gpt-4o", "gemini-2*"]
}
Markdown
| Setting |
Type |
Default |
Description |
markdown.codeBlockIndent |
string |
" " |
Indentation for code blocks |
Resources
These settings define where to load extensions, skills, prompts, and themes from.
Paths in ~/.pi/agent/settings.json resolve relative to ~/.pi/agent. Paths in .pi/settings.json resolve relative to .pi. Absolute paths and ~ are supported.
| Setting |
Type |
Default |
Description |
packages |
array |
[] |
npm/git packages to load resources from |
extensions |
string[] |
[] |
Local extension file paths or directories |
skills |
string[] |
[] |
Local skill file paths or directories |
prompts |
string[] |
[] |
Local prompt template paths or directories |
themes |
string[] |
[] |
Local theme file paths or directories |
enableSkillCommands |
boolean |
true |
Register skills as /skill:name commands |
Arrays support glob patterns and exclusions. Use !pattern to exclude. Use +path to force-include an exact path and -path to force-exclude an exact path.
packages
String form loads all resources from a package:
{
"packages": ["pi-skills", "@org/my-extension"]
}
Object form filters which resources to load:
{
"packages": [
{
"source": "pi-skills",
"skills": ["brave-search", "transcribe"],
"extensions": []
}
]
}
See packages.md for package management details.
Example
{
"defaultProvider": "anthropic",
"defaultModel": "claude-sonnet-4-20250514",
"defaultThinkingLevel": "medium",
"theme": "dark",
"compaction": {
"enabled": true,
"reserveTokens": 16384,
"keepRecentTokens": 20000
},
"retry": {
"enabled": true,
"maxRetries": 3
},
"enabledModels": ["claude-*", "gpt-4o"],
"packages": ["pi-skills"]
}
Project Overrides
Project settings (.pi/settings.json) override global settings. Nested objects are merged:
// ~/.pi/agent/settings.json (global)
{
"theme": "dark",
"compaction": { "enabled": true, "reserveTokens": 16384 }
}
// .pi/settings.json (project)
{
"compaction": { "reserveTokens": 8192 }
}
// Result
{
"theme": "dark",
"compaction": { "enabled": true, "reserveTokens": 8192 }
}