@morphllm/morphsdk 0.2.121 → 0.2.123
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-L4PK4VC7.js → chunk-5OJE7GH4.js} +2 -2
- package/dist/chunk-63VHBANJ.js +22 -0
- package/dist/chunk-63VHBANJ.js.map +1 -0
- package/dist/{chunk-BDKXYMU2.js → chunk-ANPZFWYV.js} +2 -2
- package/dist/{chunk-DL3Y3R6A.js → chunk-BJ2764MK.js} +2 -2
- package/dist/{chunk-JBIFS33U.js → chunk-DBSOONOY.js} +2 -2
- package/dist/chunk-ETTCJWJK.js +113 -0
- package/dist/chunk-ETTCJWJK.js.map +1 -0
- package/dist/{chunk-EJYFE73S.js → chunk-FMKJ72KT.js} +3 -3
- package/dist/{chunk-EJYFE73S.js.map → chunk-FMKJ72KT.js.map} +1 -1
- package/dist/{chunk-7QZFNYOH.js → chunk-GXFJLL5O.js} +2 -2
- package/dist/chunk-H3U7J5RI.js +98 -0
- package/dist/chunk-H3U7J5RI.js.map +1 -0
- package/dist/{chunk-MAAULSSQ.js → chunk-HVBJ4UO6.js} +2 -2
- package/dist/{chunk-3HBZXN6E.js → chunk-K74GLGST.js} +2 -2
- package/dist/{chunk-EZFXR52Q.js → chunk-KL3AMLGL.js} +2 -2
- package/dist/{chunk-YMOTJ6ZP.js → chunk-L426IMZD.js} +2 -2
- package/dist/{chunk-C3BQUIFE.js → chunk-MXSGTN7R.js} +145 -9
- package/dist/chunk-MXSGTN7R.js.map +1 -0
- package/dist/{chunk-266SWRHK.js → chunk-OFJYDTQI.js} +2 -2
- package/dist/chunk-OTOVGCG6.js +42 -0
- package/dist/chunk-OTOVGCG6.js.map +1 -0
- package/dist/{chunk-W37KJB25.js → chunk-QD7KPI7A.js} +2 -2
- package/dist/chunk-QGRFAVGK.js +112 -0
- package/dist/chunk-QGRFAVGK.js.map +1 -0
- package/dist/{chunk-WEBUKGPK.js → chunk-UHL2ZEWG.js} +3 -3
- package/dist/{chunk-CIFPLFBQ.js → chunk-UJS3AIWS.js} +2 -2
- package/dist/{chunk-FV3R3JGV.js → chunk-UX65IRCX.js} +2 -2
- package/dist/{chunk-L5C6E32T.js → chunk-V3HLOZK2.js} +1 -1
- package/dist/{chunk-L5C6E32T.js.map → chunk-V3HLOZK2.js.map} +1 -1
- package/dist/{chunk-7IZUNRPZ.js → chunk-V4KBK66V.js} +54 -15
- package/dist/{chunk-7IZUNRPZ.js.map → chunk-V4KBK66V.js.map} +1 -1
- package/dist/{chunk-AI3ZCOCT.js → chunk-WE75QX2B.js} +1 -1
- package/dist/chunk-WYYR2EU6.js +29 -0
- package/dist/chunk-WYYR2EU6.js.map +1 -0
- package/dist/{chunk-GNRMDXJA.js → chunk-XXL62KSJ.js} +2 -2
- package/dist/{chunk-QDGB6FLI.js → chunk-ZZCMAFN7.js} +5 -5
- package/dist/chunk-ZZCMAFN7.js.map +1 -0
- package/dist/{client-Bp3MRcJc.d.ts → client-JHPwle1Z.d.ts} +46 -1
- package/dist/client.cjs +287 -12
- package/dist/client.cjs.map +1 -1
- package/dist/client.d.ts +2 -2
- package/dist/client.js +23 -21
- package/dist/edge.cjs +2 -2
- package/dist/edge.cjs.map +1 -1
- package/dist/edge.js +4 -4
- package/dist/index.cjs +287 -12
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +2 -2
- package/dist/index.js +24 -22
- package/dist/modelrouter/core.cjs +2 -2
- package/dist/modelrouter/core.cjs.map +1 -1
- package/dist/modelrouter/core.js +3 -3
- package/dist/modelrouter/index.cjs +2 -2
- package/dist/modelrouter/index.cjs.map +1 -1
- package/dist/modelrouter/index.js +3 -3
- package/dist/tools/browser/anthropic.cjs +2 -2
- package/dist/tools/browser/anthropic.cjs.map +1 -1
- package/dist/tools/browser/anthropic.js +5 -5
- package/dist/tools/browser/core.cjs +2 -2
- package/dist/tools/browser/core.cjs.map +1 -1
- package/dist/tools/browser/core.js +4 -4
- package/dist/tools/browser/index.cjs +2 -2
- package/dist/tools/browser/index.cjs.map +1 -1
- package/dist/tools/browser/index.js +7 -7
- package/dist/tools/browser/openai.cjs +2 -2
- package/dist/tools/browser/openai.cjs.map +1 -1
- package/dist/tools/browser/openai.js +5 -5
- package/dist/tools/browser/profiles/core.cjs +2 -2
- package/dist/tools/browser/profiles/core.cjs.map +1 -1
- package/dist/tools/browser/profiles/core.js +3 -3
- package/dist/tools/browser/profiles/index.cjs +2 -2
- package/dist/tools/browser/profiles/index.cjs.map +1 -1
- package/dist/tools/browser/profiles/index.js +3 -3
- package/dist/tools/browser/vercel.cjs +2 -2
- package/dist/tools/browser/vercel.cjs.map +1 -1
- package/dist/tools/browser/vercel.js +5 -5
- package/dist/tools/codebase_search/anthropic.cjs +2 -2
- package/dist/tools/codebase_search/anthropic.cjs.map +1 -1
- package/dist/tools/codebase_search/anthropic.js +4 -4
- package/dist/tools/codebase_search/core.cjs +2 -2
- package/dist/tools/codebase_search/core.cjs.map +1 -1
- package/dist/tools/codebase_search/core.js +3 -3
- package/dist/tools/codebase_search/index.cjs +2 -2
- package/dist/tools/codebase_search/index.cjs.map +1 -1
- package/dist/tools/codebase_search/index.js +6 -6
- package/dist/tools/codebase_search/openai.cjs +2 -2
- package/dist/tools/codebase_search/openai.cjs.map +1 -1
- package/dist/tools/codebase_search/openai.js +4 -4
- package/dist/tools/codebase_search/vercel.cjs +2 -2
- package/dist/tools/codebase_search/vercel.cjs.map +1 -1
- package/dist/tools/codebase_search/vercel.js +4 -4
- package/dist/tools/fastapply/anthropic.cjs +2 -2
- package/dist/tools/fastapply/anthropic.cjs.map +1 -1
- package/dist/tools/fastapply/anthropic.js +4 -4
- package/dist/tools/fastapply/apply.cjs +2 -2
- package/dist/tools/fastapply/apply.cjs.map +1 -1
- package/dist/tools/fastapply/apply.js +2 -2
- package/dist/tools/fastapply/core.cjs +2 -2
- package/dist/tools/fastapply/core.cjs.map +1 -1
- package/dist/tools/fastapply/core.js +3 -3
- package/dist/tools/fastapply/index.cjs +2 -2
- package/dist/tools/fastapply/index.cjs.map +1 -1
- package/dist/tools/fastapply/index.js +6 -6
- package/dist/tools/fastapply/openai.cjs +2 -2
- package/dist/tools/fastapply/openai.cjs.map +1 -1
- package/dist/tools/fastapply/openai.js +4 -4
- package/dist/tools/fastapply/vercel.cjs +2 -2
- package/dist/tools/fastapply/vercel.cjs.map +1 -1
- package/dist/tools/fastapply/vercel.js +4 -4
- package/dist/tools/index.cjs +2 -2
- package/dist/tools/index.cjs.map +1 -1
- package/dist/tools/index.js +6 -6
- package/dist/tools/utils/resilience.cjs +2 -2
- package/dist/tools/utils/resilience.cjs.map +1 -1
- package/dist/tools/utils/resilience.js +2 -2
- package/dist/tools/warp_grep/agent/runner.cjs +5 -5
- package/dist/tools/warp_grep/agent/runner.cjs.map +1 -1
- package/dist/tools/warp_grep/agent/runner.js +2 -2
- package/dist/tools/warp_grep/anthropic.cjs +476 -5
- package/dist/tools/warp_grep/anthropic.cjs.map +1 -1
- package/dist/tools/warp_grep/anthropic.d.ts +62 -2
- package/dist/tools/warp_grep/anthropic.js +11 -5
- package/dist/tools/warp_grep/client.cjs +187 -12
- package/dist/tools/warp_grep/client.cjs.map +1 -1
- package/dist/tools/warp_grep/client.d.ts +58 -2
- package/dist/tools/warp_grep/client.js +9 -3
- package/dist/tools/warp_grep/gemini.cjs +475 -5
- package/dist/tools/warp_grep/gemini.cjs.map +1 -1
- package/dist/tools/warp_grep/gemini.d.ts +62 -2
- package/dist/tools/warp_grep/gemini.js +69 -4
- package/dist/tools/warp_grep/gemini.js.map +1 -1
- package/dist/tools/warp_grep/index.cjs +228 -12
- package/dist/tools/warp_grep/index.cjs.map +1 -1
- package/dist/tools/warp_grep/index.d.ts +52 -3
- package/dist/tools/warp_grep/index.js +26 -5
- package/dist/tools/warp_grep/openai.cjs +482 -5
- package/dist/tools/warp_grep/openai.cjs.map +1 -1
- package/dist/tools/warp_grep/openai.d.ts +62 -2
- package/dist/tools/warp_grep/openai.js +11 -5
- package/dist/tools/warp_grep/providers/code_storage_http.cjs +53 -0
- package/dist/tools/warp_grep/providers/code_storage_http.cjs.map +1 -0
- package/dist/tools/warp_grep/providers/code_storage_http.d.ts +23 -0
- package/dist/tools/warp_grep/providers/code_storage_http.js +8 -0
- package/dist/tools/warp_grep/providers/code_storage_http.js.map +1 -0
- package/dist/tools/warp_grep/providers/remote.d.ts +1 -1
- package/dist/tools/warp_grep/utils/github.cjs +46 -0
- package/dist/tools/warp_grep/utils/github.cjs.map +1 -0
- package/dist/tools/warp_grep/utils/github.d.ts +13 -0
- package/dist/tools/warp_grep/utils/github.js +8 -0
- package/dist/tools/warp_grep/utils/github.js.map +1 -0
- package/dist/tools/warp_grep/vercel.cjs +245 -5
- package/dist/tools/warp_grep/vercel.cjs.map +1 -1
- package/dist/tools/warp_grep/vercel.d.ts +60 -2
- package/dist/tools/warp_grep/vercel.js +11 -5
- package/dist/{types-D5p8QErL.d.ts → types-DY_hq2eZ.d.ts} +53 -1
- package/dist/version.cjs +2 -2
- package/dist/version.cjs.map +1 -1
- package/dist/version.js +1 -1
- package/package.json +2 -2
- package/dist/chunk-C3BQUIFE.js.map +0 -1
- package/dist/chunk-CXP63PHW.js +0 -61
- package/dist/chunk-CXP63PHW.js.map +0 -1
- package/dist/chunk-KW7OEGZK.js +0 -9
- package/dist/chunk-KW7OEGZK.js.map +0 -1
- package/dist/chunk-QDGB6FLI.js.map +0 -1
- package/dist/chunk-U5UDFQXK.js +0 -66
- package/dist/chunk-U5UDFQXK.js.map +0 -1
- package/dist/chunk-XERAWJ3H.js +0 -53
- package/dist/chunk-XERAWJ3H.js.map +0 -1
- /package/dist/{chunk-L4PK4VC7.js.map → chunk-5OJE7GH4.js.map} +0 -0
- /package/dist/{chunk-BDKXYMU2.js.map → chunk-ANPZFWYV.js.map} +0 -0
- /package/dist/{chunk-DL3Y3R6A.js.map → chunk-BJ2764MK.js.map} +0 -0
- /package/dist/{chunk-JBIFS33U.js.map → chunk-DBSOONOY.js.map} +0 -0
- /package/dist/{chunk-7QZFNYOH.js.map → chunk-GXFJLL5O.js.map} +0 -0
- /package/dist/{chunk-MAAULSSQ.js.map → chunk-HVBJ4UO6.js.map} +0 -0
- /package/dist/{chunk-3HBZXN6E.js.map → chunk-K74GLGST.js.map} +0 -0
- /package/dist/{chunk-EZFXR52Q.js.map → chunk-KL3AMLGL.js.map} +0 -0
- /package/dist/{chunk-YMOTJ6ZP.js.map → chunk-L426IMZD.js.map} +0 -0
- /package/dist/{chunk-266SWRHK.js.map → chunk-OFJYDTQI.js.map} +0 -0
- /package/dist/{chunk-W37KJB25.js.map → chunk-QD7KPI7A.js.map} +0 -0
- /package/dist/{chunk-WEBUKGPK.js.map → chunk-UHL2ZEWG.js.map} +0 -0
- /package/dist/{chunk-CIFPLFBQ.js.map → chunk-UJS3AIWS.js.map} +0 -0
- /package/dist/{chunk-FV3R3JGV.js.map → chunk-UX65IRCX.js.map} +0 -0
- /package/dist/{chunk-AI3ZCOCT.js.map → chunk-WE75QX2B.js.map} +0 -0
- /package/dist/{chunk-GNRMDXJA.js.map → chunk-XXL62KSJ.js.map} +0 -0
package/dist/index.cjs
CHANGED
|
@@ -36,7 +36,7 @@ var init_package = __esm({
|
|
|
36
36
|
"package.json"() {
|
|
37
37
|
package_default = {
|
|
38
38
|
name: "@morphllm/morphsdk",
|
|
39
|
-
version: "0.2.
|
|
39
|
+
version: "0.2.123",
|
|
40
40
|
description: "TypeScript SDK and CLI for Morph Fast Apply integration",
|
|
41
41
|
type: "module",
|
|
42
42
|
main: "./dist/index.cjs",
|
|
@@ -178,7 +178,7 @@ var init_package = __esm({
|
|
|
178
178
|
"!dist/**/*.test.*"
|
|
179
179
|
],
|
|
180
180
|
scripts: {
|
|
181
|
-
build: "tsup version.ts index.ts edge.ts client.ts tools/index.ts tools/fastapply/index.ts tools/fastapply/core.ts tools/fastapply/apply.ts tools/fastapply/types.ts tools/fastapply/prompts.ts tools/fastapply/anthropic.ts tools/fastapply/openai.ts tools/fastapply/vercel.ts tools/codebase_search/index.ts tools/codebase_search/core.ts tools/codebase_search/types.ts tools/codebase_search/prompts.ts tools/codebase_search/anthropic.ts tools/codebase_search/openai.ts tools/codebase_search/vercel.ts tools/warp_grep/index.ts tools/warp_grep/client.ts tools/warp_grep/openai.ts tools/warp_grep/anthropic.ts tools/warp_grep/vercel.ts tools/warp_grep/gemini.ts tools/warp_grep/harness.ts tools/warp_grep/agent/config.ts tools/warp_grep/agent/prompt.ts tools/warp_grep/agent/parser.ts tools/warp_grep/agent/runner.ts tools/warp_grep/agent/types.ts tools/warp_grep/agent/formatter.ts tools/warp_grep/providers/types.ts tools/warp_grep/providers/local.ts tools/warp_grep/providers/remote.ts tools/warp_grep/tools/grep.ts tools/warp_grep/tools/analyse.ts tools/warp_grep/tools/read.ts tools/warp_grep/tools/finish.ts tools/warp_grep/utils/paths.ts tools/warp_grep/utils/ripgrep.ts tools/warp_grep/utils/format.ts tools/warp_grep/utils/files.ts git/index.ts git/client.ts git/config.ts git/types.ts tools/browser/index.ts tools/browser/core.ts tools/browser/types.ts tools/browser/prompts.ts tools/browser/anthropic.ts tools/browser/openai.ts tools/browser/vercel.ts tools/browser/live.ts tools/browser/errors.ts tools/browser/profiles/index.ts tools/browser/profiles/core.ts tools/browser/profiles/types.ts modelrouter/index.ts modelrouter/core.ts modelrouter/types.ts tools/compact/index.ts tools/compact/core.ts tools/compact/types.ts tools/utils/resilience.ts --format esm,cjs --sourcemap --clean --dts --dts-resolve",
|
|
181
|
+
build: "tsup version.ts index.ts edge.ts client.ts tools/index.ts tools/fastapply/index.ts tools/fastapply/core.ts tools/fastapply/apply.ts tools/fastapply/types.ts tools/fastapply/prompts.ts tools/fastapply/anthropic.ts tools/fastapply/openai.ts tools/fastapply/vercel.ts tools/codebase_search/index.ts tools/codebase_search/core.ts tools/codebase_search/types.ts tools/codebase_search/prompts.ts tools/codebase_search/anthropic.ts tools/codebase_search/openai.ts tools/codebase_search/vercel.ts tools/warp_grep/index.ts tools/warp_grep/client.ts tools/warp_grep/openai.ts tools/warp_grep/anthropic.ts tools/warp_grep/vercel.ts tools/warp_grep/gemini.ts tools/warp_grep/harness.ts tools/warp_grep/agent/config.ts tools/warp_grep/agent/prompt.ts tools/warp_grep/agent/parser.ts tools/warp_grep/agent/runner.ts tools/warp_grep/agent/types.ts tools/warp_grep/agent/formatter.ts tools/warp_grep/providers/types.ts tools/warp_grep/providers/local.ts tools/warp_grep/providers/remote.ts tools/warp_grep/providers/code_storage_http.ts tools/warp_grep/tools/grep.ts tools/warp_grep/tools/analyse.ts tools/warp_grep/tools/read.ts tools/warp_grep/tools/finish.ts tools/warp_grep/utils/paths.ts tools/warp_grep/utils/github.ts tools/warp_grep/utils/ripgrep.ts tools/warp_grep/utils/format.ts tools/warp_grep/utils/files.ts git/index.ts git/client.ts git/config.ts git/types.ts tools/browser/index.ts tools/browser/core.ts tools/browser/types.ts tools/browser/prompts.ts tools/browser/anthropic.ts tools/browser/openai.ts tools/browser/vercel.ts tools/browser/live.ts tools/browser/errors.ts tools/browser/profiles/index.ts tools/browser/profiles/core.ts tools/browser/profiles/types.ts modelrouter/index.ts modelrouter/core.ts modelrouter/types.ts tools/compact/index.ts tools/compact/core.ts tools/compact/types.ts tools/utils/resilience.ts --format esm,cjs --sourcemap --clean --dts --dts-resolve",
|
|
182
182
|
prepare: "npm run build",
|
|
183
183
|
typecheck: "tsc --noEmit",
|
|
184
184
|
lint: "eslint .",
|
|
@@ -3309,9 +3309,9 @@ async function callModel(messages, model, options = {}) {
|
|
|
3309
3309
|
});
|
|
3310
3310
|
} catch (error) {
|
|
3311
3311
|
if (error instanceof import_openai2.default.APIError && error.status === 404) {
|
|
3312
|
-
|
|
3313
|
-
|
|
3314
|
-
);
|
|
3312
|
+
const defaultMsg = "The endpoint you are trying to call is likely deprecated. Please update with: npm cache clean --force && npx -y @morphllm/morphmcp@latest or visit: https://morphllm.com/mcp";
|
|
3313
|
+
const errorText = error.message?.trim();
|
|
3314
|
+
throw new Error(errorText || defaultMsg);
|
|
3315
3315
|
}
|
|
3316
3316
|
throw error;
|
|
3317
3317
|
}
|
|
@@ -3839,7 +3839,51 @@ var RemoteCommandsProvider = class {
|
|
|
3839
3839
|
}
|
|
3840
3840
|
};
|
|
3841
3841
|
|
|
3842
|
+
// tools/warp_grep/providers/code_storage_http.ts
|
|
3843
|
+
async function post(url, body, op) {
|
|
3844
|
+
const res = await fetch(url, {
|
|
3845
|
+
method: "POST",
|
|
3846
|
+
headers: { "Content-Type": "application/json" },
|
|
3847
|
+
body: JSON.stringify(body)
|
|
3848
|
+
});
|
|
3849
|
+
if (!res.ok) {
|
|
3850
|
+
const text = await res.text().catch(() => res.statusText);
|
|
3851
|
+
throw new Error(`${op} failed (${res.status}): ${text}`);
|
|
3852
|
+
}
|
|
3853
|
+
const data = await res.json();
|
|
3854
|
+
if (data.error) throw new Error(data.error);
|
|
3855
|
+
return data.stdout;
|
|
3856
|
+
}
|
|
3857
|
+
function createCodeStorageHttpCommands(config) {
|
|
3858
|
+
const { baseUrl, repoId, branch } = config;
|
|
3859
|
+
const encodedRepoId = encodeURIComponent(repoId);
|
|
3860
|
+
return {
|
|
3861
|
+
grep: (pattern, path5, glob) => post(`${baseUrl}/api/code-search/${encodedRepoId}/grep`, { pattern, path: path5, glob, branch }, "grep"),
|
|
3862
|
+
read: (path5, start, end) => post(`${baseUrl}/api/code-search/${encodedRepoId}/read`, { path: path5, start, end, branch }, "read"),
|
|
3863
|
+
listDir: (path5, maxDepth) => post(`${baseUrl}/api/code-search/${encodedRepoId}/list`, { path: path5, maxDepth, branch }, "list")
|
|
3864
|
+
};
|
|
3865
|
+
}
|
|
3866
|
+
|
|
3867
|
+
// tools/warp_grep/utils/github.ts
|
|
3868
|
+
function parseGitHubUrl(input) {
|
|
3869
|
+
input = input.trim();
|
|
3870
|
+
const urlPattern = /^(?:https?:\/\/)?github\.com\/([^\/]+)\/([^\/\?\#]+)/;
|
|
3871
|
+
const match = input.match(urlPattern);
|
|
3872
|
+
if (match) {
|
|
3873
|
+
return { owner: match[1], repo: match[2].replace(/\.git$/, "") };
|
|
3874
|
+
}
|
|
3875
|
+
const shortPattern = /^([^\/]+)\/([^\/]+)$/;
|
|
3876
|
+
const shortMatch = input.match(shortPattern);
|
|
3877
|
+
if (shortMatch && !shortMatch[1].includes(".")) {
|
|
3878
|
+
return { owner: shortMatch[1], repo: shortMatch[2].replace(/\.git$/, "") };
|
|
3879
|
+
}
|
|
3880
|
+
throw new Error(
|
|
3881
|
+
`Invalid GitHub URL or shorthand: "${input}". Expected "owner/repo" or "https://github.com/owner/repo"`
|
|
3882
|
+
);
|
|
3883
|
+
}
|
|
3884
|
+
|
|
3842
3885
|
// tools/warp_grep/client.ts
|
|
3886
|
+
var DEFAULT_CODE_SEARCH_URL = "https://morphllm.com";
|
|
3843
3887
|
async function getLocalProvider(repoRoot, excludes) {
|
|
3844
3888
|
const { LocalRipgrepProvider: LocalRipgrepProvider2 } = await Promise.resolve().then(() => (init_local(), local_exports));
|
|
3845
3889
|
return new LocalRipgrepProvider2(repoRoot, excludes);
|
|
@@ -3847,13 +3891,7 @@ async function getLocalProvider(repoRoot, excludes) {
|
|
|
3847
3891
|
var WarpGrepClient = class {
|
|
3848
3892
|
config;
|
|
3849
3893
|
constructor(config = {}) {
|
|
3850
|
-
this.config = {
|
|
3851
|
-
morphApiKey: config.morphApiKey,
|
|
3852
|
-
morphApiUrl: config.morphApiUrl,
|
|
3853
|
-
debug: config.debug,
|
|
3854
|
-
timeout: config.timeout,
|
|
3855
|
-
retryConfig: config.retryConfig
|
|
3856
|
-
};
|
|
3894
|
+
this.config = { ...config };
|
|
3857
3895
|
}
|
|
3858
3896
|
execute(input) {
|
|
3859
3897
|
const toolConfig = {
|
|
@@ -3873,6 +3911,80 @@ var WarpGrepClient = class {
|
|
|
3873
3911
|
}
|
|
3874
3912
|
return executeToolCall({ query: input.query }, toolConfig);
|
|
3875
3913
|
}
|
|
3914
|
+
searchGitHub(input) {
|
|
3915
|
+
if (input.streamSteps) {
|
|
3916
|
+
return this._searchGitHubStreaming(input);
|
|
3917
|
+
}
|
|
3918
|
+
return this._searchGitHubAsync(input);
|
|
3919
|
+
}
|
|
3920
|
+
/**
|
|
3921
|
+
* Read a single file from a public GitHub repository
|
|
3922
|
+
*
|
|
3923
|
+
* @example
|
|
3924
|
+
* ```typescript
|
|
3925
|
+
* const result = await client.readGitHubFile({
|
|
3926
|
+
* github: 'vercel/next.js',
|
|
3927
|
+
* path: 'src/server/app-render/index.tsx',
|
|
3928
|
+
* startLine: 1,
|
|
3929
|
+
* endLine: 50,
|
|
3930
|
+
* });
|
|
3931
|
+
* if (result.success) console.log(result.content);
|
|
3932
|
+
* ```
|
|
3933
|
+
*/
|
|
3934
|
+
async readGitHubFile(input) {
|
|
3935
|
+
return executeGitHubReadFile(input, { timeout: this.config.timeout });
|
|
3936
|
+
}
|
|
3937
|
+
async _resolveGitHubRepo(input) {
|
|
3938
|
+
const { owner, repo } = parseGitHubUrl(input.github);
|
|
3939
|
+
const baseUrl = this.config.codeSearchUrl || DEFAULT_CODE_SEARCH_URL;
|
|
3940
|
+
const importRes = await fetch(`${baseUrl}/api/code-search/get-or-create?url=${encodeURIComponent(`${owner}/${repo}`)}`);
|
|
3941
|
+
if (!importRes.ok) {
|
|
3942
|
+
const text = await importRes.text().catch(() => importRes.statusText);
|
|
3943
|
+
throw new Error(`Failed to import repo ${owner}/${repo}: ${text}`);
|
|
3944
|
+
}
|
|
3945
|
+
const { repoId, defaultBranch } = await importRes.json();
|
|
3946
|
+
return {
|
|
3947
|
+
repo,
|
|
3948
|
+
remoteCommands: createCodeStorageHttpCommands({ baseUrl, repoId, branch: input.branch || defaultBranch })
|
|
3949
|
+
};
|
|
3950
|
+
}
|
|
3951
|
+
async _searchGitHubAsync(input) {
|
|
3952
|
+
try {
|
|
3953
|
+
const { repo, remoteCommands } = await this._resolveGitHubRepo(input);
|
|
3954
|
+
return this.execute({
|
|
3955
|
+
query: input.query,
|
|
3956
|
+
repoRoot: repo,
|
|
3957
|
+
remoteCommands
|
|
3958
|
+
});
|
|
3959
|
+
} catch (error) {
|
|
3960
|
+
return { success: false, error: error instanceof Error ? error.message : String(error) };
|
|
3961
|
+
}
|
|
3962
|
+
}
|
|
3963
|
+
async *_searchGitHubStreaming(input) {
|
|
3964
|
+
let repo;
|
|
3965
|
+
let remoteCommands;
|
|
3966
|
+
try {
|
|
3967
|
+
({ repo, remoteCommands } = await this._resolveGitHubRepo(input));
|
|
3968
|
+
} catch (error) {
|
|
3969
|
+
return { success: false, error: error instanceof Error ? error.message : String(error) };
|
|
3970
|
+
}
|
|
3971
|
+
const generator = this.execute({
|
|
3972
|
+
query: input.query,
|
|
3973
|
+
repoRoot: repo,
|
|
3974
|
+
remoteCommands,
|
|
3975
|
+
streamSteps: true
|
|
3976
|
+
});
|
|
3977
|
+
let result;
|
|
3978
|
+
for (; ; ) {
|
|
3979
|
+
const { value, done } = await generator.next();
|
|
3980
|
+
if (done) {
|
|
3981
|
+
result = value;
|
|
3982
|
+
break;
|
|
3983
|
+
}
|
|
3984
|
+
yield value;
|
|
3985
|
+
}
|
|
3986
|
+
return result;
|
|
3987
|
+
}
|
|
3876
3988
|
};
|
|
3877
3989
|
async function executeToolCall(input, config) {
|
|
3878
3990
|
const parsed = typeof input === "string" ? JSON.parse(input) : input;
|
|
@@ -3942,6 +4054,56 @@ async function* executeToolCallStreaming(input, config) {
|
|
|
3942
4054
|
}
|
|
3943
4055
|
return processAgentResult(agentResult);
|
|
3944
4056
|
}
|
|
4057
|
+
async function fetchRawGitHubFile(owner, repo, filePath, branch, timeout) {
|
|
4058
|
+
const branches = branch ? [branch] : ["HEAD"];
|
|
4059
|
+
const fallbacks = ["main", "master", "develop"];
|
|
4060
|
+
const fetchWithTimeout = (url) => timeout ? fetch(url, { signal: AbortSignal.timeout(timeout) }) : fetch(url);
|
|
4061
|
+
for (const b of branches) {
|
|
4062
|
+
const url = `https://raw.githubusercontent.com/${owner}/${repo}/${b}/${filePath}`;
|
|
4063
|
+
const res = await fetchWithTimeout(url);
|
|
4064
|
+
if (res.ok) return { content: await res.text(), branch: b };
|
|
4065
|
+
}
|
|
4066
|
+
for (const fb of fallbacks) {
|
|
4067
|
+
if (branch && fb === branch) continue;
|
|
4068
|
+
const url = `https://raw.githubusercontent.com/${owner}/${repo}/${fb}/${filePath}`;
|
|
4069
|
+
const res = await fetchWithTimeout(url);
|
|
4070
|
+
if (res.ok) return { content: await res.text(), branch: fb };
|
|
4071
|
+
}
|
|
4072
|
+
throw new Error(`File not found: ${owner}/${repo}/${filePath}`);
|
|
4073
|
+
}
|
|
4074
|
+
async function executeGitHubReadFile(input, config) {
|
|
4075
|
+
try {
|
|
4076
|
+
const { owner, repo } = parseGitHubUrl(input.github);
|
|
4077
|
+
const { content: raw, branch } = await fetchRawGitHubFile(
|
|
4078
|
+
owner,
|
|
4079
|
+
repo,
|
|
4080
|
+
input.path,
|
|
4081
|
+
input.branch,
|
|
4082
|
+
config?.timeout
|
|
4083
|
+
);
|
|
4084
|
+
const allLines = raw.split("\n");
|
|
4085
|
+
const totalLines = allLines.length;
|
|
4086
|
+
const start = Math.max(1, input.startLine ?? 1);
|
|
4087
|
+
const end = Math.min(totalLines, input.endLine ?? totalLines);
|
|
4088
|
+
const selected = allLines.slice(start - 1, end);
|
|
4089
|
+
const padWidth = String(end).length;
|
|
4090
|
+
const numbered = selected.map((line, i) => `${String(start + i).padStart(padWidth)}|${line}`).join("\n");
|
|
4091
|
+
return {
|
|
4092
|
+
success: true,
|
|
4093
|
+
content: numbered,
|
|
4094
|
+
path: input.path,
|
|
4095
|
+
github: `${owner}/${repo}`,
|
|
4096
|
+
branch,
|
|
4097
|
+
lineRange: [start, end],
|
|
4098
|
+
totalLines
|
|
4099
|
+
};
|
|
4100
|
+
} catch (error) {
|
|
4101
|
+
return {
|
|
4102
|
+
success: false,
|
|
4103
|
+
error: error instanceof Error ? error.message : String(error)
|
|
4104
|
+
};
|
|
4105
|
+
}
|
|
4106
|
+
}
|
|
3945
4107
|
function formatResult(result) {
|
|
3946
4108
|
if (!result.success) {
|
|
3947
4109
|
return `Search failed: ${result.error}`;
|
|
@@ -5136,6 +5298,20 @@ var RawRouter = class extends BaseRouter {
|
|
|
5136
5298
|
// tools/warp_grep/prompts.ts
|
|
5137
5299
|
var WARP_GREP_TOOL_NAME = "warpgrep_codebase_search";
|
|
5138
5300
|
var WARP_GREP_DESCRIPTION = 'IMPORTANT: If you need to explore the codebase to gather context, and the task does not involve a single file or function which is provided by name, you should ALWAYS use the warpgrep codebase search tool first instead of running search commands. When the task requires exploration beyond a single known file, invoke warpgrep first with a natural-language query describing the target functionality, bug, or architectural concern. Warp Grep is a fast and accurate tool that can search for all relevant context in a codebase. Keep queries action-oriented (e.g., "Find where billing invoices are generated and emailed"), and after reviewing the summarized results, you may verify important findings with other search tools or direct file reads to ensure completeness. Warp Grep can be used for query types like: find function responsible for <small feature>; find code that does <description>; find code path for <big feature>; Where does <minimal error message> come from?; or any query of that type. When a task requires exploration beyond a single known file, ALWAYS default to warpgrep codebase search before other search mechanisms.';
|
|
5301
|
+
var GITHUB_WARP_GREP_SEARCH_TOOL_NAME = "warpgrep_github_search";
|
|
5302
|
+
var GITHUB_WARP_GREP_SEARCH_DESCRIPTION = 'IMPORTANT: If you need to explore the codebase of a public GitHub repository (not your local workspace), use warpgrep_github_search instead of warpgrep_codebase_search. When the task requires understanding code in an external repo, invoke warpgrep_github_search with a GitHub URL or owner/repo shorthand (e.g., vercel/next.js) and a natural-language query describing the target functionality, bug, or architectural concern. WarpGrep searches GitHub repos the same way it searches local codebases: fast and accurate. Keep queries action-oriented (e.g., "Find where how the new use workflow directive works"), and after reviewing the results, you may verify important findings with other tools or direct file reads. WarpGrep can be used for query types like: find function responsible for <small feature>; find code that does <description>; find code path for <big feature>; Where does <minimal error message> come from?; or any query of that type. When a task involves exploring code in an external public repo, ALWAYS use warpgrep_github_search.';
|
|
5303
|
+
var GITHUB_WARP_GREP_SEARCH_INPUT_SCHEMA = {
|
|
5304
|
+
type: "object",
|
|
5305
|
+
properties: {
|
|
5306
|
+
query: { type: "string", description: "Natural language search query describing what to find in the repository" },
|
|
5307
|
+
github: { type: "string", description: 'owner/repo shorthand (ex: "vercel/next.js" for "https://github.com/vercel/next.js")' },
|
|
5308
|
+
branch: { type: "string", description: "Branch to search (defaults to the repository default branch)" }
|
|
5309
|
+
},
|
|
5310
|
+
required: ["query", "github"]
|
|
5311
|
+
};
|
|
5312
|
+
var GITHUB_SEARCH_TOOL_NAME = GITHUB_WARP_GREP_SEARCH_TOOL_NAME;
|
|
5313
|
+
var GITHUB_SEARCH_DESCRIPTION = GITHUB_WARP_GREP_SEARCH_DESCRIPTION;
|
|
5314
|
+
var GITHUB_SEARCH_INPUT_SCHEMA = GITHUB_WARP_GREP_SEARCH_INPUT_SCHEMA;
|
|
5139
5315
|
|
|
5140
5316
|
// tools/warp_grep/openai.ts
|
|
5141
5317
|
var TOOL_PARAMETERS = {
|
|
@@ -5166,6 +5342,28 @@ function createWarpGrepTool(config) {
|
|
|
5166
5342
|
}
|
|
5167
5343
|
});
|
|
5168
5344
|
}
|
|
5345
|
+
function createGitHubSearchTool(config) {
|
|
5346
|
+
const client = new WarpGrepClient(config);
|
|
5347
|
+
const tool4 = {
|
|
5348
|
+
type: "function",
|
|
5349
|
+
function: {
|
|
5350
|
+
name: GITHUB_SEARCH_TOOL_NAME,
|
|
5351
|
+
description: GITHUB_SEARCH_DESCRIPTION,
|
|
5352
|
+
parameters: GITHUB_SEARCH_INPUT_SCHEMA
|
|
5353
|
+
}
|
|
5354
|
+
};
|
|
5355
|
+
return Object.assign(tool4, {
|
|
5356
|
+
execute: async (input) => {
|
|
5357
|
+
return client.searchGitHub(input);
|
|
5358
|
+
},
|
|
5359
|
+
formatResult: (result) => {
|
|
5360
|
+
return formatResult(result);
|
|
5361
|
+
},
|
|
5362
|
+
getSystemPrompt: () => {
|
|
5363
|
+
return getSystemPrompt();
|
|
5364
|
+
}
|
|
5365
|
+
});
|
|
5366
|
+
}
|
|
5169
5367
|
|
|
5170
5368
|
// tools/codebase_search/prompts.ts
|
|
5171
5369
|
var CODEBASE_SEARCH_DESCRIPTION = `Semantic search that finds code by meaning, not exact text.
|
|
@@ -5410,6 +5608,18 @@ var OpenAIToolFactory = class {
|
|
|
5410
5608
|
morphApiKey: this.config.apiKey
|
|
5411
5609
|
});
|
|
5412
5610
|
}
|
|
5611
|
+
/**
|
|
5612
|
+
* Create an OpenAI-compatible GitHub search tool
|
|
5613
|
+
*
|
|
5614
|
+
* @param toolConfig - Tool configuration (morphApiKey inherited from MorphClient)
|
|
5615
|
+
* @returns OpenAI ChatCompletionTool with execute and formatResult methods
|
|
5616
|
+
*/
|
|
5617
|
+
createGitHubSearchTool(toolConfig) {
|
|
5618
|
+
return createGitHubSearchTool({
|
|
5619
|
+
...toolConfig,
|
|
5620
|
+
morphApiKey: this.config.apiKey
|
|
5621
|
+
});
|
|
5622
|
+
}
|
|
5413
5623
|
};
|
|
5414
5624
|
|
|
5415
5625
|
// tools/warp_grep/anthropic.ts
|
|
@@ -5438,6 +5648,25 @@ function createWarpGrepTool2(config) {
|
|
|
5438
5648
|
}
|
|
5439
5649
|
});
|
|
5440
5650
|
}
|
|
5651
|
+
function createGitHubSearchTool2(config) {
|
|
5652
|
+
const client = new WarpGrepClient(config);
|
|
5653
|
+
const tool4 = {
|
|
5654
|
+
name: GITHUB_SEARCH_TOOL_NAME,
|
|
5655
|
+
description: GITHUB_SEARCH_DESCRIPTION,
|
|
5656
|
+
input_schema: GITHUB_SEARCH_INPUT_SCHEMA
|
|
5657
|
+
};
|
|
5658
|
+
return Object.assign(tool4, {
|
|
5659
|
+
execute: async (input) => {
|
|
5660
|
+
return client.searchGitHub(input);
|
|
5661
|
+
},
|
|
5662
|
+
formatResult: (result) => {
|
|
5663
|
+
return formatResult(result);
|
|
5664
|
+
},
|
|
5665
|
+
getSystemPrompt: () => {
|
|
5666
|
+
return getSystemPrompt();
|
|
5667
|
+
}
|
|
5668
|
+
});
|
|
5669
|
+
}
|
|
5441
5670
|
|
|
5442
5671
|
// tools/codebase_search/anthropic.ts
|
|
5443
5672
|
function createCodebaseSearchTool2(config) {
|
|
@@ -5599,6 +5828,18 @@ var AnthropicToolFactory = class {
|
|
|
5599
5828
|
morphApiKey: this.config.apiKey
|
|
5600
5829
|
});
|
|
5601
5830
|
}
|
|
5831
|
+
/**
|
|
5832
|
+
* Create an Anthropic-compatible GitHub search tool
|
|
5833
|
+
*
|
|
5834
|
+
* @param toolConfig - Tool configuration (morphApiKey inherited from MorphClient)
|
|
5835
|
+
* @returns Anthropic Tool with execute and formatResult methods
|
|
5836
|
+
*/
|
|
5837
|
+
createGitHubSearchTool(toolConfig) {
|
|
5838
|
+
return createGitHubSearchTool2({
|
|
5839
|
+
...toolConfig,
|
|
5840
|
+
morphApiKey: this.config.apiKey
|
|
5841
|
+
});
|
|
5842
|
+
}
|
|
5602
5843
|
};
|
|
5603
5844
|
|
|
5604
5845
|
// tools/warp_grep/vercel.ts
|
|
@@ -5636,6 +5877,28 @@ function createWarpGrepTool3(config) {
|
|
|
5636
5877
|
}
|
|
5637
5878
|
});
|
|
5638
5879
|
}
|
|
5880
|
+
function createGitHubSearchTool3(config) {
|
|
5881
|
+
const client = new WarpGrepClient(config);
|
|
5882
|
+
return (0, import_ai.tool)({
|
|
5883
|
+
description: GITHUB_SEARCH_DESCRIPTION,
|
|
5884
|
+
inputSchema: import_zod.z.object({
|
|
5885
|
+
query: import_zod.z.string().describe("Natural language search query"),
|
|
5886
|
+
github: import_zod.z.string().describe('GitHub URL or "owner/repo" shorthand'),
|
|
5887
|
+
branch: import_zod.z.string().optional().describe("Branch to search (defaults to repo default branch)")
|
|
5888
|
+
}),
|
|
5889
|
+
execute: async (params) => {
|
|
5890
|
+
const result = await client.searchGitHub(params);
|
|
5891
|
+
if (!result.success) {
|
|
5892
|
+
throw new Error(`GitHub search failed: ${result.error}`);
|
|
5893
|
+
}
|
|
5894
|
+
return {
|
|
5895
|
+
success: true,
|
|
5896
|
+
contexts: result.contexts,
|
|
5897
|
+
summary: result.summary
|
|
5898
|
+
};
|
|
5899
|
+
}
|
|
5900
|
+
});
|
|
5901
|
+
}
|
|
5639
5902
|
|
|
5640
5903
|
// tools/codebase_search/vercel.ts
|
|
5641
5904
|
var import_ai2 = require("ai");
|
|
@@ -5778,6 +6041,18 @@ var VercelToolFactory = class {
|
|
|
5778
6041
|
morphApiKey: this.config.apiKey
|
|
5779
6042
|
});
|
|
5780
6043
|
}
|
|
6044
|
+
/**
|
|
6045
|
+
* Create a Vercel AI SDK-compatible GitHub search tool
|
|
6046
|
+
*
|
|
6047
|
+
* @param toolConfig - Tool configuration (morphApiKey inherited from MorphClient)
|
|
6048
|
+
* @returns Vercel AI SDK tool
|
|
6049
|
+
*/
|
|
6050
|
+
createGitHubSearchTool(toolConfig) {
|
|
6051
|
+
return createGitHubSearchTool3({
|
|
6052
|
+
...toolConfig,
|
|
6053
|
+
morphApiKey: this.config.apiKey
|
|
6054
|
+
});
|
|
6055
|
+
}
|
|
5781
6056
|
};
|
|
5782
6057
|
|
|
5783
6058
|
// client.ts
|