@aria-cli/tools 1.0.2 → 1.0.4

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.
Files changed (157) hide show
  1. package/dist/.aria-build-stamp.json +1 -1
  2. package/dist/.tsbuildinfo +1 -1
  3. package/dist/definitions/code-intelligence.d.ts +9 -0
  4. package/dist/definitions/code-intelligence.d.ts.map +1 -0
  5. package/dist/definitions/code-intelligence.js +471 -0
  6. package/dist/definitions/code-intelligence.js.map +1 -0
  7. package/dist/definitions/core.d.ts +3 -0
  8. package/dist/definitions/core.d.ts.map +1 -1
  9. package/dist/definitions/core.js +13 -1
  10. package/dist/definitions/core.js.map +1 -1
  11. package/dist/definitions/filesystem.d.ts +3 -2
  12. package/dist/definitions/filesystem.d.ts.map +1 -1
  13. package/dist/definitions/filesystem.js +4 -38
  14. package/dist/definitions/filesystem.js.map +1 -1
  15. package/dist/definitions/frg.d.ts +4 -0
  16. package/dist/definitions/frg.d.ts.map +1 -0
  17. package/dist/definitions/frg.js +64 -0
  18. package/dist/definitions/frg.js.map +1 -0
  19. package/dist/definitions/index.d.ts +3 -0
  20. package/dist/definitions/index.d.ts.map +1 -1
  21. package/dist/definitions/index.js +3 -0
  22. package/dist/definitions/index.js.map +1 -1
  23. package/dist/definitions/search.d.ts +10 -0
  24. package/dist/definitions/search.d.ts.map +1 -0
  25. package/dist/definitions/search.js +61 -0
  26. package/dist/definitions/search.js.map +1 -0
  27. package/dist/executors/apply-patch.d.ts.map +1 -1
  28. package/dist/executors/apply-patch.js +18 -0
  29. package/dist/executors/apply-patch.js.map +1 -1
  30. package/dist/executors/code-intelligence.d.ts +139 -0
  31. package/dist/executors/code-intelligence.d.ts.map +1 -0
  32. package/dist/executors/code-intelligence.js +883 -0
  33. package/dist/executors/code-intelligence.js.map +1 -0
  34. package/dist/executors/filesystem.d.ts.map +1 -1
  35. package/dist/executors/filesystem.js +14 -8
  36. package/dist/executors/filesystem.js.map +1 -1
  37. package/dist/executors/frg-freshness.d.ts +94 -0
  38. package/dist/executors/frg-freshness.d.ts.map +1 -0
  39. package/dist/executors/frg-freshness.js +577 -0
  40. package/dist/executors/frg-freshness.js.map +1 -0
  41. package/dist/executors/frg.d.ts +28 -0
  42. package/dist/executors/frg.d.ts.map +1 -0
  43. package/dist/executors/frg.js +299 -0
  44. package/dist/executors/frg.js.map +1 -0
  45. package/dist/executors/index.d.ts +6 -0
  46. package/dist/executors/index.d.ts.map +1 -1
  47. package/dist/executors/index.js +5 -0
  48. package/dist/executors/index.js.map +1 -1
  49. package/dist/executors/lsp-client.d.ts +39 -0
  50. package/dist/executors/lsp-client.d.ts.map +1 -0
  51. package/dist/executors/lsp-client.js +297 -0
  52. package/dist/executors/lsp-client.js.map +1 -0
  53. package/dist/executors/restart.d.ts +4 -9
  54. package/dist/executors/restart.d.ts.map +1 -1
  55. package/dist/executors/restart.js +20 -51
  56. package/dist/executors/restart.js.map +1 -1
  57. package/dist/executors/search-freshness.d.ts +51 -0
  58. package/dist/executors/search-freshness.d.ts.map +1 -0
  59. package/dist/executors/search-freshness.js +196 -0
  60. package/dist/executors/search-freshness.js.map +1 -0
  61. package/dist/executors/search.d.ts +12 -0
  62. package/dist/executors/search.d.ts.map +1 -0
  63. package/dist/executors/search.js +67 -0
  64. package/dist/executors/search.js.map +1 -0
  65. package/dist/headless-control-contract.d.ts +4 -0
  66. package/dist/headless-control-contract.d.ts.map +1 -1
  67. package/dist/index.d.ts +2 -2
  68. package/dist/index.d.ts.map +1 -1
  69. package/dist/index.js +1 -1
  70. package/dist/index.js.map +1 -1
  71. package/dist/network-runtime/local-control-contract.d.ts +2 -0
  72. package/dist/network-runtime/local-control-contract.d.ts.map +1 -1
  73. package/dist/network-runtime/local-control-contract.js +2 -0
  74. package/dist/network-runtime/local-control-contract.js.map +1 -1
  75. package/dist-cjs/.tsbuildinfo +1 -1
  76. package/dist-cjs/definitions/code-intelligence.d.ts +8 -0
  77. package/dist-cjs/definitions/code-intelligence.js +474 -0
  78. package/dist-cjs/definitions/code-intelligence.js.map +1 -0
  79. package/dist-cjs/definitions/core.d.ts +3 -0
  80. package/dist-cjs/definitions/core.js +17 -2
  81. package/dist-cjs/definitions/core.js.map +1 -1
  82. package/dist-cjs/definitions/filesystem.d.ts +3 -2
  83. package/dist-cjs/definitions/filesystem.js +3 -37
  84. package/dist-cjs/definitions/filesystem.js.map +1 -1
  85. package/dist-cjs/definitions/frg.d.ts +3 -0
  86. package/dist-cjs/definitions/frg.js +67 -0
  87. package/dist-cjs/definitions/frg.js.map +1 -0
  88. package/dist-cjs/definitions/index.d.ts +3 -0
  89. package/dist-cjs/definitions/index.js +7 -1
  90. package/dist-cjs/definitions/index.js.map +1 -1
  91. package/dist-cjs/definitions/search.d.ts +9 -0
  92. package/dist-cjs/definitions/search.js +64 -0
  93. package/dist-cjs/definitions/search.js.map +1 -0
  94. package/dist-cjs/executors/apply-patch.js +18 -0
  95. package/dist-cjs/executors/apply-patch.js.map +1 -1
  96. package/dist-cjs/executors/code-intelligence.d.ts +138 -0
  97. package/dist-cjs/executors/code-intelligence.js +926 -0
  98. package/dist-cjs/executors/code-intelligence.js.map +1 -0
  99. package/dist-cjs/executors/filesystem.js +17 -8
  100. package/dist-cjs/executors/filesystem.js.map +1 -1
  101. package/dist-cjs/executors/frg-freshness.d.ts +93 -0
  102. package/dist-cjs/executors/frg-freshness.js +628 -0
  103. package/dist-cjs/executors/frg-freshness.js.map +1 -0
  104. package/dist-cjs/executors/frg.d.ts +27 -0
  105. package/dist-cjs/executors/frg.js +335 -0
  106. package/dist-cjs/executors/frg.js.map +1 -0
  107. package/dist-cjs/executors/index.d.ts +6 -0
  108. package/dist-cjs/executors/index.js +34 -2
  109. package/dist-cjs/executors/index.js.map +1 -1
  110. package/dist-cjs/executors/lsp-client.d.ts +38 -0
  111. package/dist-cjs/executors/lsp-client.js +311 -0
  112. package/dist-cjs/executors/lsp-client.js.map +1 -0
  113. package/dist-cjs/executors/restart.d.ts +4 -9
  114. package/dist-cjs/executors/restart.js +19 -50
  115. package/dist-cjs/executors/restart.js.map +1 -1
  116. package/dist-cjs/executors/search-freshness.d.ts +50 -0
  117. package/dist-cjs/executors/search-freshness.js +235 -0
  118. package/dist-cjs/executors/search-freshness.js.map +1 -0
  119. package/dist-cjs/executors/search.d.ts +11 -0
  120. package/dist-cjs/executors/search.js +103 -0
  121. package/dist-cjs/executors/search.js.map +1 -0
  122. package/dist-cjs/headless-control-contract.d.ts +15 -11
  123. package/dist-cjs/index.d.ts +2 -2
  124. package/dist-cjs/index.js +22 -2
  125. package/dist-cjs/index.js.map +1 -1
  126. package/dist-cjs/network-runtime/local-control-contract.d.ts +2 -0
  127. package/dist-cjs/network-runtime/local-control-contract.js +2 -0
  128. package/dist-cjs/network-runtime/local-control-contract.js.map +1 -1
  129. package/package.json +9 -5
  130. package/src/definitions/code-intelligence.ts +526 -0
  131. package/src/definitions/core.ts +13 -1
  132. package/src/definitions/filesystem.ts +3 -39
  133. package/src/definitions/frg.ts +67 -0
  134. package/src/definitions/index.ts +3 -0
  135. package/src/definitions/search.ts +67 -0
  136. package/src/executors/apply-patch.ts +20 -0
  137. package/src/executors/code-intelligence.ts +1179 -0
  138. package/src/executors/filesystem.ts +15 -8
  139. package/src/executors/frg-freshness.ts +743 -0
  140. package/src/executors/frg.ts +394 -0
  141. package/src/executors/index.ts +58 -0
  142. package/src/executors/lsp-client.ts +355 -0
  143. package/src/executors/restart.ts +21 -56
  144. package/src/executors/search-freshness.ts +249 -0
  145. package/src/executors/search.ts +89 -0
  146. package/src/index.ts +25 -0
  147. package/src/network-runtime/local-control-contract.ts +2 -0
  148. package/tests/definitions/tool-inventory.test.ts +17 -6
  149. package/tests/executors/frg-freshness.test.ts +136 -0
  150. package/tests/executors/frg-merge.test.ts +70 -0
  151. package/tests/executors/frg-session-content.test.ts +40 -0
  152. package/tests/executors/frg.test.ts +56 -0
  153. package/tests/integration/headless-control-contract.integration.test.ts +2 -0
  154. package/tests/loading-tier.test.ts +6 -6
  155. package/tests/test-lane-manifest.ts +4 -0
  156. package/tsconfig.cjs.json +9 -1
  157. package/tsconfig.json +1 -1
@@ -0,0 +1,526 @@
1
+ /**
2
+ * Code intelligence tool definitions
3
+ *
4
+ * 7 native tools wrapping external CLI binaries for code search, structural
5
+ * analysis, knowledge graphs, LSP intelligence, and file discovery.
6
+ */
7
+
8
+ import type { JSONSchema7 } from "json-schema";
9
+ import type { Tool } from "../types.js";
10
+ import {
11
+ executeRg,
12
+ executeUg,
13
+ executeProbe,
14
+ executeSg,
15
+ executeCbm,
16
+ executeLsp,
17
+ executeSerena,
18
+ executeFff,
19
+ } from "../executors/code-intelligence.js";
20
+
21
+ // ---------------------------------------------------------------------------
22
+ // rg — ripgrep
23
+ // ---------------------------------------------------------------------------
24
+
25
+ const rg: Tool = {
26
+ name: "rg",
27
+ description:
28
+ "Fast text/regex search (ripgrep). SIMD-accelerated, .gitignore-aware. " +
29
+ "Returns structured JSON matches with file, line, and text. " +
30
+ "Use for finding strings, patterns, identifiers. Fastest grep available.",
31
+ category: "code",
32
+ parameters: {
33
+ type: "object",
34
+ properties: {
35
+ pattern: { type: "string", description: "Search pattern (regex by default)" },
36
+ path: { type: "string", description: "File or directory to search (default: working dir)" },
37
+ ignore_case: { type: "boolean", description: "Case-insensitive search (-i)" },
38
+ smart_case: {
39
+ type: "boolean",
40
+ description: "Case-insensitive unless pattern has uppercase (-S)",
41
+ },
42
+ fixed_strings: {
43
+ type: "boolean",
44
+ description: "Treat pattern as literal string, not regex (-F)",
45
+ },
46
+ word_regexp: { type: "boolean", description: "Match whole words only (-w)" },
47
+ file_type: {
48
+ type: "string",
49
+ description: "File type filter: ts, py, rs, go, java, etc. (-t TYPE)",
50
+ },
51
+ glob: { type: "string", description: "Glob filter, prefix ! to exclude (-g GLOB)" },
52
+ context: { type: "number", description: "Context lines around matches (-C NUM)" },
53
+ max_count: { type: "number", description: "Max matches per file (-m NUM)", default: 100 },
54
+ invert: { type: "boolean", description: "Show lines NOT matching (-v)" },
55
+ files_only: { type: "boolean", description: "Only print file names with matches (-l)" },
56
+ count: { type: "boolean", description: "Only print match count per file (-c)" },
57
+ extra_args: {
58
+ type: "array",
59
+ items: { type: "string" },
60
+ description:
61
+ "Additional rg flags: ['--pcre2','-U','--max-depth=3','--hidden','--no-ignore','--type-not=test']",
62
+ },
63
+ },
64
+ required: ["pattern"],
65
+ } as JSONSchema7,
66
+ riskLevel: "safe",
67
+ isReadOnly: true,
68
+ loadingTier: "always",
69
+ execute: executeRg,
70
+ };
71
+
72
+ // ---------------------------------------------------------------------------
73
+ // ug — ugrep
74
+ // ---------------------------------------------------------------------------
75
+
76
+ const ug: Tool = {
77
+ name: "ug",
78
+ description:
79
+ "Text search with fuzzy matching, boolean queries, and archive search (ugrep). " +
80
+ "Superset of ripgrep features. Use fuzzy for approximate matching (typos), " +
81
+ "bool for AND/OR/NOT queries, decompress for searching inside zip/tar/gz.",
82
+ category: "code",
83
+ parameters: {
84
+ type: "object",
85
+ properties: {
86
+ pattern: { type: "string", description: "Search pattern (regex by default)" },
87
+ path: { type: "string", description: "File or directory to search (default: working dir)" },
88
+ ignore_case: { type: "boolean", description: "Case-insensitive (-i)" },
89
+ smart_case: {
90
+ type: "boolean",
91
+ description: "Smart case: insensitive unless uppercase present (-j)",
92
+ },
93
+ fixed_strings: { type: "boolean", description: "Literal string matching (-F)" },
94
+ word_regexp: { type: "boolean", description: "Match whole words only (-w)" },
95
+ file_type: { type: "string", description: "File type filter (-t TYPE)" },
96
+ glob: { type: "string", description: "Glob filter (-g GLOB)" },
97
+ context: { type: "number", description: "Context lines around matches (-C NUM)" },
98
+ max_count: { type: "number", description: "Max matches per file (-m NUM)", default: 100 },
99
+ fuzzy: {
100
+ oneOf: [{ type: "boolean" }, { type: "number" }],
101
+ description: "Fuzzy matching (-Z). true=default distance, number=max Levenshtein distance",
102
+ },
103
+ bool: {
104
+ type: "boolean",
105
+ description: "Boolean query mode (-%%). Pattern uses AND/OR/NOT: 'auth AND NOT test'",
106
+ },
107
+ neg_pattern: {
108
+ type: "string",
109
+ description: "Negative pattern — reject matching lines (-N PATTERN)",
110
+ },
111
+ files_only: { type: "boolean", description: "Only print file names (-l)" },
112
+ count: { type: "boolean", description: "Only print match count per file (-c)" },
113
+ decompress: {
114
+ type: "boolean",
115
+ description: "Search inside compressed files and archives (-z)",
116
+ },
117
+ extra_args: {
118
+ type: "array",
119
+ items: { type: "string" },
120
+ description:
121
+ "Additional ug flags: ['--depth=3','-O=ts,js','--min-size=1K','--format=%f:%n:%o']",
122
+ },
123
+ },
124
+ required: ["pattern"],
125
+ } as JSONSchema7,
126
+ riskLevel: "safe",
127
+ isReadOnly: true,
128
+ loadingTier: "always",
129
+ execute: executeUg,
130
+ };
131
+
132
+ // ---------------------------------------------------------------------------
133
+ // probe
134
+ // ---------------------------------------------------------------------------
135
+
136
+ const probe: Tool = {
137
+ name: "probe",
138
+ description:
139
+ "Ranked semantic code search with token budgeting (Probe). Returns complete functions/classes, " +
140
+ "not line fragments. 4 commands: search (ES-style boolean queries with BM25 ranking), " +
141
+ "extract (get code by file:line or file#symbol), symbols (list symbols in file), " +
142
+ "query (AST pattern matching). Use max_tokens for LLM context budgeting, session for pagination.",
143
+ category: "code",
144
+ parameters: {
145
+ type: "object",
146
+ properties: {
147
+ command: {
148
+ type: "string",
149
+ enum: ["search", "extract", "symbols", "query"],
150
+ default: "search",
151
+ description:
152
+ "search=semantic search, extract=get code by line/symbol, symbols=list symbols, query=AST pattern",
153
+ },
154
+ query: {
155
+ type: "string",
156
+ description:
157
+ "Search query (ES syntax: AND/OR/NOT, ext:rs, file:path, dir:tests) or AST pattern for query command",
158
+ },
159
+ path: { type: "string", description: "Directory to search (default: working dir)" },
160
+ exact: {
161
+ type: "boolean",
162
+ description:
163
+ "Exact match (true) vs stemmed search (false). 'getUserData' exact vs 'get','user','data'",
164
+ },
165
+ max_tokens: {
166
+ type: "number",
167
+ description: "Token budget — limit total output tokens for LLM context",
168
+ },
169
+ max_results: { type: "number", description: "Maximum number of results" },
170
+ session: {
171
+ type: "string",
172
+ description: "Session ID for pagination. Reuse to get next page (dedup previous results)",
173
+ },
174
+ language: {
175
+ type: "string",
176
+ description: "Language filter: rust, typescript, python, go, java, etc.",
177
+ },
178
+ reranker: {
179
+ type: "string",
180
+ description: "Ranking algorithm: bm25 (default), tfidf, hybrid, hybrid2",
181
+ },
182
+ allow_tests: { type: "boolean", description: "Include test files in results" },
183
+ files: {
184
+ type: "array",
185
+ items: { type: "string" },
186
+ description:
187
+ "File specs for extract and symbols commands: ['src/auth.ts:42', 'src/auth.ts#handleAuth', 'src/auth.ts:10-50']",
188
+ },
189
+ extra_args: {
190
+ type: "array",
191
+ items: { type: "string" },
192
+ description: "Additional probe flags: ['--files-only','--no-merge','--lsp','--timeout=60']",
193
+ },
194
+ },
195
+ required: [],
196
+ } as JSONSchema7,
197
+ riskLevel: "safe",
198
+ isReadOnly: true,
199
+ loadingTier: "always",
200
+ execute: executeProbe,
201
+ };
202
+
203
+ // ---------------------------------------------------------------------------
204
+ // sg — ast-grep
205
+ // ---------------------------------------------------------------------------
206
+
207
+ const sg: Tool = {
208
+ name: "sg",
209
+ description:
210
+ "AST structural pattern matching and rewriting (ast-grep). Patterns look like real code. " +
211
+ "$NAME matches single node, $$$ARGS matches variadic, $_ is wildcard. " +
212
+ "Examples: 'console.log($MSG)', 'async function $NAME($$$PARAMS) { $$$BODY }'. " +
213
+ "Set rewrite for search-and-replace refactoring. Use command='scan' with inline_rules for YAML rules.",
214
+ category: "code",
215
+ parameters: {
216
+ type: "object",
217
+ properties: {
218
+ command: {
219
+ type: "string",
220
+ enum: ["run", "scan"],
221
+ default: "run",
222
+ description: "run=pattern match/rewrite, scan=rule-based scanning",
223
+ },
224
+ pattern: {
225
+ type: "string",
226
+ description:
227
+ "AST pattern. $NAME=single node, $$$ARGS=variadic, $_=wildcard. " +
228
+ "Examples: 'console.log($MSG)', 'async function $NAME($$$PARAMS) { $$$BODY }'",
229
+ },
230
+ language: {
231
+ type: "string",
232
+ description:
233
+ "Language: typescript, python, rust, go, java, javascript, c, cpp, ruby, php, swift, kotlin",
234
+ },
235
+ rewrite: {
236
+ type: "string",
237
+ description:
238
+ "Replacement pattern with same metavariables. Example: pattern='console.log($MSG)' rewrite='logger.info($MSG)'",
239
+ },
240
+ strictness: {
241
+ type: "string",
242
+ enum: ["cst", "smart", "ast", "relaxed", "signature"],
243
+ description:
244
+ "Matching strictness. smart=default, ast=ignore punctuation, relaxed=ignore comments",
245
+ },
246
+ globs: { type: "string", description: "File glob filter, prefix ! to exclude" },
247
+ rule: { type: "string", description: "Path to a YAML rule file (for scan)" },
248
+ inline_rules: {
249
+ type: "string",
250
+ description:
251
+ "Inline YAML rule text (for scan). Example: 'id: no-console\\nlanguage: TypeScript\\nrule:\\n pattern: console.log($$$)'",
252
+ },
253
+ path: { type: "string", description: "Directory to search (default: working dir)" },
254
+ update_all: { type: "boolean", description: "Apply all rewrites without confirmation (-U)" },
255
+ context: { type: "number", description: "Context lines around matches (-C NUM)" },
256
+ extra_args: {
257
+ type: "array",
258
+ items: { type: "string" },
259
+ description:
260
+ "Additional sg flags: ['--selector=function_declaration','--threads=4','--no-ignore=hidden']",
261
+ },
262
+ },
263
+ required: [],
264
+ } as JSONSchema7,
265
+ riskLevel: "safe",
266
+ isReadOnly: true,
267
+ loadingTier: "always",
268
+ execute: executeSg,
269
+ };
270
+
271
+ // ---------------------------------------------------------------------------
272
+ // cbm — codebase-memory-mcp
273
+ // ---------------------------------------------------------------------------
274
+
275
+ const cbm: Tool = {
276
+ name: "cbm",
277
+ description:
278
+ "Code knowledge graph (codebase-memory-mcp). Index codebases, search symbols, trace call chains, " +
279
+ "analyze blast radius. Run action='index' once per project. Then: search (symbols by name/type/file), " +
280
+ "trace (who calls this? what does it call?), impact (what breaks if I change this?), " +
281
+ "context (360° view: definition + callers + callees in one call), architecture (project overview), " +
282
+ "snippet (read source by qualified name), code_search (graph-augmented grep), cypher (raw Cypher query).",
283
+ category: "code",
284
+ parameters: {
285
+ type: "object",
286
+ properties: {
287
+ action: {
288
+ type: "string",
289
+ enum: [
290
+ "index",
291
+ "search",
292
+ "trace",
293
+ "impact",
294
+ "context",
295
+ "snippet",
296
+ "code_search",
297
+ "architecture",
298
+ "schema",
299
+ "cypher",
300
+ "list_projects",
301
+ "delete_project",
302
+ "status",
303
+ ],
304
+ description: "Action to perform",
305
+ },
306
+ path: { type: "string", description: "Repository path to index" },
307
+ mode: {
308
+ type: "string",
309
+ enum: ["full", "fast"],
310
+ description: "full=with git history, fast=skip git",
311
+ },
312
+ name: { type: "string", description: "Symbol name or regex pattern" },
313
+ label: {
314
+ type: "string",
315
+ description:
316
+ "Node type: Function, Class, Method, Interface, Enum, Type, Module, File, Route, Package",
317
+ },
318
+ file: { type: "string", description: "File path filter" },
319
+ direction: {
320
+ type: "string",
321
+ enum: ["inbound", "outbound", "both"],
322
+ default: "both",
323
+ description: "inbound=callers, outbound=callees",
324
+ },
325
+ depth: { type: "number", description: "Traversal depth (1-5)", default: 3 },
326
+ edge_types: {
327
+ type: "array",
328
+ items: { type: "string" },
329
+ description:
330
+ "Filter edges: CALLS, IMPORTS, INHERITS, IMPLEMENTS, USES_TYPE, TESTS, HTTP_CALLS",
331
+ },
332
+ scope: { type: "string", description: "Git diff scope: 'staged', 'HEAD~1', branch name" },
333
+ base_branch: { type: "string", description: "Git branch for comparison", default: "main" },
334
+ qualified_name: {
335
+ type: "string",
336
+ description: "Full qualified name from search results (for snippet)",
337
+ },
338
+ include_neighbors: {
339
+ type: "boolean",
340
+ description: "Include caller/callee names (for snippet)",
341
+ },
342
+ code_pattern: { type: "string", description: "Text search pattern (for code_search)" },
343
+ regex: { type: "boolean", description: "Use regex for code_search" },
344
+ code_mode: {
345
+ type: "string",
346
+ enum: ["compact", "full", "files"],
347
+ description: "Output mode for code_search",
348
+ },
349
+ query: { type: "string", description: "Cypher query string (for cypher action)" },
350
+ max_rows: { type: "number", description: "Max rows for cypher query" },
351
+ project: {
352
+ type: "string",
353
+ description: "Project name (auto-detected if one project indexed)",
354
+ },
355
+ limit: { type: "number", description: "Max results", default: 20 },
356
+ context: { type: "number", description: "Context lines for code_search" },
357
+ },
358
+ required: ["action"],
359
+ } as JSONSchema7,
360
+ riskLevel: "safe",
361
+ isReadOnly: true,
362
+ loadingTier: "always",
363
+ execute: executeCbm,
364
+ };
365
+
366
+ // ---------------------------------------------------------------------------
367
+ // lsp — native LSP client (direct JSON-RPC to language servers)
368
+ // ---------------------------------------------------------------------------
369
+
370
+ const lsp: Tool = {
371
+ name: "lsp",
372
+ description:
373
+ "Compiler-accurate code intelligence via native LSP (Language Server Protocol). " +
374
+ "Spawns real language servers directly — same as VS Code and Claude Code. " +
375
+ "No Serena, no MCP, no HTTP. Supports: TypeScript, Python, Go, Rust, C/C++, Swift, Java, Kotlin, Lua, PHP, Ruby, C#. " +
376
+ "Actions: definition (go-to-definition), references (find all references), " +
377
+ "hover (type info + docs), symbols (document symbol list), rename (safe cross-file rename). " +
378
+ "Line and character are 0-based. Server starts on first use and stays warm.",
379
+ category: "code",
380
+ parameters: {
381
+ type: "object",
382
+ properties: {
383
+ action: {
384
+ type: "string",
385
+ enum: ["definition", "references", "hover", "symbols", "rename"],
386
+ description:
387
+ "definition=go to definition, references=find all references, " +
388
+ "hover=type info and docs, symbols=list all symbols in file, " +
389
+ "rename=rename symbol across codebase",
390
+ },
391
+ file: {
392
+ type: "string",
393
+ description:
394
+ "File path (relative or absolute). Language server auto-detected from extension.",
395
+ },
396
+ line: {
397
+ type: "number",
398
+ description: "0-based line number (for definition, references, hover, rename)",
399
+ },
400
+ character: {
401
+ type: "number",
402
+ description: "0-based column/character offset (for definition, references, hover, rename)",
403
+ },
404
+ new_name: {
405
+ type: "string",
406
+ description: "New symbol name (for rename action only)",
407
+ },
408
+ },
409
+ required: ["action", "file"],
410
+ } as JSONSchema7,
411
+ riskLevel: "safe",
412
+ isReadOnly: true,
413
+ loadingTier: "always",
414
+ execute: executeLsp,
415
+ };
416
+
417
+ // ---------------------------------------------------------------------------
418
+ // serena — LSP intelligence via HTTP project server
419
+ // ---------------------------------------------------------------------------
420
+
421
+ const serena: Tool = {
422
+ name: "serena",
423
+ description:
424
+ "Compiler-accurate LSP symbol navigation and editing via Serena HTTP project server. " +
425
+ "Use for symbol-level operations by name path (not line/column). " +
426
+ "Actions: find_symbol, find_references, overview, replace_body, insert_after, insert_before, rename, search. " +
427
+ "Requires: uvx --from 'git+https://github.com/oraios/serena' serena start-project-server --port 9750",
428
+ category: "code",
429
+ parameters: {
430
+ type: "object",
431
+ properties: {
432
+ action: {
433
+ type: "string",
434
+ enum: [
435
+ "find_symbol",
436
+ "find_references",
437
+ "overview",
438
+ "replace_body",
439
+ "insert_after",
440
+ "insert_before",
441
+ "rename",
442
+ "search",
443
+ ],
444
+ description: "Serena action",
445
+ },
446
+ name_path: {
447
+ type: "string",
448
+ description: "Symbol name path: 'handleAuth', 'MyClass/myMethod', '/TopLevel/Nested'",
449
+ },
450
+ relative_path: { type: "string", description: "Restrict to file or directory" },
451
+ include_body: { type: "boolean", description: "Include source code of the symbol" },
452
+ include_info: { type: "boolean", description: "Include hover info (docstring, signature)" },
453
+ depth: { type: "number", description: "Descendants depth (1=immediate children)" },
454
+ body: { type: "string", description: "New code content (for replace_body/insert)" },
455
+ new_name: { type: "string", description: "New symbol name (for rename)" },
456
+ pattern: { type: "string", description: "Regex pattern (for search action)" },
457
+ context_before: { type: "number", description: "Context lines before match" },
458
+ context_after: { type: "number", description: "Context lines after match" },
459
+ paths_include: { type: "string", description: "Glob to include files" },
460
+ paths_exclude: { type: "string", description: "Glob to exclude files" },
461
+ extra_args: { type: "object", description: "Additional Serena API params" },
462
+ },
463
+ required: ["action"],
464
+ } as JSONSchema7,
465
+ riskLevel: "safe",
466
+ isReadOnly: true,
467
+ loadingTier: "always",
468
+ execute: executeSerena,
469
+ };
470
+
471
+ // ---------------------------------------------------------------------------
472
+ // fff — frecency-aware file finder
473
+ // ---------------------------------------------------------------------------
474
+
475
+ const fff: Tool = {
476
+ name: "fff",
477
+ description:
478
+ "Frecency-aware fuzzy file finder and grep (fff). Files you access often rank higher. " +
479
+ "3 actions: grep (search file contents), find_files (fuzzy file search by topic), " +
480
+ "multi_grep (OR-search across multiple patterns). Use constraints for filtering: " +
481
+ "'*.rs' (type), 'src/' (dir), 'schema.rs' (file), '!test/' (exclude).",
482
+ category: "code",
483
+ parameters: {
484
+ type: "object",
485
+ properties: {
486
+ action: {
487
+ type: "string",
488
+ enum: ["grep", "find_files", "multi_grep"],
489
+ description:
490
+ "grep=search contents, find_files=fuzzy file search, multi_grep=OR-search multiple patterns",
491
+ },
492
+ query: { type: "string", description: "Search text or topic description" },
493
+ patterns: {
494
+ type: "array",
495
+ items: { type: "string" },
496
+ description: "Multiple patterns for OR-search (multi_grep only)",
497
+ },
498
+ constraints: {
499
+ type: "string",
500
+ description:
501
+ "Inline constraints: '*.rs' (type), 'src/' (dir), 'schema.rs' (file), '!test/' (exclude)",
502
+ },
503
+ path: { type: "string", description: "Directory to search (default: working dir)" },
504
+ },
505
+ required: ["action"],
506
+ } as JSONSchema7,
507
+ riskLevel: "safe",
508
+ isReadOnly: true,
509
+ loadingTier: "always",
510
+ execute: executeFff,
511
+ };
512
+
513
+ // ---------------------------------------------------------------------------
514
+ // Export
515
+ // ---------------------------------------------------------------------------
516
+
517
+ export const CODE_INTELLIGENCE_TOOL_DEFINITIONS: Tool[] = [
518
+ rg,
519
+ ug,
520
+ probe,
521
+ sg,
522
+ cbm,
523
+ lsp,
524
+ serena,
525
+ fff,
526
+ ];
@@ -23,6 +23,9 @@ import { NETWORK_TOOL_DEFINITIONS } from "./network.js";
23
23
  import { DEPLOY_TOOL_DEFINITIONS } from "./deploy.js";
24
24
  import { META_TOOL_DEFINITIONS } from "./meta.js";
25
25
  import { SESSION_HISTORY_TOOL_DEFINITIONS } from "./session-history.js";
26
+ import { FRG_TOOL_DEFINITIONS } from "./frg.js";
27
+ import { CODE_INTELLIGENCE_TOOL_DEFINITIONS } from "./code-intelligence.js";
28
+ import { SEARCH_TOOL_DEFINITIONS } from "./search.js";
26
29
 
27
30
  // OpenClaw forks (MIT) — Playwright browser automation and background process management
28
31
  import { browserTool } from "./browser/index.js";
@@ -43,6 +46,9 @@ export { NETWORK_TOOL_DEFINITIONS } from "./network.js";
43
46
  export { DEPLOY_TOOL_DEFINITIONS } from "./deploy.js";
44
47
  export { META_TOOL_DEFINITIONS } from "./meta.js";
45
48
  export { SESSION_HISTORY_TOOL_DEFINITIONS } from "./session-history.js";
49
+ export { FRG_TOOL_DEFINITIONS } from "./frg.js";
50
+ export { CODE_INTELLIGENCE_TOOL_DEFINITIONS } from "./code-intelligence.js";
51
+ export { SEARCH_TOOL_DEFINITIONS } from "./search.js";
46
52
 
47
53
  /**
48
54
  * All core tool definitions
@@ -53,7 +59,7 @@ export const CORE_TOOL_DEFINITIONS: Tool[] = [
53
59
  // Web tools (3 + browser)
54
60
  ...WEB_TOOL_DEFINITIONS,
55
61
  browserTool,
56
- // Filesystem tools (8, includes forked apply_patch with fuzzy matching)
62
+ // Filesystem tools (6: read_file, write_file, edit_file, glob, ls, apply_patch)
57
63
  ...FILESYSTEM_TOOL_DEFINITIONS,
58
64
  // Shell tools (7 + process)
59
65
  ...SHELL_TOOL_DEFINITIONS,
@@ -75,6 +81,12 @@ export const CORE_TOOL_DEFINITIONS: Tool[] = [
75
81
  ...META_TOOL_DEFINITIONS,
76
82
  // Session History tools (1): session_history (list/search/get/current/stats/delete/set_title)
77
83
  ...SESSION_HISTORY_TOOL_DEFINITIONS,
84
+ // Fast regex native tool (1): frg (index/search/status/update/replace)
85
+ ...FRG_TOOL_DEFINITIONS,
86
+ // Code Intelligence tools (7): rg, ug, probe, sg, cbm, serena, fff
87
+ ...CODE_INTELLIGENCE_TOOL_DEFINITIONS,
88
+ // Native indexed grep (1): grep (replaces TS grep with n-gram indexed Rust NAPI)
89
+ ...SEARCH_TOOL_DEFINITIONS,
78
90
  ];
79
91
 
80
92
  /**
@@ -1,7 +1,8 @@
1
1
  /**
2
2
  * Filesystem tool definitions
3
3
  *
4
- * Tools: read_file, write_file, edit_file, glob, grep, ls, apply_patch (7 tools)
4
+ * Tools: read_file, write_file, edit_file, glob, ls, apply_patch (6 tools)
5
+ * Note: grep replaced by native indexed search in SEARCH_TOOL_DEFINITIONS
5
6
  */
6
7
 
7
8
  import type { JSONSchema7 } from "json-schema";
@@ -12,7 +13,6 @@ import {
12
13
  executeEditFile,
13
14
  executeLs,
14
15
  executeGlob,
15
- executeGrep,
16
16
  } from "../executors/index.js";
17
17
 
18
18
  const read_file: Tool = {
@@ -157,41 +157,6 @@ const glob: Tool = {
157
157
  execute: executeGlob,
158
158
  };
159
159
 
160
- const grep: Tool = {
161
- name: "grep",
162
- description: "Search for patterns in files using regular expressions.",
163
- category: "filesystem",
164
- parameters: {
165
- type: "object",
166
- properties: {
167
- pattern: {
168
- type: "string",
169
- description: "Regular expression pattern to search for",
170
- },
171
- path: {
172
- type: "string",
173
- description: "File or directory to search in",
174
- default: ".",
175
- },
176
- glob: {
177
- type: "string",
178
- description: "Glob pattern to filter files when searching a directory",
179
- default: "**/*",
180
- },
181
- ignoreCase: {
182
- type: "boolean",
183
- description: "Case-insensitive matching",
184
- default: false,
185
- },
186
- },
187
- required: ["pattern"],
188
- } as JSONSchema7,
189
- riskLevel: "safe",
190
- isReadOnly: true,
191
- loadingTier: "always",
192
- execute: executeGrep,
193
- };
194
-
195
160
  const ls: Tool = {
196
161
  name: "ls",
197
162
  description:
@@ -241,13 +206,12 @@ const ls: Tool = {
241
206
  // Replaces the simple inline version with the full implementation from ./patch/.
242
207
  import { applyPatchTool } from "./patch/index.js";
243
208
 
244
- /** Filesystem tool definitions (7) */
209
+ /** Filesystem tool definitions (6) — grep replaced by native indexed search in SEARCH_TOOL_DEFINITIONS */
245
210
  export const FILESYSTEM_TOOL_DEFINITIONS: Tool[] = [
246
211
  read_file,
247
212
  write_file,
248
213
  edit_file,
249
214
  glob,
250
- grep,
251
215
  ls,
252
216
  applyPatchTool,
253
217
  ];