@morphllm/morphsdk 0.2.68 → 0.2.69

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 (106) hide show
  1. package/dist/{chunk-6RFT7K7F.js → chunk-26QXQFLZ.js} +88 -23
  2. package/dist/chunk-26QXQFLZ.js.map +1 -0
  3. package/dist/{chunk-FURFQDXF.js → chunk-2LSVUHIE.js} +3 -3
  4. package/dist/{chunk-RTDKF6NS.js → chunk-5QIWYEHJ.js} +2 -2
  5. package/dist/{chunk-BYNVJ4ON.js → chunk-7CJPKJEE.js} +2 -2
  6. package/dist/{chunk-SXE54MIC.js → chunk-B3J2O2NW.js} +8 -8
  7. package/dist/{chunk-VDJGZIQ5.js → chunk-BGSHC2UK.js} +2 -2
  8. package/dist/{chunk-VLZEBK7S.js → chunk-E4434A4Y.js} +3 -3
  9. package/dist/{chunk-W76ICQKY.js → chunk-IUG2FHNN.js} +2 -2
  10. package/dist/{chunk-QEGH3CWQ.js → chunk-P6OEPI4N.js} +3 -3
  11. package/dist/chunk-PZ5AY32C.js +10 -0
  12. package/dist/{chunk-K3EHH3C4.js → chunk-Q6GHKKS5.js} +3 -3
  13. package/dist/{chunk-223ZMZP6.js → chunk-QIG7YPFW.js} +89 -30
  14. package/dist/chunk-QIG7YPFW.js.map +1 -0
  15. package/dist/{chunk-HBWJLKNM.js → chunk-QZNGKOCZ.js} +2 -2
  16. package/dist/{chunk-AAIUUX4Y.js → chunk-X4WPMVCM.js} +2 -2
  17. package/dist/{chunk-JPGX6WEV.js → chunk-XFCMTW5L.js} +3 -3
  18. package/dist/client.cjs +174 -434
  19. package/dist/client.cjs.map +1 -1
  20. package/dist/client.js +11 -12
  21. package/dist/git/client.js +1 -1
  22. package/dist/git/config.js +1 -1
  23. package/dist/git/index.js +1 -1
  24. package/dist/index.cjs +174 -434
  25. package/dist/index.cjs.map +1 -1
  26. package/dist/index.js +12 -13
  27. package/dist/modelrouter/core.js +1 -1
  28. package/dist/modelrouter/index.js +1 -1
  29. package/dist/tools/browser/anthropic.js +2 -2
  30. package/dist/tools/browser/core.js +1 -1
  31. package/dist/tools/browser/index.js +4 -4
  32. package/dist/tools/browser/live.js +1 -1
  33. package/dist/tools/browser/openai.js +2 -2
  34. package/dist/tools/browser/prompts.js +1 -1
  35. package/dist/tools/browser/vercel.js +2 -2
  36. package/dist/tools/codebase_search/anthropic.js +1 -1
  37. package/dist/tools/codebase_search/core.js +1 -1
  38. package/dist/tools/codebase_search/index.js +1 -1
  39. package/dist/tools/codebase_search/openai.js +1 -1
  40. package/dist/tools/codebase_search/prompts.js +1 -1
  41. package/dist/tools/codebase_search/vercel.js +1 -1
  42. package/dist/tools/fastapply/anthropic.js +2 -2
  43. package/dist/tools/fastapply/core.js +1 -1
  44. package/dist/tools/fastapply/index.js +4 -4
  45. package/dist/tools/fastapply/openai.js +2 -2
  46. package/dist/tools/fastapply/prompts.js +1 -1
  47. package/dist/tools/fastapply/vercel.js +2 -2
  48. package/dist/tools/index.js +4 -4
  49. package/dist/tools/utils/resilience.js +1 -1
  50. package/dist/tools/warp_grep/agent/config.js +1 -1
  51. package/dist/tools/warp_grep/agent/formatter.js +1 -1
  52. package/dist/tools/warp_grep/agent/parser.js +1 -1
  53. package/dist/tools/warp_grep/agent/prompt.js +1 -1
  54. package/dist/tools/warp_grep/agent/runner.js +1 -1
  55. package/dist/tools/warp_grep/anthropic.cjs +174 -434
  56. package/dist/tools/warp_grep/anthropic.cjs.map +1 -1
  57. package/dist/tools/warp_grep/anthropic.js +5 -6
  58. package/dist/tools/warp_grep/client.cjs +174 -434
  59. package/dist/tools/warp_grep/client.cjs.map +1 -1
  60. package/dist/tools/warp_grep/client.js +4 -5
  61. package/dist/tools/warp_grep/gemini.cjs +174 -434
  62. package/dist/tools/warp_grep/gemini.cjs.map +1 -1
  63. package/dist/tools/warp_grep/gemini.js +5 -6
  64. package/dist/tools/warp_grep/harness.cjs +88 -417
  65. package/dist/tools/warp_grep/harness.cjs.map +1 -1
  66. package/dist/tools/warp_grep/harness.js +2 -3
  67. package/dist/tools/warp_grep/harness.js.map +1 -1
  68. package/dist/tools/warp_grep/index.cjs +174 -434
  69. package/dist/tools/warp_grep/index.cjs.map +1 -1
  70. package/dist/tools/warp_grep/index.js +8 -9
  71. package/dist/tools/warp_grep/openai.cjs +174 -434
  72. package/dist/tools/warp_grep/openai.cjs.map +1 -1
  73. package/dist/tools/warp_grep/openai.js +5 -6
  74. package/dist/tools/warp_grep/providers/local.cjs +88 -417
  75. package/dist/tools/warp_grep/providers/local.cjs.map +1 -1
  76. package/dist/tools/warp_grep/providers/local.d.ts +0 -6
  77. package/dist/tools/warp_grep/providers/local.js +2 -3
  78. package/dist/tools/warp_grep/providers/remote.cjs +86 -408
  79. package/dist/tools/warp_grep/providers/remote.cjs.map +1 -1
  80. package/dist/tools/warp_grep/providers/remote.d.ts +0 -7
  81. package/dist/tools/warp_grep/providers/remote.js +2 -3
  82. package/dist/tools/warp_grep/utils/files.js +1 -1
  83. package/dist/tools/warp_grep/utils/paths.js +1 -1
  84. package/dist/tools/warp_grep/utils/ripgrep.js +1 -1
  85. package/dist/tools/warp_grep/vercel.cjs +174 -434
  86. package/dist/tools/warp_grep/vercel.cjs.map +1 -1
  87. package/dist/tools/warp_grep/vercel.js +5 -6
  88. package/package.json +1 -1
  89. package/dist/chunk-223ZMZP6.js.map +0 -1
  90. package/dist/chunk-6RFT7K7F.js.map +0 -1
  91. package/dist/chunk-HKJ2B2AA.js +0 -15
  92. package/dist/chunk-S6KU22MU.js +0 -396
  93. package/dist/chunk-S6KU22MU.js.map +0 -1
  94. /package/dist/{chunk-FURFQDXF.js.map → chunk-2LSVUHIE.js.map} +0 -0
  95. /package/dist/{chunk-RTDKF6NS.js.map → chunk-5QIWYEHJ.js.map} +0 -0
  96. /package/dist/{chunk-BYNVJ4ON.js.map → chunk-7CJPKJEE.js.map} +0 -0
  97. /package/dist/{chunk-SXE54MIC.js.map → chunk-B3J2O2NW.js.map} +0 -0
  98. /package/dist/{chunk-VDJGZIQ5.js.map → chunk-BGSHC2UK.js.map} +0 -0
  99. /package/dist/{chunk-VLZEBK7S.js.map → chunk-E4434A4Y.js.map} +0 -0
  100. /package/dist/{chunk-W76ICQKY.js.map → chunk-IUG2FHNN.js.map} +0 -0
  101. /package/dist/{chunk-QEGH3CWQ.js.map → chunk-P6OEPI4N.js.map} +0 -0
  102. /package/dist/{chunk-HKJ2B2AA.js.map → chunk-PZ5AY32C.js.map} +0 -0
  103. /package/dist/{chunk-K3EHH3C4.js.map → chunk-Q6GHKKS5.js.map} +0 -0
  104. /package/dist/{chunk-HBWJLKNM.js.map → chunk-QZNGKOCZ.js.map} +0 -0
  105. /package/dist/{chunk-AAIUUX4Y.js.map → chunk-X4WPMVCM.js.map} +0 -0
  106. /package/dist/{chunk-JPGX6WEV.js.map → chunk-XFCMTW5L.js.map} +0 -0
@@ -1,31 +1,97 @@
1
1
  import {
2
- require_ignore
3
- } from "./chunk-S6KU22MU.js";
4
- import {
5
- AGENT_CONFIG,
6
- DEFAULT_EXCLUDES
2
+ AGENT_CONFIG
7
3
  } from "./chunk-XT5ZO6ES.js";
8
4
 
9
5
  // tools/warp_grep/providers/remote.ts
10
- var ignore = require_ignore().default || require_ignore();
6
+ var SKIP_NAMES = /* @__PURE__ */ new Set([
7
+ // Version control
8
+ ".git",
9
+ ".svn",
10
+ ".hg",
11
+ ".bzr",
12
+ // Dependencies
13
+ "node_modules",
14
+ "bower_components",
15
+ ".pnpm",
16
+ ".yarn",
17
+ "vendor",
18
+ "Pods",
19
+ ".bundle",
20
+ // Python
21
+ "__pycache__",
22
+ ".pytest_cache",
23
+ ".mypy_cache",
24
+ ".ruff_cache",
25
+ ".venv",
26
+ "venv",
27
+ ".tox",
28
+ ".nox",
29
+ ".eggs",
30
+ // Build outputs
31
+ "dist",
32
+ "build",
33
+ "out",
34
+ "output",
35
+ "target",
36
+ "_build",
37
+ ".next",
38
+ ".nuxt",
39
+ ".output",
40
+ ".vercel",
41
+ ".netlify",
42
+ // Cache
43
+ ".cache",
44
+ ".parcel-cache",
45
+ ".turbo",
46
+ ".nx",
47
+ ".gradle",
48
+ // IDE
49
+ ".idea",
50
+ ".vscode",
51
+ ".vs",
52
+ // Coverage
53
+ "coverage",
54
+ ".coverage",
55
+ "htmlcov",
56
+ ".nyc_output",
57
+ // Temp
58
+ "tmp",
59
+ "temp",
60
+ ".tmp",
61
+ ".temp",
62
+ // Lock files
63
+ "package-lock.json",
64
+ "yarn.lock",
65
+ "pnpm-lock.yaml",
66
+ "bun.lockb",
67
+ "Cargo.lock",
68
+ "Gemfile.lock",
69
+ "poetry.lock"
70
+ ]);
71
+ var SKIP_EXTENSIONS = /* @__PURE__ */ new Set([
72
+ ".min.js",
73
+ ".min.css",
74
+ ".bundle.js",
75
+ ".wasm",
76
+ ".so",
77
+ ".dll",
78
+ ".pyc",
79
+ ".map",
80
+ ".js.map"
81
+ ]);
82
+ function shouldSkip(name) {
83
+ if (SKIP_NAMES.has(name)) return true;
84
+ if (name.startsWith(".")) return true;
85
+ for (const ext of SKIP_EXTENSIONS) {
86
+ if (name.endsWith(ext)) return true;
87
+ }
88
+ return false;
89
+ }
11
90
  var RemoteCommandsProvider = class {
12
91
  constructor(repoRoot, commands) {
13
92
  this.repoRoot = repoRoot;
14
93
  this.commands = commands;
15
94
  }
16
- ignoreFilter = null;
17
- /**
18
- * Build an ignore filter from DEFAULT_EXCLUDES.
19
- * Note: For remote providers, we can't read .gitignore from the remote sandbox,
20
- * so we only use the built-in excludes.
21
- */
22
- getIgnoreFilter() {
23
- if (this.ignoreFilter) return this.ignoreFilter;
24
- const ig = ignore();
25
- ig.add(DEFAULT_EXCLUDES);
26
- this.ignoreFilter = ig;
27
- return ig;
28
- }
29
95
  /**
30
96
  * Run grep command and parse ripgrep output
31
97
  */
@@ -79,7 +145,6 @@ var RemoteCommandsProvider = class {
79
145
  async listDirectory(params) {
80
146
  const maxDepth = params.maxDepth ?? AGENT_CONFIG.MAX_LIST_DEPTH;
81
147
  const maxResults = params.maxResults ?? AGENT_CONFIG.MAX_OUTPUT_LINES;
82
- const ig = this.getIgnoreFilter();
83
148
  try {
84
149
  const stdout = await this.commands.listDir(params.path, maxDepth);
85
150
  const paths = (stdout || "").trim().split(/\r?\n/).filter((p) => p.length > 0);
@@ -88,12 +153,12 @@ var RemoteCommandsProvider = class {
88
153
  for (const fullPath of paths) {
89
154
  if (fullPath === params.path || fullPath === this.repoRoot) continue;
90
155
  const name = fullPath.split("/").pop() || "";
156
+ if (shouldSkip(name)) continue;
157
+ if (regex && !regex.test(name)) continue;
91
158
  let relativePath = fullPath;
92
159
  if (fullPath.startsWith(this.repoRoot)) {
93
160
  relativePath = fullPath.slice(this.repoRoot.length).replace(/^\//, "");
94
161
  }
95
- if (ig.ignores(relativePath)) continue;
96
- if (regex && !regex.test(name)) continue;
97
162
  const depth = relativePath.split("/").filter(Boolean).length - 1;
98
163
  const hasExtension = name.includes(".") && !name.startsWith(".");
99
164
  const type = hasExtension ? "file" : "dir";
@@ -115,4 +180,4 @@ var RemoteCommandsProvider = class {
115
180
  export {
116
181
  RemoteCommandsProvider
117
182
  };
118
- //# sourceMappingURL=chunk-6RFT7K7F.js.map
183
+ //# sourceMappingURL=chunk-26QXQFLZ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../tools/warp_grep/providers/remote.ts"],"sourcesContent":["/**\n * RemoteCommandsProvider - wraps simple RemoteCommands into WarpGrepProvider\n * \n * Handles parsing of raw stdout from grep/read/listDir commands.\n * Users just return stdout, SDK handles all format conversion.\n */\n\nimport type { WarpGrepProvider, GrepResult, ReadResult, ListDirectoryEntry } from './types.js';\nimport type { RemoteCommands } from '../types.js';\nimport { AGENT_CONFIG } from '../agent/config.js';\n\n/**\n * Directories/files to always skip (exact name match)\n */\nconst SKIP_NAMES = new Set([\n // Version control\n '.git', '.svn', '.hg', '.bzr',\n // Dependencies\n 'node_modules', 'bower_components', '.pnpm', '.yarn',\n 'vendor', 'Pods', '.bundle',\n // Python\n '__pycache__', '.pytest_cache', '.mypy_cache', '.ruff_cache',\n '.venv', 'venv', '.tox', '.nox', '.eggs',\n // Build outputs\n 'dist', 'build', 'out', 'output', 'target', '_build',\n '.next', '.nuxt', '.output', '.vercel', '.netlify',\n // Cache\n '.cache', '.parcel-cache', '.turbo', '.nx', '.gradle',\n // IDE\n '.idea', '.vscode', '.vs',\n // Coverage\n 'coverage', '.coverage', 'htmlcov', '.nyc_output',\n // Temp\n 'tmp', 'temp', '.tmp', '.temp',\n // Lock files\n 'package-lock.json', 'yarn.lock', 'pnpm-lock.yaml', 'bun.lockb',\n 'Cargo.lock', 'Gemfile.lock', 'poetry.lock',\n]);\n\n/**\n * File extensions to skip\n */\nconst SKIP_EXTENSIONS = new Set([\n '.min.js', '.min.css', '.bundle.js',\n '.wasm', '.so', '.dll', '.pyc',\n '.map', '.js.map',\n]);\n\n/**\n * Check if a filename should be skipped\n */\nfunction shouldSkip(name: string): boolean {\n // Skip exact name matches\n if (SKIP_NAMES.has(name)) return true;\n \n // Skip hidden files/directories (start with .)\n if (name.startsWith('.')) return true;\n \n // Skip files with certain extensions\n for (const ext of SKIP_EXTENSIONS) {\n if (name.endsWith(ext)) return true;\n }\n \n return false;\n}\n\n/**\n * Wraps simple RemoteCommands functions into a full WarpGrepProvider.\n * \n * This allows users to provide three simple functions that return raw stdout,\n * and the SDK handles all parsing internally.\n * \n * @example\n * ```typescript\n * const provider = new RemoteCommandsProvider('/home/repo', {\n * grep: async (pattern, path) => {\n * const r = await sandbox.run(`rg '${pattern}' '${path}'`);\n * return r.stdout;\n * },\n * read: async (path, start, end) => {\n * const r = await sandbox.run(`sed -n '${start},${end}p' '${path}'`);\n * return r.stdout;\n * },\n * listDir: async (path, maxDepth) => {\n * const r = await sandbox.run(`find '${path}' -maxdepth ${maxDepth}`);\n * return r.stdout;\n * },\n * });\n * ```\n */\nexport class RemoteCommandsProvider implements WarpGrepProvider {\n constructor(\n private readonly repoRoot: string,\n private readonly commands: RemoteCommands\n ) {}\n\n /**\n * Run grep command and parse ripgrep output\n */\n async grep(params: { pattern: string; path: string; glob?: string }): Promise<GrepResult> {\n try {\n const stdout = await this.commands.grep(params.pattern, params.path, params.glob);\n \n // Parse ripgrep output: each line is \"path:line:content\" or \"path-line-content\" for context\n const lines = (stdout || '')\n .trim()\n .split(/\\r?\\n/)\n .filter((l) => l.length > 0);\n \n // Check if output is too large\n if (lines.length > AGENT_CONFIG.MAX_OUTPUT_LINES) {\n return {\n lines: [],\n error: 'Query not specific enough - too many results returned. Try a more specific pattern.',\n };\n }\n \n return { lines };\n } catch (error) {\n return {\n lines: [],\n error: `[GREP ERROR] ${error instanceof Error ? error.message : String(error)}`,\n };\n }\n }\n\n /**\n * Read file and add line numbers\n */\n async read(params: { path: string; start?: number; end?: number }): Promise<ReadResult> {\n const start = params.start ?? 1;\n const end = params.end ?? 1_000_000;\n \n try {\n const stdout = await this.commands.read(params.path, start, end);\n \n // Split content into lines and add line numbers\n const contentLines = (stdout || '').split('\\n');\n \n // Remove trailing empty line if present (common with sed output)\n if (contentLines.length > 0 && contentLines[contentLines.length - 1] === '') {\n contentLines.pop();\n }\n \n // Format as \"lineNumber|content\"\n const lines = contentLines.map((content, idx) => `${start + idx}|${content}`);\n \n // Check if output is too large\n if (lines.length > AGENT_CONFIG.MAX_READ_LINES) {\n const truncated = lines.slice(0, AGENT_CONFIG.MAX_READ_LINES);\n truncated.push(`... [truncated: showing ${AGENT_CONFIG.MAX_READ_LINES} of ${lines.length} lines]`);\n return { lines: truncated };\n }\n \n return { lines };\n } catch (error) {\n return {\n lines: [],\n error: `[READ ERROR] ${error instanceof Error ? error.message : String(error)}`,\n };\n }\n }\n\n /**\n * List directory and parse find output\n */\n async listDirectory(params: { \n path: string; \n pattern?: string | null; \n maxResults?: number; \n maxDepth?: number;\n }): Promise<ListDirectoryEntry[]> {\n const maxDepth = params.maxDepth ?? AGENT_CONFIG.MAX_LIST_DEPTH;\n const maxResults = params.maxResults ?? AGENT_CONFIG.MAX_OUTPUT_LINES;\n \n try {\n const stdout = await this.commands.listDir(params.path, maxDepth);\n \n // Parse find output: one path per line\n const paths = (stdout || '')\n .trim()\n .split(/\\r?\\n/)\n .filter((p) => p.length > 0);\n \n const regex = params.pattern ? new RegExp(params.pattern) : null;\n const entries: ListDirectoryEntry[] = [];\n \n for (const fullPath of paths) {\n // Skip the root path itself\n if (fullPath === params.path || fullPath === this.repoRoot) continue;\n \n const name = fullPath.split('/').pop() || '';\n \n // Simple name-based filtering - skip junk dirs/files\n if (shouldSkip(name)) continue;\n \n // Apply pattern filter if provided\n if (regex && !regex.test(name)) continue;\n \n // Determine relative path\n let relativePath = fullPath;\n if (fullPath.startsWith(this.repoRoot)) {\n relativePath = fullPath.slice(this.repoRoot.length).replace(/^\\//, '');\n }\n \n // Calculate depth based on path separators\n const depth = relativePath.split('/').filter(Boolean).length - 1;\n \n // Determine if it's a directory (ends with / or infer from path structure)\n // Note: Most sandbox find commands don't indicate type, so we guess based on extension\n const hasExtension = name.includes('.') && !name.startsWith('.');\n const type: 'file' | 'dir' = hasExtension ? 'file' : 'dir';\n \n entries.push({\n name,\n path: relativePath,\n type,\n depth: Math.max(0, depth),\n });\n \n if (entries.length >= maxResults) break;\n }\n \n return entries;\n } catch (error) {\n // Return empty array on error (consistent with LocalRipgrepProvider)\n return [];\n }\n }\n}\n\n\n\n\n"],"mappings":"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","names":[]}
@@ -5,13 +5,13 @@ import {
5
5
  import {
6
6
  executeToolCall,
7
7
  formatResult
8
- } from "./chunk-VLZEBK7S.js";
8
+ } from "./chunk-E4434A4Y.js";
9
9
  import {
10
10
  getSystemPrompt
11
11
  } from "./chunk-Q5AHGIQO.js";
12
12
  import {
13
13
  __export
14
- } from "./chunk-HKJ2B2AA.js";
14
+ } from "./chunk-PZ5AY32C.js";
15
15
 
16
16
  // tools/warp_grep/gemini.ts
17
17
  var gemini_exports = {};
@@ -72,4 +72,4 @@ export {
72
72
  gemini_default,
73
73
  gemini_exports
74
74
  };
75
- //# sourceMappingURL=chunk-FURFQDXF.js.map
75
+ //# sourceMappingURL=chunk-2LSVUHIE.js.map
@@ -7,7 +7,7 @@ import {
7
7
  } from "./chunk-63WE2C5R.js";
8
8
  import {
9
9
  __export
10
- } from "./chunk-HKJ2B2AA.js";
10
+ } from "./chunk-PZ5AY32C.js";
11
11
 
12
12
  // tools/fastapply/openai.ts
13
13
  var openai_exports = {};
@@ -103,4 +103,4 @@ export {
103
103
  openai_default,
104
104
  openai_exports
105
105
  };
106
- //# sourceMappingURL=chunk-RTDKF6NS.js.map
106
+ //# sourceMappingURL=chunk-5QIWYEHJ.js.map
@@ -6,7 +6,7 @@ import {
6
6
  } from "./chunk-MFZP347Z.js";
7
7
  import {
8
8
  __export
9
- } from "./chunk-HKJ2B2AA.js";
9
+ } from "./chunk-PZ5AY32C.js";
10
10
 
11
11
  // tools/browser/vercel.ts
12
12
  var vercel_exports = {};
@@ -54,4 +54,4 @@ export {
54
54
  browserTool,
55
55
  vercel_exports
56
56
  };
57
- //# sourceMappingURL=chunk-BYNVJ4ON.js.map
57
+ //# sourceMappingURL=chunk-7CJPKJEE.js.map
@@ -1,15 +1,15 @@
1
1
  import {
2
2
  createWarpGrepTool as createWarpGrepTool2
3
- } from "./chunk-K3EHH3C4.js";
3
+ } from "./chunk-Q6GHKKS5.js";
4
4
  import {
5
5
  createWarpGrepTool
6
- } from "./chunk-JPGX6WEV.js";
6
+ } from "./chunk-XFCMTW5L.js";
7
7
  import {
8
8
  createWarpGrepTool as createWarpGrepTool3
9
- } from "./chunk-QEGH3CWQ.js";
9
+ } from "./chunk-P6OEPI4N.js";
10
10
  import {
11
11
  WarpGrepClient
12
- } from "./chunk-VLZEBK7S.js";
12
+ } from "./chunk-E4434A4Y.js";
13
13
  import {
14
14
  createCodebaseSearchTool as createCodebaseSearchTool3
15
15
  } from "./chunk-UBX7QYBD.js";
@@ -24,13 +24,13 @@ import {
24
24
  } from "./chunk-WM77HRKO.js";
25
25
  import {
26
26
  createEditFileTool as createEditFileTool2
27
- } from "./chunk-W76ICQKY.js";
27
+ } from "./chunk-IUG2FHNN.js";
28
28
  import {
29
29
  createEditFileTool
30
- } from "./chunk-RTDKF6NS.js";
30
+ } from "./chunk-5QIWYEHJ.js";
31
31
  import {
32
32
  createEditFileTool as createEditFileTool3
33
- } from "./chunk-HBWJLKNM.js";
33
+ } from "./chunk-QZNGKOCZ.js";
34
34
  import {
35
35
  FastApplyClient
36
36
  } from "./chunk-CKTA4AXM.js";
@@ -280,4 +280,4 @@ export {
280
280
  VercelToolFactory,
281
281
  MorphClient
282
282
  };
283
- //# sourceMappingURL=chunk-SXE54MIC.js.map
283
+ //# sourceMappingURL=chunk-B3J2O2NW.js.map
@@ -7,7 +7,7 @@ import {
7
7
  } from "./chunk-MFZP347Z.js";
8
8
  import {
9
9
  __export
10
- } from "./chunk-HKJ2B2AA.js";
10
+ } from "./chunk-PZ5AY32C.js";
11
11
 
12
12
  // tools/browser/openai.ts
13
13
  var openai_exports = {};
@@ -93,4 +93,4 @@ export {
93
93
  createBrowserTool,
94
94
  openai_exports
95
95
  };
96
- //# sourceMappingURL=chunk-VDJGZIQ5.js.map
96
+ //# sourceMappingURL=chunk-BGSHC2UK.js.map
@@ -3,10 +3,10 @@ import {
3
3
  } from "./chunk-SUBBMTMY.js";
4
4
  import {
5
5
  RemoteCommandsProvider
6
- } from "./chunk-6RFT7K7F.js";
6
+ } from "./chunk-26QXQFLZ.js";
7
7
  import {
8
8
  LocalRipgrepProvider
9
- } from "./chunk-223ZMZP6.js";
9
+ } from "./chunk-QIG7YPFW.js";
10
10
 
11
11
  // tools/warp_grep/client.ts
12
12
  var WarpGrepClient = class {
@@ -115,4 +115,4 @@ export {
115
115
  executeToolCall,
116
116
  formatResult
117
117
  };
118
- //# sourceMappingURL=chunk-VLZEBK7S.js.map
118
+ //# sourceMappingURL=chunk-E4434A4Y.js.map
@@ -7,7 +7,7 @@ import {
7
7
  } from "./chunk-63WE2C5R.js";
8
8
  import {
9
9
  __export
10
- } from "./chunk-HKJ2B2AA.js";
10
+ } from "./chunk-PZ5AY32C.js";
11
11
 
12
12
  // tools/fastapply/anthropic.ts
13
13
  var anthropic_exports = {};
@@ -91,4 +91,4 @@ export {
91
91
  getSystemPrompt,
92
92
  anthropic_exports
93
93
  };
94
- //# sourceMappingURL=chunk-W76ICQKY.js.map
94
+ //# sourceMappingURL=chunk-IUG2FHNN.js.map
@@ -4,13 +4,13 @@ import {
4
4
  import {
5
5
  executeToolCall,
6
6
  formatResult
7
- } from "./chunk-VLZEBK7S.js";
7
+ } from "./chunk-E4434A4Y.js";
8
8
  import {
9
9
  getSystemPrompt
10
10
  } from "./chunk-Q5AHGIQO.js";
11
11
  import {
12
12
  __export
13
- } from "./chunk-HKJ2B2AA.js";
13
+ } from "./chunk-PZ5AY32C.js";
14
14
 
15
15
  // tools/warp_grep/vercel.ts
16
16
  var vercel_exports = {};
@@ -54,4 +54,4 @@ export {
54
54
  vercel_default,
55
55
  vercel_exports
56
56
  };
57
- //# sourceMappingURL=chunk-QEGH3CWQ.js.map
57
+ //# sourceMappingURL=chunk-P6OEPI4N.js.map
@@ -0,0 +1,10 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __export = (target, all) => {
3
+ for (var name in all)
4
+ __defProp(target, name, { get: all[name], enumerable: true });
5
+ };
6
+
7
+ export {
8
+ __export
9
+ };
10
+ //# sourceMappingURL=chunk-PZ5AY32C.js.map
@@ -5,13 +5,13 @@ import {
5
5
  import {
6
6
  executeToolCall,
7
7
  formatResult
8
- } from "./chunk-VLZEBK7S.js";
8
+ } from "./chunk-E4434A4Y.js";
9
9
  import {
10
10
  getSystemPrompt
11
11
  } from "./chunk-Q5AHGIQO.js";
12
12
  import {
13
13
  __export
14
- } from "./chunk-HKJ2B2AA.js";
14
+ } from "./chunk-PZ5AY32C.js";
15
15
 
16
16
  // tools/warp_grep/anthropic.ts
17
17
  var anthropic_exports = {};
@@ -62,4 +62,4 @@ export {
62
62
  createWarpGrepTool,
63
63
  anthropic_exports
64
64
  };
65
- //# sourceMappingURL=chunk-K3EHH3C4.js.map
65
+ //# sourceMappingURL=chunk-Q6GHKKS5.js.map
@@ -10,9 +10,6 @@ import {
10
10
  import {
11
11
  runRipgrep
12
12
  } from "./chunk-TPP2UGQP.js";
13
- import {
14
- require_ignore
15
- } from "./chunk-S6KU22MU.js";
16
13
  import {
17
14
  AGENT_CONFIG,
18
15
  DEFAULT_EXCLUDES
@@ -21,30 +18,95 @@ import {
21
18
  // tools/warp_grep/providers/local.ts
22
19
  import fs from "fs/promises";
23
20
  import path from "path";
24
- var ignore = require_ignore().default || require_ignore();
21
+ var SKIP_NAMES = /* @__PURE__ */ new Set([
22
+ // Version control
23
+ ".git",
24
+ ".svn",
25
+ ".hg",
26
+ ".bzr",
27
+ // Dependencies
28
+ "node_modules",
29
+ "bower_components",
30
+ ".pnpm",
31
+ ".yarn",
32
+ "vendor",
33
+ "Pods",
34
+ ".bundle",
35
+ // Python
36
+ "__pycache__",
37
+ ".pytest_cache",
38
+ ".mypy_cache",
39
+ ".ruff_cache",
40
+ ".venv",
41
+ "venv",
42
+ ".tox",
43
+ ".nox",
44
+ ".eggs",
45
+ // Build outputs
46
+ "dist",
47
+ "build",
48
+ "out",
49
+ "output",
50
+ "target",
51
+ "_build",
52
+ ".next",
53
+ ".nuxt",
54
+ ".output",
55
+ ".vercel",
56
+ ".netlify",
57
+ // Cache
58
+ ".cache",
59
+ ".parcel-cache",
60
+ ".turbo",
61
+ ".nx",
62
+ ".gradle",
63
+ // IDE
64
+ ".idea",
65
+ ".vscode",
66
+ ".vs",
67
+ // Coverage
68
+ "coverage",
69
+ ".coverage",
70
+ "htmlcov",
71
+ ".nyc_output",
72
+ // Temp
73
+ "tmp",
74
+ "temp",
75
+ ".tmp",
76
+ ".temp",
77
+ // Lock files
78
+ "package-lock.json",
79
+ "yarn.lock",
80
+ "pnpm-lock.yaml",
81
+ "bun.lockb",
82
+ "Cargo.lock",
83
+ "Gemfile.lock",
84
+ "poetry.lock"
85
+ ]);
86
+ var SKIP_EXTENSIONS = /* @__PURE__ */ new Set([
87
+ ".min.js",
88
+ ".min.css",
89
+ ".bundle.js",
90
+ ".wasm",
91
+ ".so",
92
+ ".dll",
93
+ ".pyc",
94
+ ".map",
95
+ ".js.map"
96
+ ]);
97
+ function shouldSkip(name) {
98
+ if (SKIP_NAMES.has(name)) return true;
99
+ if (name.startsWith(".")) return true;
100
+ for (const ext of SKIP_EXTENSIONS) {
101
+ if (name.endsWith(ext)) return true;
102
+ }
103
+ return false;
104
+ }
25
105
  var LocalRipgrepProvider = class {
26
106
  constructor(repoRoot, excludes = DEFAULT_EXCLUDES) {
27
107
  this.repoRoot = repoRoot;
28
108
  this.excludes = excludes;
29
109
  }
30
- ignoreFilter = null;
31
- /**
32
- * Build an ignore filter that combines DEFAULT_EXCLUDES and .gitignore patterns.
33
- * Cached after first call.
34
- */
35
- async getIgnoreFilter() {
36
- if (this.ignoreFilter) return this.ignoreFilter;
37
- const ig = ignore();
38
- ig.add(this.excludes);
39
- try {
40
- const gitignorePath = path.join(this.repoRoot, ".gitignore");
41
- const gitignoreContent = await fs.readFile(gitignorePath, "utf-8");
42
- ig.add(gitignoreContent);
43
- } catch {
44
- }
45
- this.ignoreFilter = ig;
46
- return ig;
47
- }
48
110
  async grep(params) {
49
111
  let abs;
50
112
  try {
@@ -172,11 +234,10 @@ Details: ${res.stderr}` : ""}`
172
234
  const maxResults = params.maxResults ?? AGENT_CONFIG.MAX_OUTPUT_LINES;
173
235
  const maxDepth = params.maxDepth ?? AGENT_CONFIG.MAX_LIST_DEPTH;
174
236
  const regex = params.pattern ? new RegExp(params.pattern) : null;
175
- const ig = await this.getIgnoreFilter();
237
+ const repoRoot = this.repoRoot;
176
238
  const results = [];
177
239
  let timedOut = false;
178
240
  const startTime = Date.now();
179
- const repoRoot = this.repoRoot;
180
241
  async function walk(dir, depth) {
181
242
  if (Date.now() - startTime > AGENT_CONFIG.LIST_TIMEOUT_MS) {
182
243
  timedOut = true;
@@ -186,15 +247,13 @@ Details: ${res.stderr}` : ""}`
186
247
  const entries = await fs.readdir(dir, { withFileTypes: true });
187
248
  for (const entry of entries) {
188
249
  if (timedOut || results.length >= maxResults) break;
250
+ if (shouldSkip(entry.name)) continue;
251
+ if (regex && !regex.test(entry.name)) continue;
189
252
  const full = path.join(dir, entry.name);
190
- const relToRepo = toRepoRelative(repoRoot, full).replace(/^[.][/\\]?/, "");
191
253
  const isDir = entry.isDirectory();
192
- if (ig.ignores(relToRepo) || isDir && ig.ignores(relToRepo + "/")) continue;
193
- if (regex && !regex.test(entry.name)) continue;
194
254
  results.push({
195
255
  name: entry.name,
196
- path: toRepoRelative(path.resolve(""), full),
197
- // relative display
256
+ path: toRepoRelative(repoRoot, full),
198
257
  type: isDir ? "dir" : "file",
199
258
  depth
200
259
  });
@@ -211,4 +270,4 @@ Details: ${res.stderr}` : ""}`
211
270
  export {
212
271
  LocalRipgrepProvider
213
272
  };
214
- //# sourceMappingURL=chunk-223ZMZP6.js.map
273
+ //# sourceMappingURL=chunk-QIG7YPFW.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../tools/warp_grep/providers/local.ts"],"sourcesContent":["import fs from 'fs/promises';\nimport fssync from 'fs';\nimport path from 'path';\nimport { runRipgrep } from '../utils/ripgrep.js';\nimport { ensureWithinRepo, resolveUnderRepo, toRepoRelative, isSymlink, isTextualFile } from '../utils/paths.js';\nimport type { WarpGrepProvider, GrepResult, ReadResult, ListDirectoryEntry } from './types.js';\nimport { readAllLines } from '../utils/files.js';\nimport { DEFAULT_EXCLUDES, AGENT_CONFIG } from '../agent/config.js';\n\n/**\n * Directories/files to always skip (exact name match)\n */\nconst SKIP_NAMES = new Set([\n // Version control\n '.git', '.svn', '.hg', '.bzr',\n // Dependencies\n 'node_modules', 'bower_components', '.pnpm', '.yarn',\n 'vendor', 'Pods', '.bundle',\n // Python\n '__pycache__', '.pytest_cache', '.mypy_cache', '.ruff_cache',\n '.venv', 'venv', '.tox', '.nox', '.eggs',\n // Build outputs\n 'dist', 'build', 'out', 'output', 'target', '_build',\n '.next', '.nuxt', '.output', '.vercel', '.netlify',\n // Cache\n '.cache', '.parcel-cache', '.turbo', '.nx', '.gradle',\n // IDE\n '.idea', '.vscode', '.vs',\n // Coverage\n 'coverage', '.coverage', 'htmlcov', '.nyc_output',\n // Temp\n 'tmp', 'temp', '.tmp', '.temp',\n // Lock files\n 'package-lock.json', 'yarn.lock', 'pnpm-lock.yaml', 'bun.lockb',\n 'Cargo.lock', 'Gemfile.lock', 'poetry.lock',\n]);\n\n/**\n * File extensions to skip\n */\nconst SKIP_EXTENSIONS = new Set([\n '.min.js', '.min.css', '.bundle.js',\n '.wasm', '.so', '.dll', '.pyc',\n '.map', '.js.map',\n]);\n\n/**\n * Check if a filename should be skipped\n */\nfunction shouldSkip(name: string): boolean {\n // Skip exact name matches\n if (SKIP_NAMES.has(name)) return true;\n \n // Skip hidden files/directories (start with .)\n if (name.startsWith('.')) return true;\n \n // Skip files with certain extensions\n for (const ext of SKIP_EXTENSIONS) {\n if (name.endsWith(ext)) return true;\n }\n \n return false;\n}\n\nexport class LocalRipgrepProvider implements WarpGrepProvider {\n constructor(private readonly repoRoot: string, private readonly excludes: string[] = DEFAULT_EXCLUDES) {}\n\n async grep(params: { pattern: string; path: string; glob?: string }): Promise<GrepResult> {\n let abs: string;\n try {\n abs = resolveUnderRepo(this.repoRoot, params.path);\n } catch (err) {\n return {\n lines: [],\n error: `[PATH ERROR] ${err instanceof Error ? err.message : String(err)}`,\n };\n }\n const stat = await fs.stat(abs).catch(() => null);\n if (!stat) return { lines: [] };\n const targetArg = abs === path.resolve(this.repoRoot) ? '.' : toRepoRelative(this.repoRoot, abs);\n const args = [\n '--no-config',\n '--no-heading',\n '--with-filename',\n '--line-number',\n '--color=never',\n '--trim',\n '--max-columns=400',\n '-C', '1',\n ...(params.glob ? ['--glob', params.glob] : []),\n ...this.excludes.flatMap((e) => ['-g', `!${e}`]),\n params.pattern,\n targetArg || '.',\n ];\n const res = await runRipgrep(args, { cwd: this.repoRoot });\n \n // Gracefully handle ripgrep not being available\n if (res.exitCode === -1) {\n return {\n lines: [],\n error: `[RIPGREP NOT AVAILABLE] ripgrep (rg) is required but failed to execute. Please install it:\\n` +\n ` • macOS: brew install ripgrep\\n` +\n ` • Ubuntu/Debian: apt install ripgrep\\n` +\n ` • Windows: choco install ripgrep\\n` +\n ` • Or visit: https://github.com/BurntSushi/ripgrep#installation\\n` +\n `Exit code: ${res.exitCode}${res.stderr ? `\\nDetails: ${res.stderr}` : ''}`,\n };\n }\n \n // Handle other ripgrep errors gracefully\n if (res.exitCode !== 0 && res.exitCode !== 1) {\n return {\n lines: [],\n error: `[RIPGREP ERROR] grep failed with exit code ${res.exitCode}${res.stderr ? `: ${res.stderr}` : ''}`,\n };\n }\n \n const lines = (res.stdout || '')\n .trim()\n .split(/\\r?\\n/)\n .filter((l) => l.length > 0);\n if (lines.length > AGENT_CONFIG.MAX_OUTPUT_LINES) {\n return {\n lines: [],\n error: 'query not specific enough, tool tried to return too much context and failed',\n };\n }\n \n return { lines };\n }\n\n async read(params: { path: string; start?: number; end?: number }): Promise<ReadResult> {\n let abs: string;\n try {\n abs = resolveUnderRepo(this.repoRoot, params.path);\n } catch (err) {\n return {\n lines: [],\n error: `[PATH ERROR] ${err instanceof Error ? err.message : String(err)}`,\n };\n }\n const stat = await fs.stat(abs).catch(() => null);\n \n // Gracefully handle file not found / not a file\n if (!stat || !stat.isFile()) {\n return {\n lines: [],\n error: `[FILE NOT FOUND] You tried to read \"${params.path}\" but there is no file at this path. ` +\n `Double-check the path exists and is spelled correctly.`,\n };\n }\n \n // Gracefully handle symlinks\n if (isSymlink(abs)) {\n return {\n lines: [],\n error: `[SYMLINK] You tried to read \"${params.path}\" but this is a symlink. ` +\n `Try reading the actual file it points to instead.`,\n };\n }\n \n // Gracefully handle non-text or too-large files\n if (!isTextualFile(abs)) {\n return {\n lines: [],\n error: `[UNREADABLE FILE] You tried to read \"${params.path}\" but this file is either too large ` +\n `or not a text file, so it cannot be read. Try a different file.`,\n };\n }\n \n let lines: string[];\n try {\n lines = await readAllLines(abs);\n } catch (err) {\n return {\n lines: [],\n error: `[READ ERROR] Failed to read \"${params.path}\": ${err instanceof Error ? err.message : String(err)}`,\n };\n }\n const total = lines.length;\n let s = params.start ?? 1;\n let e = Math.min(params.end ?? total, total);\n if (s > total && total > 0) {\n // Model hallucinated range - fallback to full file\n s = 1;\n e = total;\n }\n const out: string[] = [];\n for (let i = s; i <= e; i += 1) {\n const content = lines[i - 1] ?? '';\n out.push(`${i}|${content}`);\n }\n if (out.length > AGENT_CONFIG.MAX_READ_LINES) {\n const truncated = out.slice(0, AGENT_CONFIG.MAX_READ_LINES);\n truncated.push(`... [truncated: showing ${AGENT_CONFIG.MAX_READ_LINES} of ${out.length} lines]`);\n return { lines: truncated };\n }\n \n return { lines: out };\n }\n\n async listDirectory(params: { path: string; pattern?: string | null; maxResults?: number; maxDepth?: number }): Promise<ListDirectoryEntry[]> {\n let abs: string;\n try {\n abs = resolveUnderRepo(this.repoRoot, params.path);\n } catch {\n // Path outside repo - return empty (graceful failure)\n return [];\n }\n const stat = await fs.stat(abs).catch(() => null);\n if (!stat || !stat.isDirectory()) {\n return [];\n }\n const maxResults = params.maxResults ?? AGENT_CONFIG.MAX_OUTPUT_LINES;\n const maxDepth = params.maxDepth ?? AGENT_CONFIG.MAX_LIST_DEPTH;\n const regex = params.pattern ? new RegExp(params.pattern) : null;\n const repoRoot = this.repoRoot;\n\n const results: ListDirectoryEntry[] = [];\n let timedOut = false;\n const startTime = Date.now();\n \n async function walk(dir: string, depth: number) {\n if (Date.now() - startTime > AGENT_CONFIG.LIST_TIMEOUT_MS) {\n timedOut = true;\n return;\n }\n if (depth > maxDepth || results.length >= maxResults) return;\n const entries = await fs.readdir(dir, { withFileTypes: true });\n for (const entry of entries) {\n if (timedOut || results.length >= maxResults) break;\n \n // Simple name-based filtering - skip junk dirs/files\n if (shouldSkip(entry.name)) continue;\n \n // Apply user-provided pattern filter\n if (regex && !regex.test(entry.name)) continue;\n \n const full = path.join(dir, entry.name);\n const isDir = entry.isDirectory();\n \n results.push({\n name: entry.name,\n path: toRepoRelative(repoRoot, full),\n type: isDir ? 'dir' : 'file',\n depth,\n });\n if (isDir) {\n await walk(full, depth + 1);\n }\n }\n }\n await walk(abs, 0);\n return results;\n }\n}\n\n\n"],"mappings":"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","names":[]}
@@ -7,7 +7,7 @@ import {
7
7
  } from "./chunk-63WE2C5R.js";
8
8
  import {
9
9
  __export
10
- } from "./chunk-HKJ2B2AA.js";
10
+ } from "./chunk-PZ5AY32C.js";
11
11
 
12
12
  // tools/fastapply/vercel.ts
13
13
  var vercel_exports = {};
@@ -86,4 +86,4 @@ export {
86
86
  vercel_default,
87
87
  vercel_exports
88
88
  };
89
- //# sourceMappingURL=chunk-HBWJLKNM.js.map
89
+ //# sourceMappingURL=chunk-QZNGKOCZ.js.map
@@ -7,7 +7,7 @@ import {
7
7
  } from "./chunk-MFZP347Z.js";
8
8
  import {
9
9
  __export
10
- } from "./chunk-HKJ2B2AA.js";
10
+ } from "./chunk-PZ5AY32C.js";
11
11
 
12
12
  // tools/browser/anthropic.ts
13
13
  var anthropic_exports = {};
@@ -77,4 +77,4 @@ export {
77
77
  createBrowserTool,
78
78
  anthropic_exports
79
79
  };
80
- //# sourceMappingURL=chunk-AAIUUX4Y.js.map
80
+ //# sourceMappingURL=chunk-X4WPMVCM.js.map
@@ -5,13 +5,13 @@ import {
5
5
  import {
6
6
  executeToolCall,
7
7
  formatResult
8
- } from "./chunk-VLZEBK7S.js";
8
+ } from "./chunk-E4434A4Y.js";
9
9
  import {
10
10
  getSystemPrompt
11
11
  } from "./chunk-Q5AHGIQO.js";
12
12
  import {
13
13
  __export
14
- } from "./chunk-HKJ2B2AA.js";
14
+ } from "./chunk-PZ5AY32C.js";
15
15
 
16
16
  // tools/warp_grep/openai.ts
17
17
  var openai_exports = {};
@@ -71,4 +71,4 @@ export {
71
71
  openai_default,
72
72
  openai_exports
73
73
  };
74
- //# sourceMappingURL=chunk-JPGX6WEV.js.map
74
+ //# sourceMappingURL=chunk-XFCMTW5L.js.map