vscode-extension-builder
npx skills add https://github.com/prulloac/agent-skills --skill vscode-extension-builder
Agent 安装分布
Skill 文档
VS Code Extension Builder
Overview
This skill guides the development of Visual Studio Code extensions by helping navigate the extensive VS Code Extension API documentation and providing structured guidance for common extension development tasks.
Documentation Base
All VS Code extension development guidance is based on the official documentation at: https://code.visualstudio.com/api
When assisting users, fetch relevant documentation pages to provide accurate, up-to-date information.
Official Documentation References
-
Your First Extension: https://code.visualstudio.com/api/get-started/your-first-extension
- Step-by-step guide for scaffolding and running your first extension
- Yeoman generator setup and project creation
- Quick iteration with Extension Development Host
- Essential debugging and testing techniques
-
Extension Anatomy: https://code.visualstudio.com/api/get-started/extension-anatomy
- File structure and configuration explanation
package.jsonmanifest details- Extension entry point (
activateanddeactivatefunctions) - Implicit activation events (VS Code 1.74.0+)
-
Wrapping Up: https://code.visualstudio.com/api/get-started/wrapping-up
- Next steps after creating your first extension
- Navigation to specialized guides and samples
- Testing, publishing, and CI/CD resources
Core Workflow
1. Understand User Intent
First, determine what the user wants to accomplish with their extension:
Common extension types:
- Commands & UI extensions – Add commands, menus, keybindings, status bar items
- Language support – Syntax highlighting, IntelliSense, diagnostics, formatting
- Themes – Color themes, file icon themes, product icon themes
- Webviews – Custom UI panels with HTML/CSS/JavaScript
- Debuggers – Debug adapter integrations
- Source control – SCM provider integrations
- Tree views – Custom sidebar explorers
- AI/Chat extensions – Chat participants, language model tools
- Testing – Test provider integrations
- Notebook support – Custom notebook renderers
2. Fetch Relevant Documentation
Based on the user’s intent, fetch the appropriate documentation:
For getting started (Getting Started Track):
- Your First Extension: https://code.visualstudio.com/api/get-started/your-first-extension
- Extension Anatomy: https://code.visualstudio.com/api/get-started/extension-anatomy
- Wrapping Up: https://code.visualstudio.com/api/get-started/wrapping-up
For capability planning:
- Extension Capabilities Overview: https://code.visualstudio.com/api/extension-capabilities/overview
- Common Capabilities: https://code.visualstudio.com/api/extension-capabilities/common-capabilities
- Extending Workbench: https://code.visualstudio.com/api/extension-capabilities/extending-workbench
- Theming: https://code.visualstudio.com/api/extension-capabilities/theming
For specific features, use the extension guides:
- Overview: https://code.visualstudio.com/api/extension-guides/overview
- AI features: https://code.visualstudio.com/api/extension-guides/ai/ai-extensibility-overview
- Language Model Tool: https://code.visualstudio.com/api/extension-guides/ai/tools
- Chat Participant: https://code.visualstudio.com/api/extension-guides/ai/chat
- MCP Dev Guide: https://code.visualstudio.com/api/extension-guides/ai/mcp
- Commands: https://code.visualstudio.com/api/extension-guides/command
- Webviews: https://code.visualstudio.com/api/extension-guides/webview
- Tree views: https://code.visualstudio.com/api/extension-guides/tree-view
- Language features: https://code.visualstudio.com/api/language-extensions/overview
- Debuggers: https://code.visualstudio.com/api/extension-guides/debugger-extension
- Themes: https://code.visualstudio.com/api/extension-guides/color-theme
- File Icon Theme: https://code.visualstudio.com/api/extension-guides/file-icon-theme
- Product Icon Theme: https://code.visualstudio.com/api/extension-guides/product-icon-theme
- Custom Editors: https://code.visualstudio.com/api/extension-guides/custom-editors
- Notebooks: https://code.visualstudio.com/api/extension-guides/notebook
- Virtual Documents: https://code.visualstudio.com/api/extension-guides/virtual-documents
- Virtual Workspaces: https://code.visualstudio.com/api/extension-guides/virtual-workspaces
- Web Extensions: https://code.visualstudio.com/api/extension-guides/web-extensions
- Workspace Trust: https://code.visualstudio.com/api/extension-guides/workspace-trust
- Task Provider: https://code.visualstudio.com/api/extension-guides/task-provider
- Source Control: https://code.visualstudio.com/api/extension-guides/scm-provider
- Markdown Extension: https://code.visualstudio.com/api/extension-guides/markdown-extension
- Test Extension: https://code.visualstudio.com/api/extension-guides/testing
- Custom Data Extension: https://code.visualstudio.com/api/extension-guides/custom-data-extension
- Telemetry: https://code.visualstudio.com/api/extension-guides/telemetry
For UX best practices:
- UX Guidelines Overview: https://code.visualstudio.com/api/ux-guidelines/overview
- Activity Bar: https://code.visualstudio.com/api/ux-guidelines/activity-bar
- Sidebars: https://code.visualstudio.com/api/ux-guidelines/sidebars
- Command Palette: https://code.visualstudio.com/api/ux-guidelines/command-palette
- Status Bar: https://code.visualstudio.com/api/ux-guidelines/status-bar
- Quick Picks: https://code.visualstudio.com/api/ux-guidelines/quick-picks
- Context Menus: https://code.visualstudio.com/api/ux-guidelines/context-menus
- Webviews: https://code.visualstudio.com/api/ux-guidelines/webviews
For API reference:
- VS Code API: https://code.visualstudio.com/api/references/vscode-api
- Contribution Points: https://code.visualstudio.com/api/references/contribution-points
- Activation Events: https://code.visualstudio.com/api/references/activation-events
- Extension Manifest: https://code.visualstudio.com/api/references/extension-manifest
- Built-In Commands: https://code.visualstudio.com/api/references/commands
- When Clause Contexts: https://code.visualstudio.com/api/references/when-clause-contexts
- Theme Color: https://code.visualstudio.com/api/references/theme-color
- Document Selector: https://code.visualstudio.com/api/references/document-selector
For testing and publishing:
- Testing Extensions: https://code.visualstudio.com/api/working-with-extensions/testing-extension
- Publishing Extensions: https://code.visualstudio.com/api/working-with-extensions/publishing-extension
- Bundling Extensions: https://code.visualstudio.com/api/working-with-extensions/bundling-extension
- Continuous Integration: https://code.visualstudio.com/api/working-with-extensions/continuous-integration
For advanced topics:
- Extension Host: https://code.visualstudio.com/api/advanced-topics/extension-host
- Remote Development: https://code.visualstudio.com/api/advanced-topics/remote-extensions
- Using Proposed API: https://code.visualstudio.com/api/advanced-topics/using-proposed-api
- Language Server Extension Guide: https://code.visualstudio.com/api/language-extensions/language-server-extension-guide
3. Guide Implementation
After fetching documentation, provide step-by-step guidance:
- Project setup – Use Yeoman generator or guide manual setup
- Package.json configuration – Help define contribution points
- Core implementation – Provide code guidance based on documentation
- Testing – Help set up extension testing
- Debugging – Guide F5 debugging setup
- Publishing – Assist with vsce packaging
Quick Start Pattern
For new extensions, always start with:
# Install dependencies (if needed)
npm install -g yo generator-code
# Or use npx without global install
npx --package yo --package generator-code -- yo code
Guide users through the prompts based on their extension type.
Key Concepts to Explain
Activation Events
When extensions are loaded (see https://code.visualstudio.com/api/references/activation-events):
onCommand:– When a command is invokedonLanguage:– When a file of specific language is openedonView:– When a view is expandedworkspaceContains:– When workspace matches a patternonDebug– When debug session starts*– On startup (use sparingly, impacts performance)
Important: Starting with VS Code 1.74.0, commands declared in contributes.commands automatically activate extensions without explicit onCommand entries.
Contribution Points
Static declarations in package.json that extend VS Code (see https://code.visualstudio.com/api/references/contribution-points):
commands– Define commands available in Command Palettemenus– Add commands to UI menuskeybindings– Define keyboard shortcutsviews– Create custom sidebar viewsviewsContainers– Define view containers (sidebars, panels)configuration– Define configuration settingslanguages– Register new language supportgrammars– Define syntax highlighting rulesthemes– Register color themesdebuggers– Register debug adapterssnippets– Define code snippetstaskDefinitions– Define custom task typessemanticTokenTypes/Modifiers– Extend semantic highlightingwalkthroughs– Create interactive extension walkthroughsnotebookProvider– Register notebook rendererscustomEditors– Register custom editor providers
Manifest Best Practices
For optimal marketplace presentation:
- Use
displayNameanddescriptionclearly and concisely - Set
categoriesfrom allowed values for better discoverability - Provide
icon(PNG, 128×128 minimum) andgalleryBannerfor visual appeal - Include
repository,bugs, andhomepagein resources section - Use
keywordsarray (up to 30) for search optimization - Set appropriate
engines.vscodeversion (don’t use*) - Configure
extensionPackfor bundling related extensions - Declare
extensionDependenciesif your extension relies on others - Mark
capabilitiesforuntrustedWorkspacesandvirtualWorkspacessupport
For pricing and availability:
- Use
pricingfield (Free/Trial) - Set
preview: truefor beta extensions - Use
previewfor extensions not ready for production
Extension Anatomy
Understanding the core components of VS Code extensions:
File Structure:
.
âââ .vscode
â âââ launch.json # Debug configuration for F5 debugging
â âââ tasks.json # Build task configuration (TypeScript compilation)
âââ .gitignore
âââ README.md
âââ src
â âââ extension.ts # Main extension code (entry point)
âââ package.json # Extension manifest
âââ tsconfig.json # TypeScript configuration
package.json – Critical Fields:
name– Extension identifier (lowercase, no spaces)displayName– Human-readable name for Marketplaceversion– SemVer version numberpublisher– Publisher identifierdescription– Short description of functionalityengines.vscode– Minimum VS Code version (e.g.,"^1.80.0")main– Entry point to extension (compiled JavaScript)browser– Entry point for Web extensionsactivationEvents– When the extension is activatedcontributes– Static declarations of extension capabilitiescategories– Marketplace categories for discoverabilityicon– Extension icon (128×128 pixels minimum)license– License informationrepository– Repository URL
Extension Entry File (extension.ts/js):
activate(context)– Called when extension activates; setup your extension heredeactivate()– Called when extension deactivates; clean up resources here- Disposables must be added to
context.subscriptionsfor proper cleanup
Key Modern Features (VS Code 1.74.0+):
- Implicit activation events: Commands declared in
contributes.commandsautomatically activate extensions - No need for explicit
onCommandactivation events - Reduces startup impact by lazy-loading extensions only when needed
Common Patterns
Testing Your Extension
Modern testing approach using the VS Code Test CLI:
# Install test dependencies
npm install --save-dev @vscode/test-cli @vscode/test-electron
Configuration (.vscode-test.js):
const { defineConfig } = require('@vscode/test-cli');
module.exports = defineConfig({ files: 'out/test/**/*.test.js' });
Run tests:
npm test
Key testing features:
- Extensions run in Extension Development Host with full API access
- Mocha test framework by default
- Can debug tests with VS Code’s debugger
- Support for multiple test configurations
- Workspace folder support during testing
- CI/CD integration ready
See https://code.visualstudio.com/api/working-with-extensions/testing-extension for detailed setup.
Debugging Your Extension
Quick Debug with F5:
- Open extension project in VS Code
- Press F5 or run Debug: Start Debugging from Command Palette
- Extension Development Host window opens with your extension loaded
- Set breakpoints by clicking line numbers
- Use Debug Console to evaluate expressions
- Use Run and Debug panel to inspect variables
Key debugging features:
- Full Node.js debugging capabilities
- Hover over variables to see values
- Watch expressions and call stacks
- VS Code’s built-in debugger works with extensions
Modern VS Code Features (1.74.0+)
Implicit Command Activation
- Commands in
contributes.commandsauto-activate the extension - Reduces explicit configuration needed
- Improves extension startup time
Web Extensions
- Extensions can run in browser-based VS Code (code.visualstudio.com)
- Use
browserfield in package.json - See https://code.visualstudio.com/api/extension-guides/web-extensions
Workspace Trust
- Extensions can declare trustworthiness requirements
- Respect user’s workspace trust decisions
- See https://code.visualstudio.com/api/extension-guides/workspace-trust
AI and Language Model Integration
- Chat Participants for AI interactions
- Language Model Tool integration
- MCP (Model Context Protocol) support
- See https://code.visualstudio.com/api/extension-guides/ai/ai-extensibility-overview
Extension Marketplace Features
extensionPackfor bundling extensionsextensionDependenciesfor runtime dependenciesextensionKindfor remote/local execution preference- Pricing models (Free/Trial)
- Preview flag for beta releases
Common Patterns and Examples
Registering a Command
import * as vscode from 'vscode';
export function activate(context: vscode.ExtensionContext) {
// Register a command - no explicit onCommand needed (VS Code 1.74.0+)
let disposable = vscode.commands.registerCommand('extension.commandName', () => {
vscode.window.showInformationMessage('Hello World!');
});
context.subscriptions.push(disposable);
}
export function deactivate() {}
In package.json:
{
"contributes": {
"commands": [
{
"command": "extension.commandName",
"title": "My Command"
}
]
}
}
Creating a Tree View
Provide hierarchical data in sidebar:
- Implement
TreeDataProvider<T> - Register with
createTreeView() - Use
onDidChangeTreeDatafor updates - See https://code.visualstudio.com/api/extension-guides/tree-view
Building a Webview
Custom HTML UI for complex interfaces:
- Create webview panels with
createWebviewPanel() - Communicate via
postMessage()API - Manage content security policy properly
- See https://code.visualstudio.com/api/extension-guides/webview
Language Server Protocol
For rich language support:
- Integrate Language Server Protocol (LSP)
- Use
vscode-languageclientnpm package - Provide IntelliSense, diagnostics, formatting
- See https://code.visualstudio.com/api/language-extensions/language-server-extension-guide
Storing Data
- Global:
context.globalState.update(key, value) - Workspace:
context.workspaceState.update(key, value) - Configuration:
vscode.workspace.getConfiguration()
Showing UI Elements
// Information message
vscode.window.showInformationMessage('Message');
// Quick pick for selection
const pick = await vscode.window.showQuickPick(['Option 1', 'Option 2']);
// Input box for text
const input = await vscode.window.showInputBox({ prompt: 'Enter text' });
// Progress indication
await vscode.window.withProgress({
location: vscode.ProgressLocation.Notification,
title: 'Processing...'
}, async (progress) => {
// Long-running operation
});
Documentation Navigation Strategy
- Start broad – Fetch overview pages to understand scope
- Go specific – Fetch detailed guides for the exact feature needed
- Check references – Fetch API references for specific types/methods
- Review examples – Point users to sample extensions at https://github.com/microsoft/vscode-extension-samples
Extension Capabilities and Restrictions
What Extensions Can Do
- Extend VS Code UI (sidebars, panels, status bar, decorations, etc.)
- Add commands and keybindings
- Create custom views with TreeView API
- Build custom UI with Webview API
- Provide language features (IntelliSense, diagnostics, formatting, etc.)
- Integrate debuggers and test frameworks
- Add themes and icons
- Register configuration settings
- Contribute walkthroughs and tutorials
- Integrate with Source Control providers
- Build custom editors and notebooks
Important Restrictions
- No DOM access – Cannot access VS Code’s internal DOM directly
- No custom CSS – Cannot inject custom stylesheets into VS Code UI
- Runs in Extension Host – Extensions run in a separate process
- Must use VS Code API – Cannot use undocumented internal APIs
- Performance constraints – Heavy operations impact all extensions
Rationale: These restrictions ensure stability, performance, and security while allowing VS Code to evolve freely without breaking extensions.
Best Practices
-
Minimal Startup Impact
- Use activation events wisely; avoid
*unless necessary - Lazy-load dependencies and APIs
- Rely on implicit activation for declared commands (VS Code 1.74.0+)
- Use activation events wisely; avoid
-
Resource Management
- Always dispose of resources in
deactivate()or add tocontext.subscriptions - Clean up event listeners, file watchers, and language clients
- Prevent memory leaks by removing references
- Always dispose of resources in
-
Type Safety
- Use TypeScript for better developer experience
- Install correct
@types/vscodeversion matchingengines.vscode - Enable strict TypeScript compilation
-
Error Handling
- Catch and handle errors in command implementations
- Provide meaningful error messages to users
- Log errors to extension output channel for debugging
-
Performance
- Bundle extensions for production (webpack/esbuild)
- Use Tree Data Provider for large datasets with pagination
- Minimize async operations in activation
-
UX Guidelines
- Follow https://code.visualstudio.com/api/ux-guidelines/overview
- Use standard notification types: information, warning, error
- Implement quick picks for user selections
- Respect workspace trust settings
-
Testing
- Write integration tests using VS Code’s test runner
- Use https://code.visualstudio.com/api/working-with-extensions/testing-extension
- Run tests with
npm run test(Mocha-based) - Use
@vscode/test-clifor modern test setup
-
Publishing
- Follow marketplace guidelines at https://code.visualstudio.com/api/working-with-extensions/publishing-extension
- Include comprehensive README with examples
- Use
vsce(Visual Studio Code Extension Manager) for packaging - Implement CI/CD with GitHub Actions or Azure DevOps
Progressive Assistance Levels
For Absolute Beginners
Goal: Get them building and debugging quickly
- Guide through “Your First Extension” walkthrough
- Explain the three core concepts:
- Activation Events: When extension loads
- Contribution Points: What the extension contributes to VS Code
- VS Code API: How to interact with VS Code
- Walk through Yeoman scaffolding step-by-step
- Show how to modify the extension and test with F5
- Explain package.json basics (name, version, main, engines)
- Show how to register and run a command
Resources:
- Start with: https://code.visualstudio.com/api/get-started/your-first-extension
- Then: https://code.visualstudio.com/api/get-started/extension-anatomy
For Intermediate Users
Goal: Build feature-rich extensions independently
- Fetch specific extension guide documentation
- Explain API patterns and best practices
- Guide through VS Code API exploration
- Help with:
- Configuration settings
- File system operations
- Tree views and sidebars
- Webview implementation
- Language features
- Assist with debugging techniques and issue diagnosis
- Help set up and run extension tests
Resources:
- Extension Guides: https://code.visualstudio.com/api/extension-guides/overview
- VS Code API Reference: https://code.visualstudio.com/api/references/vscode-api
- Testing: https://code.visualstudio.com/api/working-with-extensions/testing-extension
- UX Guidelines: https://code.visualstudio.com/api/ux-guidelines/overview
For Advanced Users
Goal: Build complex, production-grade extensions
- Point to proposed APIs for experimental features
- Help with Language Server Protocol integration
- Guide multi-extension architecture
- Assist with:
- Remote and web extension support
- Custom editors and notebooks
- Advanced tree view providers
- Semantic highlighting
- Debug adapter integration
- Help prepare for Marketplace publishing
- Advise on CI/CD setup
Resources:
- Advanced Topics: https://code.visualstudio.com/api/advanced-topics/extension-host
- Remote Extensions: https://code.visualstudio.com/api/advanced-topics/remote-extensions
- Proposed API: https://code.visualstudio.com/api/advanced-topics/using-proposed-api
- Publishing: https://code.visualstudio.com/api/working-with-extensions/publishing-extension
- CI/CD: https://code.visualstudio.com/api/working-with-extensions/continuous-integration
Reference Documentation
For comprehensive guides on specific extension types and advanced patterns, see:
- Official Documentation Map – Complete map of VS Code Extension API documentation (https://code.visualstudio.com/api)
- Extension Development Guide – Detailed guide for common extension patterns
- API Quick Reference – Quick lookup for common VS Code APIs
Read these references when users need deeper guidance on specific topics or navigation help through the official documentation.