@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.
- package/dist/{chunk-6RFT7K7F.js → chunk-26QXQFLZ.js} +88 -23
- package/dist/chunk-26QXQFLZ.js.map +1 -0
- package/dist/{chunk-RTDKF6NS.js → chunk-5QIWYEHJ.js} +2 -2
- package/dist/{chunk-BYNVJ4ON.js → chunk-7CJPKJEE.js} +2 -2
- package/dist/{chunk-SXE54MIC.js → chunk-AB27WETH.js} +8 -8
- package/dist/chunk-B5A4XLSQ.js +10 -0
- package/dist/chunk-B5A4XLSQ.js.map +1 -0
- package/dist/{chunk-VDJGZIQ5.js → chunk-BGSHC2UK.js} +2 -2
- package/dist/{chunk-VLZEBK7S.js → chunk-E4434A4Y.js} +3 -3
- package/dist/{chunk-QEGH3CWQ.js → chunk-GZP6HY5W.js} +4 -20
- package/dist/{chunk-QEGH3CWQ.js.map → chunk-GZP6HY5W.js.map} +1 -1
- package/dist/{chunk-JPGX6WEV.js → chunk-I2GXV3BQ.js} +3 -16
- package/dist/{chunk-JPGX6WEV.js.map → chunk-I2GXV3BQ.js.map} +1 -1
- package/dist/{chunk-W76ICQKY.js → chunk-IUG2FHNN.js} +2 -2
- package/dist/{chunk-K3EHH3C4.js → chunk-PT3DGIUF.js} +3 -15
- package/dist/{chunk-K3EHH3C4.js.map → chunk-PT3DGIUF.js.map} +1 -1
- package/dist/chunk-PZ5AY32C.js +10 -0
- package/dist/{chunk-223ZMZP6.js → chunk-QIG7YPFW.js} +89 -30
- package/dist/chunk-QIG7YPFW.js.map +1 -0
- package/dist/{chunk-HBWJLKNM.js → chunk-QZNGKOCZ.js} +2 -2
- package/dist/{chunk-AAIUUX4Y.js → chunk-X4WPMVCM.js} +2 -2
- package/dist/client.cjs +174 -434
- package/dist/client.cjs.map +1 -1
- package/dist/client.js +11 -12
- package/dist/git/client.js +1 -1
- package/dist/git/config.js +1 -1
- package/dist/git/index.js +1 -1
- package/dist/index.cjs +179 -446
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +12 -14
- package/dist/modelrouter/core.js +1 -1
- package/dist/modelrouter/index.js +1 -1
- package/dist/tools/browser/anthropic.js +2 -2
- package/dist/tools/browser/core.js +1 -1
- package/dist/tools/browser/index.js +4 -4
- package/dist/tools/browser/live.js +1 -1
- package/dist/tools/browser/openai.js +2 -2
- package/dist/tools/browser/prompts.js +1 -1
- package/dist/tools/browser/vercel.js +2 -2
- package/dist/tools/codebase_search/anthropic.js +1 -1
- package/dist/tools/codebase_search/core.js +1 -1
- package/dist/tools/codebase_search/index.js +1 -1
- package/dist/tools/codebase_search/openai.js +1 -1
- package/dist/tools/codebase_search/prompts.js +1 -1
- package/dist/tools/codebase_search/vercel.js +1 -1
- package/dist/tools/fastapply/anthropic.js +2 -2
- package/dist/tools/fastapply/core.js +1 -1
- package/dist/tools/fastapply/index.js +4 -4
- package/dist/tools/fastapply/openai.js +2 -2
- package/dist/tools/fastapply/prompts.js +1 -1
- package/dist/tools/fastapply/vercel.js +2 -2
- package/dist/tools/index.js +4 -4
- package/dist/tools/utils/resilience.js +1 -1
- package/dist/tools/warp_grep/agent/config.js +1 -1
- package/dist/tools/warp_grep/agent/formatter.js +1 -1
- package/dist/tools/warp_grep/agent/parser.js +1 -1
- package/dist/tools/warp_grep/agent/prompt.js +1 -1
- package/dist/tools/warp_grep/agent/runner.js +1 -1
- package/dist/tools/warp_grep/anthropic.cjs +174 -434
- package/dist/tools/warp_grep/anthropic.cjs.map +1 -1
- package/dist/tools/warp_grep/anthropic.d.ts +78 -3
- package/dist/tools/warp_grep/anthropic.js +5 -6
- package/dist/tools/warp_grep/client.cjs +174 -434
- package/dist/tools/warp_grep/client.cjs.map +1 -1
- package/dist/tools/warp_grep/client.js +4 -5
- package/dist/tools/warp_grep/gemini.cjs +176 -437
- package/dist/tools/warp_grep/gemini.cjs.map +1 -1
- package/dist/tools/warp_grep/gemini.d.ts +109 -3
- package/dist/tools/warp_grep/gemini.js +48 -12
- package/dist/tools/warp_grep/gemini.js.map +1 -1
- package/dist/tools/warp_grep/harness.cjs +88 -417
- package/dist/tools/warp_grep/harness.cjs.map +1 -1
- package/dist/tools/warp_grep/harness.js +2 -3
- package/dist/tools/warp_grep/harness.js.map +1 -1
- package/dist/tools/warp_grep/index.cjs +180 -621
- package/dist/tools/warp_grep/index.cjs.map +1 -1
- package/dist/tools/warp_grep/index.d.ts +89 -9
- package/dist/tools/warp_grep/index.js +7 -21
- package/dist/tools/warp_grep/openai.cjs +174 -434
- package/dist/tools/warp_grep/openai.cjs.map +1 -1
- package/dist/tools/warp_grep/openai.d.ts +78 -3
- package/dist/tools/warp_grep/openai.js +5 -6
- package/dist/tools/warp_grep/providers/local.cjs +88 -417
- package/dist/tools/warp_grep/providers/local.cjs.map +1 -1
- package/dist/tools/warp_grep/providers/local.d.ts +0 -6
- package/dist/tools/warp_grep/providers/local.js +2 -3
- package/dist/tools/warp_grep/providers/remote.cjs +86 -408
- package/dist/tools/warp_grep/providers/remote.cjs.map +1 -1
- package/dist/tools/warp_grep/providers/remote.d.ts +0 -7
- package/dist/tools/warp_grep/providers/remote.js +2 -3
- package/dist/tools/warp_grep/utils/files.js +1 -1
- package/dist/tools/warp_grep/utils/paths.js +1 -1
- package/dist/tools/warp_grep/utils/ripgrep.js +1 -1
- package/dist/tools/warp_grep/vercel.cjs +174 -434
- package/dist/tools/warp_grep/vercel.cjs.map +1 -1
- package/dist/tools/warp_grep/vercel.d.ts +56 -3
- package/dist/tools/warp_grep/vercel.js +5 -6
- package/package.json +1 -1
- package/dist/anthropic-BC-AMEIN.d.ts +0 -89
- package/dist/chunk-223ZMZP6.js.map +0 -1
- package/dist/chunk-6RFT7K7F.js.map +0 -1
- package/dist/chunk-FURFQDXF.js +0 -75
- package/dist/chunk-FURFQDXF.js.map +0 -1
- package/dist/chunk-HKJ2B2AA.js +0 -15
- package/dist/chunk-ISWL67SF.js +0 -1
- package/dist/chunk-ISWL67SF.js.map +0 -1
- package/dist/chunk-S6KU22MU.js +0 -396
- package/dist/chunk-S6KU22MU.js.map +0 -1
- package/dist/gemini-BIFBiIjY.d.ts +0 -119
- package/dist/openai-Beb9escY.d.ts +0 -89
- package/dist/vercel-Bo84tpBe.d.ts +0 -66
- /package/dist/{chunk-RTDKF6NS.js.map → chunk-5QIWYEHJ.js.map} +0 -0
- /package/dist/{chunk-BYNVJ4ON.js.map → chunk-7CJPKJEE.js.map} +0 -0
- /package/dist/{chunk-SXE54MIC.js.map → chunk-AB27WETH.js.map} +0 -0
- /package/dist/{chunk-VDJGZIQ5.js.map → chunk-BGSHC2UK.js.map} +0 -0
- /package/dist/{chunk-VLZEBK7S.js.map → chunk-E4434A4Y.js.map} +0 -0
- /package/dist/{chunk-W76ICQKY.js.map → chunk-IUG2FHNN.js.map} +0 -0
- /package/dist/{chunk-HKJ2B2AA.js.map → chunk-PZ5AY32C.js.map} +0 -0
- /package/dist/{chunk-HBWJLKNM.js.map → chunk-QZNGKOCZ.js.map} +0 -0
- /package/dist/{chunk-AAIUUX4Y.js.map → chunk-X4WPMVCM.js.map} +0 -0
|
@@ -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
|
// tools/warp_grep/client.ts
|
|
422
31
|
var client_exports = {};
|
|
423
32
|
__export(client_exports, {
|
|
@@ -1600,30 +1209,95 @@ async function readAllLines(filePath) {
|
|
|
1600
1209
|
}
|
|
1601
1210
|
|
|
1602
1211
|
// tools/warp_grep/providers/local.ts
|
|
1603
|
-
var
|
|
1212
|
+
var SKIP_NAMES = /* @__PURE__ */ new Set([
|
|
1213
|
+
// Version control
|
|
1214
|
+
".git",
|
|
1215
|
+
".svn",
|
|
1216
|
+
".hg",
|
|
1217
|
+
".bzr",
|
|
1218
|
+
// Dependencies
|
|
1219
|
+
"node_modules",
|
|
1220
|
+
"bower_components",
|
|
1221
|
+
".pnpm",
|
|
1222
|
+
".yarn",
|
|
1223
|
+
"vendor",
|
|
1224
|
+
"Pods",
|
|
1225
|
+
".bundle",
|
|
1226
|
+
// Python
|
|
1227
|
+
"__pycache__",
|
|
1228
|
+
".pytest_cache",
|
|
1229
|
+
".mypy_cache",
|
|
1230
|
+
".ruff_cache",
|
|
1231
|
+
".venv",
|
|
1232
|
+
"venv",
|
|
1233
|
+
".tox",
|
|
1234
|
+
".nox",
|
|
1235
|
+
".eggs",
|
|
1236
|
+
// Build outputs
|
|
1237
|
+
"dist",
|
|
1238
|
+
"build",
|
|
1239
|
+
"out",
|
|
1240
|
+
"output",
|
|
1241
|
+
"target",
|
|
1242
|
+
"_build",
|
|
1243
|
+
".next",
|
|
1244
|
+
".nuxt",
|
|
1245
|
+
".output",
|
|
1246
|
+
".vercel",
|
|
1247
|
+
".netlify",
|
|
1248
|
+
// Cache
|
|
1249
|
+
".cache",
|
|
1250
|
+
".parcel-cache",
|
|
1251
|
+
".turbo",
|
|
1252
|
+
".nx",
|
|
1253
|
+
".gradle",
|
|
1254
|
+
// IDE
|
|
1255
|
+
".idea",
|
|
1256
|
+
".vscode",
|
|
1257
|
+
".vs",
|
|
1258
|
+
// Coverage
|
|
1259
|
+
"coverage",
|
|
1260
|
+
".coverage",
|
|
1261
|
+
"htmlcov",
|
|
1262
|
+
".nyc_output",
|
|
1263
|
+
// Temp
|
|
1264
|
+
"tmp",
|
|
1265
|
+
"temp",
|
|
1266
|
+
".tmp",
|
|
1267
|
+
".temp",
|
|
1268
|
+
// Lock files
|
|
1269
|
+
"package-lock.json",
|
|
1270
|
+
"yarn.lock",
|
|
1271
|
+
"pnpm-lock.yaml",
|
|
1272
|
+
"bun.lockb",
|
|
1273
|
+
"Cargo.lock",
|
|
1274
|
+
"Gemfile.lock",
|
|
1275
|
+
"poetry.lock"
|
|
1276
|
+
]);
|
|
1277
|
+
var SKIP_EXTENSIONS = /* @__PURE__ */ new Set([
|
|
1278
|
+
".min.js",
|
|
1279
|
+
".min.css",
|
|
1280
|
+
".bundle.js",
|
|
1281
|
+
".wasm",
|
|
1282
|
+
".so",
|
|
1283
|
+
".dll",
|
|
1284
|
+
".pyc",
|
|
1285
|
+
".map",
|
|
1286
|
+
".js.map"
|
|
1287
|
+
]);
|
|
1288
|
+
function shouldSkip(name) {
|
|
1289
|
+
if (SKIP_NAMES.has(name)) return true;
|
|
1290
|
+
if (name.startsWith(".")) return true;
|
|
1291
|
+
for (const ext of SKIP_EXTENSIONS) {
|
|
1292
|
+
if (name.endsWith(ext)) return true;
|
|
1293
|
+
}
|
|
1294
|
+
return false;
|
|
1295
|
+
}
|
|
1604
1296
|
var LocalRipgrepProvider = class {
|
|
1605
1297
|
constructor(repoRoot, excludes = DEFAULT_EXCLUDES) {
|
|
1606
1298
|
this.repoRoot = repoRoot;
|
|
1607
1299
|
this.excludes = excludes;
|
|
1608
1300
|
}
|
|
1609
|
-
ignoreFilter = null;
|
|
1610
|
-
/**
|
|
1611
|
-
* Build an ignore filter that combines DEFAULT_EXCLUDES and .gitignore patterns.
|
|
1612
|
-
* Cached after first call.
|
|
1613
|
-
*/
|
|
1614
|
-
async getIgnoreFilter() {
|
|
1615
|
-
if (this.ignoreFilter) return this.ignoreFilter;
|
|
1616
|
-
const ig = ignore();
|
|
1617
|
-
ig.add(this.excludes);
|
|
1618
|
-
try {
|
|
1619
|
-
const gitignorePath = import_path4.default.join(this.repoRoot, ".gitignore");
|
|
1620
|
-
const gitignoreContent = await import_promises2.default.readFile(gitignorePath, "utf-8");
|
|
1621
|
-
ig.add(gitignoreContent);
|
|
1622
|
-
} catch {
|
|
1623
|
-
}
|
|
1624
|
-
this.ignoreFilter = ig;
|
|
1625
|
-
return ig;
|
|
1626
|
-
}
|
|
1627
1301
|
async grep(params) {
|
|
1628
1302
|
let abs;
|
|
1629
1303
|
try {
|
|
@@ -1751,11 +1425,10 @@ Details: ${res.stderr}` : ""}`
|
|
|
1751
1425
|
const maxResults = params.maxResults ?? AGENT_CONFIG.MAX_OUTPUT_LINES;
|
|
1752
1426
|
const maxDepth = params.maxDepth ?? AGENT_CONFIG.MAX_LIST_DEPTH;
|
|
1753
1427
|
const regex = params.pattern ? new RegExp(params.pattern) : null;
|
|
1754
|
-
const
|
|
1428
|
+
const repoRoot = this.repoRoot;
|
|
1755
1429
|
const results = [];
|
|
1756
1430
|
let timedOut = false;
|
|
1757
1431
|
const startTime = Date.now();
|
|
1758
|
-
const repoRoot = this.repoRoot;
|
|
1759
1432
|
async function walk(dir, depth) {
|
|
1760
1433
|
if (Date.now() - startTime > AGENT_CONFIG.LIST_TIMEOUT_MS) {
|
|
1761
1434
|
timedOut = true;
|
|
@@ -1765,15 +1438,13 @@ Details: ${res.stderr}` : ""}`
|
|
|
1765
1438
|
const entries = await import_promises2.default.readdir(dir, { withFileTypes: true });
|
|
1766
1439
|
for (const entry of entries) {
|
|
1767
1440
|
if (timedOut || results.length >= maxResults) break;
|
|
1441
|
+
if (shouldSkip(entry.name)) continue;
|
|
1442
|
+
if (regex && !regex.test(entry.name)) continue;
|
|
1768
1443
|
const full = import_path4.default.join(dir, entry.name);
|
|
1769
|
-
const relToRepo = toRepoRelative(repoRoot, full).replace(/^[.][/\\]?/, "");
|
|
1770
1444
|
const isDir = entry.isDirectory();
|
|
1771
|
-
if (ig.ignores(relToRepo) || isDir && ig.ignores(relToRepo + "/")) continue;
|
|
1772
|
-
if (regex && !regex.test(entry.name)) continue;
|
|
1773
1445
|
results.push({
|
|
1774
1446
|
name: entry.name,
|
|
1775
|
-
path: toRepoRelative(
|
|
1776
|
-
// relative display
|
|
1447
|
+
path: toRepoRelative(repoRoot, full),
|
|
1777
1448
|
type: isDir ? "dir" : "file",
|
|
1778
1449
|
depth
|
|
1779
1450
|
});
|
|
@@ -1788,25 +1459,95 @@ Details: ${res.stderr}` : ""}`
|
|
|
1788
1459
|
};
|
|
1789
1460
|
|
|
1790
1461
|
// tools/warp_grep/providers/remote.ts
|
|
1791
|
-
var
|
|
1462
|
+
var SKIP_NAMES2 = /* @__PURE__ */ new Set([
|
|
1463
|
+
// Version control
|
|
1464
|
+
".git",
|
|
1465
|
+
".svn",
|
|
1466
|
+
".hg",
|
|
1467
|
+
".bzr",
|
|
1468
|
+
// Dependencies
|
|
1469
|
+
"node_modules",
|
|
1470
|
+
"bower_components",
|
|
1471
|
+
".pnpm",
|
|
1472
|
+
".yarn",
|
|
1473
|
+
"vendor",
|
|
1474
|
+
"Pods",
|
|
1475
|
+
".bundle",
|
|
1476
|
+
// Python
|
|
1477
|
+
"__pycache__",
|
|
1478
|
+
".pytest_cache",
|
|
1479
|
+
".mypy_cache",
|
|
1480
|
+
".ruff_cache",
|
|
1481
|
+
".venv",
|
|
1482
|
+
"venv",
|
|
1483
|
+
".tox",
|
|
1484
|
+
".nox",
|
|
1485
|
+
".eggs",
|
|
1486
|
+
// Build outputs
|
|
1487
|
+
"dist",
|
|
1488
|
+
"build",
|
|
1489
|
+
"out",
|
|
1490
|
+
"output",
|
|
1491
|
+
"target",
|
|
1492
|
+
"_build",
|
|
1493
|
+
".next",
|
|
1494
|
+
".nuxt",
|
|
1495
|
+
".output",
|
|
1496
|
+
".vercel",
|
|
1497
|
+
".netlify",
|
|
1498
|
+
// Cache
|
|
1499
|
+
".cache",
|
|
1500
|
+
".parcel-cache",
|
|
1501
|
+
".turbo",
|
|
1502
|
+
".nx",
|
|
1503
|
+
".gradle",
|
|
1504
|
+
// IDE
|
|
1505
|
+
".idea",
|
|
1506
|
+
".vscode",
|
|
1507
|
+
".vs",
|
|
1508
|
+
// Coverage
|
|
1509
|
+
"coverage",
|
|
1510
|
+
".coverage",
|
|
1511
|
+
"htmlcov",
|
|
1512
|
+
".nyc_output",
|
|
1513
|
+
// Temp
|
|
1514
|
+
"tmp",
|
|
1515
|
+
"temp",
|
|
1516
|
+
".tmp",
|
|
1517
|
+
".temp",
|
|
1518
|
+
// Lock files
|
|
1519
|
+
"package-lock.json",
|
|
1520
|
+
"yarn.lock",
|
|
1521
|
+
"pnpm-lock.yaml",
|
|
1522
|
+
"bun.lockb",
|
|
1523
|
+
"Cargo.lock",
|
|
1524
|
+
"Gemfile.lock",
|
|
1525
|
+
"poetry.lock"
|
|
1526
|
+
]);
|
|
1527
|
+
var SKIP_EXTENSIONS2 = /* @__PURE__ */ new Set([
|
|
1528
|
+
".min.js",
|
|
1529
|
+
".min.css",
|
|
1530
|
+
".bundle.js",
|
|
1531
|
+
".wasm",
|
|
1532
|
+
".so",
|
|
1533
|
+
".dll",
|
|
1534
|
+
".pyc",
|
|
1535
|
+
".map",
|
|
1536
|
+
".js.map"
|
|
1537
|
+
]);
|
|
1538
|
+
function shouldSkip2(name) {
|
|
1539
|
+
if (SKIP_NAMES2.has(name)) return true;
|
|
1540
|
+
if (name.startsWith(".")) return true;
|
|
1541
|
+
for (const ext of SKIP_EXTENSIONS2) {
|
|
1542
|
+
if (name.endsWith(ext)) return true;
|
|
1543
|
+
}
|
|
1544
|
+
return false;
|
|
1545
|
+
}
|
|
1792
1546
|
var RemoteCommandsProvider = class {
|
|
1793
1547
|
constructor(repoRoot, commands) {
|
|
1794
1548
|
this.repoRoot = repoRoot;
|
|
1795
1549
|
this.commands = commands;
|
|
1796
1550
|
}
|
|
1797
|
-
ignoreFilter = null;
|
|
1798
|
-
/**
|
|
1799
|
-
* Build an ignore filter from DEFAULT_EXCLUDES.
|
|
1800
|
-
* Note: For remote providers, we can't read .gitignore from the remote sandbox,
|
|
1801
|
-
* so we only use the built-in excludes.
|
|
1802
|
-
*/
|
|
1803
|
-
getIgnoreFilter() {
|
|
1804
|
-
if (this.ignoreFilter) return this.ignoreFilter;
|
|
1805
|
-
const ig = ignore2();
|
|
1806
|
-
ig.add(DEFAULT_EXCLUDES);
|
|
1807
|
-
this.ignoreFilter = ig;
|
|
1808
|
-
return ig;
|
|
1809
|
-
}
|
|
1810
1551
|
/**
|
|
1811
1552
|
* Run grep command and parse ripgrep output
|
|
1812
1553
|
*/
|
|
@@ -1860,7 +1601,6 @@ var RemoteCommandsProvider = class {
|
|
|
1860
1601
|
async listDirectory(params) {
|
|
1861
1602
|
const maxDepth = params.maxDepth ?? AGENT_CONFIG.MAX_LIST_DEPTH;
|
|
1862
1603
|
const maxResults = params.maxResults ?? AGENT_CONFIG.MAX_OUTPUT_LINES;
|
|
1863
|
-
const ig = this.getIgnoreFilter();
|
|
1864
1604
|
try {
|
|
1865
1605
|
const stdout = await this.commands.listDir(params.path, maxDepth);
|
|
1866
1606
|
const paths = (stdout || "").trim().split(/\r?\n/).filter((p) => p.length > 0);
|
|
@@ -1869,12 +1609,12 @@ var RemoteCommandsProvider = class {
|
|
|
1869
1609
|
for (const fullPath of paths) {
|
|
1870
1610
|
if (fullPath === params.path || fullPath === this.repoRoot) continue;
|
|
1871
1611
|
const name = fullPath.split("/").pop() || "";
|
|
1612
|
+
if (shouldSkip2(name)) continue;
|
|
1613
|
+
if (regex && !regex.test(name)) continue;
|
|
1872
1614
|
let relativePath = fullPath;
|
|
1873
1615
|
if (fullPath.startsWith(this.repoRoot)) {
|
|
1874
1616
|
relativePath = fullPath.slice(this.repoRoot.length).replace(/^\//, "");
|
|
1875
1617
|
}
|
|
1876
|
-
if (ig.ignores(relativePath)) continue;
|
|
1877
|
-
if (regex && !regex.test(name)) continue;
|
|
1878
1618
|
const depth = relativePath.split("/").filter(Boolean).length - 1;
|
|
1879
1619
|
const hasExtension = name.includes(".") && !name.startsWith(".");
|
|
1880
1620
|
const type = hasExtension ? "file" : "dir";
|