Skip to main content
Glama
achatainga

mcp-code-context

by achatainga

mcp-code-context

License: MIT npm version npm downloads TypeScript Tests Ko-fi PayPal

MCP server with Tree-sitter WASM parsers for 100% AST accuracy. Zero native dependencies. Production-ready with persistent caching, structured logging, fuzzy search, multi-process safety, and session-scoped state.

๐Ÿš€ Quick Start (Claude Desktop)

  1. Install: npm install -g mcp-code-context

  2. Configure: Add to claude_desktop_config.json:

{
  "mcpServers": {
    "code-context": {
      "command": "npx",
      "args": ["-y", "mcp-code-context"]
    }
  }
}
  1. Enjoy: Use symbols like @code-context to map repos or edit code surgically.

No build tools required - Works on Windows/Mac/Linux without Visual Studio, Python, or node-gyp.

Works with Claude Desktop, Cursor, Windsurf, GitHub Copilot, Amazon Q, and any Model Context Protocol compatible client.

๐Ÿ“– For AI Agents: See INSTRUCTIONS.md for essential usage patterns and best practices.


Related MCP server: Semantic Cache MCP

๐Ÿ’ก Why This Exists

This tool was born out of necessity in Caracas, Venezuela ๐Ÿ‡ป๐Ÿ‡ช, where economic limitations made every API token count. When you're choosing between groceries and Claude API credits, you learn to optimize fast.

What started as a personal script to compress context windows became a full MCP server when I realized others faced the same problem: LLM APIs are expensive, and most tools waste tokens on boilerplate.

If this tool saves you money or time, consider supporting its development. Every contribution helps keep this project maintained and free for everyone.


The Problem

LLMs working with code face two bottlenecks:

  1. Reading: Sending raw source files wastes the context window on function bodies and boilerplate. A 500-line file might contain only 30 lines of structural information the LLM needs.

  2. Writing: Rewriting entire files to change one function is error-prone, token-expensive, and risks corrupting unrelated code.

The Solution

mcp-code-context provides 25 tools โ€” covering reading, writing, AST transformation, search, and session management โ€” all operating at the symbol level (functions, classes, methods). Tools support a className scope to correctly isolate identical symbol names in the same file (e.g. Flutter build() methods). Read tools extract structural skeletons. Write tools splice changes into the exact AST location.

File

Original

Compressed

Reduction

PHP class (426 lines)

426

60

85.9%

Dart repository (230 lines)

230

30

87.0%

PHP config (68 lines)

68

15

77.9%

Token Savings

Real-world results:

  • TypeScript project: 73% reduction in tokens sent to LLM

  • PHP application: 82% reduction

  • Dart codebase: 79% reduction


Reliability & Testing

Built to be robust and precise. Both read and write engines are tested against real-world, complex codebases (including nested generic types in Dart, complex interfaces in PHP, and multi-file rename operations) with a 100% test pass rate across all languages and operations.

Production-Ready Features

Feature

v3.6.x

v3.7.1

Benefit

Multi-process safety

โœ…

โœ…

No file corruption

Persistent cache

โœ…

โœ…

<100ms cache hits

Session-scoped state

โŒ

โœ…

No state leakage between clients

Crash recovery

โŒ

โœ…

Pending operations survive restart

Expanded ReDoS protection

6 patterns

15+ patterns

Better security

Auto-persist before eviction

โŒ

โœ…

Cache data preserved


Features

What's New in v3.7.1

Feature

Description

๐Ÿ”’ Session-scoped state

Each MCP client gets isolated locks, confirmation store, rate limiter (no state leakage)

๐Ÿ’พ Crash recovery

SQLite-backed pending operations store - survive restarts

๐Ÿ” Expanded ReDoS protection

15+ patterns (was 6) - better protection against regex DoS

โšก Auto-persist before eviction

CacheManager now persists before LRU eviction

๐Ÿ“Š Higher file limits

MAX_FILES_REPO_MAP = 2000 (was 500)

๐Ÿงช Multi-client tests

New integration tests for concurrent MCP clients

๐Ÿ“ New tools: get_session_stats, clear_session_cache, list_pending_operations

Session-aware operations

Previous Versions (v3.6.x)

Feature

Description

โšก Persistent Cache

WASM SQLite cache โ€” <100ms hits, 10ร— faster on repeated reads

๐Ÿ“ Structured Logging

pino JSON logging to stderr (MCP-safe, never pollutes stdio)

๐Ÿ‘๏ธ File Watcher

chokidar auto-invalidates cache on file changes

๐Ÿ” Fuzzy Search

fuse.js finds authUser when you search authenticateUser

๐Ÿ“„ Pagination

Search defaults to 10 results with startIndex for navigation

๐Ÿ”’ Multi-process Safe

Filesystem locks via proper-lockfile (was in-memory)

๐Ÿ’พ OS Temp Backups

Backups in os.tmpdir() โ€” no more hot-reload loops

๐Ÿงช 74 Tests

Unit + integration + performance + stress tests

๐ŸŽฏ Token Savings

50-80% reduction: compact diffs, no Phase 2 repeat, auto-optimize output

Read

  • ๐ŸŒณ AST-based compression โ€” Real Tree-sitter WASM parsers for TypeScript/JavaScript/Python/PHP/Dart. Zero regex-based parsing.

  • ๐Ÿ”ฌ Surgical symbol extraction โ€” Extract a single function, class, or method from a file by name. Use className to scope disambiguation (e.g., getting multiple build() methods in Dart).

  • ๐Ÿ’ฅ Impact analysis โ€” Discover all files that depend on a given file before refactoring. Supports ES imports, CommonJS require(), Python imports, PHP use/require_once/include, and Dart imports.

  • ๐Ÿ“ Smart file walking โ€” Respects .gitignore and .repomixignore rules. Automatically excludes node_modules, dist, vendor, .git, etc.

  • ๐Ÿ“„ Multi-format output โ€” XML (optimized for LLM consumption) or Markdown (human-readable).

Write

  • โœ๏ธ Surgical symbol replacement โ€” Replace a function, method, or class body without touching the rest of the file. Narrow down the target using the className parameter.

  • โž• Precise code insertion โ€” Insert new code before/after a symbol, or inside a class at the start/end.

  • ๐Ÿ”„ Repository-wide rename โ€” Rename a symbol in its definition AND all files that import it, atomically.

  • ๐Ÿ—‘๏ธ Safe symbol removal โ€” Delete code with automatic dependency checking to prevent breakage.

  • ๐Ÿ” Mandatory dry-run flow โ€” Write tools return a preview diff and a confirmationToken by default. Changes are only applied after explicit confirmation.

  • ๐Ÿ’พ Robust rolling backups โ€” Automatically keeps the last 5 versions of modified files in the OS temp directory.

  • โช Surgical rollback โ€” Revert files to any of the 5 previous states using the rollback_file tool.

  • ๏ฟฝ๏ฟฝ๏ฟฝ๏ฟฝ Fuzzy symbol matching โ€” When a symbol is not found, the server provides structured suggestions based on Levenshtein distance.

  • ๐Ÿ” Private symbol support โ€” Full support for _ and __ prefixed symbols in Dart and Python.


Supported Languages

Language

Read (Compress + Extract)

Write (Replace + Insert + Rename + Remove)

Import Analysis

TypeScript / JavaScript

โœ… AST (Tree-sitter WASM)

โœ… AST (Tree-sitter WASM)

โœ…

PHP

โœ… AST (Tree-sitter WASM)

โœ… AST + line-splice

โœ…

Dart

โœ… AST (Tree-sitter WASM)

โœ… AST + line-splice

โœ…

Python

โœ… AST (Tree-sitter WASM)

โœ… Indentation-aware

โœ…

Others (JSON, YAML, CSS, etc.)

Passthrough / truncation

โ€”

โ€”


โš ๏ธ Known Limitations

rename_symbol Tool

All languages: The definition file is renamed using AST (Tree-sitter) โ€” safe and precise. โœ…

Cross-file rename (dependent files): Updated using regex word-boundaries for all languages, including TypeScript, JavaScript, and PHP.

  • Risk: Regex may match strings, comments, or unrelated identifiers sharing the same name

  • Dart and Python: Higher risk โ€” import syntax (import 'package:...', from module import name) is less reliably matched by the current regex patterns

  • Recommendation: Always review the generated diff carefully before confirming

  • Alternative: Use write_file_surgical to rename within a single file safely

get_semantic_repo_map Tool

  • Max files: Limited to 2000 files to prevent timeouts (increased from 500 in v3.7.1)

  • Performance: Synchronous I/O may take 10-30 seconds on large repositories

  • Recommendation: Use @folder syntax to target specific directories

General

  • Validation: No automatic syntax checking after edits. Always review diffs carefully before confirming.

  • Backups: 5-version rolling backup system. Use rollback_file if something goes wrong.

  • Large files: Files >10MB are skipped for safety.

  • Phase 2 tokens: Confirmation tokens expire after 5 minutes.


Installation

# Global installation (recommended)
npm install -g mcp-code-context

# Or use directly with npx (no installation)
npx -y mcp-code-context

Note: Unlike v2.x, this version uses web-tree-sitter (WASM) instead of native bindings. No Visual Studio, Python, or node-gyp required!


Session State (v3.7.1+)

Important: v3.7.1 introduces session-scoped state for each MCP client connection. This prevents state leakage when multiple agents (Amazon Q, Kiro, Cursor, etc.) use the same server instance.

What Changed

Before (v3.6.x)

After (v3.7.1)

Global LockManager (shared by all clients)

Session-scoped sessionStates Map

Global ConfirmationStore (in-memory Map)

Session-scoped confirmation store + SQLite persistence

Global RateLimiter (shared tokens)

Per-session token bucket

No crash recovery

SQLite-backed pending operations store

Benefits

  • โœ… No state leakage: Each agent gets isolated locks, confirmation store, and rate limiter

  • โœ… Crash recovery: Pending operations survive server restarts

  • โœ… Multi-agent safe: Amazon Q and Kiro can run simultaneously without conflicts

Configuration

No additional configuration needed. Session isolation is automatic. Just configure your MCP server normally:

{
  "mcpServers": {
    "mcp-code-context": {
      "command": "npx",
      "args": ["-y", "mcp-code-context"]
    }
  }
}

New Tools (v3.7.1)

  • get_session_stats โ€” Get stats for current session only

  • clear_session_cache โ€” Clear cache for current session only

  • list_pending_operations โ€” List pending operations for recovery


Configuration

Claude Desktop

Add to your claude_desktop_config.json:

{
  "mcpServers": {
    "mcp-code-context": {
      "command": "npx",
      "args": ["-y", "mcp-code-context"]
    }
  }
}

Cursor

Add to your Cursor MCP settings (.cursor/mcp.json):

{
  "mcpServers": {
    "mcp-code-context": {
      "command": "npx",
      "args": ["-y", "mcp-code-context"]
    }
  }
}

Windsurf

Add to your Windsurf MCP config:

{
  "mcpServers": {
    "mcp-code-context": {
      "command": "npx",
      "args": ["-y", "mcp-code-context"]
    }
  }
}

Amazon Q

Add to your Amazon Q MCP config:

{
  "mcpServers": {
    "mcp-code-context": {
      "command": "npx",
      "args": ["-y", "mcp-code-context"]
    }
  }
}

Kiro

Add to your Kiro MCP config (.kiro/settings/mcp.json):

{
  "mcpServers": {
    "mcp-code-context": {
      "command": "npx",
      "args": ["-y", "mcp-code-context"]
    }
  }
}

Antigravity

Add to your Antigravity MCP config (.antigravity/mcp.json):

{
  "mcpServers": {
    "mcp-code-context": {
      "command": "npx",
      "args": ["-y", "mcp-code-context"]
    }
  }
}

Other MCP Clients

Any MCP-compatible client can use this server. The transport is stdio (JSON-RPC over stdin/stdout). Point your client to npx -y mcp-code-context.


Tools

Tool Reference (25 tools)

Read Tools

Tool

Key Params

Description

get_semantic_repo_map

directoryPath, projectRoot, format

Compressed XML/Markdown repo overview with AST symbols

read_file_surgical

filePath, projectRoot, symbolName?, className?

Extract one symbol or full file

analyze_impact

filePath, projectRoot, rootDir?

All files that depend on this file

read_file_lines

filePath, projectRoot, startLine?, endLine?, aroundPattern?

Read a line range or pattern context

search_code_pattern

rootDir, projectRoot, pattern, fileExtensions?, fuzzyMatch?

Regex search across files (ripgrep-fast)

parse_file

filePath, projectRoot

All symbols with line numbers (cheap index)

search_symbols

rootDir, projectRoot, query, fuzzy?, types?

AST symbol search by name, not text

explain_symbol

filePath, projectRoot, symbolName, rootDir?

Signature + location + callers in one call

batch_read

reads[], projectRoot

N symbols from N files in 1 round-trip

get_rate_limit_status

โ€”

Token balance + canAfford map

Write Tools (Two-Phase: preview โ†’ confirm)

All write tools require two calls:

  1. Phase 1 โ€” Call normally โ†’ returns diff + confirmationToken

  2. Phase 2 โ€” Call again with confirm: true + confirmationToken โ†’ applies changes

newContent/code are not required in Phase 2 โ€” the server stores them from Phase 1.

Tool

Key Params

Description

write_file_surgical

filePath, projectRoot, symbolName, newContent, className?

Replace a symbol with new code

insert_symbol

filePath, projectRoot, code, anchorSymbol?, position?, className?

Insert code before/after/inside a symbol

remove_symbol

filePath, projectRoot, symbolName, className?, force?

Remove a symbol (with dependency check)

rename_symbol

filePath, projectRoot, oldName, newName, rootDir?

Rename across entire repo (AST + regex)

ast_transform

filePath, projectRoot, symbolName, transform, className?

Declarative transforms: wrap_with_try_catch, add_parameter, add_decorator, change_return_type, extract_variable

Admin / Recovery Tools

Tool

Key Params

Description

rollback_file

filePath, projectRoot, steps?

Restore file from rolling backup (up to 5 versions)

clean_backups

projectRoot

Delete all backups for this project

get_server_stats

โ€”

Telemetry, audit stats, rate limiter state

get_cache_stats

projectRoot

Cache entries, size, hit rate

clear_cache

projectRoot

Invalidate cache for this project

configure_file_watcher

projectRoot, action (start/stop), debounceMs?

Auto-invalidate cache on file changes

get_file_watcher_status

projectRoot

Watcher state + watched paths

get_session_stats

โ€”

Per-session: pending ops, locks, tokens

clear_session_cache

projectRoot?

Clear cache for current session only

list_pending_operations

โ€”

List pending Phase 1 tokens (crash recovery)


  1. Understand โ†’ get_semantic_repo_map to see the architecture

  2. Read โ†’ read_file_surgical with symbol name for specific implementations

  3. Assess โ†’ analyze_impact before modifying shared files

  4. Edit (Preview) โ†’ Call write tools to generate a diff and confirmationToken

  5. Confirm โ†’ Call the same write tool with the token and confirm: true to apply

  6. Recovery โ†’ Use rollback_file if something goes wrong after confirmation


๐Ÿ’ฐ Support This Project

Why Support?

This tool was born in Caracas, Venezuela ๐Ÿ‡ป๐Ÿ‡ช, where economic limitations mean every API token counts. What started as a personal script to save money on Claude API became a full MCP server when I realized others faced the same problem.

Current Reality:

  • โฐ ~10 hours/week of maintenance

  • ๐Ÿ’ต ~$20/month in costs (npm, testing, domain)

  • ๐Ÿ†“ 100% free and open source (always will be)

If this tool saves you time or money, consider supporting its development.


๐Ÿ’ณ Ways to Support

๐Ÿ”น One-Time Donation

Ko-fi (PayPal + Cards, 0% fees)
ko-fi.com/achatainga

PayPal (Direct)
paypal.me/achatainga

Binance (USDT) (Crypto, lowest fees)

  • TRC20/ERC20: 0xa68d53f7853ce0175eb96aaad4a30c068ca96444

  • Binance Pay ID: 367669339

Recommended: TRC20 for lower gas fees

Suggested Amounts:

  • โ˜• $5 - A coffee (1 hour of development)

  • ๐Ÿ• $25 - A pizza (testing a new language)

  • ๐Ÿš€ $100 - Rocket fuel (major feature development)


๐Ÿ”น Recurring Support

Ko-fi Membership
ko-fi.com/achatainga/tiers

Monthly tiers:

  • $5/month - Supporter (name in SPONSORS.md)

  • $25/month - Contributor (priority support, early access)

  • $100/month - Sponsor (feature requests, 1-on-1 consultation)


๐Ÿ”น Hire Me

Need custom MCP tools or AI integrations?

  • ๐Ÿ’ผ Available for: Freelance contracts

  • ๐ŸŒ Location: Caracas, Venezuela (Remote)

  • ๐Ÿ’ป Skills: TypeScript, Node.js, MCP, AI/LLM integrations

  • ๐Ÿ’ต Rate: $50-75/hour

๐Ÿ“ง Contact: a.chataing.a@gmail.com
๐Ÿ“„ Details: HIRE_ME.md


๐Ÿ“Š Transparency

I believe in radical transparency:

Current Status:

  • ๐Ÿ’ฐ Donations received: $0

  • ๐Ÿ’ธ Expenses: $20/month (npm, testing)

  • โฐ Time invested: ~10 hours/week

  • ๐Ÿ“ฆ Downloads: 10,000+/month

(Updated monthly)


๐Ÿ† Hall of Fame

Thank you to these amazing supporters:

(No sponsors yet - be the first!)

See full list: SPONSORS.md


โค๏ธ Non-Financial Support

Can't donate? No problem! You can still help:

  • โญ Star the repo on GitHub

  • ๐Ÿ› Report bugs or suggest features

  • ๐Ÿ“ Improve documentation

  • ๐Ÿ—ฃ๏ธ Share with others who might benefit

  • ๐Ÿ’ฌ Join discussions and help other users

Every contribution matters, financial or not.


Development

# Build
npm run build

# Run tests
npm test

# Development (build + start)
npm run dev

Technical Details

  • Transport: stdio (JSON-RPC over stdin/stdout)

  • Runtime: Node.js >= 18

  • Protocol: Model Context Protocol

  • AST Engines: web-tree-sitter@0.25.1 (WASM) for TypeScript/JS/Python/PHP/Dart

  • Language Grammars: tree-sitter-wasms@0.1.13 (ABI v15)

  • Cache: sql.js@1.14.1 (WASM SQLite, zero native deps)

  • Logging: pino@10.3.1 (JSON to stderr, MCP-safe)

  • File Watcher: chokidar@5.0.0 (auto cache invalidation)

  • Fuzzy Search: fuse.js@7.3.0 (typo-tolerant matching)

  • File Locking: proper-lockfile@4.1.2 (multi-process safe, OS temp)

  • Diff: diff-match-patch@1.0.5 (Myers algorithm, O(n+dยฒ))

  • Ignore Engine: ignore npm package (full .gitignore spec support)

  • Safety Features: Mandatory two-phase confirmation, rolling 5-version backups, fuzzy matching, dependency checking, surgical restoration, ReDoS protection via worker_threads, session-scoped state.

  • Portability: 100% WASM - no native dependencies, works on all platforms

  • Tests: 83 passing (unit + integration + performance + stress)

v3.7.1 Key Changes

Component

Change

Benefit

State management

Session-scoped instead of global

No state leakage between clients

Pending operations

SQLite-backed

Survive server restarts

ReDoS patterns

6 โ†’ 15+

Better security

Cache eviction

Auto-persist before close

Cache data preserved

File limits

MAX_FILES = 2000 (was 500)

Better support for large projects

Tests

Added multi-client concurrency tests

Production readiness verified


Contributing

See CONTRIBUTING.md for guidelines.


Security

See SECURITY.md for security policies and reporting vulnerabilities.


Troubleshooting

See TROUBLESHOOTING.md for common issues and solutions.

Viewing Logs

Because MCP uses stdout for protocol communication, all logs are safely routed to stderr. You can view them in your client's log files:

  • Claude Desktop (macOS): ~/Library/Logs/Claude/mcp-server-mcp-code-context.log

  • Claude Desktop (Windows): %APPDATA%\Claude\logs\mcp-server-mcp-code-context.log

  • Cursor: Output panel โ†’ Select mcp-code-context from the dropdown

  • Amazon Q: Check stderr output in the MCP server configuration

  • Kiro: Check logs in the MCP server view

  • Antigravity: Check logs in the MCP server view

Environment Variables (optional):

{
  "mcpServers": {
    "mcp-code-context": {
      "command": "npx",
      "args": ["-y", "mcp-code-context"],
      "env": {
        "NODE_ENV": "development",
        "LOG_LEVEL": "debug"
      }
    }
  }
}

Supported LOG_LEVEL values: fatal, error, warn, info, debug, trace (default: info).


Changelog

See CHANGELOG.md for version history.


License

MIT


Built with โค๏ธ from Caracas, Venezuela ๐Ÿ‡ป๐Ÿ‡ช

Install Server
A
license - permissive license
B
quality
A
maintenance

Maintenance

โ€“Maintainers
โ€“Response time
3dRelease cycle
5Releases (12mo)
Commit activity

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/achatainga/mcp-code-context'

If you have feedback or need assistance with the MCP directory API, please join our Discord server