@morphllm/morphsdk 0.2.68 → 0.2.70

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 (120) 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-RTDKF6NS.js → chunk-5QIWYEHJ.js} +2 -2
  4. package/dist/{chunk-BYNVJ4ON.js → chunk-7CJPKJEE.js} +2 -2
  5. package/dist/{chunk-SXE54MIC.js → chunk-AB27WETH.js} +8 -8
  6. package/dist/chunk-B5A4XLSQ.js +10 -0
  7. package/dist/chunk-B5A4XLSQ.js.map +1 -0
  8. package/dist/{chunk-VDJGZIQ5.js → chunk-BGSHC2UK.js} +2 -2
  9. package/dist/{chunk-VLZEBK7S.js → chunk-E4434A4Y.js} +3 -3
  10. package/dist/{chunk-QEGH3CWQ.js → chunk-GZP6HY5W.js} +4 -20
  11. package/dist/{chunk-QEGH3CWQ.js.map → chunk-GZP6HY5W.js.map} +1 -1
  12. package/dist/{chunk-JPGX6WEV.js → chunk-I2GXV3BQ.js} +3 -16
  13. package/dist/{chunk-JPGX6WEV.js.map → chunk-I2GXV3BQ.js.map} +1 -1
  14. package/dist/{chunk-W76ICQKY.js → chunk-IUG2FHNN.js} +2 -2
  15. package/dist/{chunk-K3EHH3C4.js → chunk-PT3DGIUF.js} +3 -15
  16. package/dist/{chunk-K3EHH3C4.js.map → chunk-PT3DGIUF.js.map} +1 -1
  17. package/dist/chunk-PZ5AY32C.js +10 -0
  18. package/dist/{chunk-223ZMZP6.js → chunk-QIG7YPFW.js} +89 -30
  19. package/dist/chunk-QIG7YPFW.js.map +1 -0
  20. package/dist/{chunk-HBWJLKNM.js → chunk-QZNGKOCZ.js} +2 -2
  21. package/dist/{chunk-AAIUUX4Y.js → chunk-X4WPMVCM.js} +2 -2
  22. package/dist/client.cjs +174 -434
  23. package/dist/client.cjs.map +1 -1
  24. package/dist/client.js +11 -12
  25. package/dist/git/client.js +1 -1
  26. package/dist/git/config.js +1 -1
  27. package/dist/git/index.js +1 -1
  28. package/dist/index.cjs +179 -446
  29. package/dist/index.cjs.map +1 -1
  30. package/dist/index.js +12 -14
  31. package/dist/modelrouter/core.js +1 -1
  32. package/dist/modelrouter/index.js +1 -1
  33. package/dist/tools/browser/anthropic.js +2 -2
  34. package/dist/tools/browser/core.js +1 -1
  35. package/dist/tools/browser/index.js +4 -4
  36. package/dist/tools/browser/live.js +1 -1
  37. package/dist/tools/browser/openai.js +2 -2
  38. package/dist/tools/browser/prompts.js +1 -1
  39. package/dist/tools/browser/vercel.js +2 -2
  40. package/dist/tools/codebase_search/anthropic.js +1 -1
  41. package/dist/tools/codebase_search/core.js +1 -1
  42. package/dist/tools/codebase_search/index.js +1 -1
  43. package/dist/tools/codebase_search/openai.js +1 -1
  44. package/dist/tools/codebase_search/prompts.js +1 -1
  45. package/dist/tools/codebase_search/vercel.js +1 -1
  46. package/dist/tools/fastapply/anthropic.js +2 -2
  47. package/dist/tools/fastapply/core.js +1 -1
  48. package/dist/tools/fastapply/index.js +4 -4
  49. package/dist/tools/fastapply/openai.js +2 -2
  50. package/dist/tools/fastapply/prompts.js +1 -1
  51. package/dist/tools/fastapply/vercel.js +2 -2
  52. package/dist/tools/index.js +4 -4
  53. package/dist/tools/utils/resilience.js +1 -1
  54. package/dist/tools/warp_grep/agent/config.js +1 -1
  55. package/dist/tools/warp_grep/agent/formatter.js +1 -1
  56. package/dist/tools/warp_grep/agent/parser.js +1 -1
  57. package/dist/tools/warp_grep/agent/prompt.js +1 -1
  58. package/dist/tools/warp_grep/agent/runner.js +1 -1
  59. package/dist/tools/warp_grep/anthropic.cjs +174 -434
  60. package/dist/tools/warp_grep/anthropic.cjs.map +1 -1
  61. package/dist/tools/warp_grep/anthropic.d.ts +78 -3
  62. package/dist/tools/warp_grep/anthropic.js +5 -6
  63. package/dist/tools/warp_grep/client.cjs +174 -434
  64. package/dist/tools/warp_grep/client.cjs.map +1 -1
  65. package/dist/tools/warp_grep/client.js +4 -5
  66. package/dist/tools/warp_grep/gemini.cjs +176 -437
  67. package/dist/tools/warp_grep/gemini.cjs.map +1 -1
  68. package/dist/tools/warp_grep/gemini.d.ts +109 -3
  69. package/dist/tools/warp_grep/gemini.js +48 -12
  70. package/dist/tools/warp_grep/gemini.js.map +1 -1
  71. package/dist/tools/warp_grep/harness.cjs +88 -417
  72. package/dist/tools/warp_grep/harness.cjs.map +1 -1
  73. package/dist/tools/warp_grep/harness.js +2 -3
  74. package/dist/tools/warp_grep/harness.js.map +1 -1
  75. package/dist/tools/warp_grep/index.cjs +180 -621
  76. package/dist/tools/warp_grep/index.cjs.map +1 -1
  77. package/dist/tools/warp_grep/index.d.ts +89 -9
  78. package/dist/tools/warp_grep/index.js +7 -21
  79. package/dist/tools/warp_grep/openai.cjs +174 -434
  80. package/dist/tools/warp_grep/openai.cjs.map +1 -1
  81. package/dist/tools/warp_grep/openai.d.ts +78 -3
  82. package/dist/tools/warp_grep/openai.js +5 -6
  83. package/dist/tools/warp_grep/providers/local.cjs +88 -417
  84. package/dist/tools/warp_grep/providers/local.cjs.map +1 -1
  85. package/dist/tools/warp_grep/providers/local.d.ts +0 -6
  86. package/dist/tools/warp_grep/providers/local.js +2 -3
  87. package/dist/tools/warp_grep/providers/remote.cjs +86 -408
  88. package/dist/tools/warp_grep/providers/remote.cjs.map +1 -1
  89. package/dist/tools/warp_grep/providers/remote.d.ts +0 -7
  90. package/dist/tools/warp_grep/providers/remote.js +2 -3
  91. package/dist/tools/warp_grep/utils/files.js +1 -1
  92. package/dist/tools/warp_grep/utils/paths.js +1 -1
  93. package/dist/tools/warp_grep/utils/ripgrep.js +1 -1
  94. package/dist/tools/warp_grep/vercel.cjs +174 -434
  95. package/dist/tools/warp_grep/vercel.cjs.map +1 -1
  96. package/dist/tools/warp_grep/vercel.d.ts +56 -3
  97. package/dist/tools/warp_grep/vercel.js +5 -6
  98. package/package.json +1 -1
  99. package/dist/anthropic-BC-AMEIN.d.ts +0 -89
  100. package/dist/chunk-223ZMZP6.js.map +0 -1
  101. package/dist/chunk-6RFT7K7F.js.map +0 -1
  102. package/dist/chunk-FURFQDXF.js +0 -75
  103. package/dist/chunk-FURFQDXF.js.map +0 -1
  104. package/dist/chunk-HKJ2B2AA.js +0 -15
  105. package/dist/chunk-ISWL67SF.js +0 -1
  106. package/dist/chunk-ISWL67SF.js.map +0 -1
  107. package/dist/chunk-S6KU22MU.js +0 -396
  108. package/dist/chunk-S6KU22MU.js.map +0 -1
  109. package/dist/gemini-BIFBiIjY.d.ts +0 -119
  110. package/dist/openai-Beb9escY.d.ts +0 -89
  111. package/dist/vercel-Bo84tpBe.d.ts +0 -66
  112. /package/dist/{chunk-RTDKF6NS.js.map → chunk-5QIWYEHJ.js.map} +0 -0
  113. /package/dist/{chunk-BYNVJ4ON.js.map → chunk-7CJPKJEE.js.map} +0 -0
  114. /package/dist/{chunk-SXE54MIC.js.map → chunk-AB27WETH.js.map} +0 -0
  115. /package/dist/{chunk-VDJGZIQ5.js.map → chunk-BGSHC2UK.js.map} +0 -0
  116. /package/dist/{chunk-VLZEBK7S.js.map → chunk-E4434A4Y.js.map} +0 -0
  117. /package/dist/{chunk-W76ICQKY.js.map → chunk-IUG2FHNN.js.map} +0 -0
  118. /package/dist/{chunk-HKJ2B2AA.js.map → chunk-PZ5AY32C.js.map} +0 -0
  119. /package/dist/{chunk-HBWJLKNM.js.map → chunk-QZNGKOCZ.js.map} +0 -0
  120. /package/dist/{chunk-AAIUUX4Y.js.map → chunk-X4WPMVCM.js.map} +0 -0
package/dist/index.cjs CHANGED
@@ -5,9 +5,6 @@ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
5
  var __getOwnPropNames = Object.getOwnPropertyNames;
6
6
  var __getProtoOf = Object.getPrototypeOf;
7
7
  var __hasOwnProp = Object.prototype.hasOwnProperty;
8
- var __commonJS = (cb, mod) => function __require() {
9
- return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
10
- };
11
8
  var __export = (target, all) => {
12
9
  for (var name in all)
13
10
  __defProp(target, name, { get: all[name], enumerable: true });
@@ -30,394 +27,6 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
30
27
  ));
31
28
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
32
29
 
33
- // node_modules/ignore/index.js
34
- var require_ignore = __commonJS({
35
- "node_modules/ignore/index.js"(exports2, module2) {
36
- "use strict";
37
- function makeArray(subject) {
38
- return Array.isArray(subject) ? subject : [subject];
39
- }
40
- var EMPTY = "";
41
- var SPACE = " ";
42
- var ESCAPE = "\\";
43
- var REGEX_TEST_BLANK_LINE = /^\s+$/;
44
- var REGEX_INVALID_TRAILING_BACKSLASH = /(?:[^\\]|^)\\$/;
45
- var REGEX_REPLACE_LEADING_EXCAPED_EXCLAMATION = /^\\!/;
46
- var REGEX_REPLACE_LEADING_EXCAPED_HASH = /^\\#/;
47
- var REGEX_SPLITALL_CRLF = /\r?\n/g;
48
- var REGEX_TEST_INVALID_PATH = /^\.*\/|^\.+$/;
49
- var SLASH = "/";
50
- var TMP_KEY_IGNORE = "node-ignore";
51
- if (typeof Symbol !== "undefined") {
52
- TMP_KEY_IGNORE = Symbol.for("node-ignore");
53
- }
54
- var KEY_IGNORE = TMP_KEY_IGNORE;
55
- var define = (object, key, value) => Object.defineProperty(object, key, { value });
56
- var REGEX_REGEXP_RANGE = /([0-z])-([0-z])/g;
57
- var RETURN_FALSE = () => false;
58
- var sanitizeRange = (range) => range.replace(
59
- REGEX_REGEXP_RANGE,
60
- (match, from, to) => from.charCodeAt(0) <= to.charCodeAt(0) ? match : EMPTY
61
- );
62
- var cleanRangeBackSlash = (slashes) => {
63
- const { length } = slashes;
64
- return slashes.slice(0, length - length % 2);
65
- };
66
- var REPLACERS = [
67
- [
68
- // remove BOM
69
- // TODO:
70
- // Other similar zero-width characters?
71
- /^\uFEFF/,
72
- () => EMPTY
73
- ],
74
- // > Trailing spaces are ignored unless they are quoted with backslash ("\")
75
- [
76
- // (a\ ) -> (a )
77
- // (a ) -> (a)
78
- // (a ) -> (a)
79
- // (a \ ) -> (a )
80
- /((?:\\\\)*?)(\\?\s+)$/,
81
- (_, m1, m2) => m1 + (m2.indexOf("\\") === 0 ? SPACE : EMPTY)
82
- ],
83
- // replace (\ ) with ' '
84
- // (\ ) -> ' '
85
- // (\\ ) -> '\\ '
86
- // (\\\ ) -> '\\ '
87
- [
88
- /(\\+?)\s/g,
89
- (_, m1) => {
90
- const { length } = m1;
91
- return m1.slice(0, length - length % 2) + SPACE;
92
- }
93
- ],
94
- // Escape metacharacters
95
- // which is written down by users but means special for regular expressions.
96
- // > There are 12 characters with special meanings:
97
- // > - the backslash \,
98
- // > - the caret ^,
99
- // > - the dollar sign $,
100
- // > - the period or dot .,
101
- // > - the vertical bar or pipe symbol |,
102
- // > - the question mark ?,
103
- // > - the asterisk or star *,
104
- // > - the plus sign +,
105
- // > - the opening parenthesis (,
106
- // > - the closing parenthesis ),
107
- // > - and the opening square bracket [,
108
- // > - the opening curly brace {,
109
- // > These special characters are often called "metacharacters".
110
- [
111
- /[\\$.|*+(){^]/g,
112
- (match) => `\\${match}`
113
- ],
114
- [
115
- // > a question mark (?) matches a single character
116
- /(?!\\)\?/g,
117
- () => "[^/]"
118
- ],
119
- // leading slash
120
- [
121
- // > A leading slash matches the beginning of the pathname.
122
- // > For example, "/*.c" matches "cat-file.c" but not "mozilla-sha1/sha1.c".
123
- // A leading slash matches the beginning of the pathname
124
- /^\//,
125
- () => "^"
126
- ],
127
- // replace special metacharacter slash after the leading slash
128
- [
129
- /\//g,
130
- () => "\\/"
131
- ],
132
- [
133
- // > A leading "**" followed by a slash means match in all directories.
134
- // > For example, "**/foo" matches file or directory "foo" anywhere,
135
- // > the same as pattern "foo".
136
- // > "**/foo/bar" matches file or directory "bar" anywhere that is directly
137
- // > under directory "foo".
138
- // Notice that the '*'s have been replaced as '\\*'
139
- /^\^*\\\*\\\*\\\//,
140
- // '**/foo' <-> 'foo'
141
- () => "^(?:.*\\/)?"
142
- ],
143
- // starting
144
- [
145
- // there will be no leading '/'
146
- // (which has been replaced by section "leading slash")
147
- // If starts with '**', adding a '^' to the regular expression also works
148
- /^(?=[^^])/,
149
- function startingReplacer() {
150
- return !/\/(?!$)/.test(this) ? "(?:^|\\/)" : "^";
151
- }
152
- ],
153
- // two globstars
154
- [
155
- // Use lookahead assertions so that we could match more than one `'/**'`
156
- /\\\/\\\*\\\*(?=\\\/|$)/g,
157
- // Zero, one or several directories
158
- // should not use '*', or it will be replaced by the next replacer
159
- // Check if it is not the last `'/**'`
160
- (_, index, str) => index + 6 < str.length ? "(?:\\/[^\\/]+)*" : "\\/.+"
161
- ],
162
- // normal intermediate wildcards
163
- [
164
- // Never replace escaped '*'
165
- // ignore rule '\*' will match the path '*'
166
- // 'abc.*/' -> go
167
- // 'abc.*' -> skip this rule,
168
- // coz trailing single wildcard will be handed by [trailing wildcard]
169
- /(^|[^\\]+)(\\\*)+(?=.+)/g,
170
- // '*.js' matches '.js'
171
- // '*.js' doesn't match 'abc'
172
- (_, p1, p2) => {
173
- const unescaped = p2.replace(/\\\*/g, "[^\\/]*");
174
- return p1 + unescaped;
175
- }
176
- ],
177
- [
178
- // unescape, revert step 3 except for back slash
179
- // For example, if a user escape a '\\*',
180
- // after step 3, the result will be '\\\\\\*'
181
- /\\\\\\(?=[$.|*+(){^])/g,
182
- () => ESCAPE
183
- ],
184
- [
185
- // '\\\\' -> '\\'
186
- /\\\\/g,
187
- () => ESCAPE
188
- ],
189
- [
190
- // > The range notation, e.g. [a-zA-Z],
191
- // > can be used to match one of the characters in a range.
192
- // `\` is escaped by step 3
193
- /(\\)?\[([^\]/]*?)(\\*)($|\])/g,
194
- (match, leadEscape, range, endEscape, close) => leadEscape === ESCAPE ? `\\[${range}${cleanRangeBackSlash(endEscape)}${close}` : close === "]" ? endEscape.length % 2 === 0 ? `[${sanitizeRange(range)}${endEscape}]` : "[]" : "[]"
195
- ],
196
- // ending
197
- [
198
- // 'js' will not match 'js.'
199
- // 'ab' will not match 'abc'
200
- /(?:[^*])$/,
201
- // WTF!
202
- // https://git-scm.com/docs/gitignore
203
- // changes in [2.22.1](https://git-scm.com/docs/gitignore/2.22.1)
204
- // which re-fixes #24, #38
205
- // > If there is a separator at the end of the pattern then the pattern
206
- // > will only match directories, otherwise the pattern can match both
207
- // > files and directories.
208
- // 'js*' will not match 'a.js'
209
- // 'js/' will not match 'a.js'
210
- // 'js' will match 'a.js' and 'a.js/'
211
- (match) => /\/$/.test(match) ? `${match}$` : `${match}(?=$|\\/$)`
212
- ],
213
- // trailing wildcard
214
- [
215
- /(\^|\\\/)?\\\*$/,
216
- (_, p1) => {
217
- const prefix = p1 ? `${p1}[^/]+` : "[^/]*";
218
- return `${prefix}(?=$|\\/$)`;
219
- }
220
- ]
221
- ];
222
- var regexCache = /* @__PURE__ */ Object.create(null);
223
- var makeRegex = (pattern, ignoreCase) => {
224
- let source = regexCache[pattern];
225
- if (!source) {
226
- source = REPLACERS.reduce(
227
- (prev, [matcher, replacer]) => prev.replace(matcher, replacer.bind(pattern)),
228
- pattern
229
- );
230
- regexCache[pattern] = source;
231
- }
232
- return ignoreCase ? new RegExp(source, "i") : new RegExp(source);
233
- };
234
- var isString = (subject) => typeof subject === "string";
235
- var checkPattern = (pattern) => pattern && isString(pattern) && !REGEX_TEST_BLANK_LINE.test(pattern) && !REGEX_INVALID_TRAILING_BACKSLASH.test(pattern) && pattern.indexOf("#") !== 0;
236
- var splitPattern = (pattern) => pattern.split(REGEX_SPLITALL_CRLF);
237
- var IgnoreRule = class {
238
- constructor(origin, pattern, negative, regex) {
239
- this.origin = origin;
240
- this.pattern = pattern;
241
- this.negative = negative;
242
- this.regex = regex;
243
- }
244
- };
245
- var createRule = (pattern, ignoreCase) => {
246
- const origin = pattern;
247
- let negative = false;
248
- if (pattern.indexOf("!") === 0) {
249
- negative = true;
250
- pattern = pattern.substr(1);
251
- }
252
- pattern = pattern.replace(REGEX_REPLACE_LEADING_EXCAPED_EXCLAMATION, "!").replace(REGEX_REPLACE_LEADING_EXCAPED_HASH, "#");
253
- const regex = makeRegex(pattern, ignoreCase);
254
- return new IgnoreRule(
255
- origin,
256
- pattern,
257
- negative,
258
- regex
259
- );
260
- };
261
- var throwError = (message, Ctor) => {
262
- throw new Ctor(message);
263
- };
264
- var checkPath = (path5, originalPath, doThrow) => {
265
- if (!isString(path5)) {
266
- return doThrow(
267
- `path must be a string, but got \`${originalPath}\``,
268
- TypeError
269
- );
270
- }
271
- if (!path5) {
272
- return doThrow(`path must not be empty`, TypeError);
273
- }
274
- if (checkPath.isNotRelative(path5)) {
275
- const r = "`path.relative()`d";
276
- return doThrow(
277
- `path should be a ${r} string, but got "${originalPath}"`,
278
- RangeError
279
- );
280
- }
281
- return true;
282
- };
283
- var isNotRelative = (path5) => REGEX_TEST_INVALID_PATH.test(path5);
284
- checkPath.isNotRelative = isNotRelative;
285
- checkPath.convert = (p) => p;
286
- var Ignore = class {
287
- constructor({
288
- ignorecase = true,
289
- ignoreCase = ignorecase,
290
- allowRelativePaths = false
291
- } = {}) {
292
- define(this, KEY_IGNORE, true);
293
- this._rules = [];
294
- this._ignoreCase = ignoreCase;
295
- this._allowRelativePaths = allowRelativePaths;
296
- this._initCache();
297
- }
298
- _initCache() {
299
- this._ignoreCache = /* @__PURE__ */ Object.create(null);
300
- this._testCache = /* @__PURE__ */ Object.create(null);
301
- }
302
- _addPattern(pattern) {
303
- if (pattern && pattern[KEY_IGNORE]) {
304
- this._rules = this._rules.concat(pattern._rules);
305
- this._added = true;
306
- return;
307
- }
308
- if (checkPattern(pattern)) {
309
- const rule = createRule(pattern, this._ignoreCase);
310
- this._added = true;
311
- this._rules.push(rule);
312
- }
313
- }
314
- // @param {Array<string> | string | Ignore} pattern
315
- add(pattern) {
316
- this._added = false;
317
- makeArray(
318
- isString(pattern) ? splitPattern(pattern) : pattern
319
- ).forEach(this._addPattern, this);
320
- if (this._added) {
321
- this._initCache();
322
- }
323
- return this;
324
- }
325
- // legacy
326
- addPattern(pattern) {
327
- return this.add(pattern);
328
- }
329
- // | ignored : unignored
330
- // negative | 0:0 | 0:1 | 1:0 | 1:1
331
- // -------- | ------- | ------- | ------- | --------
332
- // 0 | TEST | TEST | SKIP | X
333
- // 1 | TESTIF | SKIP | TEST | X
334
- // - SKIP: always skip
335
- // - TEST: always test
336
- // - TESTIF: only test if checkUnignored
337
- // - X: that never happen
338
- // @param {boolean} whether should check if the path is unignored,
339
- // setting `checkUnignored` to `false` could reduce additional
340
- // path matching.
341
- // @returns {TestResult} true if a file is ignored
342
- _testOne(path5, checkUnignored) {
343
- let ignored = false;
344
- let unignored = false;
345
- this._rules.forEach((rule) => {
346
- const { negative } = rule;
347
- if (unignored === negative && ignored !== unignored || negative && !ignored && !unignored && !checkUnignored) {
348
- return;
349
- }
350
- const matched = rule.regex.test(path5);
351
- if (matched) {
352
- ignored = !negative;
353
- unignored = negative;
354
- }
355
- });
356
- return {
357
- ignored,
358
- unignored
359
- };
360
- }
361
- // @returns {TestResult}
362
- _test(originalPath, cache, checkUnignored, slices) {
363
- const path5 = originalPath && checkPath.convert(originalPath);
364
- checkPath(
365
- path5,
366
- originalPath,
367
- this._allowRelativePaths ? RETURN_FALSE : throwError
368
- );
369
- return this._t(path5, cache, checkUnignored, slices);
370
- }
371
- _t(path5, cache, checkUnignored, slices) {
372
- if (path5 in cache) {
373
- return cache[path5];
374
- }
375
- if (!slices) {
376
- slices = path5.split(SLASH);
377
- }
378
- slices.pop();
379
- if (!slices.length) {
380
- return cache[path5] = this._testOne(path5, checkUnignored);
381
- }
382
- const parent = this._t(
383
- slices.join(SLASH) + SLASH,
384
- cache,
385
- checkUnignored,
386
- slices
387
- );
388
- return cache[path5] = parent.ignored ? parent : this._testOne(path5, checkUnignored);
389
- }
390
- ignores(path5) {
391
- return this._test(path5, this._ignoreCache, false).ignored;
392
- }
393
- createFilter() {
394
- return (path5) => !this.ignores(path5);
395
- }
396
- filter(paths) {
397
- return makeArray(paths).filter(this.createFilter());
398
- }
399
- // @returns {TestResult}
400
- test(path5) {
401
- return this._test(path5, this._testCache, true);
402
- }
403
- };
404
- var factory = (options) => new Ignore(options);
405
- var isPathValid = (path5) => checkPath(path5 && checkPath.convert(path5), path5, RETURN_FALSE);
406
- factory.isPathValid = isPathValid;
407
- factory.default = factory;
408
- module2.exports = factory;
409
- if (
410
- // Detect `process` so that it can run in browsers.
411
- typeof process !== "undefined" && (process.env && process.env.IGNORE_TEST_WIN32 || process.platform === "win32")
412
- ) {
413
- const makePosix = (str) => /^\\\\\?\\/.test(str) || /["<>|\u0000-\u001F]+/u.test(str) ? str : str.replace(/\\/g, "/");
414
- checkPath.convert = makePosix;
415
- const REGIX_IS_WINDOWS_PATH_ABSOLUTE = /^[a-z]:\//i;
416
- checkPath.isNotRelative = (path5) => REGIX_IS_WINDOWS_PATH_ABSOLUTE.test(path5) || isNotRelative(path5);
417
- }
418
- }
419
- });
420
-
421
30
  // index.ts
422
31
  var index_exports = {};
423
32
  __export(index_exports, {
@@ -2487,30 +2096,95 @@ async function readAllLines(filePath) {
2487
2096
  }
2488
2097
 
2489
2098
  // tools/warp_grep/providers/local.ts
2490
- var ignore = require_ignore().default || require_ignore();
2099
+ var SKIP_NAMES = /* @__PURE__ */ new Set([
2100
+ // Version control
2101
+ ".git",
2102
+ ".svn",
2103
+ ".hg",
2104
+ ".bzr",
2105
+ // Dependencies
2106
+ "node_modules",
2107
+ "bower_components",
2108
+ ".pnpm",
2109
+ ".yarn",
2110
+ "vendor",
2111
+ "Pods",
2112
+ ".bundle",
2113
+ // Python
2114
+ "__pycache__",
2115
+ ".pytest_cache",
2116
+ ".mypy_cache",
2117
+ ".ruff_cache",
2118
+ ".venv",
2119
+ "venv",
2120
+ ".tox",
2121
+ ".nox",
2122
+ ".eggs",
2123
+ // Build outputs
2124
+ "dist",
2125
+ "build",
2126
+ "out",
2127
+ "output",
2128
+ "target",
2129
+ "_build",
2130
+ ".next",
2131
+ ".nuxt",
2132
+ ".output",
2133
+ ".vercel",
2134
+ ".netlify",
2135
+ // Cache
2136
+ ".cache",
2137
+ ".parcel-cache",
2138
+ ".turbo",
2139
+ ".nx",
2140
+ ".gradle",
2141
+ // IDE
2142
+ ".idea",
2143
+ ".vscode",
2144
+ ".vs",
2145
+ // Coverage
2146
+ "coverage",
2147
+ ".coverage",
2148
+ "htmlcov",
2149
+ ".nyc_output",
2150
+ // Temp
2151
+ "tmp",
2152
+ "temp",
2153
+ ".tmp",
2154
+ ".temp",
2155
+ // Lock files
2156
+ "package-lock.json",
2157
+ "yarn.lock",
2158
+ "pnpm-lock.yaml",
2159
+ "bun.lockb",
2160
+ "Cargo.lock",
2161
+ "Gemfile.lock",
2162
+ "poetry.lock"
2163
+ ]);
2164
+ var SKIP_EXTENSIONS = /* @__PURE__ */ new Set([
2165
+ ".min.js",
2166
+ ".min.css",
2167
+ ".bundle.js",
2168
+ ".wasm",
2169
+ ".so",
2170
+ ".dll",
2171
+ ".pyc",
2172
+ ".map",
2173
+ ".js.map"
2174
+ ]);
2175
+ function shouldSkip(name) {
2176
+ if (SKIP_NAMES.has(name)) return true;
2177
+ if (name.startsWith(".")) return true;
2178
+ for (const ext of SKIP_EXTENSIONS) {
2179
+ if (name.endsWith(ext)) return true;
2180
+ }
2181
+ return false;
2182
+ }
2491
2183
  var LocalRipgrepProvider = class {
2492
2184
  constructor(repoRoot, excludes = DEFAULT_EXCLUDES) {
2493
2185
  this.repoRoot = repoRoot;
2494
2186
  this.excludes = excludes;
2495
2187
  }
2496
- ignoreFilter = null;
2497
- /**
2498
- * Build an ignore filter that combines DEFAULT_EXCLUDES and .gitignore patterns.
2499
- * Cached after first call.
2500
- */
2501
- async getIgnoreFilter() {
2502
- if (this.ignoreFilter) return this.ignoreFilter;
2503
- const ig = ignore();
2504
- ig.add(this.excludes);
2505
- try {
2506
- const gitignorePath = import_path5.default.join(this.repoRoot, ".gitignore");
2507
- const gitignoreContent = await import_promises3.default.readFile(gitignorePath, "utf-8");
2508
- ig.add(gitignoreContent);
2509
- } catch {
2510
- }
2511
- this.ignoreFilter = ig;
2512
- return ig;
2513
- }
2514
2188
  async grep(params) {
2515
2189
  let abs;
2516
2190
  try {
@@ -2638,11 +2312,10 @@ Details: ${res.stderr}` : ""}`
2638
2312
  const maxResults = params.maxResults ?? AGENT_CONFIG.MAX_OUTPUT_LINES;
2639
2313
  const maxDepth = params.maxDepth ?? AGENT_CONFIG.MAX_LIST_DEPTH;
2640
2314
  const regex = params.pattern ? new RegExp(params.pattern) : null;
2641
- const ig = await this.getIgnoreFilter();
2315
+ const repoRoot = this.repoRoot;
2642
2316
  const results = [];
2643
2317
  let timedOut = false;
2644
2318
  const startTime = Date.now();
2645
- const repoRoot = this.repoRoot;
2646
2319
  async function walk(dir, depth) {
2647
2320
  if (Date.now() - startTime > AGENT_CONFIG.LIST_TIMEOUT_MS) {
2648
2321
  timedOut = true;
@@ -2652,15 +2325,13 @@ Details: ${res.stderr}` : ""}`
2652
2325
  const entries = await import_promises3.default.readdir(dir, { withFileTypes: true });
2653
2326
  for (const entry of entries) {
2654
2327
  if (timedOut || results.length >= maxResults) break;
2328
+ if (shouldSkip(entry.name)) continue;
2329
+ if (regex && !regex.test(entry.name)) continue;
2655
2330
  const full = import_path5.default.join(dir, entry.name);
2656
- const relToRepo = toRepoRelative(repoRoot, full).replace(/^[.][/\\]?/, "");
2657
2331
  const isDir = entry.isDirectory();
2658
- if (ig.ignores(relToRepo) || isDir && ig.ignores(relToRepo + "/")) continue;
2659
- if (regex && !regex.test(entry.name)) continue;
2660
2332
  results.push({
2661
2333
  name: entry.name,
2662
- path: toRepoRelative(import_path5.default.resolve(""), full),
2663
- // relative display
2334
+ path: toRepoRelative(repoRoot, full),
2664
2335
  type: isDir ? "dir" : "file",
2665
2336
  depth
2666
2337
  });
@@ -2675,25 +2346,95 @@ Details: ${res.stderr}` : ""}`
2675
2346
  };
2676
2347
 
2677
2348
  // tools/warp_grep/providers/remote.ts
2678
- var ignore2 = require_ignore().default || require_ignore();
2349
+ var SKIP_NAMES2 = /* @__PURE__ */ new Set([
2350
+ // Version control
2351
+ ".git",
2352
+ ".svn",
2353
+ ".hg",
2354
+ ".bzr",
2355
+ // Dependencies
2356
+ "node_modules",
2357
+ "bower_components",
2358
+ ".pnpm",
2359
+ ".yarn",
2360
+ "vendor",
2361
+ "Pods",
2362
+ ".bundle",
2363
+ // Python
2364
+ "__pycache__",
2365
+ ".pytest_cache",
2366
+ ".mypy_cache",
2367
+ ".ruff_cache",
2368
+ ".venv",
2369
+ "venv",
2370
+ ".tox",
2371
+ ".nox",
2372
+ ".eggs",
2373
+ // Build outputs
2374
+ "dist",
2375
+ "build",
2376
+ "out",
2377
+ "output",
2378
+ "target",
2379
+ "_build",
2380
+ ".next",
2381
+ ".nuxt",
2382
+ ".output",
2383
+ ".vercel",
2384
+ ".netlify",
2385
+ // Cache
2386
+ ".cache",
2387
+ ".parcel-cache",
2388
+ ".turbo",
2389
+ ".nx",
2390
+ ".gradle",
2391
+ // IDE
2392
+ ".idea",
2393
+ ".vscode",
2394
+ ".vs",
2395
+ // Coverage
2396
+ "coverage",
2397
+ ".coverage",
2398
+ "htmlcov",
2399
+ ".nyc_output",
2400
+ // Temp
2401
+ "tmp",
2402
+ "temp",
2403
+ ".tmp",
2404
+ ".temp",
2405
+ // Lock files
2406
+ "package-lock.json",
2407
+ "yarn.lock",
2408
+ "pnpm-lock.yaml",
2409
+ "bun.lockb",
2410
+ "Cargo.lock",
2411
+ "Gemfile.lock",
2412
+ "poetry.lock"
2413
+ ]);
2414
+ var SKIP_EXTENSIONS2 = /* @__PURE__ */ new Set([
2415
+ ".min.js",
2416
+ ".min.css",
2417
+ ".bundle.js",
2418
+ ".wasm",
2419
+ ".so",
2420
+ ".dll",
2421
+ ".pyc",
2422
+ ".map",
2423
+ ".js.map"
2424
+ ]);
2425
+ function shouldSkip2(name) {
2426
+ if (SKIP_NAMES2.has(name)) return true;
2427
+ if (name.startsWith(".")) return true;
2428
+ for (const ext of SKIP_EXTENSIONS2) {
2429
+ if (name.endsWith(ext)) return true;
2430
+ }
2431
+ return false;
2432
+ }
2679
2433
  var RemoteCommandsProvider = class {
2680
2434
  constructor(repoRoot, commands) {
2681
2435
  this.repoRoot = repoRoot;
2682
2436
  this.commands = commands;
2683
2437
  }
2684
- ignoreFilter = null;
2685
- /**
2686
- * Build an ignore filter from DEFAULT_EXCLUDES.
2687
- * Note: For remote providers, we can't read .gitignore from the remote sandbox,
2688
- * so we only use the built-in excludes.
2689
- */
2690
- getIgnoreFilter() {
2691
- if (this.ignoreFilter) return this.ignoreFilter;
2692
- const ig = ignore2();
2693
- ig.add(DEFAULT_EXCLUDES);
2694
- this.ignoreFilter = ig;
2695
- return ig;
2696
- }
2697
2438
  /**
2698
2439
  * Run grep command and parse ripgrep output
2699
2440
  */
@@ -2747,7 +2488,6 @@ var RemoteCommandsProvider = class {
2747
2488
  async listDirectory(params) {
2748
2489
  const maxDepth = params.maxDepth ?? AGENT_CONFIG.MAX_LIST_DEPTH;
2749
2490
  const maxResults = params.maxResults ?? AGENT_CONFIG.MAX_OUTPUT_LINES;
2750
- const ig = this.getIgnoreFilter();
2751
2491
  try {
2752
2492
  const stdout = await this.commands.listDir(params.path, maxDepth);
2753
2493
  const paths = (stdout || "").trim().split(/\r?\n/).filter((p) => p.length > 0);
@@ -2756,12 +2496,12 @@ var RemoteCommandsProvider = class {
2756
2496
  for (const fullPath of paths) {
2757
2497
  if (fullPath === params.path || fullPath === this.repoRoot) continue;
2758
2498
  const name = fullPath.split("/").pop() || "";
2499
+ if (shouldSkip2(name)) continue;
2500
+ if (regex && !regex.test(name)) continue;
2759
2501
  let relativePath = fullPath;
2760
2502
  if (fullPath.startsWith(this.repoRoot)) {
2761
2503
  relativePath = fullPath.slice(this.repoRoot.length).replace(/^\//, "");
2762
2504
  }
2763
- if (ig.ignores(relativePath)) continue;
2764
- if (regex && !regex.test(name)) continue;
2765
2505
  const depth = relativePath.split("/").filter(Boolean).length - 1;
2766
2506
  const hasExtension = name.includes(".") && !name.startsWith(".");
2767
2507
  const type = hasExtension ? "file" : "dir";
@@ -4378,18 +4118,11 @@ var MorphClient = class {
4378
4118
  }
4379
4119
  };
4380
4120
 
4381
- // tools/warp_grep/gemini.ts
4382
- var import_generative_ai = require("@google/generative-ai");
4383
- var TOOL_PARAMETERS2 = {
4384
- type: import_generative_ai.SchemaType.OBJECT,
4385
- properties: {
4386
- query: {
4387
- type: import_generative_ai.SchemaType.STRING,
4388
- description: "Free-form repository question"
4389
- }
4390
- },
4391
- required: ["query"]
4392
- };
4121
+ // tools/warp_grep/index.ts
4122
+ var import_zod4 = require("zod");
4123
+ var warpGrepInputSchema = import_zod4.z.object({
4124
+ query: import_zod4.z.string().describe("Free-form repository question")
4125
+ });
4393
4126
  // Annotate the CommonJS export names for ESM import in node:
4394
4127
  0 && (module.exports = {
4395
4128
  AnthropicRouter,