@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
package/dist/client.js CHANGED
@@ -1,39 +1,40 @@
1
1
  import {
2
2
  MorphClient
3
- } from "./chunk-SU5CKH4F.js";
4
- import "./chunk-AQD2JCLI.js";
5
- import "./chunk-XLSODV6H.js";
6
- import "./chunk-7V2KIZT5.js";
3
+ } from "./chunk-SXE54MIC.js";
4
+ import "./chunk-K3EHH3C4.js";
5
+ import "./chunk-JPGX6WEV.js";
6
+ import "./chunk-QEGH3CWQ.js";
7
7
  import "./chunk-KW7OEGZK.js";
8
- import "./chunk-7JEL2VZO.js";
8
+ import "./chunk-VLZEBK7S.js";
9
9
  import "./chunk-SUBBMTMY.js";
10
- import "./chunk-GGYMQZXI.js";
10
+ import "./chunk-6RFT7K7F.js";
11
11
  import "./chunk-DCIUCDWJ.js";
12
12
  import "./chunk-APP75CBN.js";
13
13
  import "./chunk-5QRN3JNB.js";
14
14
  import "./chunk-Q5AHGIQO.js";
15
- import "./chunk-ZO4PPFCZ.js";
15
+ import "./chunk-223ZMZP6.js";
16
16
  import "./chunk-G2RSY56Q.js";
17
17
  import "./chunk-SMGZ6A64.js";
18
18
  import "./chunk-TPP2UGQP.js";
19
+ import "./chunk-S6KU22MU.js";
19
20
  import "./chunk-XT5ZO6ES.js";
20
21
  import "./chunk-UBX7QYBD.js";
21
22
  import "./chunk-GJU7UOFL.js";
22
23
  import "./chunk-76DJEQEP.js";
23
24
  import "./chunk-WM77HRKO.js";
24
25
  import "./chunk-YQMPVJ2L.js";
25
- import "./chunk-IUG2FHNN.js";
26
- import "./chunk-5QIWYEHJ.js";
27
- import "./chunk-QZNGKOCZ.js";
26
+ import "./chunk-W76ICQKY.js";
27
+ import "./chunk-RTDKF6NS.js";
28
+ import "./chunk-HBWJLKNM.js";
28
29
  import "./chunk-CKTA4AXM.js";
29
30
  import "./chunk-63WE2C5R.js";
30
- import "./chunk-IZISG7DL.js";
31
+ import "./chunk-MFZP347Z.js";
31
32
  import "./chunk-SQN4DUQS.js";
32
33
  import "./chunk-GZMUGMOZ.js";
33
34
  import "./chunk-VJU3BRET.js";
34
35
  import "./chunk-CP4NZGRY.js";
35
36
  import "./chunk-4VWJFZVS.js";
36
- import "./chunk-PZ5AY32C.js";
37
+ import "./chunk-HKJ2B2AA.js";
37
38
  export {
38
39
  MorphClient
39
40
  };
@@ -102,16 +102,18 @@ interface GeminiWarpGrepTool extends FunctionDeclaration {
102
102
  * });
103
103
  * ```
104
104
  */
105
- declare function createMorphWarpGrepTool(config: WarpGrepToolConfig): GeminiWarpGrepTool;
105
+ declare function createWarpGrepTool(config: WarpGrepToolConfig): GeminiWarpGrepTool;
106
+ declare const createMorphWarpGrepTool: typeof createWarpGrepTool;
106
107
 
107
108
  type gemini_GeminiWarpGrepTool = GeminiWarpGrepTool;
108
109
  declare const gemini_createMorphWarpGrepTool: typeof createMorphWarpGrepTool;
110
+ declare const gemini_createWarpGrepTool: typeof createWarpGrepTool;
109
111
  declare const gemini_execute: typeof execute;
110
112
  declare const gemini_formatResult: typeof formatResult;
111
113
  declare const gemini_getSystemPrompt: typeof getSystemPrompt;
112
114
  declare const gemini_warpGrepFunctionDeclaration: typeof warpGrepFunctionDeclaration;
113
115
  declare namespace gemini {
114
- export { type gemini_GeminiWarpGrepTool as GeminiWarpGrepTool, gemini_createMorphWarpGrepTool as createMorphWarpGrepTool, warpGrepFunctionDeclaration as default, gemini_execute as execute, gemini_formatResult as formatResult, gemini_getSystemPrompt as getSystemPrompt, gemini_warpGrepFunctionDeclaration as warpGrepFunctionDeclaration };
116
+ export { type gemini_GeminiWarpGrepTool as GeminiWarpGrepTool, gemini_createMorphWarpGrepTool as createMorphWarpGrepTool, gemini_createWarpGrepTool as createWarpGrepTool, warpGrepFunctionDeclaration as default, gemini_execute as execute, gemini_formatResult as formatResult, gemini_getSystemPrompt as getSystemPrompt, gemini_warpGrepFunctionDeclaration as warpGrepFunctionDeclaration };
115
117
  }
116
118
 
117
- export { type GeminiWarpGrepTool as G, createMorphWarpGrepTool as c, execute as e, gemini as g, warpGrepFunctionDeclaration as w };
119
+ export { type GeminiWarpGrepTool as G, createMorphWarpGrepTool as a, createWarpGrepTool as c, execute as e, gemini as g, warpGrepFunctionDeclaration as w };
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  MorphGit
3
3
  } from "../chunk-VJU3BRET.js";
4
- import "../chunk-PZ5AY32C.js";
4
+ import "../chunk-HKJ2B2AA.js";
5
5
  export {
6
6
  MorphGit
7
7
  };
@@ -1,4 +1,4 @@
1
- import "../chunk-PZ5AY32C.js";
1
+ import "../chunk-HKJ2B2AA.js";
2
2
 
3
3
  // git/config.ts
4
4
  var DEFAULT_PROXY_URL = "https://repos.morphllm.com";
package/dist/git/index.js CHANGED
@@ -5,7 +5,7 @@ import {
5
5
  import {
6
6
  MorphGit
7
7
  } from "../chunk-VJU3BRET.js";
8
- import "../chunk-PZ5AY32C.js";
8
+ import "../chunk-HKJ2B2AA.js";
9
9
  export {
10
10
  MorphGit,
11
11
  default2 as git,
package/dist/index.cjs CHANGED
@@ -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,6 +30,394 @@ 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
  // index.ts
31
422
  var index_exports = {};
32
423
  __export(index_exports, {
@@ -751,14 +1142,17 @@ async function executeWithRecording(input, config = {}) {
751
1142
  recording
752
1143
  };
753
1144
  } catch (error) {
1145
+ const errorRecording = {
1146
+ id: taskResult.recording_id,
1147
+ status: "ERROR",
1148
+ error: error instanceof Error ? error.message : String(error),
1149
+ created_at: (/* @__PURE__ */ new Date()).toISOString(),
1150
+ getWebp: (options) => getWebp(taskResult.recording_id, config, options),
1151
+ getErrors: () => getErrors(taskResult.recording_id, config)
1152
+ };
754
1153
  return {
755
1154
  ...taskResult,
756
- recording: {
757
- id: taskResult.recording_id,
758
- status: "ERROR",
759
- error: error instanceof Error ? error.message : String(error),
760
- created_at: (/* @__PURE__ */ new Date()).toISOString()
761
- }
1155
+ recording: errorRecording
762
1156
  };
763
1157
  }
764
1158
  }
@@ -2093,11 +2487,30 @@ async function readAllLines(filePath) {
2093
2487
  }
2094
2488
 
2095
2489
  // tools/warp_grep/providers/local.ts
2490
+ var ignore = require_ignore().default || require_ignore();
2096
2491
  var LocalRipgrepProvider = class {
2097
2492
  constructor(repoRoot, excludes = DEFAULT_EXCLUDES) {
2098
2493
  this.repoRoot = repoRoot;
2099
2494
  this.excludes = excludes;
2100
2495
  }
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
+ }
2101
2514
  async grep(params) {
2102
2515
  let abs;
2103
2516
  try {
@@ -2225,9 +2638,11 @@ Details: ${res.stderr}` : ""}`
2225
2638
  const maxResults = params.maxResults ?? AGENT_CONFIG.MAX_OUTPUT_LINES;
2226
2639
  const maxDepth = params.maxDepth ?? AGENT_CONFIG.MAX_LIST_DEPTH;
2227
2640
  const regex = params.pattern ? new RegExp(params.pattern) : null;
2641
+ const ig = await this.getIgnoreFilter();
2228
2642
  const results = [];
2229
2643
  let timedOut = false;
2230
2644
  const startTime = Date.now();
2645
+ const repoRoot = this.repoRoot;
2231
2646
  async function walk(dir, depth) {
2232
2647
  if (Date.now() - startTime > AGENT_CONFIG.LIST_TIMEOUT_MS) {
2233
2648
  timedOut = true;
@@ -2238,17 +2653,18 @@ Details: ${res.stderr}` : ""}`
2238
2653
  for (const entry of entries) {
2239
2654
  if (timedOut || results.length >= maxResults) break;
2240
2655
  const full = import_path5.default.join(dir, entry.name);
2241
- const rel = toRepoRelative(abs, full).replace(/^[.][/\\]?/, "");
2242
- if (DEFAULT_EXCLUDES.some((ex) => rel.split(import_path5.default.sep).includes(ex))) continue;
2656
+ const relToRepo = toRepoRelative(repoRoot, full).replace(/^[.][/\\]?/, "");
2657
+ const isDir = entry.isDirectory();
2658
+ if (ig.ignores(relToRepo) || isDir && ig.ignores(relToRepo + "/")) continue;
2243
2659
  if (regex && !regex.test(entry.name)) continue;
2244
2660
  results.push({
2245
2661
  name: entry.name,
2246
2662
  path: toRepoRelative(import_path5.default.resolve(""), full),
2247
2663
  // relative display
2248
- type: entry.isDirectory() ? "dir" : "file",
2664
+ type: isDir ? "dir" : "file",
2249
2665
  depth
2250
2666
  });
2251
- if (entry.isDirectory()) {
2667
+ if (isDir) {
2252
2668
  await walk(full, depth + 1);
2253
2669
  }
2254
2670
  }
@@ -2259,11 +2675,25 @@ Details: ${res.stderr}` : ""}`
2259
2675
  };
2260
2676
 
2261
2677
  // tools/warp_grep/providers/remote.ts
2678
+ var ignore2 = require_ignore().default || require_ignore();
2262
2679
  var RemoteCommandsProvider = class {
2263
2680
  constructor(repoRoot, commands) {
2264
2681
  this.repoRoot = repoRoot;
2265
2682
  this.commands = commands;
2266
2683
  }
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
+ }
2267
2697
  /**
2268
2698
  * Run grep command and parse ripgrep output
2269
2699
  */
@@ -2317,6 +2747,7 @@ var RemoteCommandsProvider = class {
2317
2747
  async listDirectory(params) {
2318
2748
  const maxDepth = params.maxDepth ?? AGENT_CONFIG.MAX_LIST_DEPTH;
2319
2749
  const maxResults = params.maxResults ?? AGENT_CONFIG.MAX_OUTPUT_LINES;
2750
+ const ig = this.getIgnoreFilter();
2320
2751
  try {
2321
2752
  const stdout = await this.commands.listDir(params.path, maxDepth);
2322
2753
  const paths = (stdout || "").trim().split(/\r?\n/).filter((p) => p.length > 0);
@@ -2325,11 +2756,12 @@ var RemoteCommandsProvider = class {
2325
2756
  for (const fullPath of paths) {
2326
2757
  if (fullPath === params.path || fullPath === this.repoRoot) continue;
2327
2758
  const name = fullPath.split("/").pop() || "";
2328
- if (regex && !regex.test(name)) continue;
2329
2759
  let relativePath = fullPath;
2330
2760
  if (fullPath.startsWith(this.repoRoot)) {
2331
2761
  relativePath = fullPath.slice(this.repoRoot.length).replace(/^\//, "");
2332
2762
  }
2763
+ if (ig.ignores(relativePath)) continue;
2764
+ if (regex && !regex.test(name)) continue;
2333
2765
  const depth = relativePath.split("/").filter(Boolean).length - 1;
2334
2766
  const hasExtension = name.includes(".") && !name.startsWith(".");
2335
2767
  const type = hasExtension ? "file" : "dir";