@morphllm/morphsdk 0.2.66 → 0.2.68

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 (131) hide show
  1. package/dist/anthropic-B6my2oBx.d.ts +56 -0
  2. package/dist/{chunk-ZO4PPFCZ.js → chunk-223ZMZP6.js} +30 -5
  3. package/dist/chunk-223ZMZP6.js.map +1 -0
  4. package/dist/{chunk-GGYMQZXI.js → chunk-6RFT7K7F.js} +23 -3
  5. package/dist/chunk-6RFT7K7F.js.map +1 -0
  6. package/dist/chunk-AAIUUX4Y.js +80 -0
  7. package/dist/chunk-AAIUUX4Y.js.map +1 -0
  8. package/dist/chunk-BYNVJ4ON.js +57 -0
  9. package/dist/chunk-BYNVJ4ON.js.map +1 -0
  10. package/dist/{chunk-ASO5YWQ4.js → chunk-FURFQDXF.js} +7 -4
  11. package/dist/{chunk-ASO5YWQ4.js.map → chunk-FURFQDXF.js.map} +1 -1
  12. package/dist/{chunk-QZNGKOCZ.js → chunk-HBWJLKNM.js} +2 -2
  13. package/dist/chunk-HKJ2B2AA.js +15 -0
  14. package/dist/{chunk-XLSODV6H.js → chunk-JPGX6WEV.js} +3 -3
  15. package/dist/{chunk-AQD2JCLI.js → chunk-K3EHH3C4.js} +3 -3
  16. package/dist/{chunk-IZISG7DL.js → chunk-MFZP347Z.js} +10 -7
  17. package/dist/chunk-MFZP347Z.js.map +1 -0
  18. package/dist/{chunk-7V2KIZT5.js → chunk-QEGH3CWQ.js} +3 -3
  19. package/dist/{chunk-5QIWYEHJ.js → chunk-RTDKF6NS.js} +2 -2
  20. package/dist/chunk-S6KU22MU.js +396 -0
  21. package/dist/chunk-S6KU22MU.js.map +1 -0
  22. package/dist/{chunk-SU5CKH4F.js → chunk-SXE54MIC.js} +9 -9
  23. package/dist/chunk-VDJGZIQ5.js +96 -0
  24. package/dist/chunk-VDJGZIQ5.js.map +1 -0
  25. package/dist/{chunk-7JEL2VZO.js → chunk-VLZEBK7S.js} +3 -3
  26. package/dist/{chunk-IUG2FHNN.js → chunk-W76ICQKY.js} +2 -2
  27. package/dist/client.cjs +443 -11
  28. package/dist/client.cjs.map +1 -1
  29. package/dist/client.js +13 -12
  30. package/dist/{gemini-DPFWWG3k.d.ts → gemini-BIFBiIjY.d.ts} +5 -3
  31. package/dist/git/client.js +1 -1
  32. package/dist/git/config.js +1 -1
  33. package/dist/git/index.js +1 -1
  34. package/dist/index.cjs +443 -11
  35. package/dist/index.cjs.map +1 -1
  36. package/dist/index.js +14 -13
  37. package/dist/modelrouter/core.js +1 -1
  38. package/dist/modelrouter/index.js +1 -1
  39. package/dist/openai-BQMeDFef.d.ts +81 -0
  40. package/dist/tools/browser/anthropic.cjs.map +1 -1
  41. package/dist/tools/browser/anthropic.d.ts +3 -50
  42. package/dist/tools/browser/anthropic.js +6 -65
  43. package/dist/tools/browser/anthropic.js.map +1 -1
  44. package/dist/tools/browser/core.cjs +9 -6
  45. package/dist/tools/browser/core.cjs.map +1 -1
  46. package/dist/tools/browser/core.d.ts +6 -6
  47. package/dist/tools/browser/core.js +2 -2
  48. package/dist/tools/browser/index.cjs +278 -6
  49. package/dist/tools/browser/index.cjs.map +1 -1
  50. package/dist/tools/browser/index.d.ts +125 -1
  51. package/dist/tools/browser/index.js +98 -2
  52. package/dist/tools/browser/index.js.map +1 -1
  53. package/dist/tools/browser/live.js +1 -1
  54. package/dist/tools/browser/openai.cjs.map +1 -1
  55. package/dist/tools/browser/openai.d.ts +3 -72
  56. package/dist/tools/browser/openai.js +9 -75
  57. package/dist/tools/browser/openai.js.map +1 -1
  58. package/dist/tools/browser/prompts.js +1 -1
  59. package/dist/tools/browser/vercel.cjs.map +1 -1
  60. package/dist/tools/browser/vercel.d.ts +3 -68
  61. package/dist/tools/browser/vercel.js +6 -42
  62. package/dist/tools/browser/vercel.js.map +1 -1
  63. package/dist/tools/codebase_search/anthropic.js +1 -1
  64. package/dist/tools/codebase_search/core.js +1 -1
  65. package/dist/tools/codebase_search/index.js +1 -1
  66. package/dist/tools/codebase_search/openai.js +1 -1
  67. package/dist/tools/codebase_search/prompts.js +1 -1
  68. package/dist/tools/codebase_search/vercel.js +1 -1
  69. package/dist/tools/fastapply/anthropic.js +2 -2
  70. package/dist/tools/fastapply/core.js +1 -1
  71. package/dist/tools/fastapply/index.js +4 -4
  72. package/dist/tools/fastapply/openai.js +2 -2
  73. package/dist/tools/fastapply/prompts.js +1 -1
  74. package/dist/tools/fastapply/vercel.js +2 -2
  75. package/dist/tools/index.js +4 -4
  76. package/dist/tools/utils/resilience.js +1 -1
  77. package/dist/tools/warp_grep/agent/config.js +1 -1
  78. package/dist/tools/warp_grep/agent/formatter.js +1 -1
  79. package/dist/tools/warp_grep/agent/parser.js +1 -1
  80. package/dist/tools/warp_grep/agent/prompt.js +1 -1
  81. package/dist/tools/warp_grep/agent/runner.js +1 -1
  82. package/dist/tools/warp_grep/anthropic.cjs +434 -5
  83. package/dist/tools/warp_grep/anthropic.cjs.map +1 -1
  84. package/dist/tools/warp_grep/anthropic.js +6 -5
  85. package/dist/tools/warp_grep/client.cjs +434 -5
  86. package/dist/tools/warp_grep/client.cjs.map +1 -1
  87. package/dist/tools/warp_grep/client.js +5 -4
  88. package/dist/tools/warp_grep/gemini.cjs +438 -6
  89. package/dist/tools/warp_grep/gemini.cjs.map +1 -1
  90. package/dist/tools/warp_grep/gemini.d.ts +1 -1
  91. package/dist/tools/warp_grep/gemini.js +8 -5
  92. package/dist/tools/warp_grep/harness.cjs +417 -4
  93. package/dist/tools/warp_grep/harness.cjs.map +1 -1
  94. package/dist/tools/warp_grep/harness.js +3 -2
  95. package/dist/tools/warp_grep/harness.js.map +1 -1
  96. package/dist/tools/warp_grep/index.cjs +437 -6
  97. package/dist/tools/warp_grep/index.cjs.map +1 -1
  98. package/dist/tools/warp_grep/index.d.ts +1 -1
  99. package/dist/tools/warp_grep/index.js +9 -8
  100. package/dist/tools/warp_grep/openai.cjs +434 -5
  101. package/dist/tools/warp_grep/openai.cjs.map +1 -1
  102. package/dist/tools/warp_grep/openai.js +6 -5
  103. package/dist/tools/warp_grep/providers/local.cjs +417 -4
  104. package/dist/tools/warp_grep/providers/local.cjs.map +1 -1
  105. package/dist/tools/warp_grep/providers/local.d.ts +6 -0
  106. package/dist/tools/warp_grep/providers/local.js +3 -2
  107. package/dist/tools/warp_grep/providers/remote.cjs +408 -1
  108. package/dist/tools/warp_grep/providers/remote.cjs.map +1 -1
  109. package/dist/tools/warp_grep/providers/remote.d.ts +7 -0
  110. package/dist/tools/warp_grep/providers/remote.js +3 -2
  111. package/dist/tools/warp_grep/utils/files.js +1 -1
  112. package/dist/tools/warp_grep/utils/paths.js +1 -1
  113. package/dist/tools/warp_grep/utils/ripgrep.js +1 -1
  114. package/dist/tools/warp_grep/vercel.cjs +434 -5
  115. package/dist/tools/warp_grep/vercel.cjs.map +1 -1
  116. package/dist/tools/warp_grep/vercel.js +6 -5
  117. package/dist/vercel-CsnNSdze.d.ts +74 -0
  118. package/package.json +1 -1
  119. package/dist/chunk-GGYMQZXI.js.map +0 -1
  120. package/dist/chunk-IZISG7DL.js.map +0 -1
  121. package/dist/chunk-PZ5AY32C.js +0 -10
  122. package/dist/chunk-ZO4PPFCZ.js.map +0 -1
  123. /package/dist/{chunk-QZNGKOCZ.js.map → chunk-HBWJLKNM.js.map} +0 -0
  124. /package/dist/{chunk-PZ5AY32C.js.map → chunk-HKJ2B2AA.js.map} +0 -0
  125. /package/dist/{chunk-XLSODV6H.js.map → chunk-JPGX6WEV.js.map} +0 -0
  126. /package/dist/{chunk-AQD2JCLI.js.map → chunk-K3EHH3C4.js.map} +0 -0
  127. /package/dist/{chunk-7V2KIZT5.js.map → chunk-QEGH3CWQ.js.map} +0 -0
  128. /package/dist/{chunk-5QIWYEHJ.js.map → chunk-RTDKF6NS.js.map} +0 -0
  129. /package/dist/{chunk-SU5CKH4F.js.map → chunk-SXE54MIC.js.map} +0 -0
  130. /package/dist/{chunk-7JEL2VZO.js.map → chunk-VLZEBK7S.js.map} +0 -0
  131. /package/dist/{chunk-IUG2FHNN.js.map → chunk-W76ICQKY.js.map} +0 -0
@@ -3,20 +3,21 @@ import {
3
3
  executeToolCall,
4
4
  executeWarpGrep,
5
5
  formatResult
6
- } from "../../chunk-7JEL2VZO.js";
6
+ } from "../../chunk-VLZEBK7S.js";
7
7
  import "../../chunk-SUBBMTMY.js";
8
- import "../../chunk-GGYMQZXI.js";
8
+ import "../../chunk-6RFT7K7F.js";
9
9
  import "../../chunk-DCIUCDWJ.js";
10
10
  import "../../chunk-APP75CBN.js";
11
11
  import "../../chunk-5QRN3JNB.js";
12
12
  import "../../chunk-Q5AHGIQO.js";
13
- import "../../chunk-ZO4PPFCZ.js";
13
+ import "../../chunk-223ZMZP6.js";
14
14
  import "../../chunk-G2RSY56Q.js";
15
15
  import "../../chunk-SMGZ6A64.js";
16
16
  import "../../chunk-TPP2UGQP.js";
17
+ import "../../chunk-S6KU22MU.js";
17
18
  import "../../chunk-XT5ZO6ES.js";
18
19
  import "../../chunk-4VWJFZVS.js";
19
- import "../../chunk-PZ5AY32C.js";
20
+ import "../../chunk-HKJ2B2AA.js";
20
21
  export {
21
22
  WarpGrepClient,
22
23
  executeToolCall,
@@ -5,6 +5,9 @@ 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
+ };
8
11
  var __export = (target, all) => {
9
12
  for (var name in all)
10
13
  __defProp(target, name, { get: all[name], enumerable: true });
@@ -27,10 +30,399 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
27
30
  ));
28
31
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
32
 
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
+
30
421
  // tools/warp_grep/gemini.ts
31
422
  var gemini_exports = {};
32
423
  __export(gemini_exports, {
33
424
  createMorphWarpGrepTool: () => createMorphWarpGrepTool,
425
+ createWarpGrepTool: () => createWarpGrepTool,
34
426
  default: () => gemini_default,
35
427
  execute: () => execute,
36
428
  formatResult: () => formatResult,
@@ -1212,11 +1604,30 @@ async function readAllLines(filePath) {
1212
1604
  }
1213
1605
 
1214
1606
  // tools/warp_grep/providers/local.ts
1607
+ var ignore = require_ignore().default || require_ignore();
1215
1608
  var LocalRipgrepProvider = class {
1216
1609
  constructor(repoRoot, excludes = DEFAULT_EXCLUDES) {
1217
1610
  this.repoRoot = repoRoot;
1218
1611
  this.excludes = excludes;
1219
1612
  }
1613
+ ignoreFilter = null;
1614
+ /**
1615
+ * Build an ignore filter that combines DEFAULT_EXCLUDES and .gitignore patterns.
1616
+ * Cached after first call.
1617
+ */
1618
+ async getIgnoreFilter() {
1619
+ if (this.ignoreFilter) return this.ignoreFilter;
1620
+ const ig = ignore();
1621
+ ig.add(this.excludes);
1622
+ try {
1623
+ const gitignorePath = import_path4.default.join(this.repoRoot, ".gitignore");
1624
+ const gitignoreContent = await import_promises2.default.readFile(gitignorePath, "utf-8");
1625
+ ig.add(gitignoreContent);
1626
+ } catch {
1627
+ }
1628
+ this.ignoreFilter = ig;
1629
+ return ig;
1630
+ }
1220
1631
  async grep(params) {
1221
1632
  let abs;
1222
1633
  try {
@@ -1344,9 +1755,11 @@ Details: ${res.stderr}` : ""}`
1344
1755
  const maxResults = params.maxResults ?? AGENT_CONFIG.MAX_OUTPUT_LINES;
1345
1756
  const maxDepth = params.maxDepth ?? AGENT_CONFIG.MAX_LIST_DEPTH;
1346
1757
  const regex = params.pattern ? new RegExp(params.pattern) : null;
1758
+ const ig = await this.getIgnoreFilter();
1347
1759
  const results = [];
1348
1760
  let timedOut = false;
1349
1761
  const startTime = Date.now();
1762
+ const repoRoot = this.repoRoot;
1350
1763
  async function walk(dir, depth) {
1351
1764
  if (Date.now() - startTime > AGENT_CONFIG.LIST_TIMEOUT_MS) {
1352
1765
  timedOut = true;
@@ -1357,17 +1770,18 @@ Details: ${res.stderr}` : ""}`
1357
1770
  for (const entry of entries) {
1358
1771
  if (timedOut || results.length >= maxResults) break;
1359
1772
  const full = import_path4.default.join(dir, entry.name);
1360
- const rel = toRepoRelative(abs, full).replace(/^[.][/\\]?/, "");
1361
- if (DEFAULT_EXCLUDES.some((ex) => rel.split(import_path4.default.sep).includes(ex))) continue;
1773
+ const relToRepo = toRepoRelative(repoRoot, full).replace(/^[.][/\\]?/, "");
1774
+ const isDir = entry.isDirectory();
1775
+ if (ig.ignores(relToRepo) || isDir && ig.ignores(relToRepo + "/")) continue;
1362
1776
  if (regex && !regex.test(entry.name)) continue;
1363
1777
  results.push({
1364
1778
  name: entry.name,
1365
1779
  path: toRepoRelative(import_path4.default.resolve(""), full),
1366
1780
  // relative display
1367
- type: entry.isDirectory() ? "dir" : "file",
1781
+ type: isDir ? "dir" : "file",
1368
1782
  depth
1369
1783
  });
1370
- if (entry.isDirectory()) {
1784
+ if (isDir) {
1371
1785
  await walk(full, depth + 1);
1372
1786
  }
1373
1787
  }
@@ -1378,11 +1792,25 @@ Details: ${res.stderr}` : ""}`
1378
1792
  };
1379
1793
 
1380
1794
  // tools/warp_grep/providers/remote.ts
1795
+ var ignore2 = require_ignore().default || require_ignore();
1381
1796
  var RemoteCommandsProvider = class {
1382
1797
  constructor(repoRoot, commands) {
1383
1798
  this.repoRoot = repoRoot;
1384
1799
  this.commands = commands;
1385
1800
  }
1801
+ ignoreFilter = null;
1802
+ /**
1803
+ * Build an ignore filter from DEFAULT_EXCLUDES.
1804
+ * Note: For remote providers, we can't read .gitignore from the remote sandbox,
1805
+ * so we only use the built-in excludes.
1806
+ */
1807
+ getIgnoreFilter() {
1808
+ if (this.ignoreFilter) return this.ignoreFilter;
1809
+ const ig = ignore2();
1810
+ ig.add(DEFAULT_EXCLUDES);
1811
+ this.ignoreFilter = ig;
1812
+ return ig;
1813
+ }
1386
1814
  /**
1387
1815
  * Run grep command and parse ripgrep output
1388
1816
  */
@@ -1436,6 +1864,7 @@ var RemoteCommandsProvider = class {
1436
1864
  async listDirectory(params) {
1437
1865
  const maxDepth = params.maxDepth ?? AGENT_CONFIG.MAX_LIST_DEPTH;
1438
1866
  const maxResults = params.maxResults ?? AGENT_CONFIG.MAX_OUTPUT_LINES;
1867
+ const ig = this.getIgnoreFilter();
1439
1868
  try {
1440
1869
  const stdout = await this.commands.listDir(params.path, maxDepth);
1441
1870
  const paths = (stdout || "").trim().split(/\r?\n/).filter((p) => p.length > 0);
@@ -1444,11 +1873,12 @@ var RemoteCommandsProvider = class {
1444
1873
  for (const fullPath of paths) {
1445
1874
  if (fullPath === params.path || fullPath === this.repoRoot) continue;
1446
1875
  const name = fullPath.split("/").pop() || "";
1447
- if (regex && !regex.test(name)) continue;
1448
1876
  let relativePath = fullPath;
1449
1877
  if (fullPath.startsWith(this.repoRoot)) {
1450
1878
  relativePath = fullPath.slice(this.repoRoot.length).replace(/^\//, "");
1451
1879
  }
1880
+ if (ig.ignores(relativePath)) continue;
1881
+ if (regex && !regex.test(name)) continue;
1452
1882
  const depth = relativePath.split("/").filter(Boolean).length - 1;
1453
1883
  const hasExtension = name.includes(".") && !name.startsWith(".");
1454
1884
  const type = hasExtension ? "file" : "dir";
@@ -1538,7 +1968,7 @@ var warpGrepFunctionDeclaration = {
1538
1968
  async function execute(input, config) {
1539
1969
  return executeToolCall(input, config);
1540
1970
  }
1541
- function createMorphWarpGrepTool(config) {
1971
+ function createWarpGrepTool(config) {
1542
1972
  const declaration = {
1543
1973
  name: config.name ?? WARP_GREP_TOOL_NAME,
1544
1974
  description: config.description ?? WARP_GREP_DESCRIPTION,
@@ -1556,10 +1986,12 @@ function createMorphWarpGrepTool(config) {
1556
1986
  }
1557
1987
  });
1558
1988
  }
1989
+ var createMorphWarpGrepTool = createWarpGrepTool;
1559
1990
  var gemini_default = warpGrepFunctionDeclaration;
1560
1991
  // Annotate the CommonJS export names for ESM import in node:
1561
1992
  0 && (module.exports = {
1562
1993
  createMorphWarpGrepTool,
1994
+ createWarpGrepTool,
1563
1995
  execute,
1564
1996
  formatResult,
1565
1997
  getSystemPrompt,