Back to MCP Servers

Javalens

56 semantic Java analysis tools via Eclipse JDT. Compiler-accurate navigation, refactoring, find references, call hierarchy, and code metrics for AI agents.

developer-toolsaiagent
By pzalutski-pixel
3111Updated 2 weeks agoJavaMIT

Installation

npx -y javalens-mcp

Configuration

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

How to use

  1. Run the installation command above (if needed)
  2. Open your Claude Code settings file (~/.claude/settings.json)
  3. Add the configuration to the mcpServers section
  4. Restart Claude Code to apply changes

JavaLens: AI-First Code Analysis for Java

GitHub release License: MIT Java 21

An MCP server providing 75 semantic analysis tools for Java, built directly on Eclipse JDT for compiler-accurate code understanding.

Built for AI Agents

JavaLens exists because AI systems need compiler-accurate insights that reading source files cannot provide. When an AI uses grep or Read to find usages of a method, it cannot distinguish:

  • A method call from a method with the same name in an unrelated class
  • A field read from a field write
  • An interface implementation from an unrelated class
  • A cast to a type from other references to that type

This leads to incorrect refactorings, missed usages, and incomplete understanding of code behavior.

Compiler-Accurate Analysis

JavaLens provides compiler-accurate code analysis through Eclipse JDT—the same engine that powers Eclipse IDE. Unlike text search, JDT understands:

  • Type resolution across inheritance hierarchies
  • Method overloading and overriding
  • Generic type arguments
  • Import resolution and classpath dependencies
  • Java source from version 1.1 through Java 25 (markdown Javadoc, module imports, compact source files, flexible constructor bodies)
  • Lombok-generated members — a bundled agent makes @Data accessors and the like resolve, so code using them is not flagged as undefined

Example: Finding all places where UserService.save() is called:

ApproachResult
grep "save("Returns 47 matches including orderService.save(), saveButton, comments
find_referencesReturns exactly 12 calls to UserService.save()

AI Training Bias Warning

⚠️ Important for AI developers and users

AI models may exhibit trained bias toward native tools (Grep, Read, LSP) over MCP server tools, even when semantic analysis provides better results. This happens because:

  1. Training data contains extensive grep/text-search patterns
  2. Native tools are "always available" in the model's experience
  3. The model may not recognize when semantic analysis is superior

To get the best results:

Add guidance to your project instructions or system prompt (e.g., CLAUDE.md for Claude Code):

## Code Analysis Preferences

For Java code analysis, prefer JavaLens MCP tools over text search:
- Use `find_references` instead of grep for finding usages
- Use `find_implementations` instead of text search for implementations
- Use `analyze_type` to understand a class before modifying it
- Use refactoring tools (rename_symbol, extract_method) for safe changes

Semantic analysis from JDT is more accurate than text-based search,
especially for overloaded methods, inheritance, and generic types.

What is JavaLens?

JavaLens is an MCP server that gives AI assistants deep understanding of Java codebases. It provides semantic analysis, navigation, refactoring, and code intelligence tools that go beyond simple text search.

Why Not LSP?

Language Server Protocol was designed for IDE autocomplete and basic navigation—not for AI agent workflows that require deep semantic analysis.

CapabilityNative LSPJavaLens
Find all @Annotation usages
Find all new Type() instantiations
Find all casts to a type
Distinguish field reads from writes
Detect circular package dependencies
Calculate cyclomatic complexity
Find unused private methods
Detect possible null pointer bugs
Project-wide dead-code reachability from entry points
Find the tests that exercise a symbol, transitively

JavaLens wraps Eclipse JDT Core directly via OSGi, providing:

  • Fine-grained reference types: Find specifically casts, annotations, throws clauses, catch blocks, instanceof checks, method references, type arguments
  • Read vs write access distinction: Track where fields are mutated vs just read
  • Indexed search: JDT pre-builds an index at load time, so symbol/reference queries do not walk source files
  • Full AST access: Direct manipulation for complex refactorings

Installation

Prerequisites

  • Java 21 or later (must be on PATH or set JAVA_HOME) — required for both install paths.
  • Node.js 18+ — required only if you use the npm/npx install path below. Skip if you use the direct-download path.

JavaLens is an analytical server, not a compiler. It uses Eclipse JDT 2025-12 to parse and understand Java source code from version 1.1 through 25. Java 21 is required only as the server runtime.

Install from GitHub Releases (recommended — Java only)

This is the simplest path if you already have Java 21 and don't have Node.js. Download from Releases:

PlatformFile
All platformsjavalens.zip or javalens.tar.gz

Extract to a location of your choice (e.g., /opt/javalens or C:\javalens). Then point your MCP client at the bundled jar — see Configure MCP Client below.

Install via npm (requires Node.js 18+)

If you already have Node.js, npx will download and cache the JavaLens distribution (~23 MB) on first run:

{
  "mcpServers": {
    "javalens": {
      "command": "npx",
      "args": ["-y", "javalens-mcp"],
      "env": {
        "JAVA_PROJECT_PATH": "/path/to/your/java/project"
      }
    }
  }
}

Configure MCP Client

Add to your MCP configuration (e.g., .mcp.json for Claude Code):

{
  "mcpServers": {
    "javalens": {
      "command": "java",
      "args": ["-jar", "/path/to/javalens/javalens.jar", "-data", "/path/to/javalens-workspaces"]
    }
  }
}

The -data argument specifies where JavaLens stores its workspace metadata. See How Workspaces Work below.

Auto-Load a Project

Set JAVA_PROJECT_PATH to auto-load a project when the server starts:

{
  "mcpServers": {
    "javalens": {
      "command": "java",
      "args": ["-jar", "/path/to/javalens/javalens.jar", "-data", "/path/to/javalens-workspaces"],
      "env": {
        "JAVA_PROJECT_PATH": "/path/to/your/java/project"
      }
    }
  }
}

Note: Project loading happens asynchronously in the background. The MCP server responds immediately while the project loads. Use health_check to monitor loading status—it will show "project.status": "loading" until complete, then "loaded" when ready.

How Workspaces Work

Unlike in-memory code models, Eclipse JDT requires a workspace directory to store:

  • Search indexes for fast symbol lookup
  • Compilation state and caches
  • Project metadata

Workspaces Are Outside Your Source

JavaLens creates its workspace outside your source project to keep your codebase clean:

Your Java Project (unchanged)
├── src/main/java/
├── pom.xml
└── (no Eclipse files added)

JavaLens Workspace (specified by -data)
└── {session-uuid}/
    ├── .metadata/          <- JDT indexes and state
    └── javalens-project/   <- Links to your source (not copies)

Why this matters:

  1. No pollution: Your source tree stays clean—no .project or .classpath files
  2. No conflicts: Works alongside any build system without interference
  3. Session isolation: Each MCP session gets its own workspace, enabling concurrent analysis

Session Lifecycle

  1. JavaLens starts and creates a unique workspace: {base}/{uuid}/
  2. load_project creates linked folders pointing to your source
  3. JDT builds indexes in the workspace (not in your project)
  4. When the session ends, the workspace is cleaned up

Tools

Navigation (10 tools)

ToolDescription
search_symbolsSearch types, methods, fields by glob pattern
go_to_definitionNavigate to symbol definition
find_referencesFind all usages of a symbol
find_implementationsFind interface/class implementations
get_type_hierarchyGet inheritance chain
get_document_symbolsGet all symbols in a file
get_symbol_infoGet detailed symbol information at position
get_type_at_positionGet type details at cursor
get_method_at_positionGet method details at cursor
get_field_at_positionGet field details at cursor

Fine-Grained Reference Search (9 tools)

These use JDT's unique reference type constants—not available through LSP:

ToolDescription
find_annotation_usagesFind all @Annotation usages
find_type_instantiationsFind all new Type() calls
find_castsFind all (Type) expr casts
find_instanceof_checksFind all x instanceof Type
find_throws_declarationsFind all throws Exception in signatures
find_catch_blocksFind all catch(Exception e) blocks
find_method_referencesFind all Type::method expressions
find_type_argumentsFind all List<Type> usages
find_reflection_usageFind Class.forName(), Method.invoke(), and other reflection calls

Analysis (20 tools)

ToolDescription
get_diagnosticsGet compilation errors and warnings
validate_syntaxFast syntax-only validation
get_call_hierarchy_incomingFind all callers of a method
get_call_hierarchy_outgoingFind all methods called by a method
find_field_writesFind where fields are mutated
find_testsDiscover JUnit/TestNG test methods
find_unused_codeFind unused private members
find_unreachable_codeProject-wide dead code — members unreachable from any main method or test, over the whole-program call graph
find_affected_testsThe tests that exercise a symbol, directly or transitively — the set to run after changing it
find_possible_bugsDetect null risks, empty catches, resource leaks
get_hover_infoGet documentation/signature for symbol
get_javadocGet parsed Javadoc
get_signature_helpGet method signature at call site
get_enclosing_elementGet containing method/class at position
analyze_change_impactBlast radius — direct call sites by depth, or the full transitive closure over the project graph (transitive=true)
analyze_data_flowVariable read/write/declaration tracking within a method; opt-in followCalls tracks null/taint facts across calls to sinks
analyze_control_flowBranching, loops, return/throw points, nesting depth
get_di_registrationsFind Spring DI registrations (@Component, @Bean, @Autowired, @Inject)
get_jpa_modelAssembled JPA entity model — tables, id fields, relationships with resolved targets and mappedBy sides
get_http_endpointsAssembled HTTP route table — Spring and JAX-RS paths composed from class prefixes, mapped to handler methods

Compound Analysis (4 tools)

Combine multiple queries to reduce round-trips:

ToolDescription
analyze_fileGet imports, types, diagnostics in one call
analyze_typeGet members, hierarchy, usages, diagnostics
analyze_methodGet signature, callers, callees, overrides
get_type_usage_summaryGet instantiations, casts, instanceof counts

Refactoring (16 tools)

All refactoring tools return text edits (and new-file content where a refactoring creates one) rather than applying changes directly:

ToolDescription
rename_symbolRename across entire project
organize_importsSort and clean imports
extract_variableExtract expression to

View source on GitHub