@morphllm/morphsdk 0.2.171 → 0.2.172
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-3XRNC56L.js → chunk-2SNAXTUJ.js} +4 -4
- package/dist/chunk-453ZV2AX.js +120 -0
- package/dist/chunk-453ZV2AX.js.map +1 -0
- package/dist/chunk-53ZJMCWU.js +142 -0
- package/dist/chunk-53ZJMCWU.js.map +1 -0
- package/dist/{chunk-IW4TYYG6.js → chunk-5DA6SZQJ.js} +2 -2
- package/dist/chunk-66OHYI24.js +78 -0
- package/dist/chunk-66OHYI24.js.map +1 -0
- package/dist/chunk-6X6QMRQG.js +158 -0
- package/dist/chunk-6X6QMRQG.js.map +1 -0
- package/dist/{chunk-C37YAYBK.js → chunk-7PVVPLRL.js} +2 -2
- package/dist/{chunk-MZZMSL26.js → chunk-AE7M2I52.js} +2 -2
- package/dist/{chunk-JLLIVBKY.js → chunk-CQF76HJC.js} +30 -6
- package/dist/chunk-CQF76HJC.js.map +1 -0
- package/dist/{chunk-EFCDIESP.js → chunk-ESXCQBMU.js} +2 -2
- package/dist/{chunk-FQJCE2FX.js → chunk-FOIDGIY4.js} +29 -10
- package/dist/chunk-FOIDGIY4.js.map +1 -0
- package/dist/{chunk-JEDEBCZM.js → chunk-GJZXDRH5.js} +8 -3
- package/dist/{chunk-JEDEBCZM.js.map → chunk-GJZXDRH5.js.map} +1 -1
- package/dist/{chunk-2ALTBYMY.js → chunk-IJ33I7P5.js} +4 -4
- package/dist/{chunk-UK7TI7QY.js → chunk-IN2U7AAI.js} +99 -143
- package/dist/chunk-IN2U7AAI.js.map +1 -0
- package/dist/{chunk-LE66XCOI.js → chunk-JWZ5DLAS.js} +27 -10
- package/dist/chunk-JWZ5DLAS.js.map +1 -0
- package/dist/chunk-LKFZBBTD.js +12 -0
- package/dist/chunk-LKFZBBTD.js.map +1 -0
- package/dist/{chunk-TAS6S42A.js → chunk-MO6S2LRD.js} +2 -2
- package/dist/{chunk-2OAKX4SZ.js → chunk-NI7PWQ3B.js} +4 -4
- package/dist/{chunk-GLQWEINZ.js → chunk-QAXXE4AD.js} +2 -2
- package/dist/{chunk-3BCKZKNK.js → chunk-QFE5523Q.js} +2 -2
- package/dist/{chunk-LL3EWDKD.js → chunk-QQXNZIVK.js} +4 -4
- package/dist/{chunk-IGQYZ2KH.js → chunk-QZ3V2BP7.js} +2 -2
- package/dist/chunk-QZR7SJ5N.js +24 -0
- package/dist/chunk-QZR7SJ5N.js.map +1 -0
- package/dist/{chunk-SW527EQT.js → chunk-SJVLAGUL.js} +4 -4
- package/dist/{chunk-CMFY26F3.js → chunk-U4J3BVAQ.js} +4 -4
- package/dist/{chunk-5EUMJI3I.js → chunk-U4MRSZQQ.js} +2 -2
- package/dist/{chunk-ZJQTTOHO.js → chunk-UADW6FYD.js} +2 -2
- package/dist/{chunk-4324ZSCW.js → chunk-VBARKJWL.js} +2 -2
- package/dist/{chunk-OPNTDMHH.js → chunk-VLZ6PNAD.js} +4 -4
- package/dist/chunk-VZ7BOH2K.js +1 -0
- package/dist/chunk-VZ7BOH2K.js.map +1 -0
- package/dist/{chunk-Y6T4NA75.js → chunk-XJDXV5VX.js} +2 -2
- package/dist/{chunk-JTUB5ZCT.js → chunk-XYTYIAMQ.js} +2 -2
- package/dist/{chunk-4MTZUTNH.js → chunk-Z4GJVN52.js} +23 -8
- package/dist/chunk-Z4GJVN52.js.map +1 -0
- package/dist/chunk-ZLSNL6M2.js +97 -0
- package/dist/chunk-ZLSNL6M2.js.map +1 -0
- package/dist/{client-DsAAqupx.d.ts → client-Dh6yzCm4.d.ts} +14 -5
- package/dist/client.cjs +724 -523
- package/dist/client.cjs.map +1 -1
- package/dist/client.d.ts +5 -1
- package/dist/client.js +31 -27
- package/dist/core/client.cjs +540 -0
- package/dist/core/client.cjs.map +1 -0
- package/dist/core/client.d.ts +79 -0
- package/dist/core/client.js +12 -0
- package/dist/core/client.js.map +1 -0
- package/dist/core/error.cjs +309 -0
- package/dist/core/error.cjs.map +1 -0
- package/dist/core/error.d.ts +18 -0
- package/dist/core/error.js +10 -0
- package/dist/core/error.js.map +1 -0
- package/dist/core/index.cjs +552 -0
- package/dist/core/index.cjs.map +1 -0
- package/dist/core/index.d.ts +4 -0
- package/dist/core/index.js +20 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/resource.cjs +36 -0
- package/dist/core/resource.cjs.map +1 -0
- package/dist/core/resource.d.ts +18 -0
- package/dist/core/resource.js +8 -0
- package/dist/core/resource.js.map +1 -0
- package/dist/edge.cjs +236 -173
- package/dist/edge.cjs.map +1 -1
- package/dist/edge.d.ts +2 -0
- package/dist/edge.js +8 -5
- package/dist/git/client.cjs +529 -9
- package/dist/git/client.cjs.map +1 -1
- package/dist/git/client.d.ts +8 -2
- package/dist/git/client.js +7 -1
- package/dist/git/index.cjs +529 -9
- package/dist/git/index.cjs.map +1 -1
- package/dist/git/index.d.ts +2 -0
- package/dist/git/index.js +7 -1
- package/dist/index.cjs +672 -465
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +6 -2
- package/dist/index.js +49 -33
- package/dist/modelrouter/core.cjs +204 -125
- package/dist/modelrouter/core.cjs.map +1 -1
- package/dist/modelrouter/core.d.ts +36 -9
- package/dist/modelrouter/core.js +6 -3
- package/dist/modelrouter/index.cjs +204 -125
- package/dist/modelrouter/index.cjs.map +1 -1
- package/dist/modelrouter/index.d.ts +3 -0
- package/dist/modelrouter/index.js +6 -3
- package/dist/subagents/anthropic.cjs +268 -52
- package/dist/subagents/anthropic.cjs.map +1 -1
- package/dist/subagents/anthropic.js +10 -6
- package/dist/subagents/vercel.cjs +268 -52
- package/dist/subagents/vercel.cjs.map +1 -1
- package/dist/subagents/vercel.js +10 -6
- package/dist/tools/browser/anthropic.cjs +7 -2
- package/dist/tools/browser/anthropic.cjs.map +1 -1
- package/dist/tools/browser/anthropic.js +9 -6
- package/dist/tools/browser/core.cjs +162 -10
- package/dist/tools/browser/core.cjs.map +1 -1
- package/dist/tools/browser/core.d.ts +8 -2
- package/dist/tools/browser/core.js +8 -5
- package/dist/tools/browser/index.cjs +163 -11
- package/dist/tools/browser/index.cjs.map +1 -1
- package/dist/tools/browser/index.d.ts +2 -0
- package/dist/tools/browser/index.js +18 -15
- package/dist/tools/browser/index.js.map +1 -1
- package/dist/tools/browser/openai.cjs +7 -2
- package/dist/tools/browser/openai.cjs.map +1 -1
- package/dist/tools/browser/openai.js +9 -6
- package/dist/tools/browser/profiles/core.cjs +7 -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 +7 -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 +7 -2
- package/dist/tools/browser/vercel.cjs.map +1 -1
- package/dist/tools/browser/vercel.js +9 -6
- package/dist/tools/codebase_search/anthropic.cjs +162 -41
- package/dist/tools/codebase_search/anthropic.cjs.map +1 -1
- package/dist/tools/codebase_search/anthropic.js +7 -4
- package/dist/tools/codebase_search/core.cjs +195 -66
- package/dist/tools/codebase_search/core.cjs.map +1 -1
- package/dist/tools/codebase_search/core.d.ts +18 -7
- package/dist/tools/codebase_search/core.js +6 -3
- package/dist/tools/codebase_search/index.cjs +162 -41
- package/dist/tools/codebase_search/index.cjs.map +1 -1
- package/dist/tools/codebase_search/index.d.ts +2 -0
- package/dist/tools/codebase_search/index.js +13 -10
- package/dist/tools/codebase_search/openai.cjs +162 -41
- package/dist/tools/codebase_search/openai.cjs.map +1 -1
- package/dist/tools/codebase_search/openai.js +7 -4
- package/dist/tools/codebase_search/vercel.cjs +162 -41
- package/dist/tools/codebase_search/vercel.cjs.map +1 -1
- package/dist/tools/codebase_search/vercel.js +7 -4
- package/dist/tools/compact/core.cjs +551 -47
- package/dist/tools/compact/core.cjs.map +1 -1
- package/dist/tools/compact/core.d.ts +16 -3
- package/dist/tools/compact/core.js +7 -1
- package/dist/tools/compact/index.cjs +549 -47
- package/dist/tools/compact/index.cjs.map +1 -1
- package/dist/tools/compact/index.d.ts +2 -0
- package/dist/tools/compact/index.js +8 -2
- package/dist/tools/fastapply/anthropic.cjs +16 -2
- package/dist/tools/fastapply/anthropic.cjs.map +1 -1
- package/dist/tools/fastapply/anthropic.js +8 -4
- package/dist/tools/fastapply/apply.cjs +7 -2
- package/dist/tools/fastapply/apply.cjs.map +1 -1
- package/dist/tools/fastapply/apply.js +2 -2
- package/dist/tools/fastapply/core.cjs +242 -12
- package/dist/tools/fastapply/core.cjs.map +1 -1
- package/dist/tools/fastapply/core.d.ts +8 -2
- package/dist/tools/fastapply/core.js +7 -3
- package/dist/tools/fastapply/index.cjs +16 -2
- package/dist/tools/fastapply/index.cjs.map +1 -1
- package/dist/tools/fastapply/index.d.ts +2 -0
- package/dist/tools/fastapply/index.js +13 -9
- package/dist/tools/fastapply/openai.cjs +16 -2
- package/dist/tools/fastapply/openai.cjs.map +1 -1
- package/dist/tools/fastapply/openai.js +8 -4
- package/dist/tools/fastapply/vercel.cjs +16 -2
- package/dist/tools/fastapply/vercel.cjs.map +1 -1
- package/dist/tools/fastapply/vercel.js +8 -4
- package/dist/tools/index.cjs +16 -2
- package/dist/tools/index.cjs.map +1 -1
- package/dist/tools/index.d.ts +2 -0
- package/dist/tools/index.js +13 -9
- package/dist/tools/reflex/core.cjs +693 -0
- package/dist/tools/reflex/core.cjs.map +1 -0
- package/dist/tools/reflex/core.d.ts +53 -0
- package/dist/tools/reflex/core.js +16 -0
- package/dist/tools/reflex/core.js.map +1 -0
- package/dist/tools/reflex/index.cjs +693 -0
- package/dist/tools/reflex/index.cjs.map +1 -0
- package/dist/tools/reflex/index.d.ts +5 -0
- package/dist/tools/reflex/index.js +16 -0
- package/dist/tools/reflex/index.js.map +1 -0
- package/dist/tools/reflex/types.cjs +19 -0
- package/dist/tools/reflex/types.cjs.map +1 -0
- package/dist/tools/reflex/types.d.ts +113 -0
- package/dist/tools/reflex/types.js +1 -0
- package/dist/tools/reflex/types.js.map +1 -0
- package/dist/tools/utils/resilience.cjs +7 -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 +7 -2
- 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 +268 -52
- package/dist/tools/warp_grep/anthropic.cjs.map +1 -1
- package/dist/tools/warp_grep/anthropic.d.ts +2 -0
- package/dist/tools/warp_grep/anthropic.js +10 -6
- package/dist/tools/warp_grep/client.cjs +268 -52
- package/dist/tools/warp_grep/client.cjs.map +1 -1
- package/dist/tools/warp_grep/client.d.ts +8 -2
- package/dist/tools/warp_grep/client.js +9 -5
- package/dist/tools/warp_grep/gemini.cjs +268 -52
- package/dist/tools/warp_grep/gemini.cjs.map +1 -1
- package/dist/tools/warp_grep/gemini.d.ts +2 -0
- package/dist/tools/warp_grep/gemini.js +9 -5
- package/dist/tools/warp_grep/gemini.js.map +1 -1
- package/dist/tools/warp_grep/harness.js +5 -5
- package/dist/tools/warp_grep/index.cjs +268 -52
- package/dist/tools/warp_grep/index.cjs.map +1 -1
- package/dist/tools/warp_grep/index.d.ts +2 -0
- package/dist/tools/warp_grep/index.js +12 -8
- package/dist/tools/warp_grep/openai.cjs +268 -52
- package/dist/tools/warp_grep/openai.cjs.map +1 -1
- package/dist/tools/warp_grep/openai.d.ts +2 -0
- package/dist/tools/warp_grep/openai.js +10 -6
- package/dist/tools/warp_grep/providers/local.js +2 -2
- package/dist/tools/warp_grep/vercel.cjs +268 -52
- package/dist/tools/warp_grep/vercel.cjs.map +1 -1
- package/dist/tools/warp_grep/vercel.d.ts +2 -0
- package/dist/tools/warp_grep/vercel.js +10 -6
- package/dist/version.cjs +7 -2
- package/dist/version.cjs.map +1 -1
- package/dist/version.js +1 -1
- package/package.json +7 -2
- package/dist/chunk-4MTZUTNH.js.map +0 -1
- package/dist/chunk-FQJCE2FX.js.map +0 -1
- package/dist/chunk-H5WNI6R5.js +0 -102
- package/dist/chunk-H5WNI6R5.js.map +0 -1
- package/dist/chunk-JLLIVBKY.js.map +0 -1
- package/dist/chunk-KCFMXLZ7.js +0 -197
- package/dist/chunk-KCFMXLZ7.js.map +0 -1
- package/dist/chunk-LE66XCOI.js.map +0 -1
- package/dist/chunk-SCVWDNQP.js +0 -84
- package/dist/chunk-SCVWDNQP.js.map +0 -1
- package/dist/chunk-UK7TI7QY.js.map +0 -1
- /package/dist/{chunk-3XRNC56L.js.map → chunk-2SNAXTUJ.js.map} +0 -0
- /package/dist/{chunk-IW4TYYG6.js.map → chunk-5DA6SZQJ.js.map} +0 -0
- /package/dist/{chunk-C37YAYBK.js.map → chunk-7PVVPLRL.js.map} +0 -0
- /package/dist/{chunk-MZZMSL26.js.map → chunk-AE7M2I52.js.map} +0 -0
- /package/dist/{chunk-EFCDIESP.js.map → chunk-ESXCQBMU.js.map} +0 -0
- /package/dist/{chunk-2ALTBYMY.js.map → chunk-IJ33I7P5.js.map} +0 -0
- /package/dist/{chunk-TAS6S42A.js.map → chunk-MO6S2LRD.js.map} +0 -0
- /package/dist/{chunk-2OAKX4SZ.js.map → chunk-NI7PWQ3B.js.map} +0 -0
- /package/dist/{chunk-GLQWEINZ.js.map → chunk-QAXXE4AD.js.map} +0 -0
- /package/dist/{chunk-3BCKZKNK.js.map → chunk-QFE5523Q.js.map} +0 -0
- /package/dist/{chunk-LL3EWDKD.js.map → chunk-QQXNZIVK.js.map} +0 -0
- /package/dist/{chunk-IGQYZ2KH.js.map → chunk-QZ3V2BP7.js.map} +0 -0
- /package/dist/{chunk-SW527EQT.js.map → chunk-SJVLAGUL.js.map} +0 -0
- /package/dist/{chunk-CMFY26F3.js.map → chunk-U4J3BVAQ.js.map} +0 -0
- /package/dist/{chunk-5EUMJI3I.js.map → chunk-U4MRSZQQ.js.map} +0 -0
- /package/dist/{chunk-ZJQTTOHO.js.map → chunk-UADW6FYD.js.map} +0 -0
- /package/dist/{chunk-4324ZSCW.js.map → chunk-VBARKJWL.js.map} +0 -0
- /package/dist/{chunk-OPNTDMHH.js.map → chunk-VLZ6PNAD.js.map} +0 -0
- /package/dist/{chunk-Y6T4NA75.js.map → chunk-XJDXV5VX.js.map} +0 -0
- /package/dist/{chunk-JTUB5ZCT.js.map → chunk-XYTYIAMQ.js.map} +0 -0
|
@@ -939,7 +939,7 @@ var import_openai = __toESM(require("openai"), 1);
|
|
|
939
939
|
// package.json
|
|
940
940
|
var package_default = {
|
|
941
941
|
name: "@morphllm/morphsdk",
|
|
942
|
-
version: "0.2.
|
|
942
|
+
version: "0.2.172",
|
|
943
943
|
description: "TypeScript SDK and CLI for Morph Fast Apply integration",
|
|
944
944
|
type: "module",
|
|
945
945
|
main: "./dist/index.cjs",
|
|
@@ -1076,6 +1076,11 @@ var package_default = {
|
|
|
1076
1076
|
import: "./dist/tools/compact/index.js",
|
|
1077
1077
|
require: "./dist/tools/compact/index.cjs"
|
|
1078
1078
|
},
|
|
1079
|
+
"./tools/reflex": {
|
|
1080
|
+
types: "./dist/tools/reflex/index.d.ts",
|
|
1081
|
+
import: "./dist/tools/reflex/index.js",
|
|
1082
|
+
require: "./dist/tools/reflex/index.cjs"
|
|
1083
|
+
},
|
|
1079
1084
|
"./subagents": {
|
|
1080
1085
|
types: "./dist/subagents/index.d.ts",
|
|
1081
1086
|
import: "./dist/subagents/index.js",
|
|
@@ -1101,7 +1106,7 @@ var package_default = {
|
|
|
1101
1106
|
"!dist/**/*.test.*"
|
|
1102
1107
|
],
|
|
1103
1108
|
scripts: {
|
|
1104
|
-
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/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 subagents/index.ts subagents/types.ts subagents/prompts.ts subagents/vercel.ts subagents/anthropic.ts --format esm,cjs --sourcemap --clean --dts --dts-resolve",
|
|
1109
|
+
build: "tsup version.ts index.ts edge.ts client.ts core/index.ts core/client.ts core/resource.ts core/error.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/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/reflex/index.ts tools/reflex/core.ts tools/reflex/types.ts tools/utils/resilience.ts subagents/index.ts subagents/types.ts subagents/prompts.ts subagents/vercel.ts subagents/anthropic.ts --format esm,cjs --sourcemap --clean --dts --dts-resolve",
|
|
1105
1110
|
prepare: "npm run build",
|
|
1106
1111
|
typecheck: "tsc --noEmit",
|
|
1107
1112
|
lint: "eslint .",
|
|
@@ -1884,16 +1889,238 @@ function parseGitHubUrl(input) {
|
|
|
1884
1889
|
);
|
|
1885
1890
|
}
|
|
1886
1891
|
|
|
1892
|
+
// tools/utils/resilience.ts
|
|
1893
|
+
var DEFAULT_RETRY_CONFIG = {
|
|
1894
|
+
maxRetries: 3,
|
|
1895
|
+
initialDelay: 1e3,
|
|
1896
|
+
maxDelay: 3e4,
|
|
1897
|
+
backoffMultiplier: 2,
|
|
1898
|
+
retryableErrors: ["ECONNREFUSED", "ETIMEDOUT", "ENOTFOUND"]
|
|
1899
|
+
};
|
|
1900
|
+
async function fetchWithRetry(url, options, retryConfig = {}) {
|
|
1901
|
+
const {
|
|
1902
|
+
maxRetries = DEFAULT_RETRY_CONFIG.maxRetries,
|
|
1903
|
+
initialDelay = DEFAULT_RETRY_CONFIG.initialDelay,
|
|
1904
|
+
maxDelay = DEFAULT_RETRY_CONFIG.maxDelay,
|
|
1905
|
+
backoffMultiplier = DEFAULT_RETRY_CONFIG.backoffMultiplier,
|
|
1906
|
+
retryableErrors = DEFAULT_RETRY_CONFIG.retryableErrors,
|
|
1907
|
+
onRetry
|
|
1908
|
+
} = retryConfig;
|
|
1909
|
+
let lastError = null;
|
|
1910
|
+
let delay = initialDelay;
|
|
1911
|
+
options = { ...options, headers: { "X-Morph-SDK-Version": SDK_VERSION, ...options.headers } };
|
|
1912
|
+
for (let attempt = 0; attempt <= maxRetries; attempt++) {
|
|
1913
|
+
try {
|
|
1914
|
+
const response = await fetch(url, options);
|
|
1915
|
+
if (response.status === 429 || response.status === 503) {
|
|
1916
|
+
if (attempt < maxRetries) {
|
|
1917
|
+
const retryAfter = response.headers.get("Retry-After");
|
|
1918
|
+
const waitTime = retryAfter ? parseInt(retryAfter) * 1e3 : Math.min(delay, maxDelay);
|
|
1919
|
+
const error = new Error(`HTTP ${response.status}: Retrying after ${waitTime}ms`);
|
|
1920
|
+
if (onRetry) {
|
|
1921
|
+
onRetry(attempt + 1, error);
|
|
1922
|
+
}
|
|
1923
|
+
await sleep(waitTime);
|
|
1924
|
+
delay *= backoffMultiplier;
|
|
1925
|
+
continue;
|
|
1926
|
+
}
|
|
1927
|
+
}
|
|
1928
|
+
return response;
|
|
1929
|
+
} catch (error) {
|
|
1930
|
+
lastError = error;
|
|
1931
|
+
const isRetryable = retryableErrors.some(
|
|
1932
|
+
(errType) => lastError?.message?.includes(errType)
|
|
1933
|
+
);
|
|
1934
|
+
if (!isRetryable || attempt === maxRetries) {
|
|
1935
|
+
throw lastError;
|
|
1936
|
+
}
|
|
1937
|
+
const waitTime = Math.min(delay, maxDelay);
|
|
1938
|
+
if (onRetry) {
|
|
1939
|
+
onRetry(attempt + 1, lastError);
|
|
1940
|
+
}
|
|
1941
|
+
await sleep(waitTime);
|
|
1942
|
+
delay *= backoffMultiplier;
|
|
1943
|
+
}
|
|
1944
|
+
}
|
|
1945
|
+
throw lastError || new Error("Max retries exceeded");
|
|
1946
|
+
}
|
|
1947
|
+
async function withTimeout(promise, timeoutMs, errorMessage) {
|
|
1948
|
+
let timeoutId;
|
|
1949
|
+
const timeoutPromise = new Promise((_, reject) => {
|
|
1950
|
+
timeoutId = setTimeout(() => {
|
|
1951
|
+
reject(new Error(errorMessage || `Operation timed out after ${timeoutMs}ms`));
|
|
1952
|
+
}, timeoutMs);
|
|
1953
|
+
});
|
|
1954
|
+
try {
|
|
1955
|
+
const result = await Promise.race([promise, timeoutPromise]);
|
|
1956
|
+
clearTimeout(timeoutId);
|
|
1957
|
+
return result;
|
|
1958
|
+
} catch (error) {
|
|
1959
|
+
clearTimeout(timeoutId);
|
|
1960
|
+
throw error;
|
|
1961
|
+
}
|
|
1962
|
+
}
|
|
1963
|
+
function sleep(ms) {
|
|
1964
|
+
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
1965
|
+
}
|
|
1966
|
+
var MorphError = class extends Error {
|
|
1967
|
+
constructor(message, code, statusCode, retryable = false) {
|
|
1968
|
+
super(message);
|
|
1969
|
+
this.code = code;
|
|
1970
|
+
this.statusCode = statusCode;
|
|
1971
|
+
this.retryable = retryable;
|
|
1972
|
+
this.name = "MorphError";
|
|
1973
|
+
}
|
|
1974
|
+
};
|
|
1975
|
+
|
|
1976
|
+
// core/error.ts
|
|
1977
|
+
async function toMorphError(response) {
|
|
1978
|
+
let message = `Morph API request failed (${response.status})`;
|
|
1979
|
+
let code = "api_error";
|
|
1980
|
+
try {
|
|
1981
|
+
const body = await response.json();
|
|
1982
|
+
message = body.error?.message ?? body.message ?? message;
|
|
1983
|
+
code = body.error?.code ?? body.error?.type ?? code;
|
|
1984
|
+
} catch {
|
|
1985
|
+
}
|
|
1986
|
+
if (response.status === 401) code = "authentication_error";
|
|
1987
|
+
if (response.status === 429) code = "rate_limit_exceeded";
|
|
1988
|
+
const retryable = response.status === 429 || response.status === 503;
|
|
1989
|
+
return new MorphError(message, code, response.status, retryable);
|
|
1990
|
+
}
|
|
1991
|
+
|
|
1992
|
+
// core/client.ts
|
|
1993
|
+
var DEFAULT_BASE_URL = "https://api.morphllm.com";
|
|
1994
|
+
var DEFAULT_REPOS_URL = "https://repos.morphllm.com";
|
|
1995
|
+
var DEFAULT_BROWSER_URL = "https://browser.morphllm.com";
|
|
1996
|
+
var DEFAULT_TIMEOUT = 6e4;
|
|
1997
|
+
var env = (name) => typeof process !== "undefined" ? process.env?.[name] : void 0;
|
|
1998
|
+
var stripTrailingSlash = (url) => url.replace(/\/+$/, "");
|
|
1999
|
+
var MorphAPIClient = class {
|
|
2000
|
+
/** Explicit key as provided; resolved against env at request time. */
|
|
2001
|
+
apiKey;
|
|
2002
|
+
baseURL;
|
|
2003
|
+
reposURL;
|
|
2004
|
+
browserURL;
|
|
2005
|
+
/** Explicit default timeout (ms), if set. The request default is applied lazily so
|
|
2006
|
+
* resources can read an undefined value and supply their own fallback. */
|
|
2007
|
+
timeout;
|
|
2008
|
+
retryConfig;
|
|
2009
|
+
debug;
|
|
2010
|
+
constructor(options = {}) {
|
|
2011
|
+
this.apiKey = options.apiKey;
|
|
2012
|
+
this.baseURL = stripTrailingSlash(options.baseURL ?? DEFAULT_BASE_URL);
|
|
2013
|
+
this.reposURL = stripTrailingSlash(options.reposURL ?? env("MORPH_SEARCH_URL") ?? DEFAULT_REPOS_URL);
|
|
2014
|
+
this.browserURL = stripTrailingSlash(
|
|
2015
|
+
options.browserURL ?? (env("MORPH_ENVIRONMENT") === "DEV" ? "http://localhost:8000" : DEFAULT_BROWSER_URL)
|
|
2016
|
+
);
|
|
2017
|
+
this.timeout = options.timeout;
|
|
2018
|
+
this.retryConfig = options.retryConfig;
|
|
2019
|
+
this.debug = options.debug ?? false;
|
|
2020
|
+
if (this.debug) logger.enable();
|
|
2021
|
+
}
|
|
2022
|
+
/** The key actually used for requests: explicit, else `MORPH_API_KEY`. */
|
|
2023
|
+
resolveApiKey() {
|
|
2024
|
+
return this.apiKey ?? env("MORPH_API_KEY");
|
|
2025
|
+
}
|
|
2026
|
+
/** Headers shared with tools that bring their own HTTP client (FastApply/WarpGrep via the `openai` package). */
|
|
2027
|
+
defaultHeaders() {
|
|
2028
|
+
return { "X-Morph-SDK-Version": SDK_VERSION };
|
|
2029
|
+
}
|
|
2030
|
+
buildURL(path6, baseURL) {
|
|
2031
|
+
if (/^https?:\/\//i.test(path6)) return path6;
|
|
2032
|
+
const base = stripTrailingSlash(baseURL ?? this.baseURL);
|
|
2033
|
+
return `${base}${path6.startsWith("/") ? "" : "/"}${path6}`;
|
|
2034
|
+
}
|
|
2035
|
+
buildHeaders(apiKey, extra) {
|
|
2036
|
+
return {
|
|
2037
|
+
"Content-Type": "application/json",
|
|
2038
|
+
"X-Morph-SDK-Version": SDK_VERSION,
|
|
2039
|
+
Authorization: `Bearer ${apiKey}`,
|
|
2040
|
+
...extra
|
|
2041
|
+
};
|
|
2042
|
+
}
|
|
2043
|
+
applyQuery(url, query) {
|
|
2044
|
+
if (!query) return url;
|
|
2045
|
+
const params = new URLSearchParams();
|
|
2046
|
+
for (const [key, value] of Object.entries(query)) {
|
|
2047
|
+
if (value !== void 0 && value !== null) params.set(key, String(value));
|
|
2048
|
+
}
|
|
2049
|
+
const qs = params.toString();
|
|
2050
|
+
return qs ? `${url}${url.includes("?") ? "&" : "?"}${qs}` : url;
|
|
2051
|
+
}
|
|
2052
|
+
async request(method, path6, opts = {}) {
|
|
2053
|
+
const apiKey = this.resolveApiKey();
|
|
2054
|
+
if (!apiKey) {
|
|
2055
|
+
throw new MorphError(
|
|
2056
|
+
"Morph API key not found. Set the MORPH_API_KEY environment variable or pass apiKey in config.",
|
|
2057
|
+
"missing_api_key",
|
|
2058
|
+
401
|
|
2059
|
+
);
|
|
2060
|
+
}
|
|
2061
|
+
const url = this.applyQuery(this.buildURL(path6, opts.baseURL), opts.query);
|
|
2062
|
+
const timeout = opts.timeout ?? this.timeout ?? DEFAULT_TIMEOUT;
|
|
2063
|
+
const init = {
|
|
2064
|
+
method,
|
|
2065
|
+
headers: this.buildHeaders(apiKey, opts.headers),
|
|
2066
|
+
...opts.body !== void 0 ? { body: JSON.stringify(opts.body) } : {},
|
|
2067
|
+
...opts.signal ? { signal: opts.signal } : {}
|
|
2068
|
+
};
|
|
2069
|
+
logger.debug("MorphAPIClient", "request", { method, url });
|
|
2070
|
+
const response = await withTimeout(
|
|
2071
|
+
fetchWithRetry(url, init, this.retryConfig ?? {}),
|
|
2072
|
+
timeout,
|
|
2073
|
+
`Morph request to ${url} timed out after ${timeout}ms`
|
|
2074
|
+
);
|
|
2075
|
+
if (opts.raw) return response;
|
|
2076
|
+
if (!response.ok) throw await toMorphError(response);
|
|
2077
|
+
if (opts.stream) return response;
|
|
2078
|
+
if (response.status === 204) return void 0;
|
|
2079
|
+
const text = await response.text();
|
|
2080
|
+
return text ? JSON.parse(text) : void 0;
|
|
2081
|
+
}
|
|
2082
|
+
get(path6, opts) {
|
|
2083
|
+
return this.request("GET", path6, opts);
|
|
2084
|
+
}
|
|
2085
|
+
post(path6, opts) {
|
|
2086
|
+
return this.request("POST", path6, opts);
|
|
2087
|
+
}
|
|
2088
|
+
delete(path6, opts) {
|
|
2089
|
+
return this.request("DELETE", path6, opts);
|
|
2090
|
+
}
|
|
2091
|
+
};
|
|
2092
|
+
|
|
2093
|
+
// core/resource.ts
|
|
2094
|
+
var APIResource = class {
|
|
2095
|
+
_client;
|
|
2096
|
+
constructor(client) {
|
|
2097
|
+
this._client = client;
|
|
2098
|
+
}
|
|
2099
|
+
};
|
|
2100
|
+
|
|
1887
2101
|
// tools/compact/core.ts
|
|
1888
2102
|
var DEFAULT_API_URL2 = "https://api.morphllm.com";
|
|
1889
|
-
var
|
|
1890
|
-
|
|
2103
|
+
var DEFAULT_TIMEOUT2 = 12e4;
|
|
2104
|
+
function resolveClient(clientOrConfig) {
|
|
2105
|
+
if (clientOrConfig instanceof MorphAPIClient) return clientOrConfig;
|
|
2106
|
+
return new MorphAPIClient({
|
|
2107
|
+
apiKey: clientOrConfig.morphApiKey,
|
|
2108
|
+
baseURL: clientOrConfig.morphApiUrl ?? DEFAULT_API_URL2,
|
|
2109
|
+
timeout: clientOrConfig.timeout ?? DEFAULT_TIMEOUT2,
|
|
2110
|
+
retryConfig: clientOrConfig.retryConfig,
|
|
2111
|
+
debug: clientOrConfig.debug
|
|
2112
|
+
});
|
|
2113
|
+
}
|
|
2114
|
+
var CompactClient = class extends APIResource {
|
|
2115
|
+
/** Resolved URL/timeout, exposed for backwards-compatible introspection. */
|
|
1891
2116
|
config;
|
|
1892
|
-
constructor(
|
|
2117
|
+
constructor(clientOrConfig = {}) {
|
|
2118
|
+
super(resolveClient(clientOrConfig));
|
|
2119
|
+
const cfg = clientOrConfig instanceof MorphAPIClient ? {} : clientOrConfig;
|
|
1893
2120
|
this.config = {
|
|
1894
|
-
|
|
1895
|
-
|
|
1896
|
-
|
|
2121
|
+
morphApiUrl: this._client.baseURL,
|
|
2122
|
+
timeout: cfg.timeout ?? DEFAULT_TIMEOUT2,
|
|
2123
|
+
debug: cfg.debug ?? false
|
|
1897
2124
|
};
|
|
1898
2125
|
}
|
|
1899
2126
|
/**
|
|
@@ -1912,17 +2139,6 @@ var CompactClient = class {
|
|
|
1912
2139
|
* ```
|
|
1913
2140
|
*/
|
|
1914
2141
|
async compact(input) {
|
|
1915
|
-
const apiKey = this.config.morphApiKey || (typeof process !== "undefined" ? process.env?.MORPH_API_KEY : void 0);
|
|
1916
|
-
const debug = this.config.debug || false;
|
|
1917
|
-
if (!apiKey) {
|
|
1918
|
-
throw new Error(
|
|
1919
|
-
"Morph API key not found. Set MORPH_API_KEY environment variable or pass morphApiKey in config."
|
|
1920
|
-
);
|
|
1921
|
-
}
|
|
1922
|
-
const url = `${this.config.morphApiUrl}/v1/compact`;
|
|
1923
|
-
if (debug) {
|
|
1924
|
-
console.log(`[Compact] Calling ${url}`);
|
|
1925
|
-
}
|
|
1926
2142
|
const body = {
|
|
1927
2143
|
compression_ratio: input.compressionRatio ?? 0.5,
|
|
1928
2144
|
preserve_recent: input.preserveRecent ?? 2,
|
|
@@ -1930,37 +2146,19 @@ var CompactClient = class {
|
|
|
1930
2146
|
include_line_ranges: input.includeLineRanges ?? true,
|
|
1931
2147
|
include_markers: input.includeMarkers ?? true
|
|
1932
2148
|
};
|
|
1933
|
-
if (input.query !== void 0)
|
|
1934
|
-
|
|
1935
|
-
|
|
1936
|
-
if (input.
|
|
1937
|
-
|
|
1938
|
-
|
|
1939
|
-
|
|
1940
|
-
}
|
|
1941
|
-
|
|
1942
|
-
|
|
1943
|
-
|
|
1944
|
-
|
|
1945
|
-
const startTime = Date.now();
|
|
1946
|
-
const response = await fetch(url, {
|
|
1947
|
-
method: "POST",
|
|
1948
|
-
headers: {
|
|
1949
|
-
"Authorization": `Bearer ${apiKey}`,
|
|
1950
|
-
"Content-Type": "application/json"
|
|
1951
|
-
},
|
|
1952
|
-
body: JSON.stringify(body),
|
|
1953
|
-
signal: AbortSignal.timeout(this.config.timeout)
|
|
1954
|
-
});
|
|
1955
|
-
if (!response.ok) {
|
|
1956
|
-
const text = await response.text();
|
|
1957
|
-
throw new Error(`Compact API error ${response.status}: ${text}`);
|
|
1958
|
-
}
|
|
1959
|
-
const data = await response.json();
|
|
1960
|
-
if (debug) {
|
|
1961
|
-
console.log(`[Compact] compact() done in ${Date.now() - startTime}ms`);
|
|
2149
|
+
if (input.query !== void 0) body.query = input.query;
|
|
2150
|
+
if (input.messages) body.messages = input.messages;
|
|
2151
|
+
else if (typeof input.input === "string") body.input = input.input;
|
|
2152
|
+
else if (Array.isArray(input.input)) body.messages = input.input;
|
|
2153
|
+
else throw new Error("Either 'input' or 'messages' must be provided");
|
|
2154
|
+
try {
|
|
2155
|
+
return await this._client.post("/v1/compact", { body, timeout: this.config.timeout });
|
|
2156
|
+
} catch (err) {
|
|
2157
|
+
if (err instanceof MorphError) {
|
|
2158
|
+
throw new Error(`Compact API error ${err.statusCode}: ${err.message}`);
|
|
2159
|
+
}
|
|
2160
|
+
throw err;
|
|
1962
2161
|
}
|
|
1963
|
-
return data;
|
|
1964
2162
|
}
|
|
1965
2163
|
};
|
|
1966
2164
|
|
|
@@ -2016,10 +2214,28 @@ async function getLocalProvider(repoRoot, excludes, allowNames) {
|
|
|
2016
2214
|
const opts = allowNames?.length ? { allowNames } : void 0;
|
|
2017
2215
|
return new LocalRipgrepProvider2(repoRoot, excludes, opts);
|
|
2018
2216
|
}
|
|
2019
|
-
var WarpGrepClient = class {
|
|
2217
|
+
var WarpGrepClient = class extends APIResource {
|
|
2020
2218
|
config;
|
|
2021
|
-
constructor(
|
|
2022
|
-
|
|
2219
|
+
constructor(clientOrConfig = {}) {
|
|
2220
|
+
const isClient = clientOrConfig instanceof MorphAPIClient;
|
|
2221
|
+
super(
|
|
2222
|
+
isClient ? clientOrConfig : new MorphAPIClient({
|
|
2223
|
+
apiKey: clientOrConfig.morphApiKey,
|
|
2224
|
+
baseURL: clientOrConfig.morphApiUrl,
|
|
2225
|
+
timeout: clientOrConfig.timeout,
|
|
2226
|
+
retryConfig: clientOrConfig.retryConfig,
|
|
2227
|
+
debug: clientOrConfig.debug
|
|
2228
|
+
})
|
|
2229
|
+
);
|
|
2230
|
+
const cfg = isClient ? {} : clientOrConfig;
|
|
2231
|
+
this.config = {
|
|
2232
|
+
...cfg,
|
|
2233
|
+
morphApiKey: this._client.resolveApiKey(),
|
|
2234
|
+
morphApiUrl: this._client.baseURL,
|
|
2235
|
+
timeout: this._client.timeout,
|
|
2236
|
+
retryConfig: this._client.retryConfig,
|
|
2237
|
+
debug: this._client.debug
|
|
2238
|
+
};
|
|
2023
2239
|
}
|
|
2024
2240
|
execute(input) {
|
|
2025
2241
|
const toolConfig = {
|