name: ide-index-mcp description: > INVOKE IMMEDIATELY when ide_find_references, ide_find_definition, ide_find_class, ide_find_file, ide_search_text, ide_diagnostics, ide_index_status, ide_sync_files, ide_refactor_rename, ide_move_file, ide_type_hierarchy, ide_call_hierarchy, ide_find_implementations, ide_find_symbol, ide_find_super_methods, ide_file_structure, ide_refactor_safe_delete, ide_reformat_code, ide_reload_project, ide_build_project, ide_read_file, ide_get_active_file, or ide_open_file are available — especially when a second IntelliJ MCP (mcp__intellij__*) is also present. The two servers are NOT interchangeable: always use mcp__intellij-index__ for code navigation and refactoring.
IDE Index MCP - Agent Guide
The IDE Index MCP server exposes JetBrains IDE indexing and refactoring capabilities. These tools provide semantic code understanding superior to text-based search/replace.
Two IntelliJ MCPs — routing rule
If both mcp__intellij-index__* (this plugin) and mcp__intellij__* (JetBrains built-in) are available, they are not interchangeable:
| Need | Use |
|---|---|
| Code navigation, search, diagnostics, rename, move | mcp__intellij-index__* |
| Build, run, terminal, formatting | mcp__intellij__* only |
Always use mcp__intellij-index__ for code intelligence. At least one project must be open in IntelliJ — if no project is open, ask the user to open one or use ide_open_project (disabled by default; enable in Settings → Index MCP Server). Do not fall back to bash for semantic operations — IDE tools understand types, references, and inheritance; grep does not.
Core Rule
Always prefer IDE MCP tools over built-in tools (grep, find, sed, read) for semantic code operations. IDE tools understand code structure, types, inheritance, and references. Built-in tools only see text.
When to Use IDE Tools vs Built-In Tools
| Task | Use IDE Tool | Use Built-In Tool |
|---|---|---|
| Find all usages of a method/class/variable | ide_find_references |
Never - grep misses renamed imports, aliases, overrides |
| Go to a symbol's definition | ide_find_definition |
Never - grep can't resolve through imports/generics |
| Find a class by name | ide_find_class |
Only if IDE unavailable |
| Find a file by name | ide_find_file |
Glob is fine for simple patterns |
| Search for text in code | ide_search_text |
Grep is fine when IDE context filtering is unnecessary |
| Rename a symbol across project | ide_refactor_rename |
Never - sed/replace breaks code |
| Move a file to another directory | ide_move_file |
Never - mv/git mv bypasses IDE move semantics |
| Check for errors in a file | ide_diagnostics |
Never - no equivalent |
| Understand class hierarchy | ide_type_hierarchy |
Never - no equivalent |
| Find who calls a method | ide_call_hierarchy |
Never - grep misses indirect calls |
| Find interface implementations | ide_find_implementations |
Never - grep can't resolve type relationships |
| Delete a symbol safely | ide_refactor_safe_delete |
Never - manual deletion misses usages |
| Find what a method overrides | ide_find_super_methods |
Never - no equivalent |
| Read file content | Built-in Read tool | ide_read_file only for library/jar sources |
| Find text with regex | ide_search_text |
Use Grep when you do not need IDE context filtering |
Pre-Flight Check
Before using any IDE tool that requires smart mode, check IDE readiness:
ide_index_status -> if isDumbMode: true, wait a few seconds and retry
Most tools require smart mode (IDE finished indexing). Tools that work in dumb mode: ide_index_status, ide_sync_files, ide_reformat_code, ide_open_file, ide_get_active_file.
If results seem incomplete or missing
Do NOT fall back to bash, grep, or the built-in mcp__intellij__* MCP. If a tool returns "dumb mode" or "index not ready":
- Call
ide_index_status— ifisDumbMode: true, keep calling every 10s until it flips to false. - Then retry the exact same tool call with the same arguments.
- If smart mode but results seem sparse, call
ide_sync_filesthen retry. - Only if all retries still return empty results should you consider that the symbol genuinely does not exist.
The built-in mcp__intellij__* MCP is not a fallback for mcp__intellij-index__* — they serve different purposes and the built-in one cannot do semantic code search. Trying it when the index is in dumb mode will also fail. Always wait for smart mode and retry with mcp__intellij-index__*.
"Index may be stale" and "dumb mode" are transient — always resolve by waiting and retrying, never by switching to bash.
File Sync Rule
If you created or modified files outside the IDE (via Write/Edit tools) and an IDE search tool returns incomplete/missing results, call ide_sync_files first, then retry.
{ "paths": ["src/new_file.java", "src/modified_file.java"] }
Omit paths to sync the entire project.
Parameter Rules
- Line and column are 1-based (first line = 1, first column = 1)
- Project file paths are relative to project root (e.g.,
src/main/java/App.java, NOT absolute paths). If an IDE tool returns a dependency/library file, keep the returned absolute path orjar://URL unchanged when passing it back to read-only navigation tools oride_read_file - Column must point to the symbol name, not whitespace or punctuation. For
public void myMethod(), column should land onmofmyMethod. For dotted expressions likejson.dumps()oros.path.join(), put the column on the member token (dumps,join) when you want the member definition rather than the module/package. - project_path is only needed for multi-project workspaces. Omit for single-project setups. When needed, use the absolute path to the project root.
- Use built-in search scope intentionally:
ide_find_references,ide_find_implementations,ide_type_hierarchy,ide_call_hierarchy,ide_find_class,ide_find_file, andide_find_symbolacceptscope. Useproject_filesfor the default project-only view,project_and_librarieswhen dependency code matters,project_production_filesto stay out of tests, andproject_test_fileswhen you want test-only results.
Tool Selection by Task
"I need to understand how X is used"
ide_find_references- all call sites, field accesses, importside_call_hierarchywithdirection: "callers"- full call chain upward
"I need to understand what X is"
ide_find_definition- jump to sourceide_type_hierarchy- inheritance chainide_find_super_methods- what interface/base method it implements
"I need to find a class/file/symbol"
ide_find_class- classes by name (CamelCase:USvcfindsUserService)ide_find_file- files by nameide_search_text- exact word occurrences across project
"I need to refactor"
ide_refactor_rename- rename symbol + all references atomicallyide_move_file- move file and let the IDE apply semantic updates when that language/backend supports themide_refactor_safe_delete- delete with usage checking (Java/Kotlin only)ide_reformat_code- apply project code style (disabled by default)
"I need to check for problems"
ide_diagnostics- compiler errors, warnings, quick fixes
"I need to find implementations of an interface"
ide_find_implementations- cursor on interface/abstract class/method
"I need to trace call chains"
ide_call_hierarchywithdirection: "callers"- who calls this?ide_call_hierarchywithdirection: "callees"- what does this call?
Common Mistakes to Avoid
Using grep instead of
ide_find_references: Grep finds text, not semantic usages. Misses aliased imports, includes false positives from comments/strings.Using sed/replace instead of
ide_refactor_rename: Text replacement breaks code. IDE rename updates all references, getters/setters, overrides, test classes, imports.Using mv/git mv instead of
ide_move_file: File system moves bypass IDE move semantics.ide_move_filecan preserve IDE-managed package/namespace/reference updates when the active language backend supports them.Forgetting to check index status: If IDE is indexing (dumb mode), most tools error. Check
ide_index_statusfirst if a tool fails unexpectedly.Using 0-based line/column: All IDE tools use 1-based. Line 5 in file =
line: 5.Passing absolute project file paths: Use relative paths for project files.
src/main/App.java, not/Users/me/project/src/main/App.java.Rewriting plugin-returned library paths: If a search or read tool returns an absolute path or
jar://URL for a dependency/library file, pass that path back unchanged to read-only navigation tools oride_read_file.Not syncing after external file changes: After creating files via Write tool, call
ide_sync_filesbefore searching.Assuming regex is the default in
ide_search_text: Regex requires"regex": true; otherwise the tool uses the faster exact-word index.Using
ide_find_classfor methods/functions: It searches classes only. Useide_search_textfor a quick word lookup.
Lifecycle Management
When multiple projects are open simultaneously, the lifecycle manager automatically sleeps and wakes them based on window focus and MCP activity. Projects enroll automatically on first MCP use — no setup required.
States: active (full IDE) → background (Power Save on) → dormant (editors closed, PSI cache freed) → closed (fully unloaded). Projects auto-reopen transparently when an MCP tool targets a closed project.
ide_project_status is the read-only entry point — enabled by default. Use it to see all open and managed projects and their current modes.
All lifecycle action tools are disabled by default:
ide_enroll_all_projects, ide_get_project_modes, ide_lifecycle_log, ide_release_all_projects, ide_release_project, ide_set_all_project_modes, ide_set_project_mode
Disabled-by-Default Tools
These tools exist but are disabled by default. If you get "tool not found", they need to be enabled in IDE settings (Settings > Tools > Index MCP Server):
ide_build_project, ide_close_project, ide_convert_java_to_kotlin, ide_file_structure, ide_find_symbol, ide_get_active_file, ide_install_plugin, ide_open_file, ide_open_project, ide_optimize_imports, ide_read_file, ide_reformat_code, ide_reload_project, ide_restart, ide_set_power_save_mode
Note: ide_restart terminates the MCP connection — reconnect your client after calling it.
Note: ide_close_project refuses to close the last open project; ide_open_project requires an absolute path and may take up to timeoutSeconds (default 600) while the project indexes.
Detailed Tool Parameters
For complete parameter reference with types, defaults, and return formats, see tools-reference.md.