Minimal VS Code extension for pi coding agent.
- Terminal-based — Opens pi as an integrated terminal with full TUI/PTY support (opens beside the editor)
- VS Code bridge — Bundles a pi extension and local bridge so pi can query live editor state
- Editor awareness — pi can inspect the active editor, current/latest selection, open editors, workspace folders, and VS Code diagnostics (LSP / lint / type errors)
- Status bar button — PI button in the status bar for quick access
- Open with file context — Send current file path and line range (or cursor position) to pi, available from the editor title bar
- Send selection — Send selected text directly to the pi terminal
@pichat participant — Use@piin VS Code Chat for streamed RPC-backed replies while keeping the terminal workflow for normal Pi sessions- Package manager — Browse, search, install, and uninstall pi packages from the sidebar with live output streaming and cancel support; automatically detects package capabilities (extensions, skills, prompts, themes)
- Auto-detection — Finds the pi binary automatically from common paths (
~/.bun/bin,~/.local/bin,~/.npm-global/bin)
piCLI installed (npm i -g @mariozechner/pi-coding-agentorbun i -g @mariozechner/pi-coding-agent)- An API key configured for at least one provider
Available on the VS Code Marketplace and Open VSX:
# VS Code / Cursor
ext install pi0.pi-vscode
# Open VSX (VSCodium, etc.)
ovsx get pi0.pi-vscode| Command | Keybinding | Description |
|---|---|---|
Pi: Open |
Ctrl+Alt+3 |
Open or focus the pi terminal |
Pi: Open with File |
Editor title bar | Open pi with current file context |
Pi: Send Selection |
— | Send selected text to pi terminal |
The Pi activity bar icon opens a sidebar with:
- Packages view — Search the npm registry for
pi-packagepackages, see capability labels (extensions, skills, prompts, themes), install/uninstall with live streamed output, and cancel in-progress operations
Each pi terminal launched by the extension loads a bundled pi extension that can call back into live VS Code APIs.
| Tool | What it returns |
|---|---|
vscode_get_editor_state |
Aggregate snapshot of workspace folders, active editor metadata, current selection, latest cached selection, and open editors |
vscode_get_selection |
Current active editor selection including selected text, file path, and coordinates |
vscode_get_latest_selection |
Most recent cached selection seen by the extension, even if focus already moved |
vscode_get_diagnostics |
VS Code diagnostics for a specific file or the whole workspace |
vscode_get_open_editors |
Visible/open file editors with language, dirty state, and active flag |
vscode_get_workspace_folders |
Workspace folders for the current VS Code window |
vscode_get_document_symbols |
Outline symbols for a file from the active language server |
vscode_get_definitions |
Symbol definition locations at a given file position |
vscode_get_type_definitions |
Symbol type-definition locations at a given file position |
vscode_get_implementations |
Concrete implementation locations for an interface or abstract member |
vscode_get_declarations |
Symbol declaration locations at a given file position |
vscode_get_hover |
Hover docs, inferred types, signatures, and markdown/code snippets from the language server |
vscode_get_workspace_symbols |
Global workspace symbol search through VS Code language providers |
vscode_get_references |
Symbol references at a given file position |
vscode_get_code_actions |
Available code actions / quick fixes for a selection or explicit range, plus intersecting diagnostics |
vscode_get_notifications |
Buffered bridge events such as selection, editor, diagnostics, save, and dirty-state changes |
| Tool | What it does |
|---|---|
vscode_open_file |
Opens a file in VS Code and can reveal/select a range |
vscode_check_document_dirty |
Checks whether a file is open and whether it has unsaved changes |
vscode_save_document |
Saves a document through VS Code |
vscode_execute_code_action |
Executes a previously returned code action by actionId |
vscode_apply_workspace_edit |
Applies explicit range-based text replacements through VS Code so open buffers stay synchronized |
vscode_format_document |
Runs the active document formatter for a file and applies the resulting edits through VS Code |
vscode_format_range |
Runs the active range formatter for a selection/range and applies the resulting edits |
vscode_clear_notifications |
Clears the buffered bridge notification queue |
vscode_show_notification |
Shows an info, warning, or error notification inside VS Code |
- Paths accepted by file-based bridge tools can be absolute or workspace-relative.
vscode_get_code_actionsaccepts eitherselectionor explicitstart/endpositions.vscode_execute_code_actiononly works with anactionIdreturned by the most recentvscode_get_code_actionscalls while that cached entry still exists.vscode_apply_workspace_editapplies one or more{ filePath, range, newText }replacements via VS Code rather than editing files behind the editor's back.vscode_format_rangeaccepts eitherselectionor explicitstart/endpositions.vscode_format_document/vscode_format_rangeuse VS Code formatting providers and apply formatter-generatedTextEdit[]results withworkspace.applyEdit, which is safer for open or dirty buffers than shelling out.vscode_get_notificationssupportssinceandlimitparameters for incremental polling.
These bridge tools let pi inspect selections, diagnostics, symbols, definitions, declarations, implementations, hover/type info, workspace-wide symbol search, references, quick-fix availability, dirty state, and recent IDE events, while also safely opening files, saving buffers, applying workspace edits, formatting open buffers through VS Code providers, running VS Code code actions, and surfacing notifications back to the user.
| Setting | Default | Description |
|---|---|---|
pi-vscode.path |
"" |
Absolute path to the pi binary (auto-detected if empty) |