PyCharm 2026.1 Help

MCP Server

Starting with version 2025.2, PyCharm comes with an integrated MCP server, allowing external clients such as Claude Desktop, Cursor, Codex, VS Code, and others to access tools provided by the IDE. This provides users with the ability to control and interact with JetBrains IDEs without leaving their application of choice.

Enable the MCP Server plugin

This functionality relies on the MCP Server plugin, which is bundled and enabled in PyCharm by default. If the relevant features are not available, make sure that you did not disable the plugin.

  1. Press Ctrl+Alt+S to open settings and then select Plugins.

  2. Open the Installed tab, find the MCP Server plugin, and select the checkbox next to the plugin name.

External client setup

For external clients like Claude Code, Claude Desktop, Cursor, VS Code, Codex, and Windsurf, configuration can be performed automatically:

  1. In the main menu, go to Settings | Tools | MCP Server.

  2. Click Enable MCP Server.

  3. In the Clients Auto-Configuration section, click Auto-Configure for each client you want to set up for use with the MCP server. This will automatically update their JSON configuration.

    MCP Server settings
  4. Restart your client for configuration to take effect.

If you want to connect to the MCP server from any other client, you will need to perform manual configuration:

  1. In the Manual Client Configuration section, click either Copy SSE Config, Copy Stdio Config, or Copy HTTP Stream Config depending on the connection type.

    MCP Server manual configuration
  2. Paste the copied configuration into your client's settings or configuration file.

  3. Restart your client for configuration to take effect.

Execute actions without confirmation

The MCP server allows connected external clients to execute terminal commands or run configurations in the IDE without prompting for user confirmation each time.

To enable this mode:

  1. In the main menu, go to Settings | Tools | MCP Server.

  2. In the Command execution section, enable the Run shell commands or run configurations without confirmation (brave mode) setting.

  3. Click Apply.

Supported tools

The MCP Server exposes a set of tools that allow external clients to interact with your IDE and project – for example, to analyze code, modify files, run configurations, or execute terminal commands.

You can view and manage the full list of available tools in Settings | Tools | MCP Server | Exposed Tools. From this page, you can enable or disable specific tools depending on your workflow and preferences.

Below you can find the list of tools provided by the MCP server.

Analysis tools

build_project

Triggers building of the project or specified files, waits for completion, and returns build errors. Use this tool to build the project or compile files and get detailed information about compilation errors and warnings.

You have to use this tool after performing edits to validate if the edits are valid.

Parameters:

  • rebuild: Whether to perform the full rebuild the of project. Defaults to false. Effective only when filesToRebuild is not specified.

  • filesToRebuild: If specified, only compile files with the specified paths. Paths are relative to the project root.

  • timeout: Timeout in milliseconds.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

get_file_problems

Analyzes the specified file for errors and warnings using IntelliJ inspections. Use this tool to identify coding issues, syntax errors, and other problems in a specific file.

Returns a list of problems, including severity, description, and location information.

Parameters:

  • filePath: Path relative to the project root.

  • errorsOnly: Whether to include only errors or both errors and warnings.

  • timeout: Timeout in milliseconds.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

get_project_dependencies

Returns a list of all dependencies defined in the project. Provides structured information about library names.

Parameters:

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

get_project_modules

Returns a list of all modules in the project with their types. Provides structured information about each module, including its name and type.

Parameters:

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

Code insight tools

get_symbol_info

Retrieves information about the symbol at the specified position in the specified file. Provides the same information as IntelliJ IDEA's Quick Documentation feature. The information may include the symbol's name, signature, type, documentation, and other details, depending on the programming language.

If the position references a symbol, the tool will return a code snippet with the symbol's declaration, if available. Use this tool to understand a symbol's declaration, semantics, and location.

Parameters:

  • filePath: Path relative to the project root.

  • line: 1-based line number.

  • column: 1-based column number.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

Database-specific tools

To guarantee strictly read-only access for an AI agent, use a database user with properly restricted (read-only) privileges and configure the data source to use that user.

get_database_object_description

Retrieves the structure of a database object (columns, types, keys, indexes) within a particular schema as a hierarchical text representation.

In case of ambiguity returns definition of all applicable objects.

Parameters:

  • connectionId: Unique connection ID.

  • databaseName: Name of the database the schema belongs to. Can be empty if the DBMS has no databases but only schemas.

  • schemaName: Name of the schema.

  • kind: Set this parameter to a particular object kind code to list only objects of that kind. Set it to null to retrieve all objects in the schema.

  • objectName: Object name of the specified kind (e.g., table or view name). May not be empty.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

list_database_connections

Retrieves a list of configured database connections or data sources in the project. For each connection returns its unique ID, name, DBMS, and driver name.

test_database_connection

Returns connection diagnostic info:

  • Flag indicating if the connection is problematic: yes, no, or unknown.

  • Detailed information about database connection such as DBMS type, version, and JDBC driver.

  • Summary of the connection attempt result. In case of a failure, contains a DBMS-provided error description.

Parameters:

  • id: Unique connection ID.

list_database_schemas

Retrieves a list of database schemas in the specified database connection.

For each schema, the tool returns the schema's own name as well as the database name (empty if not applicable).

Parameters:

  • connectionId: Unique connection ID.

  • selectedOnly: True if only the schemas selected in the database tree should be listed; false if all schemas should be listed.

list_schema_object_kinds

Retrieves a list of supported schema object kinds for the given database connection. For each object kind, returns the object kind unique code and human-readable name.

Parameters:

  • connectionId: Unique connection ID.

list_schema_objects

Retrieves a list of database objects within the given schema. For each object, returns the object name within schema and its kind.

Parameters:

  • connectionId: Unique connection ID.

  • schemaName: Name of the schema.

  • databaseName: Name of the database the schema belongs to. Can be empty if the DBMS has no databases but only schemas.

  • kind: Set this parameter to a particular object kind code to list only objects of that kind. Set it to null to retrieve all objects in the schema.

list_recent_sql_queries

This feature is not available in free subscription plans.

Retrieves a list of recent, including currently running, queries for the given database connection.

For each query returns:

  • Unique ID of a query session.

  • Time spent on running the query (in milliseconds).

  • The current state of the query. For example, running, cancelling, finished, and so on.

  • Completion status of the query. For example, success, finished with error, cancelled, and so on.

  • Text of the query.

Parameters:

  • connectionId: Unique connection ID.

cancel_sql_query

Cancel a running query using its unique ID.

Parameters:

  • sessionId: Query session ID.

execute_sql_query

Execute a SQL query against the given database connection.

The tool reports execution status: success or error. For errors, it also provides error description.

If the query returns data, it is appended to the tool response in the CSV format.

Parameters:

  • connectionId: Unique connection ID.

  • queryText: SQL query to be executed.

preview_table_data

Returns preview data of the table, view, materialized view, or other table-like object using a given database connection.

The tool returns table content in CSV format.

Parameters:

  • connectionId: Unique connection ID.

  • schemaName: Name of the schema.

  • databaseName: Name of the database the schema belongs to. Can be empty if the DBMS has no databases but only schemas.

  • tableName: Name of the table.

  • maxRowCount: Maximum number of rows to return. Default is 100.

Developer kit MCP tools

find_lock_requirement_usages

Analyzes the usage of the Read/Write lock for the method under the caret. Also analyzes call paths to some depth. Use this tool to identify possible usages of Read/Write lock requirements. Returns a list of lock requirements with the call path to them.

Parameters:

  • filePath: Path relative to the project root.

  • line: Line where cursor is located.

  • column: Column where cursor is located.

  • timeout: Timeout in milliseconds.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

find_threading_requirements_usages

Analyzes the usage of threading constraints (i.e., whether the method needs to run on the UI thread or on the background thread) for the method under the caret. Also analyzes call paths to some depth. Use this tool to identify possible usages of threading requirements. Returns a list of threading requirements with the call path to them.

Parameters:

  • filePath: Path relative to the project root.

  • line: Line where cursor is located.

  • column: Column where cursor is located.

  • timeout: Timeout in milliseconds.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

Execution tools

execute_run_configuration

Run either an existing run configuration by name or a temporary run configuration created from a code location (filePath + line) in the current project, then wait up to specified timeout for it to finish. Use this tool with either a configuration name returned by get_run_configurations, or with a run point (filePath + line) returned by get_run_configurations(filePath = ...).

Optional launch overrides (programArguments, workingDirectory, envs) are applied only for this run and are not persisted. Do not pass these override parameters unless you explicitly need to change the configured launch values for this run. Missing/null override parameters keep existing run configuration values unchanged. For string overrides (programArguments, workingDirectory), missing/null or empty string ("") keeps the existing value unchanged. Pass a whitespace-only string such as " " to clear an existing value for this launch.

Pass either configurationName, or filePath together with line. These modes are mutually exclusive.

Behavior:

  • When waitForExit=true, waits up to timeout milliseconds for process termination. If the timeout expires, the process keeps running in the background and exitCode is omitted from the result.

  • When waitForExit=false, waits only for the process to start, then returns immediately without applying timeout.

  • fullOutputPath points to a temp file with the full raw output and may continue growing while the process is alive.

Returns the execution result including current output snapshot, optional exit code, and optional fullOutputPath.

Parameters:

  • configurationName: Name of the existing run configuration to execute.

  • filePath: File path relative to the project root. Provide together with line to create and execute a temporary run configuration from code context.

  • line: 1-based line number for filePath. Provide together with filePath and do not combine with configurationName.

  • timeout: Timeout in milliseconds.

  • waitForExit: Whether to wait for process termination. If false, the tool returns immediately after the process starts and ignores timeout.

  • programArguments: Optional program arguments override for this launch only. Missing/null or empty string keeps the existing value; whitespace-only string clears it.

  • workingDirectory: Optional working directory override for this launch only. Missing/null or empty string keeps the existing value; whitespace-only string clears it.

  • envs: Optional environment variable overrides for this launch only. Missing/null keeps existing env unchanged; when provided, values are merged over existing env.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

get_run_configurations

Returns either project run configurations or executable code locations, depending on the input.

Without filePath, this tool lists the project's existing run configurations. The result includes configuration names and, when available, launch details such as program arguments, working directory, environment variables, and supportsDynamicLaunchOverrides.

supportsDynamicLaunchOverrides is the source-of-truth capability flag for one-time launch overrides (programArguments, workingDirectory, envs) and in execute_run_configuration. Only pass those override parameters when this flag is true for the selected configuration.

With filePath, this tool discovers executable entry points (run points) in that file, such as test methods, main methods, or other executable entry points where the IDE shows a Run gutter icon. The result contains filePath and runPoints; use the returned line numbers with execute_run_configuration to run from code.

Parameters:

  • filePath: Optional file path relative to the project root. When provided, returns run points (executable entry points) in the file instead of project-wide run configurations.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

File tools

create_new_file

Creates a new file at the specified path within the project directory. Optionally, writes the provided text into the file.

Parameters:

  • pathInProject: Path where the file should be created relative to the project root.

  • text (optional): Content to write into the new file.

  • overwrite: Whether to overwrite an existing file. If set to false, an exception is thrown in case of a conflict.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

find_files_by_glob

Searches for all files in the project whose relative paths match the specified glob pattern. The search is performed recursively in all subdirectories of the project directory or a specified subdirectory. Use this tool to find files by a glob pattern (for example, **/*.txt).

Parameters:

  • globPattern: Glob pattern to search for. The pattern must be relative to the project root. Example: src/**/*.java.

  • subDirectoryRelativePath (optional): Subdirectory relative to the project to search in.

  • addExcluded: Whether to add excluded/ignored files to the search results. Files can be excluded by the user or by ignore rules.

  • fileCountLimit: Maximum number of files to return.

  • timeout: Timeout in milliseconds.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

find_files_by_name_keyword

Searches for all files in the project whose names contain the specified keyword (case-sensitive). Use this tool to locate files when you know part of the file name.

Parameters:

  • nameKeyword: Substring to search for in the file names.

  • fileCountLimit: Maximum number of files to return.

  • timeout: Timeout in milliseconds.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

get_all_open_file_paths

Returns the paths of all files opened for editing in the active editor or any other open editors, relative to the project root. Use this tool to explore currently open editors.

Parameters:

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

list_directory_tree

Provides a tree representation of the specified directory in the pseudo-graphic format, similar to the tree utility. Use this tool to explore the contents of a directory or the entire project. Prefer this tool over command-line utilities like ls or dir for directory listing.

Parameters:

  • directoryPath: Path relative to the project root.

  • maxDepth: Maximum recursion depth.

  • timeout: Timeout in milliseconds.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

open_file_in_editor

Opens the specified file in the JetBrains IDE editor. Requires a filePath parameter containing the path to the file to open. The file path can be absolute or relative to the project root.

Parameters:

  • filePath: Path relative to the project root.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

Formatting tools

reformat_file

Reformats the specified file in the JetBrains IDE. Use this tool to apply code formatting to a file identified by its path.

Parameters:

  • path: Path relative to the project root.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

Inspection generator MCP Tools

validate_inspection_kts

Validates an inspection.kts script against specification examples. Compiles the inspection and runs it against positive/negative examples. Returns compilation status and detailed verification results.

Positive examples should trigger the inspection (problems expected). Negative examples should NOT trigger the inspection (no problems expected on forbidden lines).

Returns overall success, per-example results, and aggregation statistics.

Parameters:

  • inspectionKtsCode: The inspection.kts script content to compile and validate.

  • pathToSpecification: Path to specification with examples to validate against.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

Inspection KTS MCP tools

generate_inspection_kts_api

Returns the Inspection KTS API documentation for the target language. Provides available classes and functions that can be used when writing inspection.kts files.

Parameters:

  • language: Target language: 'Java' or 'Kotlin'.

  • wrapInTags: If true, wraps the API content in <API> and <api.kt> tags.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

generate_inspection_kts_examples

Returns example inspection.kts templates for the target language to guide code generation. Provides XML-wrapped examples showing how to write inspections using the InspectionKts API.

Parameters:

  • language: Target language: 'Java' or 'Kotlin'.

  • includeAdditionalExamples: If true, includes additional curated examples besides templates.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

generate_psi_tree

Creates a PSI tree for provided Java or Kotlin code and returns it as indented text. Use this tool to understand the PSI structure of code snippets when writing inspections. The output shows element types and their hierarchy, with hints about when node.children() is needed.

Parameters:

  • code: Source code snippet to parse.

  • language: Target language: 'Java' or 'Kotlin'.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

run_inspection_kts

Compiles an inspection.kts script and runs it against a target file. Returns compilation errors if any, or the list of problems found by the inspection. Use this tool to test inspection.kts scripts during development.

Parameters:

  • inspectionKtsCode: The inspection.kts script content to compile and run.

  • contextPath: Relative path of the target file inside project to analyze (e.g., src/my/package/Example.kt).

  • targetFileContent: The content of the target file to analyze. If not provided, the file must exist in the project.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

Monorepo developer kit MCP tools

get_project_status

Check if the project is ready for code analysis operations. Returns indexing and scanning status. Use before heavy operations like lint_files or get_file_problems to avoid timeouts.

Parameters:

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

Read tools

read_file

Reads a file in the project directory or from any project dependency or other project source root. Can read sources inside Jar/Jrt files and decompile Java class files inside Jar/Jrt files or on disk. Returns numbered lines (1-indexed) as text.

Modes:

  • slice

  • lines

  • line_columns

  • offsets

  • indentation

Mode details:

  • slice uses start_line and max_lines.

  • lines uses start_line/end_line (inclusive).

  • line_columns uses start_line/start_column and end_line/end_column (end is exclusive; end_line defaults to start_line).

  • offsets uses start_offset/end_offset (end is exclusive).

  • indentation uses start_line with max_levels/include_*.

max_lines caps the total output in all modes; context_lines applies to range modes (per side).

Parameters:

  • file_path: Path to the file. Supports project-relative paths, paths with '..', absolute paths, archive entries like /path/lib.jar!/pkg/Foo .class, and URLs such as file://, jar://, and jrt://. Any path returned from the other tools can be passed as is (e.g. paths from search_* tools).

  • mode: Read mode: slice, lines, line_columns, offsets, or indentation.

  • start_line: 1-based line number to start reading from.

  • max_lines: Maximum number of lines to return (slice uses as line count; all modes cap output).

  • end_line: 1-based end line for lines/line_columns mode (inclusive for lines; exclusive for line_columns).

  • start_column: 1-based start column for line_columns mode.

  • end_column: 1-based end column for range read (exclusive).

  • start_offset: 0-based start offset for offsets mode (requires end_offset).

  • end_offset: 0-based end offset for offsets mode (exclusive).

  • context_lines: Number of context lines to include around the range (per side).

  • max_levels: Indentation mode: maximum indentation levels to include (0 = only anchor block).

  • include_siblings: Indentation mode: include sibling blocks at the same indentation level.

  • include_header: Indentation mode: include header comments/annotations directly above anchor.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

Refactoring tools

rename_refactoring

Renames a symbol (variable, function, class, etc.) in the specified file. Use this tool to perform rename refactoring operations.

Unlike a simple text search-and-replace, the rename_refactoring tool is a context-aware utility that understands the code's structure. It intelligently updates all references to the specified symbol throughout the project, ensuring code integrity and preventing broken references. It is always the preferred method for renaming programmatic symbols.

The tool returns a success message if the rename operation was successful, or an error message if the file or symbol cannot be found, or if the rename operation fails.

Parameters:

  • pathInProject: Path relative to the project root.

  • symbolName: Name of the symbol to rename.

  • newName: New name for the symbol.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

Run notebook tools

runNotebookCell

Execute one or all cells of a Jupyter notebook.

Examples:

  • {"file_path": "/abs/path/demo.ipynb", "cell_id": "13c5cec416369e19"}

  • {"file_path": "/abs/path/demo.ipynb"}

Parameters:

  • file_path: Absolute path to the .ipynb notebook.

  • cell_id: Optional Jupyter cell ID. If omitted, all cells are executed.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

Search tools

search_file

Searches for files by glob pattern within the project. Use this tool when you need to match file paths using glob syntax.

Glob patterns are relative to the project root.

Examples:

  • "**/*.kt"

  • "src/**/Foo*.java"

  • "build.gradle.kts"

Patterns without '/' are treated as "**/pattern". paths are optional additional glob filters relative to the project root.

Parameters:

  • q: Glob pattern to search for.

  • paths: Optional list of project-relative glob patterns to filter results. Supports ! excludes. Trailing / expands to **. Patterns without / are treated as **/pattern. Empty strings are ignored.

  • includeExcluded: Whether to include excluded/ignored files in results.

  • limit: Maximum number of results to return.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

search_regex

Searches for regex matches within project files. Use this tool when you need regex search with snippet results. Results include match coordinates when available (1-based line/column, 0-based offsets).

Paths are glob patterns relative to the project root.

Examples:

  • ["src/**", "!**/test/**"]

  • ["**/*.kt"]

  • ["foo/"]

Parameters:

  • q: Regex pattern to search for.

  • paths: Optional list of project-relative glob patterns to filter results. Supports ! excludes. Trailing / expands to **. Patterns without / are treated as **/pattern. Empty strings are ignored.

  • limit: Maximum number of results to return.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

search_symbol

Searches for symbols (classes, methods, fields). Use this tool for semantic lookup by identifier fragments. Results include match coordinates when available (1-based line/column, 0-based offsets).

Paths are glob patterns relative to the project root.

By default, this searches project symbols only. If you don't find a suitable result, try again with include_external=true to search SDK and library symbols too.

Parameters:

  • q: Symbol query text.

  • paths: Optional list of project-relative glob patterns to filter results. Supports ! excludes. Trailing / expands to **. Patterns without / are treated as **/pattern. Empty strings are ignored.

  • include_external: Whether to include SDK and library symbols. Disabled by default; if nothing suitable is found, try again with include_external=true.

  • limit: Maximum number of results to return.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

search_text

Searches for a text substring within project files. Use this tool for fast text search with snippet results. Results include match coordinates when available (1-based line/column, 0-based offsets).

Paths are glob patterns relative to the project root.

Examples:

  • ["src/**", "!**/test/**"]

  • ["**/*.kt"]

  • ["foo/"]

Parameters:

  • q: Text to search for.

  • paths: Optional list of project-relative glob patterns to filter results. Supports ! excludes. Trailing / expands to **. Patterns without / are treated as **/pattern. Empty strings are ignored.

  • limit: Maximum number of results to return.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

Terminal tools

execute_terminal_command

Executes a specified shell command in the IDE's integrated terminal. Use this tool to run terminal commands within the IDE environment.

Important features and limitations:

  • Checks if a process is running before collecting output.

  • Limits output to 2000 lines (truncates any excess).

  • Times out after the specified timeout, with a notification.

  • Requires user confirmation unless Brave Mode is enabled in the settings.

Returns possible responses:

  • Terminal output (truncated if over 2000 lines).

  • Output with an interruption notice if the command times out.

  • Error messages for various failure cases.

Parameters:

  • command: Shell command to execute.

  • executeInShell: Whether to execute the command in the user's default shell (bash, zsh, etc.). Useful if the command is a shell script or if it is important to preserve the real environment of the user's terminal. If set to false, the command will be started as a process.

  • reuseExistingTerminalWindow: Whether to reuse an existing terminal window to avoid creating multiple terminals.

  • timeout: Timeout in milliseconds.

  • maxLinesCount: Maximum number of lines to return.

  • truncateMode: How to truncate the text: from the start, in the middle, at the end, or do not truncate at all.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

Text tools

get_file_text_by_path

Retrieves the text content of a file using its path relative to the project root. Use this tool to read file contents when you have the file's project-relative path.

Parameters:

  • pathInProject: Path where the file should be created relative to the project root.

  • truncateMode: How to truncate the text: from the start, in the middle, at the end, or do not truncate at all.

  • maxLinesCount: Maximum number of lines to return.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

replace_text_in_file

Replaces text in a file with flexible options for find-and-replace operations. Use this tool to make targeted changes without replacing the entire file content. This is the most efficient tool for file modifications when you know the exact text to replace.

Returns one of the following responses:

  • ok – replacement was successful.

  • project dir not found – the project directory cannot be determined.

  • file not found – the specified file does not exist.

  • could not get document – the file content cannot be accessed.

  • no occurrences found – the text to replace was not found in the file.

Parameters:

  • pathInProject: Path to target file relative to the project root.

  • oldText: Text to be replaced.

  • newText: Replacement text.

  • replaceAll: Whether to replace all occurrences.

  • caseSensitive: Whether the search is case-sensitive.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

search_in_files_by_regex

Searches for a regex pattern within all files in the project using IntelliJ's search engine. Prefer this tool over reading files with command-line tools because it is much faster.

Occurrences in the results are surrounded with || characters. For example: some text ||substring|| text.

Parameters:

  • regexPattern: Regex pattern to search for.

  • directoryToSearch: Directory to search in, relative to project root. If not specified, searches the entire project.

  • fileMask: File mask to search for. If not specified, searches for all files. Example: *.java.

  • caseSensitive: Whether the search is case-sensitive.

  • maxUsageCount: Maximum number of entries to return.

  • timeout: Timeout in milliseconds.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

search_in_files_by_text

Searches for a text substring within all files in the project using IntelliJ's search engine. Prefer this tool over reading files with command-line tools because it is much faster.

Occurrences in the results are surrounded with || characters. For example some text ||substring|| text.

Parameters:

  • searchText: Text substring to search for.

  • directoryToSearch: Directory to search in, relative to project root. If not specified, searches the entire project.

  • fileMask: File mask to search for. If not specified, searches for all files. Example: *.java.

  • caseSensitive: Whether the search is case-sensitive.

  • maxUsageCount: Maximum number of entries to return.

  • timeout: Timeout in milliseconds.

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

VCS tools

get_repositories

Retrieves the list of VCS roots in the project. Use this tool to identify all repositories in a multi-repository project.

Parameters:

  • projectPath: The project path. Always provide this value if known to reduce ambiguous calls. If only the current working directory is known, you can use it as the project path.

13 May 2026