@colbymchenry/codegraph 0.8.0 → 0.9.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +23 -7
- package/npm-shim.js +43 -0
- package/package.json +13 -51
- package/LICENSE +0 -21
- package/dist/bin/codegraph.d.ts +0 -21
- package/dist/bin/codegraph.d.ts.map +0 -1
- package/dist/bin/codegraph.js +0 -1257
- package/dist/bin/codegraph.js.map +0 -1
- package/dist/bin/node-version-check.d.ts +0 -20
- package/dist/bin/node-version-check.d.ts.map +0 -1
- package/dist/bin/node-version-check.js +0 -42
- package/dist/bin/node-version-check.js.map +0 -1
- package/dist/bin/uninstall.d.ts +0 -14
- package/dist/bin/uninstall.d.ts.map +0 -1
- package/dist/bin/uninstall.js +0 -36
- package/dist/bin/uninstall.js.map +0 -1
- package/dist/config.d.ts +0 -51
- package/dist/config.d.ts.map +0 -1
- package/dist/config.js +0 -321
- package/dist/config.js.map +0 -1
- package/dist/context/formatter.d.ts +0 -30
- package/dist/context/formatter.d.ts.map +0 -1
- package/dist/context/formatter.js +0 -244
- package/dist/context/formatter.js.map +0 -1
- package/dist/context/index.d.ts +0 -97
- package/dist/context/index.d.ts.map +0 -1
- package/dist/context/index.js +0 -1050
- package/dist/context/index.js.map +0 -1
- package/dist/db/index.d.ts +0 -72
- package/dist/db/index.d.ts.map +0 -1
- package/dist/db/index.js +0 -200
- package/dist/db/index.js.map +0 -1
- package/dist/db/migrations.d.ts +0 -44
- package/dist/db/migrations.d.ts.map +0 -1
- package/dist/db/migrations.js +0 -131
- package/dist/db/migrations.js.map +0 -1
- package/dist/db/queries.d.ts +0 -253
- package/dist/db/queries.d.ts.map +0 -1
- package/dist/db/queries.js +0 -1207
- package/dist/db/queries.js.map +0 -1
- package/dist/db/schema.sql +0 -151
- package/dist/db/sqlite-adapter.d.ts +0 -52
- package/dist/db/sqlite-adapter.d.ts.map +0 -1
- package/dist/db/sqlite-adapter.js +0 -237
- package/dist/db/sqlite-adapter.js.map +0 -1
- package/dist/directory.d.ts +0 -57
- package/dist/directory.d.ts.map +0 -1
- package/dist/directory.js +0 -264
- package/dist/directory.js.map +0 -1
- package/dist/errors.d.ts +0 -136
- package/dist/errors.d.ts.map +0 -1
- package/dist/errors.js +0 -219
- package/dist/errors.js.map +0 -1
- package/dist/extraction/dfm-extractor.d.ts +0 -31
- package/dist/extraction/dfm-extractor.d.ts.map +0 -1
- package/dist/extraction/dfm-extractor.js +0 -151
- package/dist/extraction/dfm-extractor.js.map +0 -1
- package/dist/extraction/grammars.d.ts +0 -78
- package/dist/extraction/grammars.d.ts.map +0 -1
- package/dist/extraction/grammars.js +0 -322
- package/dist/extraction/grammars.js.map +0 -1
- package/dist/extraction/index.d.ts +0 -130
- package/dist/extraction/index.d.ts.map +0 -1
- package/dist/extraction/index.js +0 -1305
- package/dist/extraction/index.js.map +0 -1
- package/dist/extraction/languages/c-cpp.d.ts +0 -4
- package/dist/extraction/languages/c-cpp.d.ts.map +0 -1
- package/dist/extraction/languages/c-cpp.js +0 -126
- package/dist/extraction/languages/c-cpp.js.map +0 -1
- package/dist/extraction/languages/csharp.d.ts +0 -3
- package/dist/extraction/languages/csharp.d.ts.map +0 -1
- package/dist/extraction/languages/csharp.js +0 -72
- package/dist/extraction/languages/csharp.js.map +0 -1
- package/dist/extraction/languages/dart.d.ts +0 -3
- package/dist/extraction/languages/dart.d.ts.map +0 -1
- package/dist/extraction/languages/dart.js +0 -192
- package/dist/extraction/languages/dart.js.map +0 -1
- package/dist/extraction/languages/go.d.ts +0 -3
- package/dist/extraction/languages/go.d.ts.map +0 -1
- package/dist/extraction/languages/go.js +0 -58
- package/dist/extraction/languages/go.js.map +0 -1
- package/dist/extraction/languages/index.d.ts +0 -10
- package/dist/extraction/languages/index.d.ts.map +0 -1
- package/dist/extraction/languages/index.js +0 -45
- package/dist/extraction/languages/index.js.map +0 -1
- package/dist/extraction/languages/java.d.ts +0 -3
- package/dist/extraction/languages/java.d.ts.map +0 -1
- package/dist/extraction/languages/java.js +0 -64
- package/dist/extraction/languages/java.js.map +0 -1
- package/dist/extraction/languages/javascript.d.ts +0 -3
- package/dist/extraction/languages/javascript.d.ts.map +0 -1
- package/dist/extraction/languages/javascript.js +0 -90
- package/dist/extraction/languages/javascript.js.map +0 -1
- package/dist/extraction/languages/kotlin.d.ts +0 -3
- package/dist/extraction/languages/kotlin.d.ts.map +0 -1
- package/dist/extraction/languages/kotlin.js +0 -253
- package/dist/extraction/languages/kotlin.js.map +0 -1
- package/dist/extraction/languages/pascal.d.ts +0 -3
- package/dist/extraction/languages/pascal.d.ts.map +0 -1
- package/dist/extraction/languages/pascal.js +0 -66
- package/dist/extraction/languages/pascal.js.map +0 -1
- package/dist/extraction/languages/php.d.ts +0 -3
- package/dist/extraction/languages/php.d.ts.map +0 -1
- package/dist/extraction/languages/php.js +0 -107
- package/dist/extraction/languages/php.js.map +0 -1
- package/dist/extraction/languages/python.d.ts +0 -3
- package/dist/extraction/languages/python.d.ts.map +0 -1
- package/dist/extraction/languages/python.js +0 -56
- package/dist/extraction/languages/python.js.map +0 -1
- package/dist/extraction/languages/ruby.d.ts +0 -3
- package/dist/extraction/languages/ruby.d.ts.map +0 -1
- package/dist/extraction/languages/ruby.js +0 -114
- package/dist/extraction/languages/ruby.js.map +0 -1
- package/dist/extraction/languages/rust.d.ts +0 -3
- package/dist/extraction/languages/rust.d.ts.map +0 -1
- package/dist/extraction/languages/rust.js +0 -109
- package/dist/extraction/languages/rust.js.map +0 -1
- package/dist/extraction/languages/scala.d.ts +0 -3
- package/dist/extraction/languages/scala.d.ts.map +0 -1
- package/dist/extraction/languages/scala.js +0 -139
- package/dist/extraction/languages/scala.js.map +0 -1
- package/dist/extraction/languages/swift.d.ts +0 -3
- package/dist/extraction/languages/swift.d.ts.map +0 -1
- package/dist/extraction/languages/swift.js +0 -91
- package/dist/extraction/languages/swift.js.map +0 -1
- package/dist/extraction/languages/typescript.d.ts +0 -3
- package/dist/extraction/languages/typescript.d.ts.map +0 -1
- package/dist/extraction/languages/typescript.js +0 -129
- package/dist/extraction/languages/typescript.js.map +0 -1
- package/dist/extraction/liquid-extractor.d.ts +0 -52
- package/dist/extraction/liquid-extractor.d.ts.map +0 -1
- package/dist/extraction/liquid-extractor.js +0 -313
- package/dist/extraction/liquid-extractor.js.map +0 -1
- package/dist/extraction/parse-worker.d.ts +0 -8
- package/dist/extraction/parse-worker.d.ts.map +0 -1
- package/dist/extraction/parse-worker.js +0 -94
- package/dist/extraction/parse-worker.js.map +0 -1
- package/dist/extraction/svelte-extractor.d.ts +0 -56
- package/dist/extraction/svelte-extractor.d.ts.map +0 -1
- package/dist/extraction/svelte-extractor.js +0 -272
- package/dist/extraction/svelte-extractor.js.map +0 -1
- package/dist/extraction/tree-sitter-helpers.d.ts +0 -28
- package/dist/extraction/tree-sitter-helpers.d.ts.map +0 -1
- package/dist/extraction/tree-sitter-helpers.js +0 -103
- package/dist/extraction/tree-sitter-helpers.js.map +0 -1
- package/dist/extraction/tree-sitter-types.d.ts +0 -179
- package/dist/extraction/tree-sitter-types.d.ts.map +0 -1
- package/dist/extraction/tree-sitter-types.js +0 -10
- package/dist/extraction/tree-sitter-types.js.map +0 -1
- package/dist/extraction/tree-sitter.d.ts +0 -233
- package/dist/extraction/tree-sitter.d.ts.map +0 -1
- package/dist/extraction/tree-sitter.js +0 -2393
- package/dist/extraction/tree-sitter.js.map +0 -1
- package/dist/extraction/vue-extractor.d.ts +0 -36
- package/dist/extraction/vue-extractor.d.ts.map +0 -1
- package/dist/extraction/vue-extractor.js +0 -163
- package/dist/extraction/vue-extractor.js.map +0 -1
- package/dist/extraction/wasm/tree-sitter-pascal.wasm +0 -0
- package/dist/extraction/wasm/tree-sitter-scala.wasm +0 -0
- package/dist/graph/index.d.ts +0 -8
- package/dist/graph/index.d.ts.map +0 -1
- package/dist/graph/index.js +0 -13
- package/dist/graph/index.js.map +0 -1
- package/dist/graph/queries.d.ts +0 -106
- package/dist/graph/queries.d.ts.map +0 -1
- package/dist/graph/queries.js +0 -366
- package/dist/graph/queries.js.map +0 -1
- package/dist/graph/traversal.d.ts +0 -127
- package/dist/graph/traversal.d.ts.map +0 -1
- package/dist/graph/traversal.js +0 -493
- package/dist/graph/traversal.js.map +0 -1
- package/dist/index.d.ts +0 -447
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -825
- package/dist/index.js.map +0 -1
- package/dist/installer/claude-md-template.d.ts +0 -14
- package/dist/installer/claude-md-template.d.ts.map +0 -1
- package/dist/installer/claude-md-template.js +0 -21
- package/dist/installer/claude-md-template.js.map +0 -1
- package/dist/installer/config-writer.d.ts +0 -29
- package/dist/installer/config-writer.d.ts.map +0 -1
- package/dist/installer/config-writer.js +0 -111
- package/dist/installer/config-writer.js.map +0 -1
- package/dist/installer/index.d.ts +0 -65
- package/dist/installer/index.d.ts.map +0 -1
- package/dist/installer/index.js +0 -406
- package/dist/installer/index.js.map +0 -1
- package/dist/installer/instructions-template.d.ts +0 -28
- package/dist/installer/instructions-template.d.ts.map +0 -1
- package/dist/installer/instructions-template.js +0 -64
- package/dist/installer/instructions-template.js.map +0 -1
- package/dist/installer/targets/claude.d.ts +0 -31
- package/dist/installer/targets/claude.d.ts.map +0 -1
- package/dist/installer/targets/claude.js +0 -308
- package/dist/installer/targets/claude.js.map +0 -1
- package/dist/installer/targets/codex.d.ts +0 -18
- package/dist/installer/targets/codex.d.ts.map +0 -1
- package/dist/installer/targets/codex.js +0 -185
- package/dist/installer/targets/codex.js.map +0 -1
- package/dist/installer/targets/cursor.d.ts +0 -35
- package/dist/installer/targets/cursor.d.ts.map +0 -1
- package/dist/installer/targets/cursor.js +0 -229
- package/dist/installer/targets/cursor.js.map +0 -1
- package/dist/installer/targets/opencode.d.ts +0 -30
- package/dist/installer/targets/opencode.d.ts.map +0 -1
- package/dist/installer/targets/opencode.js +0 -235
- package/dist/installer/targets/opencode.js.map +0 -1
- package/dist/installer/targets/registry.d.ts +0 -35
- package/dist/installer/targets/registry.d.ts.map +0 -1
- package/dist/installer/targets/registry.js +0 -83
- package/dist/installer/targets/registry.js.map +0 -1
- package/dist/installer/targets/shared.d.ts +0 -77
- package/dist/installer/targets/shared.d.ts.map +0 -1
- package/dist/installer/targets/shared.js +0 -246
- package/dist/installer/targets/shared.js.map +0 -1
- package/dist/installer/targets/toml.d.ts +0 -52
- package/dist/installer/targets/toml.d.ts.map +0 -1
- package/dist/installer/targets/toml.js +0 -147
- package/dist/installer/targets/toml.js.map +0 -1
- package/dist/installer/targets/types.d.ts +0 -116
- package/dist/installer/targets/types.d.ts.map +0 -1
- package/dist/installer/targets/types.js +0 -16
- package/dist/installer/targets/types.js.map +0 -1
- package/dist/mcp/index.d.ts +0 -94
- package/dist/mcp/index.d.ts.map +0 -1
- package/dist/mcp/index.js +0 -453
- package/dist/mcp/index.js.map +0 -1
- package/dist/mcp/server-instructions.d.ts +0 -19
- package/dist/mcp/server-instructions.d.ts.map +0 -1
- package/dist/mcp/server-instructions.js +0 -71
- package/dist/mcp/server-instructions.js.map +0 -1
- package/dist/mcp/tools.d.ts +0 -257
- package/dist/mcp/tools.d.ts.map +0 -1
- package/dist/mcp/tools.js +0 -1633
- package/dist/mcp/tools.js.map +0 -1
- package/dist/mcp/transport.d.ts +0 -106
- package/dist/mcp/transport.d.ts.map +0 -1
- package/dist/mcp/transport.js +0 -233
- package/dist/mcp/transport.js.map +0 -1
- package/dist/resolution/frameworks/cargo-workspace.d.ts +0 -18
- package/dist/resolution/frameworks/cargo-workspace.d.ts.map +0 -1
- package/dist/resolution/frameworks/cargo-workspace.js +0 -225
- package/dist/resolution/frameworks/cargo-workspace.js.map +0 -1
- package/dist/resolution/frameworks/csharp.d.ts +0 -8
- package/dist/resolution/frameworks/csharp.d.ts.map +0 -1
- package/dist/resolution/frameworks/csharp.js +0 -213
- package/dist/resolution/frameworks/csharp.js.map +0 -1
- package/dist/resolution/frameworks/express.d.ts +0 -8
- package/dist/resolution/frameworks/express.d.ts.map +0 -1
- package/dist/resolution/frameworks/express.js +0 -225
- package/dist/resolution/frameworks/express.js.map +0 -1
- package/dist/resolution/frameworks/go.d.ts +0 -8
- package/dist/resolution/frameworks/go.d.ts.map +0 -1
- package/dist/resolution/frameworks/go.js +0 -158
- package/dist/resolution/frameworks/go.js.map +0 -1
- package/dist/resolution/frameworks/index.d.ts +0 -42
- package/dist/resolution/frameworks/index.d.ts.map +0 -1
- package/dist/resolution/frameworks/index.js +0 -133
- package/dist/resolution/frameworks/index.js.map +0 -1
- package/dist/resolution/frameworks/java.d.ts +0 -8
- package/dist/resolution/frameworks/java.d.ts.map +0 -1
- package/dist/resolution/frameworks/java.js +0 -177
- package/dist/resolution/frameworks/java.js.map +0 -1
- package/dist/resolution/frameworks/laravel.d.ts +0 -13
- package/dist/resolution/frameworks/laravel.d.ts.map +0 -1
- package/dist/resolution/frameworks/laravel.js +0 -248
- package/dist/resolution/frameworks/laravel.js.map +0 -1
- package/dist/resolution/frameworks/nestjs.d.ts +0 -26
- package/dist/resolution/frameworks/nestjs.d.ts.map +0 -1
- package/dist/resolution/frameworks/nestjs.js +0 -374
- package/dist/resolution/frameworks/nestjs.js.map +0 -1
- package/dist/resolution/frameworks/python.d.ts +0 -10
- package/dist/resolution/frameworks/python.d.ts.map +0 -1
- package/dist/resolution/frameworks/python.js +0 -278
- package/dist/resolution/frameworks/python.js.map +0 -1
- package/dist/resolution/frameworks/react.d.ts +0 -8
- package/dist/resolution/frameworks/react.d.ts.map +0 -1
- package/dist/resolution/frameworks/react.js +0 -272
- package/dist/resolution/frameworks/react.js.map +0 -1
- package/dist/resolution/frameworks/ruby.d.ts +0 -8
- package/dist/resolution/frameworks/ruby.d.ts.map +0 -1
- package/dist/resolution/frameworks/ruby.js +0 -198
- package/dist/resolution/frameworks/ruby.js.map +0 -1
- package/dist/resolution/frameworks/rust.d.ts +0 -8
- package/dist/resolution/frameworks/rust.d.ts.map +0 -1
- package/dist/resolution/frameworks/rust.js +0 -207
- package/dist/resolution/frameworks/rust.js.map +0 -1
- package/dist/resolution/frameworks/svelte.d.ts +0 -9
- package/dist/resolution/frameworks/svelte.d.ts.map +0 -1
- package/dist/resolution/frameworks/svelte.js +0 -249
- package/dist/resolution/frameworks/svelte.js.map +0 -1
- package/dist/resolution/frameworks/swift.d.ts +0 -10
- package/dist/resolution/frameworks/swift.d.ts.map +0 -1
- package/dist/resolution/frameworks/swift.js +0 -376
- package/dist/resolution/frameworks/swift.js.map +0 -1
- package/dist/resolution/frameworks/vue.d.ts +0 -9
- package/dist/resolution/frameworks/vue.d.ts.map +0 -1
- package/dist/resolution/frameworks/vue.js +0 -306
- package/dist/resolution/frameworks/vue.js.map +0 -1
- package/dist/resolution/import-resolver.d.ts +0 -40
- package/dist/resolution/import-resolver.d.ts.map +0 -1
- package/dist/resolution/import-resolver.js +0 -663
- package/dist/resolution/import-resolver.js.map +0 -1
- package/dist/resolution/index.d.ts +0 -106
- package/dist/resolution/index.d.ts.map +0 -1
- package/dist/resolution/index.js +0 -709
- package/dist/resolution/index.js.map +0 -1
- package/dist/resolution/name-matcher.d.ts +0 -32
- package/dist/resolution/name-matcher.d.ts.map +0 -1
- package/dist/resolution/name-matcher.js +0 -384
- package/dist/resolution/name-matcher.js.map +0 -1
- package/dist/resolution/path-aliases.d.ts +0 -68
- package/dist/resolution/path-aliases.d.ts.map +0 -1
- package/dist/resolution/path-aliases.js +0 -238
- package/dist/resolution/path-aliases.js.map +0 -1
- package/dist/resolution/strip-comments.d.ts +0 -27
- package/dist/resolution/strip-comments.d.ts.map +0 -1
- package/dist/resolution/strip-comments.js +0 -441
- package/dist/resolution/strip-comments.js.map +0 -1
- package/dist/resolution/types.d.ts +0 -172
- package/dist/resolution/types.d.ts.map +0 -1
- package/dist/resolution/types.js +0 -8
- package/dist/resolution/types.js.map +0 -1
- package/dist/search/query-parser.d.ts +0 -57
- package/dist/search/query-parser.d.ts.map +0 -1
- package/dist/search/query-parser.js +0 -177
- package/dist/search/query-parser.js.map +0 -1
- package/dist/search/query-utils.d.ts +0 -53
- package/dist/search/query-utils.d.ts.map +0 -1
- package/dist/search/query-utils.js +0 -350
- package/dist/search/query-utils.js.map +0 -1
- package/dist/sync/git-hooks.d.ts +0 -45
- package/dist/sync/git-hooks.d.ts.map +0 -1
- package/dist/sync/git-hooks.js +0 -223
- package/dist/sync/git-hooks.js.map +0 -1
- package/dist/sync/index.d.ts +0 -17
- package/dist/sync/index.d.ts.map +0 -1
- package/dist/sync/index.js +0 -28
- package/dist/sync/index.js.map +0 -1
- package/dist/sync/watch-policy.d.ts +0 -48
- package/dist/sync/watch-policy.d.ts.map +0 -1
- package/dist/sync/watch-policy.js +0 -124
- package/dist/sync/watch-policy.js.map +0 -1
- package/dist/sync/watcher.d.ts +0 -81
- package/dist/sync/watcher.d.ts.map +0 -1
- package/dist/sync/watcher.js +0 -194
- package/dist/sync/watcher.js.map +0 -1
- package/dist/types.d.ts +0 -423
- package/dist/types.d.ts.map +0 -1
- package/dist/types.js +0 -256
- package/dist/types.js.map +0 -1
- package/dist/ui/glyphs.d.ts +0 -42
- package/dist/ui/glyphs.d.ts.map +0 -1
- package/dist/ui/glyphs.js +0 -78
- package/dist/ui/glyphs.js.map +0 -1
- package/dist/ui/shimmer-progress.d.ts +0 -11
- package/dist/ui/shimmer-progress.d.ts.map +0 -1
- package/dist/ui/shimmer-progress.js +0 -90
- package/dist/ui/shimmer-progress.js.map +0 -1
- package/dist/ui/shimmer-worker.d.ts +0 -2
- package/dist/ui/shimmer-worker.d.ts.map +0 -1
- package/dist/ui/shimmer-worker.js +0 -118
- package/dist/ui/shimmer-worker.js.map +0 -1
- package/dist/ui/types.d.ts +0 -17
- package/dist/ui/types.d.ts.map +0 -1
- package/dist/ui/types.js +0 -3
- package/dist/ui/types.js.map +0 -1
- package/dist/utils.d.ts +0 -205
- package/dist/utils.d.ts.map +0 -1
- package/dist/utils.js +0 -549
- package/dist/utils.js.map +0 -1
- package/scripts/agent-eval/audit.sh +0 -68
- package/scripts/agent-eval/itrun.sh +0 -107
- package/scripts/agent-eval/parse-run.mjs +0 -45
- package/scripts/agent-eval/parse-session.mjs +0 -93
- package/scripts/agent-eval/run-agent.sh +0 -34
- package/scripts/agent-eval/run-all.sh +0 -67
- package/scripts/extract-release-notes.mjs +0 -130
- package/scripts/local-install.sh +0 -41
- package/scripts/patch-tree-sitter-dart.js +0 -112
- package/scripts/release.sh +0 -68
|
@@ -1,71 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.SERVER_INSTRUCTIONS = void 0;
|
|
4
|
-
/**
|
|
5
|
-
* Server-level instructions emitted in the MCP `initialize` response.
|
|
6
|
-
*
|
|
7
|
-
* MCP clients (Claude Code, Cursor, opencode, LangChain, OpenAI Agent
|
|
8
|
-
* SDK, …) surface this text in the agent's system prompt automatically,
|
|
9
|
-
* giving the agent a high-level playbook for the codegraph toolset
|
|
10
|
-
* before it sees individual tool descriptions.
|
|
11
|
-
*
|
|
12
|
-
* Goals when editing this:
|
|
13
|
-
* - Tool selection by intent (which tool for which question)
|
|
14
|
-
* - Common chains (refactor planning = X then Y)
|
|
15
|
-
* - Anti-patterns (don't grep when codegraph_search is faster)
|
|
16
|
-
*
|
|
17
|
-
* Keep it tight. The agent reads this every session — long instructions
|
|
18
|
-
* burn tokens. Reference only tools that exist on `main`; gate any
|
|
19
|
-
* conditional tools behind feature checks if/when they ship.
|
|
20
|
-
*/
|
|
21
|
-
exports.SERVER_INSTRUCTIONS = `# Codegraph — code intelligence over an indexed knowledge graph
|
|
22
|
-
|
|
23
|
-
Codegraph is a SQLite knowledge graph of every symbol, edge, and file
|
|
24
|
-
in the workspace. Reads are sub-millisecond; the index lags writes by
|
|
25
|
-
about a second through the file watcher. Consult it BEFORE writing or
|
|
26
|
-
editing code, not during.
|
|
27
|
-
|
|
28
|
-
## Answer directly — don't delegate exploration
|
|
29
|
-
|
|
30
|
-
For "how does X work", architecture, trace, or where-is-X questions,
|
|
31
|
-
answer DIRECTLY using 2-3 codegraph calls: \`codegraph_context\` first,
|
|
32
|
-
then ONE \`codegraph_explore\` for the source of the symbols it surfaces.
|
|
33
|
-
Codegraph IS the pre-built search index — so delegating the lookup to a
|
|
34
|
-
separate file-reading sub-task/agent, or running your own grep + read
|
|
35
|
-
loop, repeats work codegraph already did and costs more for the same
|
|
36
|
-
answer. Reach for raw Read/Grep only to confirm a specific detail
|
|
37
|
-
codegraph didn't cover. A direct codegraph answer is typically a handful
|
|
38
|
-
of calls; a grep/read exploration is dozens.
|
|
39
|
-
|
|
40
|
-
## Tool selection by intent
|
|
41
|
-
|
|
42
|
-
- **"What is the symbol named X?"** → \`codegraph_search\`
|
|
43
|
-
- **"What's the deal with this task / feature / area?"** → \`codegraph_context\` (PRIMARY — composes search + node + callers + callees in one call)
|
|
44
|
-
- **"What calls this?"** → \`codegraph_callers\`
|
|
45
|
-
- **"What does this call?"** → \`codegraph_callees\`
|
|
46
|
-
- **"What would changing this break?"** → \`codegraph_impact\`
|
|
47
|
-
- **"Show me this symbol's source / signature / docstring."** → \`codegraph_node\`
|
|
48
|
-
- **"Show me several related symbols' source / survey an area."** → \`codegraph_explore\` (ONE capped call; prefer over many codegraph_node/Read)
|
|
49
|
-
- **"What's in directory X?"** → \`codegraph_files\`
|
|
50
|
-
- **"Is the index ready / what's its size?"** → \`codegraph_status\`
|
|
51
|
-
|
|
52
|
-
## Common chains
|
|
53
|
-
|
|
54
|
-
- **Onboarding**: \`codegraph_context\` first. If still unclear, \`codegraph_explore\` for breadth, then \`codegraph_node\` on specific symbols.
|
|
55
|
-
- **Refactor planning**: \`codegraph_search\` → \`codegraph_callers\` → \`codegraph_impact\`. The blast-radius answer comes from impact, not from walking callers manually.
|
|
56
|
-
- **Debugging a regression**: \`codegraph_callers\` of the suspected symbol; widen with \`codegraph_impact\` if an unexpected call appears.
|
|
57
|
-
|
|
58
|
-
## Anti-patterns
|
|
59
|
-
|
|
60
|
-
- **Don't grep first** when looking up a symbol by name — \`codegraph_search\` is faster and returns kind + location + signature.
|
|
61
|
-
- **Don't chain \`codegraph_search\` + \`codegraph_node\`** when you just want context — \`codegraph_context\` is one round-trip.
|
|
62
|
-
- **Don't loop \`codegraph_node\` over many symbols** — one \`codegraph_explore\` call returns them all grouped by file, while each separate call re-reads the whole context and costs far more. Use \`codegraph_node\` for a single symbol.
|
|
63
|
-
- **Don't query the index immediately after editing a file** — the watcher needs ~500ms to debounce + sync. Wait for the next turn.
|
|
64
|
-
|
|
65
|
-
## Limitations
|
|
66
|
-
|
|
67
|
-
- Index lags file writes by ~1 second.
|
|
68
|
-
- Cross-file resolution is best-effort name matching; ambiguous calls may return multiple candidates.
|
|
69
|
-
- No live correctness validation — that's still the TypeScript compiler / test suite / linter's job. Codegraph supplements those with structural context they don't have.
|
|
70
|
-
`;
|
|
71
|
-
//# sourceMappingURL=server-instructions.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"server-instructions.js","sourceRoot":"","sources":["../../src/mcp/server-instructions.ts"],"names":[],"mappings":";;;AAAA;;;;;;;;;;;;;;;;GAgBG;AACU,QAAA,mBAAmB,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAiDlC,CAAC"}
|
package/dist/mcp/tools.d.ts
DELETED
|
@@ -1,257 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* MCP Tool Definitions
|
|
3
|
-
*
|
|
4
|
-
* Defines the tools exposed by the CodeGraph MCP server.
|
|
5
|
-
*/
|
|
6
|
-
import CodeGraph from '../index';
|
|
7
|
-
/**
|
|
8
|
-
* Calculate the recommended number of codegraph_explore calls based on project size.
|
|
9
|
-
* Larger codebases need more exploration calls to cover their surface area,
|
|
10
|
-
* but smaller ones should use fewer to avoid unnecessary overhead.
|
|
11
|
-
*/
|
|
12
|
-
export declare function getExploreBudget(fileCount: number): number;
|
|
13
|
-
/**
|
|
14
|
-
* Adaptive output budget for `codegraph_explore`, scaled to project size.
|
|
15
|
-
*
|
|
16
|
-
* Smaller codebases get a tighter total cap, fewer default files, smaller
|
|
17
|
-
* per-file cap, and tighter clustering — so a focused query on a 100-file
|
|
18
|
-
* project doesn't dump a whole file's worth of source into the agent's
|
|
19
|
-
* context. Larger codebases keep the generous defaults because the
|
|
20
|
-
* agent's native discovery cost (grep + find + many Reads) genuinely
|
|
21
|
-
* dwarfs a fat explore call at that scale.
|
|
22
|
-
*
|
|
23
|
-
* Meta-text (relationships map, "additional relevant files" list,
|
|
24
|
-
* completeness signal, budget note) is gated off for tiny projects
|
|
25
|
-
* where one rich call is the whole story and the extra prose is just
|
|
26
|
-
* overhead.
|
|
27
|
-
*
|
|
28
|
-
* Tier breakpoints mirror `getExploreBudget` so a project sits in the
|
|
29
|
-
* same tier across both knobs.
|
|
30
|
-
*/
|
|
31
|
-
export interface ExploreOutputBudget {
|
|
32
|
-
/** Hard cap on total output characters. */
|
|
33
|
-
maxOutputChars: number;
|
|
34
|
-
/** Default `maxFiles` when the caller didn't specify one. */
|
|
35
|
-
defaultMaxFiles: number;
|
|
36
|
-
/** Cap on contiguous source returned per file (across all its clusters). */
|
|
37
|
-
maxCharsPerFile: number;
|
|
38
|
-
/** Cluster gap threshold in lines — tighter clustering on small projects. */
|
|
39
|
-
gapThreshold: number;
|
|
40
|
-
/** Max symbols listed in the per-file header (`#### path — sym(kind), ...`). */
|
|
41
|
-
maxSymbolsInFileHeader: number;
|
|
42
|
-
/** Max edges shown per relationship kind in the Relationships section. */
|
|
43
|
-
maxEdgesPerRelationshipKind: number;
|
|
44
|
-
/** Include the "Relationships" section. */
|
|
45
|
-
includeRelationships: boolean;
|
|
46
|
-
/** Include the "Additional relevant files (not shown)" trailing list. */
|
|
47
|
-
includeAdditionalFiles: boolean;
|
|
48
|
-
/** Include the "Complete source code is included above…" reminder. */
|
|
49
|
-
includeCompletenessSignal: boolean;
|
|
50
|
-
/** Include the explore-budget reminder at the end. */
|
|
51
|
-
includeBudgetNote: boolean;
|
|
52
|
-
}
|
|
53
|
-
export declare function getExploreOutputBudget(fileCount: number): ExploreOutputBudget;
|
|
54
|
-
/**
|
|
55
|
-
* MCP Tool definition
|
|
56
|
-
*/
|
|
57
|
-
export interface ToolDefinition {
|
|
58
|
-
name: string;
|
|
59
|
-
description: string;
|
|
60
|
-
inputSchema: {
|
|
61
|
-
type: 'object';
|
|
62
|
-
properties: Record<string, PropertySchema>;
|
|
63
|
-
required?: string[];
|
|
64
|
-
};
|
|
65
|
-
}
|
|
66
|
-
interface PropertySchema {
|
|
67
|
-
type: string;
|
|
68
|
-
description: string;
|
|
69
|
-
enum?: string[];
|
|
70
|
-
default?: unknown;
|
|
71
|
-
}
|
|
72
|
-
/**
|
|
73
|
-
* Tool execution result
|
|
74
|
-
*/
|
|
75
|
-
export interface ToolResult {
|
|
76
|
-
content: Array<{
|
|
77
|
-
type: 'text';
|
|
78
|
-
text: string;
|
|
79
|
-
}>;
|
|
80
|
-
isError?: boolean;
|
|
81
|
-
}
|
|
82
|
-
/**
|
|
83
|
-
* All CodeGraph MCP tools
|
|
84
|
-
*
|
|
85
|
-
* Designed for minimal context usage - use codegraph_context as the primary tool,
|
|
86
|
-
* and only use other tools for targeted follow-up queries.
|
|
87
|
-
*
|
|
88
|
-
* All tools support cross-project queries via the optional `projectPath` parameter.
|
|
89
|
-
*/
|
|
90
|
-
export declare const tools: ToolDefinition[];
|
|
91
|
-
/**
|
|
92
|
-
* Tool handler that executes tools against a CodeGraph instance
|
|
93
|
-
*
|
|
94
|
-
* Supports cross-project queries via the projectPath parameter.
|
|
95
|
-
* Other projects are opened on-demand and cached for performance.
|
|
96
|
-
*/
|
|
97
|
-
export declare class ToolHandler {
|
|
98
|
-
private cg;
|
|
99
|
-
private projectCache;
|
|
100
|
-
private defaultProjectHint;
|
|
101
|
-
constructor(cg: CodeGraph | null);
|
|
102
|
-
/**
|
|
103
|
-
* Update the default CodeGraph instance (e.g. after lazy initialization)
|
|
104
|
-
*/
|
|
105
|
-
setDefaultCodeGraph(cg: CodeGraph): void;
|
|
106
|
-
/**
|
|
107
|
-
* Record the directory the server tried to resolve the default project from.
|
|
108
|
-
* Used only to make the "no default project" error actionable.
|
|
109
|
-
*/
|
|
110
|
-
setDefaultProjectHint(searchedPath: string): void;
|
|
111
|
-
/**
|
|
112
|
-
* Whether a default CodeGraph instance is available
|
|
113
|
-
*/
|
|
114
|
-
hasDefaultCodeGraph(): boolean;
|
|
115
|
-
/**
|
|
116
|
-
* Get tool definitions with dynamic descriptions based on project size.
|
|
117
|
-
* The codegraph_explore tool description includes a budget recommendation
|
|
118
|
-
* scaled to the number of indexed files.
|
|
119
|
-
*/
|
|
120
|
-
getTools(): ToolDefinition[];
|
|
121
|
-
/**
|
|
122
|
-
* Get CodeGraph instance for a project
|
|
123
|
-
*
|
|
124
|
-
* If projectPath is provided, opens that project's CodeGraph (cached).
|
|
125
|
-
* Otherwise returns the default CodeGraph instance.
|
|
126
|
-
*
|
|
127
|
-
* Walks up parent directories to find the nearest .codegraph/ folder,
|
|
128
|
-
* similar to how git finds .git/ directories.
|
|
129
|
-
*/
|
|
130
|
-
private getCodeGraph;
|
|
131
|
-
/**
|
|
132
|
-
* Close all cached project connections
|
|
133
|
-
*/
|
|
134
|
-
closeAll(): void;
|
|
135
|
-
/**
|
|
136
|
-
* Validate that a value is a non-empty string
|
|
137
|
-
*/
|
|
138
|
-
private validateString;
|
|
139
|
-
/**
|
|
140
|
-
* Execute a tool by name
|
|
141
|
-
*/
|
|
142
|
-
execute(toolName: string, args: Record<string, unknown>): Promise<ToolResult>;
|
|
143
|
-
/**
|
|
144
|
-
* Handle codegraph_search
|
|
145
|
-
*/
|
|
146
|
-
private handleSearch;
|
|
147
|
-
/**
|
|
148
|
-
* Handle codegraph_context
|
|
149
|
-
*/
|
|
150
|
-
private handleContext;
|
|
151
|
-
/**
|
|
152
|
-
* Heuristic to detect if a query looks like a feature request
|
|
153
|
-
*/
|
|
154
|
-
private looksLikeFeatureRequest;
|
|
155
|
-
/**
|
|
156
|
-
* Handle codegraph_callers
|
|
157
|
-
*/
|
|
158
|
-
private handleCallers;
|
|
159
|
-
/**
|
|
160
|
-
* Handle codegraph_callees
|
|
161
|
-
*/
|
|
162
|
-
private handleCallees;
|
|
163
|
-
/**
|
|
164
|
-
* Handle codegraph_impact
|
|
165
|
-
*/
|
|
166
|
-
private handleImpact;
|
|
167
|
-
/**
|
|
168
|
-
* Handle codegraph_explore — deep exploration in a single call
|
|
169
|
-
*
|
|
170
|
-
* Strategy: find relevant symbols via graph traversal, group by file,
|
|
171
|
-
* then read contiguous file sections covering all symbols per file.
|
|
172
|
-
* This replaces multiple codegraph_node + Read calls.
|
|
173
|
-
*
|
|
174
|
-
* Output size is adaptive to project file count via
|
|
175
|
-
* `getExploreOutputBudget` — see #185 for why a fixed 35k cap was a
|
|
176
|
-
* tax on small projects while earning its keep on large ones.
|
|
177
|
-
*/
|
|
178
|
-
private handleExplore;
|
|
179
|
-
/**
|
|
180
|
-
* Handle codegraph_node
|
|
181
|
-
*/
|
|
182
|
-
private handleNode;
|
|
183
|
-
/**
|
|
184
|
-
* Handle codegraph_status
|
|
185
|
-
*/
|
|
186
|
-
private handleStatus;
|
|
187
|
-
/**
|
|
188
|
-
* Handle codegraph_files - get project file structure from the index
|
|
189
|
-
*/
|
|
190
|
-
private handleFiles;
|
|
191
|
-
/**
|
|
192
|
-
* Convert glob pattern to regex
|
|
193
|
-
*/
|
|
194
|
-
private globToRegex;
|
|
195
|
-
/**
|
|
196
|
-
* Format files as a flat list
|
|
197
|
-
*/
|
|
198
|
-
private formatFilesFlat;
|
|
199
|
-
/**
|
|
200
|
-
* Format files grouped by language
|
|
201
|
-
*/
|
|
202
|
-
private formatFilesGrouped;
|
|
203
|
-
/**
|
|
204
|
-
* Format files as a tree structure
|
|
205
|
-
*/
|
|
206
|
-
private formatFilesTree;
|
|
207
|
-
/**
|
|
208
|
-
* Find a symbol by name, handling disambiguation when multiple matches exist.
|
|
209
|
-
* Returns the best match and a note about alternatives if any.
|
|
210
|
-
*/
|
|
211
|
-
/**
|
|
212
|
-
* Check if a node matches a symbol query.
|
|
213
|
-
*
|
|
214
|
-
* Accepts simple names (`run`) and three flavors of qualifier:
|
|
215
|
-
* - dotted `Session.request` (TS/JS/Python)
|
|
216
|
-
* - colon-pair `stage_apply::run` (Rust, C++, Ruby)
|
|
217
|
-
* - slash `configurator/stage_apply` (path-ish)
|
|
218
|
-
*
|
|
219
|
-
* Multi-level qualifiers compose: `crate::configurator::stage_apply::run`
|
|
220
|
-
* works. Rust path prefixes (`crate`, `super`, `self`) are stripped so
|
|
221
|
-
* the canonical `crate::module::symbol` form resolves.
|
|
222
|
-
*
|
|
223
|
-
* Resolution order, last part must always equal `node.name`:
|
|
224
|
-
* 1. Suffix-match against `qualifiedName` (handles class-scoped methods
|
|
225
|
-
* where the extractor builds the qualified name from the AST stack)
|
|
226
|
-
* 2. File-path containment (handles file-derived modules in Rust/
|
|
227
|
-
* Python — `stage_apply::run` matches a `run` in `stage_apply.rs`)
|
|
228
|
-
*/
|
|
229
|
-
private matchesSymbol;
|
|
230
|
-
private findSymbol;
|
|
231
|
-
/**
|
|
232
|
-
* Find ALL symbols matching a name. Used by callers/callees/impact to aggregate
|
|
233
|
-
* results across all matching symbols (e.g., multiple classes with an `execute` method).
|
|
234
|
-
*/
|
|
235
|
-
private findAllSymbols;
|
|
236
|
-
/**
|
|
237
|
-
* Truncate output if it exceeds the maximum length
|
|
238
|
-
*/
|
|
239
|
-
private truncateOutput;
|
|
240
|
-
private formatSearchResults;
|
|
241
|
-
private formatNodeList;
|
|
242
|
-
private formatImpact;
|
|
243
|
-
/**
|
|
244
|
-
* Build a compact structural outline of a container symbol from its
|
|
245
|
-
* indexed children (methods, fields, properties, …) — name, kind,
|
|
246
|
-
* line number, and signature — so the agent gets the shape of a class
|
|
247
|
-
* without the full source of every method. Returns '' when the container
|
|
248
|
-
* has no indexed children, so the caller can fall back to full source.
|
|
249
|
-
*/
|
|
250
|
-
private buildContainerOutline;
|
|
251
|
-
private formatNodeDetails;
|
|
252
|
-
private formatTaskContext;
|
|
253
|
-
private textResult;
|
|
254
|
-
private errorResult;
|
|
255
|
-
}
|
|
256
|
-
export {};
|
|
257
|
-
//# sourceMappingURL=tools.d.ts.map
|
package/dist/mcp/tools.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"tools.d.ts","sourceRoot":"","sources":["../../src/mcp/tools.ts"],"names":[],"mappings":"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"}
|