npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

mcp-codebase-intelligence

v0.3.0

Published

MCP server providing semantic code intelligence — symbol search, references, call graphs, impact analysis, and architecture diagrams via tree-sitter

Readme

mcp-codebase-intelligence

Give your AI assistant a deep understanding of your codebase.

CI License: MIT

An MCP server that parses your entire codebase with tree-sitter, builds a semantic graph of symbols, references, and dependencies, and lets AI assistants query it in real time. Works with Claude Code, Cursor, VS Code, and any MCP-compatible client.


Why?

AI coding assistants are limited by what fits in their context window. When they need to understand your codebase -- find callers of a function, trace a dependency chain, or assess the impact of a change -- they resort to grep and guesswork.

mcp-codebase-intelligence gives them structural understanding instead.

| Without | With | |---------|------| | AI greps for function name, misses qualified calls | AI queries the symbol graph, finds all 47 callers instantly | | AI reads files one by one to trace imports | AI gets the full dependency tree in one call | | AI reviews a PR by reading the diff | AI analyzes which 12 downstream modules are affected by the change | | AI guesses at project structure | AI generates an architecture diagram from the actual import graph |


Quick Start

One-liner (no clone needed)

# Add to Claude Code via npx — auto-detects your project from cwd
claude mcp add codebase-intelligence npx mcp-codebase-intelligence

Or with an explicit project path:

claude mcp add codebase-intelligence \
  npx mcp-codebase-intelligence \
  -e PROJECT_ROOT=/path/to/your/project

JSON config (Claude Code, Cursor, VS Code)

Add to your MCP config file:

{
  "mcpServers": {
    "codebase-intelligence": {
      "command": "npx",
      "args": ["mcp-codebase-intelligence"],
      "env": {
        "PROJECT_ROOT": "/path/to/your/project"
      }
    }
  }
}

From source (for development)

git clone https://github.com/g-tiwari/mcp-codebase-intelligence.git
cd mcp-codebase-intelligence
npm install && npm run build

claude mcp add codebase-intelligence \
  node /path/to/mcp-codebase-intelligence/dist/index.js \
  -e PROJECT_ROOT=/path/to/your/project

That's it. The server indexes your codebase on startup and watches for changes.


Multi-Project Support

Work across multiple repos, monorepos, or a mix of both — from a single MCP server.

Auto-detection (zero config)

When no config is set, the server auto-detects your project:

  1. Finds the git root from your current directory
  2. Detects monorepo markers (pnpm, lerna, nx, npm/yarn workspaces, go.work, Cargo workspace)
  3. Indexes accordingly

Multi-repo projects

Use PROJECT_ROOTS for projects spanning multiple repositories:

claude mcp add codebase-intelligence \
  npx mcp-codebase-intelligence \
  -e PROJECT_ROOTS="/code/shared-models,/code/api-gateway,/code/android-app"

Config file (power users)

Create .codegraph.json in your project root (or ~/.codegraph/config.json for user-level config):

{
  "projects": {
    "tv-backend": {
      "root": "/code/monorepo",
      "include": ["packages/api-gateway", "packages/shared-models"],
      "roots": ["/code/android-app", "/code/webos-app"]
    },
    "music-service": {
      "roots": ["/code/music-api", "/code/music-models"]
    }
  }
}

Then use list_projects and switch_project tools to navigate between projects.


17 Tools

Code Navigation

| Tool | What it does | |------|-------------| | find_symbol | Search for functions, classes, interfaces, types by name. Fuzzy matching, kind/scope filters. | | get_references | Find all callers/users of a symbol. Transitive: follow the chain N levels deep. | | get_exports | Public API surface of any file -- all exported symbols with signatures. | | get_dependencies | Import graph for a file. Transitive: see the full dependency tree. | | get_call_graph | Who calls this function? What does it call? Tree or mermaid diagram output. |

Code Intelligence (LSP-powered)

| Tool | What it does | |------|-------------| | goto_definition | Jump to the definition of any symbol at a given position (TS/JS). | | get_type_info | Get the inferred type of any expression at a given position (TS/JS). | | find_implementations | Find all implementations of an interface or abstract method (TS/JS). |

Change Analysis

| Tool | What it does | |------|-------------| | semantic_diff | Feed it a git_ref (e.g. HEAD~1). It identifies affected symbols, finds all downstream dependents, and flags breaking changes. | | analyze_change_impact | Point it at specific lines in a file. It tells you which symbols are affected and who depends on them. |

Architecture & Discovery

| Tool | What it does | |------|-------------| | architecture_diagram | Auto-generate a mermaid diagram of module dependencies, grouped by directory. | | query_codebase | Ask natural language questions: "find all API endpoints", "what does the orders module do?", "what depends on the database layer?" |

Project Management

| Tool | What it does | |------|-------------| | list_projects | Show all configured projects, their roots, and index stats. | | switch_project | Change active project context. All tools operate against the selected project. | | add_project | Add a new project at runtime. Indexes immediately and persists to config. |

Admin

| Tool | What it does | |------|-------------| | get_index_stats | How many files, symbols, references, and imports are indexed. | | reindex | Trigger a full re-index after major changes. |


8 Languages

| Language | Extensions | Parser | |----------|-----------|--------| | TypeScript | .ts .tsx .mts .cts | tree-sitter + LSP | | JavaScript | .js .jsx .mjs .cjs | tree-sitter + LSP | | Python | .py .pyi | tree-sitter | | Go | .go | tree-sitter | | Rust | .rs | tree-sitter | | Java | .java | tree-sitter | | C | .c .h | tree-sitter | | C++ | .cpp .cc .cxx .hpp .hxx .hh | tree-sitter |

All languages get symbol extraction, reference tracking, import/export analysis, and call graphs. TypeScript/JavaScript additionally get LSP-powered go-to-definition, type info, and find-implementations.


How It Works

Source Files ──> tree-sitter AST ──> Symbol Extraction ──> SQLite Graph
                                                              │
                                    File Watcher ─────────────┤ (incremental updates)
                                                              │
                                    MCP Tools ◄───────────────┘ (AI queries)
                                        │
                                    LSP Servers ──> Type Info (TS/JS)
  1. Parse -- tree-sitter builds ASTs for all supported files
  2. Extract -- language plugins walk the AST to find symbols, references, imports, inheritance
  3. Store -- everything goes into a SQLite database with WAL mode, prepared statements, batch transactions
  4. Watch -- chokidar monitors the filesystem; changed files are re-indexed incrementally
  5. Query -- MCP tools run recursive SQL queries against the graph (transitive references, dependency chains)
  6. LSP -- typescript-language-server provides type-aware intelligence for TS/JS

Performance

  • Batch indexing with single-transaction writes
  • Prepared statement cache -- 14 SQL statements prepared once at startup
  • In-memory hash cache -- skip DB lookups for unchanged files
  • Incremental updates -- only re-index files that actually changed

Tested on real-world projects: Zod, Express, gin, ripgrep, gson.


Testing

npm test

108 tests across 8 test suites covering all language parsers, grammar regression tests, the graph engine, and semantic diff.


Configuration

Environment Variables

| Variable | Description | Default | |----------|-------------|---------| | PROJECT_ROOT | Path to a single codebase to index | git root of cwd() | | PROJECT_ROOTS | Comma-separated paths for multi-repo projects | — | | DB_PATH | Path to SQLite database file | ~/.codegraph/graphs/<project>.db | | LOG_LEVEL | Logging verbosity: debug, info, warn, error | info |

Config Files

| File | Scope | Purpose | |------|-------|---------| | .codegraph.json | Project (check into git) | Define project roots, monorepo scoping | | ~/.codegraph/config.json | User | Personal multi-project setup |


License

MIT