VS Claude
Allows viewing git diffs between different versions of files, including working changes, staged changes, and commits, and opening files with line highlighting.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@VS Claudeopen index.ts lines 10-20"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
VS Claude
A VS Code extension with an integrated MCP server that allows MCP clients like Claude to interact with Visual Studio Code.
Key Features
Smart File Operations - Open files, diffs, and Git comparisons in VS Code
Batch Operations - Open multiple files at once for efficient workflow
Git Integration - View git diffs between different versions of files
Line Highlighting - Jump to specific lines or highlight line ranges
Overview
VS Claude provides a simple tool for AI assistants to open files and diffs in VS Code through the MCP (Model Context Protocol) interface.
Navigation Tool
open - Open files, diffs, and git comparisons in VS Code
Open files with optional line highlighting
Show diffs between two files
View git diffs (working changes, staged, commits)
Open multiple files in a single operation
See
mcp/main.gofor the full tool description
Installation
Option 1: From VS Code Extension Marketplace
Open VS Code
Go to Extensions (Cmd+Shift+X / Ctrl+Shift+X)
Search for "VS Claude"
Click Install
Option 2: Build from Source
Build the VSIX package:
git clone https://github.com/your-username/vs-claude.git
cd vs-claude
npm install
npm run build
npm install -g @vscode/vsce
vsce packageInstall in VS Code:
Press
Cmd+Shift+P(Mac) orCtrl+Shift+P(Windows/Linux)Run "Extensions: Install from VSIX..."
Select the generated
.vsixfile
Set up Claude Integration
After installation, you will be prompted to install the MCP server for Claude. Click "Install" to proceed.
If you need to install it later or manually:
Open the Command Palette (
Cmd+Shift+Pon Mac orCtrl+Shift+Pon Windows/Linux)Run "VS Claude: Install MCP"
Restart Claude to activate
Instruct Claude to use the vs-claude tools if appropriate for the task
Set up Integration with Other AI Assistants
If your AI assistant supports MCP servers:
Open the Command Palette (
Cmd+Shift+Pon Mac orCtrl+Shift+Pon Windows/Linux)Run "VS Claude: Install MCP"
Click "Manual Setup"
Follow the MCP server configuration instructions for your AI assistant
Architecture
VS Claude consists of two components:
VS Code Extension (TypeScript)
Installs the MCP server with Claude CLI
Implements the file opening logic using VS Code APIs
Handles file-based IPC for communication with MCP clients
Commands:
VS Claude: Install MCP- Install the MCP server with ClaudeVS Claude: Uninstall MCP- Remove the MCP server from Claude
MCP Server (Go)
Simple proxy that forwards tool calls from MCP clients to VS Code
Returns responses from VS Code back to the MCP client
Communication Flow
MCP Client (Claude) ↔ MCP Server ↔ File System ↔ VS Code ExtensionMCP Server writes commands to
~/.vs-claude/{windowId}.inVS Code Extension writes responses to
~/.vs-claude/{windowId}.outEach VS Code window has a unique ID with metadata in
~/.vs-claude/{windowId}.meta.jsonWhen multiple windows are open, the MCP server returns an error listing available windows
Development
Prerequisites
Node.js 16+
Go 1.21+
VS Code
Scripts
npm run build # Build TypeScript and Go binaries
npm run build:debug # Build with Go debug symbols (no cross-compilation)
npm run check # Format with Biome, lint, and type check all code
npm run test # Run tests
npm run clean # Remove build artifactsBuild System
Extension bundling with esbuild
Cross-platform Go binaries for macOS (Intel/ARM), Linux, and Windows
Project Structure
vs-claude/
├── src/ # TypeScript extension source
│ ├── extension.ts # Main entry point
│ ├── tools/ # Tool implementations
│ │ ├── open-tool.ts # File opening logic
│ │ └── types.ts # TypeScript types
│ ├── command-handler.ts # Command dispatcher
│ ├── window-manager.ts # Window IPC management
│ ├── logger.ts # Logging system
│ └── setup.ts # MCP installation logic
├── mcp/ # Go MCP server source
│ └── main.go # MCP server implementation
├── scripts/ # Build scripts
│ ├── build-extension.js # Extension bundling
│ └── build-mcp-server.sh # Cross-platform Go compilation
├── test/ # Test suite
│ ├── suite/ # Test implementations
│ └── test-workspace/ # Sample project for testing
├── build/ # Build outputs (generated)
│ ├── mcp/ # Cross-platform Go binaries
│ └── extension/ # TypeScript compilation output
└── CLAUDE.md # Project-specific instructionsTesting
The project includes comprehensive tests that:
Launch VS Code with the extension
Test file opening functionality
Verify the MCP integration
Run tests with:
npm testDevelopment
Press F5 to run the extension in development mode.
Troubleshooting
Tool Not Available
Ensure VS Code is running with the extension installed
Check that the MCP server is configured:
claude mcp listRestart Claude after installation
Multiple VS Code Windows
When multiple windows are open, the MCP server returns an error listing available windows. The MCP client must then specify a windowId with each request:
mcp_vs-claude_open({
args: {"type": "file", "path": "/path/to/file.ts"},
windowId: "window-123"
})Contributing
Contributions are welcome! Please read our contributing guidelines and submit pull requests to our repository.
Publishing to VS Code extension marketplace
Go to https://dev.azure.com/badlogicgames/badlogicgames
Sign in with badlogicgames@gmail.com
Click the non-descriptive icon next to MZ in the top right
Click on "Personal access tokens"
Generate a new token, cause the old one likely expired. Select "All accessible organizations" for Organization, Scope Full access
vsce publish, enter the stupid tokenCheck https://marketplace.visualstudio.com/manage/publishers/mariozechner?noPrompt=true for status of publication
License
[License information here]
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/badlogic/vs-claude'
If you have feedback or need assistance with the MCP directory API, please join our Discord server