name: searching_dependency_sources
description: >-
Explores and searches source code of all external library dependencies, plugins, and Gradle internals
via indexed symbol, full-text, and glob search; STRONGLY PREFERRED for understanding APIs, finding class/method definitions, and reading implementation logic.
Do NOT use for project source code (use grep), Gradle documentation (use researching_gradle_internals), or Maven Central discovery (use managing_gradle_dependencies).
license: Apache-2.0
metadata:
author: https://github.com/rnett/gradle-mcp
version: "1.4"
Authoritative Dependency Source & API Exploration
Explores, navigates, and analyzes the internal logic, APIs, and symbol implementations of external libraries and plugins with absolute precision using high-performance, indexed searching.
Constitution
- ALWAYS use
search_dependency_sourcesas the primary discovery tool for external library and plugin code. - ALWAYS prefer reading source code over interactive REPL exploration for understanding unfamiliar library APIs.
- ALWAYS provide absolute paths for
projectRoot. - ALWAYS use the
dependencyparameter to target a single library (e.g.,dependency="org.mongodb:mongodb-driver-sync") when the target is known. This is significantly faster and more focused than searching the entire project graph. Note that whendependencyis used insearch_dependency_sourcesorread_dependency_sources, thepathand all results are relative to the library root (omitting the<group>/<artifact>...prefix). - NEVER use
gradleSource: truein this skill; useresearching_gradle_internalsfor Gradle's internal implementation. - NEVER use generic shell tools like
greporfindto locate dependency sources; they reside in remote caches whose paths are not predictable in advance. - MAY use shell tools like
rgorast-grepto operate on a sources root path explicitly returned byread_dependency_sourcesorsearch_dependency_sourcesin theSources root: <path>header line. Dependency directories inside the sources root are symlinks; always pass--followtorg(e.g.,rg --follow <pattern> <sources-root>). - ALWAYS escape Lucene special characters (
:,=,+,-,*,/) inFULL_TEXTsearches using a backslash (e.g.,\:) or double quotes. - ALWAYS use
read_dependency_sourcesonce a specific file path has been identified via search. - ALWAYS use
fresh: trueif a search returns aSearchResponsewith anerrorindicating a missing index; the tool will return an error message rather than throwing an exception if the index is not found. - BE AWARE that indexing and extraction failures (e.g.,
ZipException) are still propagated and will cause the tool to fail with a descriptive error. - NOTE that the
dependencyfilter targets ONLY the specific library version matched, NOT its transitive dependencies.
Directives
- Identify Search Mode Authoritatively:
- DECLARATION: Best for classes, methods, or interfaces. Matches against the simple name (tokenized for CamelCase) and the full path (exact literal). All declaration searches are case-sensitive. Do NOT include keywords like
class,interface, orfun. Supports exact names, exact FQNs, glob wildcards (e.g.,*,**), and regular expressions. Partial package paths require wildcards (e.g., use*.MyClassto findcom.example.MyClass). You can target specific fields usingname:(discovery) orfqn:(precision) prefixes. - FULL_TEXT: Best for literal strings, constants, and complex code patterns using Lucene. Case-insensitive.
- GLOB: Best for finding specific files (XML, properties, etc.) by name or extension. Case-insensitive.
- DECLARATION: Best for classes, methods, or interfaces. Matches against the simple name (tokenized for CamelCase) and the full path (exact literal). All declaration searches are case-sensitive. Do NOT include keywords like
- Invoke Precisely: ALWAYS set
searchTypeexplicitly if the intent is not a general full-text search. This improves result accuracy and reduces noise. - Scope Surgically: Use
projectPath,configurationPath, orsourceSetPathto narrow the search and improve performance if the target library's context is known. To search a plugin, useconfigurationPath=":buildscript:classpath". - Target Libraries Directly: Use the
dependencyparameter to search or read from a single library. It supportsgroup:name:version:variant,group:name:version,group:name, or justgroup. This bypasses project-level index merging and provides instantaneous results from the global extracted source cache. Note that results will be relative to the targeted library root. - Troubleshoot Targeted Searches: If a targeted search using the
dependencyparameter fails or returns no matches, useinspect_dependenciesfirst to verify the exact coordinates (group, name, version, variant) of the dependency as resolved by Gradle. - Refresh Indices: Use
fresh: trueif project dependencies have recently changed to ensure the index is up-to-date. - Use Returned Sources Root: Every response from
read_dependency_sourcesandsearch_dependency_sourcesincludes aSources root: <absolute-path>header. Use this path withrg,ast-grep, or other shell tools for operations not covered by the MCP tools (e.g., regex-heavy searches). Because dependency directories are symlinks, always pass--followtorg:rg --follow <pattern> <sources-root>. - Explore Packages Authoritatively: Use
read_dependency_sourceswith a dot-separated package path (e.g.,org.gradle.api) to list its direct symbols and sub-packages. This is backed by the symbol index and is more reliable than directory-based exploration for Kotlin projects. - Analyze Implementation: Use
read_dependency_sourcesto retrieve the implementation logic. If the file is large, usepaginationto read specific sections. You can target plugins by passingconfigurationPath=":buildscript:classpath". - Trace Symbols Authoritatively: When encountering an unknown symbol, use
DECLARATIONsearch to jump directly to its definition in the library. This is the only reliable way to understand exact behavior and available methods.
When to Use
- API & Symbol Discovery: When you need to find the implementation, signature, or documentation of a class, interface, or method imported from a library.
- Library Usage Research: When understanding how to use a library's API by reading its internal implementation or looking for usage patterns in its source.
- Internal Logic Auditing: When researching how a dependency handles specific operations, edge cases, or performance-critical logic.
- Resource File Location: When searching for configuration files (XML, JSON, properties), specific named files (e.g.,
build.gradle), or metadata (AndroidManifest.xml) packaged within library jars. - Constant & Literal Research: When searching for specific constant values, error strings, or literal keys within external code.
Workflows
1. Tracing a Symbol from Project Code
- Identify the symbol name (e.g.,
JsonConfiguration) or fully qualified name from an import. - Call
search_dependency_sources(query="<SymbolName>", searchType="DECLARATION"). - Identify the correct file path from the results.
- Call
read_dependency_sources(path="<path>")to analyze the implementation.
2. Discovering API Usage through Source
- Search for a known entry point (e.g., a constructor or main class) using
DECLARATIONorFULL_TEXT. - Once the file is found, use
read_dependency_sourcesto read its source. - Look for internal calls, helper methods, or factory patterns to understand the library's preferred usage.
3. Searching for Constants or Error Codes
- Identify the constant name or a snippet of an error message.
- Call
search_dependency_sources(query="\"<text>\"")(defaults toFULL_TEXT). - Review matches to find where the value is defined or used.
Targeted Search for a Single Library
- Identify the dependency coordinates (e.g., from
inspect_dependenciesor project files). - Call
search_dependency_sources(query="<query>", dependency="<group:artifact>"). - The results will be scoped ONLY to that library, ensuring maximum speed and relevance.
Path Relativity and Targeted Searching
When using the dependency parameter, all file paths and search results are relative to the library's root, omitting the <group>/<artifact>... prefix.
- Merged Scope (No Filter):
path = "org/mongodb/mongodb-driver-sync/4.11.1-sources/org/mongodb/client/MongoClient.kt" - Targeted Scope (
dependency="org.mongodb:mongodb-driver-sync"):path = "org/mongodb/client/MongoClient.kt"
This approach is significantly faster and simplifies path handling when you are focused on a specific library.
Examples
Search for a specific class definition within a targeted library
{
"query": "MongoClient",
"searchType": "DECLARATION",
"dependency": "org.mongodb:mongodb-driver-sync"
}
// Reasoning: Using the 'dependency' parameter to target only the 'mongodb-driver-sync' library for a fast, focused search.
Read sources from a specific dependency
{
"dependency": "org.jetbrains.kotlinx:kotlinx-coroutines-core",
"path": "kotlinx/coroutines/Job.kt"
}
// Reasoning: Reading 'Job.kt' directly from the targeted 'kotlinx-coroutines-core' library. Note the 'group/artifact...' prefix is omitted.
Search for a specific class definition
{
"query": "JsonConfiguration",
"searchType": "DECLARATION"
}
// Reasoning: Using DECLARATION search to find a class named 'JsonConfiguration' across both name and FQN fields.
Search with field-specific precision
{
"query": "fqn:kotlinx.serialization.json.*",
"searchType": "DECLARATION"
}
// Reasoning: Using the 'fqn:' prefix with a wildcard to find all declarations within a specific package literal.
Search with name-specific discovery (CamelCase)
{
"query": "name:Configuration",
"searchType": "DECLARATION"
}
// Reasoning: Using the 'name:' prefix to find classes like 'JsonConfiguration' via CamelCase tokenization.
Trace a method signature using wildcards
{
"query": "encodeTo*",
"searchType": "DECLARATION"
}
// Reasoning: Finding all definitions starting with 'encodeTo' across both name and FQN fields.
Use regular expressions for complex matching
{
"query": "fqn:/.*\\.internal\\..*/",
"searchType": "DECLARATION"
}
// Reasoning: Using a regular expression on the 'fqn' field to find all internal declarations.
Search for a constant value assignment
{
"query": "DEFAULT_TIMEOUT_MS \\: 5000"
}
// Reasoning: Using FULL_TEXT (default) with escaped colon to find a specific constant assignment.
Locate a specific file by its exact name
{
"query": "**/AndroidManifest.xml",
"searchType": "GLOB"
}
// Reasoning: Using GLOB search to find a specific file by name across the dependency graph.
Read a specific dependency source file
{
"path": "kotlinx/serialization/json/Json.kt"
}
// Reasoning: Reading the implementation of a known class path identified from previous search results.
Explore a package via its FQN
{
"path": "org.gradle.api"
}
// Reasoning: Listing the direct symbols and sub-packages of 'org.gradle.api' using index-backed exploration.
Resources
- Lucene Query Syntax: Refer to the tool description for
search_dependency_sourcesfor details on complex queries and escaping. - Troubleshooting Targeted Searches: If
dependencyfilter fails, runinspect_dependenciesto confirm the exact coordinates.