@cline/core 0.0.41 → 0.0.42-nightly.1779765362

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.
@@ -7,6 +7,7 @@ export interface CronRunnerOptions {
7
7
  store: SqliteCronStore;
8
8
  materializer: CronMaterializer;
9
9
  runtimeHandlers: HubScheduleRuntimeHandlers;
10
+ eventPublisher?: (eventType: string, payload: Record<string, unknown>) => void;
10
11
  /** Default runtime workspace for the hub/daemon process. */
11
12
  workspaceRoot: string;
12
13
  /** Cron spec source/report location. Defaults to global `~/.cline/cron`. */
@@ -38,6 +39,7 @@ export declare class CronRunner {
38
39
  sessionId?: string;
39
40
  }>;
40
41
  private executeClaim;
42
+ private publishScheduleExecutionEvent;
41
43
  private buildPrompt;
42
44
  private startClaimLeaseHeartbeat;
43
45
  private buildSystemPrompt;
@@ -45,7 +45,7 @@ export interface ActiveScheduledExecution {
45
45
  }
46
46
  export interface HubScheduleServiceOptions {
47
47
  runtimeHandlers: HubScheduleRuntimeHandlers;
48
- eventPublisher?: (eventType: string, payload: unknown) => void;
48
+ eventPublisher?: (eventType: string, payload: Record<string, unknown>) => void;
49
49
  logger?: BasicLogger;
50
50
  dbPath?: string;
51
51
  pollIntervalMs?: number;
@@ -21,4 +21,18 @@ export interface ContextCompactionPrepareTurnOptions {
21
21
  mode?: ContextCompactionMode;
22
22
  manualTargetRatio?: number;
23
23
  }
24
- export declare function createContextCompactionPrepareTurn(config: Pick<CoreSessionConfig, "providerConfig" | "providerId" | "modelId" | "compaction" | "logger">, options?: ContextCompactionPrepareTurnOptions): ((context: ContextPipelinePrepareTurnInput) => Promise<ContextPipelinePrepareTurnResult | undefined>) | undefined;
24
+ /**
25
+ * Build the `prepareTurn` callback used by the agent runtime to compact the
26
+ * transcript before each model request.
27
+ *
28
+ * Telemetry: emits `task.compaction_executed` on a successful compaction and
29
+ * `task.compaction_skipped` when the configured strategy returns `undefined`.
30
+ * Telemetry is keyed by `config.sessionId` (falling back to the per-turn
31
+ * `conversationId`) and tagged with `provider` / `modelId`.
32
+ *
33
+ * Known gap: compactions performed via plugin `registerMessageBuilder()` or
34
+ * via the `beforeModel` runtime hook bypass this wrapper entirely, so they
35
+ * do not emit compaction telemetry. If we want coverage there too, the
36
+ * plugin/hook pipelines must be instrumented separately.
37
+ */
38
+ export declare function createContextCompactionPrepareTurn(config: Pick<CoreSessionConfig, "providerConfig" | "providerId" | "modelId" | "compaction" | "logger" | "telemetry" | "sessionId">, options?: ContextCompactionPrepareTurnOptions): ((context: ContextPipelinePrepareTurnInput) => Promise<ContextPipelinePrepareTurnResult | undefined>) | undefined;
@@ -1 +1 @@
1
- import{createRequire as GG}from"node:module";var QG=GG(import.meta.url);import{normalizePluginManifest as CG}from"@cline/shared";import{existsSync as L,readFileSync as j}from"node:fs";import{builtinModules as UG,createRequire as m}from"node:module";import{dirname as D,extname as E,isAbsolute as XG,resolve as K}from"node:path";import{fileURLToPath as h}from"node:url";import{PLUGIN_FILE_EXTENSIONS as YG}from"@cline/shared";var d=D(h(import.meta.url)),ZG=m(import.meta.url),$G=K(d,"..","..","..","..",".."),b=WG($G),qG=["@cline/agents","@cline/core","@cline/core/hub","@cline/core/hub/daemon-entry","@cline/core/telemetry","@cline/llms","@cline/llms/browser","@cline/shared","@cline/shared/automation","@cline/shared/browser","@cline/shared/storage","@cline/shared/db","@cline/shared/types"],R=new Set(UG.flatMap((G)=>[G,G.replace(/^node:/,"")])),B=new Set(YG),KG=["development","node","import","require","default"];function WG(G){let Q={},U={"@cline/agents":K(G,"packages/agents/src/index.ts"),"@cline/core":K(G,"packages/core/src/index.ts"),"@cline/llms":K(G,"packages/llms/src/index.ts"),"@cline/shared":K(G,"packages/shared/src/index.ts"),"@cline/shared/storage":K(G,"packages/shared/src/storage/index.ts"),"@cline/shared/db":K(G,"packages/shared/src/db/index.ts")};for(let[X,Y]of Object.entries(U))if(L(Y))Q[X]=Y;for(let X of["agents","core","llms","shared"]){let Y=K(G,"packages",X),$=K(Y,"package.json");if(!L($))continue;try{let Z=JSON.parse(j($,"utf8"));if(typeof Z.name!=="string"||!Z.exports)continue;if(typeof Z.exports==="string"){let w=K(Y,Z.exports);if(L(w))Q[Z.name]=w;continue}if(typeof Z.exports!=="object")continue;for(let[w,A]of Object.entries(Z.exports)){let W=wG(Y,A);if(!W)continue;let _=w==="."?Z.name:`${Z.name}/${w.replace(/^\.\//,"")}`;Q[_]=W}}catch{}}return Q}function wG(G,Q){let U=k(Q);if(!U)return null;let X=u(G,U);for(let Y of X)if(L(Y))return Y;return null}function k(G,Q=new Set){if(typeof G==="string")return G;if(!G||typeof G!=="object")return null;if(Q.has(G))return null;Q.add(G);let U=G;for(let X of KG){let Y=k(U[X],Q);if(Y)return Y}return null}function u(G,Q){let U=Q.replace(/^\.\//,""),X=[K(G,Q)];if(U.startsWith("dist/")){let Y=U.replace(/^dist\//,"src/").replace(/\.(mjs|cjs|js)$/,"");return[K(G,`${Y}.ts`),K(G,`${Y}.tsx`),K(G,`${Y}.mts`),K(G,`${Y}.cts`),...X]}return X}function _G(G){return Object.fromEntries(Object.entries(G).sort(([Q],[U])=>U.length-Q.length))}function H(G){return!(G.startsWith(".")||G.startsWith("/")||G.startsWith("file:")||G.startsWith("data:")||G.startsWith("http:")||G.startsWith("https:"))}function C(G){if(G.startsWith("@")){let[Q,U]=G.split("/",3);return U?`${Q}/${U}`:G}return G.split("/",1)[0]??G}function LG(G){let Q=C(G);if(G===Q)return".";return`.${G.slice(Q.length)}`}function c(G){return C(G).startsWith("@cline/")}function T(G,Q){let U=C(Q),X=D(G);while(!0){let Y=K(X,"node_modules",U);if(L(Y)||L(K(Y,"package.json")))return!0;let $=K(X,"..");if($===X)return!1;X=$}}function P(G){return y(G)!==null}function y(G){try{return ZG.resolve(G)}catch{}return AG(G)}function AG(G){let Q=C(G),U=MG(Q);if(!U)return null;let X=K(U,"package.json");try{let Y=JSON.parse(j(X,"utf8")),$=LG(G),Z=$==="."&&typeof Y.exports==="string"?Y.exports:Y.exports&&typeof Y.exports==="object"&&Object.hasOwn(Y.exports,$)?Y.exports[$]:void 0,w=k(Z)??($==="."&&typeof Y.main==="string"?Y.main:null);if(!w)return null;let A=K(U,w),W=[A,...u(U,w).filter((_)=>_!==A)];for(let _ of W)if(L(_))return _;return null}catch{return null}}function MG(G){let Q=d;while(!0){let U=K(Q,"package.json");if(L(U))try{if(JSON.parse(j(U,"utf8")).name===G)return Q}catch{}let X=K(Q,"node_modules",G,"package.json");if(L(X))return D(X);let Y=K(Q,"..");if(Y===Q)return null;Q=Y}}function zG(G){let U=D(G);for(let X=0;X<4;X++){let Y=K(U,"package.json");if(L(Y))try{let Z=JSON.parse(j(Y,"utf8"));return Z!=null&&typeof Z==="object"&&"cline"in Z}catch{return!1}let $=K(U,"..");if($===U)return!1;U=$}return!1}function l(G,Q){let U=Q.startsWith("file:")?h(Q):XG(Q)?Q:K(D(G),Q);if(L(U)&&B.has(E(U)))return U;for(let X of B){let Y=`${U}${X}`;if(L(Y))return Y}for(let X of B){let Y=K(U,`index${X}`);if(L(Y))return Y}return null}function g(G){let Q=new Set,U=[/\bimport\s+(?:type\s+)?[^"'`]*?\bfrom\s*["'`]([^"'`]+)["'`]/g,/\bexport\s+[^"'`]*?\bfrom\s*["'`]([^"'`]+)["'`]/g,/\bimport\s*\(\s*["'`]([^"'`]+)["'`]\s*\)/g,/\brequire\s*\(\s*["'`]([^"'`]+)["'`]\s*\)/g];for(let X of U)for(let Y of G.matchAll(X)){let $=Y[1];if($)Q.add($)}return[...Q]}function FG(G){return E(G)!==".ts"}function o(G,Q,U=new Set){if(U.has(G)||!L(G))return;if(U.add(G),!B.has(E(G)))return;let X=j(G,"utf8"),Y=FG(G);for(let $ of g(X)){if($.startsWith("node:")||R.has($))continue;if(H($)){if(!Y)continue;if(Object.hasOwn(b,$)||Object.hasOwn(b,C($))||T(G,$)||c($)&&P($)||Q&&P($))continue;throw Error(`Cannot find module '${C($)}'`)}let Z=l(G,$);if(Z)o(Z,Q,U)}}function n(G,Q=new Set,U=new Set){if(Q.has(G)||!L(G))return U;if(Q.add(G),!B.has(E(G)))return U;let X=j(G,"utf8");for(let Y of g(X)){if(U.add(Y),H(Y))continue;let $=l(G,Y);if($)n($,Q,U)}return U}function JG(G,Q){let U=m(G),X={},Y=n(G),$=new Set(qG);for(let[Z,w]of Object.entries(b)){try{U.resolve(Z);continue}catch{}X[Z]=w}for(let Z of Y)if(H(Z)&&(c(Z)||Q))$.add(Z);for(let Z of $){if(Object.hasOwn(X,Z)||T(G,Z))continue;let w=y(Z);if(w)X[Z]=w}if(!Q)return X;for(let Z of Y){if(!H(Z)||Object.hasOwn(X,Z)||T(G,Z)||Z.startsWith("node:")||R.has(Z))continue;let w=y(Z);if(w)X[Z]=w}return X}async function p(G,Q={}){let U=!zG(G);o(G,U);let X=JG(G,U),Y=_G(X),$=await import("jiti"),Z=typeof $==="function"?$:typeof $.default==="function"?$.default:void 0;if(!Z)throw Error("Unable to load jiti");return await Z(G,{alias:Y,cache:Q.useCache,requireCache:Q.useCache,esmResolve:!0,interopDefault:!1,nativeModules:[...R],transformModules:Object.keys(Y)}).import(G,{})}function s(G,Q){if(!G)return!0;if(G.providerIds?.length){if(!Q?.providerId||!G.providerIds.includes(Q.providerId))return!1}if(G.modelIds?.length){if(!Q?.modelId||!G.modelIds.includes(Q.modelId))return!1}return!0}function z(G){return typeof G==="object"&&G!==null}function r(G){return Array.isArray(G)&&G.every((Q)=>typeof Q==="string")}function jG(G,Q){if(!z(G))throw Error(`Invalid plugin module: ${Q}`);if(typeof G.name!=="string"||!G.name)throw Error(`Invalid plugin name: ${Q}`);if(!z(G.manifest))throw Error(`Invalid plugin manifest: ${Q}`);if(Object.hasOwn(G.manifest,"providerIds")&&!r(G.manifest.providerIds))throw Error(`Invalid plugin manifest.providerIds: ${Q}`);if(Object.hasOwn(G.manifest,"modelIds")&&!r(G.manifest.modelIds))throw Error(`Invalid plugin manifest.modelIds: ${Q}`)}function BG(G){if(!z(G))throw Error("Plugin setup context must be an object");if(G.session!==void 0&&!z(G.session))throw Error("Plugin setup context session must be an object");if(G.client!==void 0&&!z(G.client))throw Error("Plugin setup context client must be an object");if(G.user!==void 0&&!z(G.user))throw Error("Plugin setup context user must be an object");if(G.workspaceInfo!==void 0&&!z(G.workspaceInfo))throw Error("Plugin setup context workspaceInfo must be an object");if(G.automation!==void 0&&!z(G.automation))throw Error("Plugin setup context automation must be an object");if(G.automation!==void 0&&typeof G.automation.ingestEvent!=="function")throw Error("Plugin setup context automation.ingestEvent must be a function");if(G.logger!==void 0&&!z(G.logger))throw Error("Plugin setup context logger must be an object")}var t=0,I=new Map,x=new Map;function DG(G){let Q=G instanceof Error?G.message:String(G),U=G instanceof Error?G.stack:void 0;return{message:Q,stack:U}}function v(G,Q,U,X){if(!process.send)return;process.send({type:"response",id:G,ok:Q,result:U,error:X})}function f(G,Q){if(!process.send)return;process.send({type:"event",name:G,payload:Q})}globalThis.__clinePluginHost={emitEvent:f};globalThis.__clineSessionEnv={cwd:void 0,workspaceInfo:void 0};function a(G){if(!G||typeof G!=="object")return{};return G}function OG(G){if(!G||typeof G!=="object")return;let Q={...G};if(Q.error instanceof Error)Q.error={name:Q.error.name,message:Q.error.message,stack:Q.error.stack};return Q}function NG(G){let Q=(U,X,Y)=>{f("plugin_log",{level:U,pluginName:G,message:X,metadata:OG(Y)})};return{debug:(U,X)=>Q("debug",U,X),log:(U,X)=>Q("log",U,X),error:(U,X)=>Q("error",U,X)}}function O(G,Q){let U=`${G}:${Q}`,X=(x.get(U)??0)+1;return x.set(U,X),`${G}_${Q}_${X}`}function HG(G){let Q=typeof G.eventType==="string"?G.eventType.trim():"",U=typeof G.source==="string"?G.source.trim():"";if(!Q)throw Error("Automation event type contribution requires eventType");if(!U)throw Error("Automation event type contribution requires source");return{...G,eventType:Q,source:U,examples:G.examples?[...G.examples]:void 0,metadata:G.metadata?a(G.metadata):void 0}}function S(G){let Q=I.get(G);if(!Q)throw Error(`Unknown sandbox plugin id: ${G}`);return Q}async function EG(G){if(I.clear(),t=0,x.clear(),G.cwd)try{process.chdir(G.cwd)}catch{}let Q=globalThis.__clineSessionEnv;if(Q)Q.cwd=G.cwd,Q.workspaceInfo=G.workspaceInfo;let U=[],X=[],Y=[],$=G.exportName||"plugin",Z=new Map,w={providerId:G.providerId,modelId:G.modelId};for(let A of G.pluginPaths||[]){let W;try{let _=await p(A);if(W=_.default??_[$],jG(W,A),W.manifest=CG(W.manifest),!s(W.manifest,w))continue;let F=`plugin_${++t}`,J={tools:[],commands:[],messageBuilders:[],providers:[],automationEventTypes:[],shortcuts:[],flags:[]},N={tools:new Map,commands:new Map,messageBuilders:new Map},i={registerTool:(q)=>{let M=O(F,"tool");N.tools.set(M,q.execute),J.tools.push({id:M,name:q.name,description:q.description,inputSchema:q.inputSchema,timeoutMs:q.timeoutMs,retryable:q.retryable})},registerCommand:(q)=>{let M=O(F,"command");if(typeof q.handler==="function")N.commands.set(M,q.handler);J.commands.push({id:M,name:q.name,description:q.description})},registerMessageBuilder:(q)=>{let M=O(F,"builder");N.messageBuilders.set(M,q.build),J.messageBuilders.push({id:M,name:q.name})},registerProvider:(q)=>{J.providers.push({id:O(F,"provider"),name:q.name,description:q.description,metadata:a(q.metadata)})},registerAutomationEventType:(q)=>{J.automationEventTypes.push({id:O(F,"automation_event"),...HG(q)})}};if(typeof W.setup==="function")try{let q={session:G.session,client:G.client,user:G.user,workspaceInfo:G.workspaceInfo,...G.loggerEnabled?{logger:NG(W.name)}:{},...W.manifest.capabilities.includes("automationEvents")?{automation:{ingestEvent:(M)=>{f("automation_event",M)}}}:{}};BG(q),await W.setup(i,q)}catch(q){X.push({pluginPath:A,pluginName:W.name,phase:"setup",message:q instanceof Error?q.message:String(q),stack:q instanceof Error?q.stack:void 0});continue}let V=Z.get(W.name);if(V!==void 0){let q=U[V];if(!q)Z.delete(W.name);else{Y.push({type:"duplicate_plugin_override",pluginName:W.name,pluginPath:A,overriddenPluginPath:q.pluginPath,message:`Plugin "${W.name}" from ${A} overrides ${q.pluginPath}`}),I.delete(q.pluginId),U.splice(V,1),Z.clear();for(let[M,e]of U.entries())Z.set(e.name,M)}}I.set(F,{plugin:W,handlers:N}),Z.set(W.name,U.length),U.push({pluginId:F,pluginPath:A,name:W.name,manifest:W.manifest,hooks:W.hooks?Object.entries(W.hooks).filter(([,q])=>typeof q==="function").map(([q])=>q):void 0,contributions:J})}catch(_){X.push({pluginPath:A,pluginName:W?.name,phase:"load",message:_ instanceof Error?_.message:String(_),stack:_ instanceof Error?_.stack:void 0})}}return{plugins:U,failures:X,warnings:Y}}async function IG(G){let U=S(G.pluginId).plugin.hooks?.[G.hookName];if(typeof U!=="function")return;return await U(G.payload)}async function SG(G){let U=S(G.pluginId).handlers.tools.get(G.contributionId);if(typeof U!=="function")throw Error("Unknown sandbox tool contribution");return await U(G.input,G.context)}async function VG(G){let U=S(G.pluginId).handlers.commands.get(G.contributionId);if(typeof U!=="function")return"";return await U(G.input)}async function bG(G){let U=S(G.pluginId).handlers.messageBuilders.get(G.contributionId);if(typeof U!=="function")return[];return await U(G.messages)}var TG={initialize:EG,invokeHook:IG,executeTool:SG,executeCommand:VG,buildMessages:bG};process.on("message",async(G)=>{if(!G||G.type!=="call")return;let Q=TG[G.method];if(!Q){v(G.id,!1,void 0,{message:`Unknown method: ${String(G.method)}`});return}try{let U=await Q(G.args||{});v(G.id,!0,U)}catch(U){v(G.id,!1,void 0,DG(U))}});
1
+ import{createRequire as GG}from"node:module";var QG=GG(import.meta.url);import{normalizePluginManifest as jG}from"@cline/shared";import{existsSync as _,readFileSync as C}from"node:fs";import{builtinModules as UG,createRequire as b}from"node:module";import{dirname as M,extname as O,isAbsolute as XG,resolve as K}from"node:path";import{fileURLToPath as P}from"node:url";import{PLUGIN_FILE_EXTENSIONS as YG}from"@cline/shared";var h=M(P(import.meta.url)),ZG=b(import.meta.url),$G=K(h,"..","..","..","..",".."),S=WG($G),qG=["@cline/sdk","@cline/agents","@cline/core","@cline/core/hub","@cline/core/hub/daemon-entry","@cline/core/telemetry","@cline/llms","@cline/llms/browser","@cline/shared","@cline/shared/automation","@cline/shared/browser","@cline/shared/storage","@cline/shared/db","@cline/shared/types"],y=new Set(UG.flatMap((G)=>[G,G.replace(/^node:/,"")])),I=new Set(YG),KG=["development","node","import","require","default"];function WG(G){let Q={},U={"@cline/sdk":K(G,"packages/sdk/src/index.ts"),"@cline/agents":K(G,"packages/agents/src/index.ts"),"@cline/core":K(G,"packages/core/src/index.ts"),"@cline/llms":K(G,"packages/llms/src/index.ts"),"@cline/shared":K(G,"packages/shared/src/index.ts"),"@cline/shared/storage":K(G,"packages/shared/src/storage/index.ts"),"@cline/shared/db":K(G,"packages/shared/src/db/index.ts")};for(let[Y,Z]of Object.entries(U))if(_(Z))Q[Y]=Z;for(let Y of["agents","core","llms","shared"]){let Z=K(G,"packages",Y),$=K(Z,"package.json");if(!_($))continue;try{let X=JSON.parse(C($,"utf8"));if(typeof X.name!=="string"||!X.exports)continue;if(typeof X.exports==="string"){let q=K(Z,X.exports);if(_(q))Q[X.name]=q;continue}if(typeof X.exports!=="object")continue;for(let[q,w]of Object.entries(X.exports)){let A=_G(Z,w);if(!A)continue;let L=q==="."?X.name:`${X.name}/${q.replace(/^\.\//,"")}`;Q[L]=A}}catch{}}return Q}function _G(G,Q){let U=R(Q);if(!U)return null;let Y=m(G,U);for(let Z of Y)if(_(Z))return Z;return null}function R(G,Q=new Set){if(typeof G==="string")return G;if(!G||typeof G!=="object")return null;if(Q.has(G))return null;Q.add(G);let U=G;for(let Y of KG){let Z=R(U[Y],Q);if(Z)return Z}return null}function m(G,Q){let U=Q.replace(/^\.\//,""),Y=[K(G,Q)];if(U.startsWith("dist/")){let Z=U.replace(/^dist\//,"src/").replace(/\.(mjs|cjs|js)$/,"");return[K(G,`${Z}.ts`),K(G,`${Z}.tsx`),K(G,`${Z}.mts`),K(G,`${Z}.cts`),...Y]}return Y}function LG(G){return Object.fromEntries(Object.entries(G).sort(([Q],[U])=>U.length-Q.length))}function D(G){return!(G.startsWith(".")||G.startsWith("/")||G.startsWith("file:")||G.startsWith("data:")||G.startsWith("http:")||G.startsWith("https:"))}function J(G){if(G.startsWith("@")){let[Q,U]=G.split("/",3);return U?`${Q}/${U}`:G}return G.split("/",1)[0]??G}function wG(G){let Q=J(G);if(G===Q)return".";return`.${G.slice(Q.length)}`}function d(G){return J(G).startsWith("@cline/")}function V(G,Q){let U=J(Q),Y=M(G);while(!0){let Z=K(Y,"node_modules",U);if(_(Z)||_(K(Z,"package.json")))return!0;let $=K(Y,"..");if($===Y)return!1;Y=$}}function f(G){return T(G)!==null}function T(G){try{return ZG.resolve(G)}catch{}return AG(G)}function AG(G){let Q=J(G),U=u(Q);if(!U)return null;let Y=K(U,"package.json");try{let Z=JSON.parse(C(Y,"utf8")),$=wG(G),X=$==="."&&typeof Z.exports==="string"?Z.exports:Z.exports&&typeof Z.exports==="object"&&Object.hasOwn(Z.exports,$)?Z.exports[$]:void 0,q=R(X)??($==="."&&typeof Z.main==="string"?Z.main:null);if(!q)return null;let w=K(U,q),A=[w,...m(U,q).filter((L)=>L!==w)];for(let L of A)if(_(L))return L;return null}catch{return null}}function zG(){let G=[h],Q=process.env.CLINE_WRAPPER_PATH?.trim();if(Q)G.push(M(M(Q)));let U=process.execPath?.trim();if(U)G.push(M(U));return[...new Set(G.map((Y)=>K(Y)))]}function MG(G,Q){let U=G;while(!0){let Y=K(U,"package.json");if(_(Y))try{if(JSON.parse(C(Y,"utf8")).name===Q)return U}catch{}let Z=K(U,"node_modules",Q,"package.json");if(_(Z))return M(Z);let $=K(U,"..");if($===U)return null;U=$}}function u(G){for(let Q of zG()){let U=MG(Q,G);if(U)return U}return null}function FG(G){let U=M(G);for(let Y=0;Y<4;Y++){let Z=K(U,"package.json");if(_(Z))try{let X=JSON.parse(C(Z,"utf8"));return X!=null&&typeof X==="object"&&"cline"in X}catch{return!1}let $=K(U,"..");if($===U)return!1;U=$}return!1}function l(G,Q){let U=Q.startsWith("file:")?P(Q):XG(Q)?Q:K(M(G),Q);if(_(U)&&I.has(O(U)))return U;for(let Y of I){let Z=`${U}${Y}`;if(_(Z))return Z}for(let Y of I){let Z=K(U,`index${Y}`);if(_(Z))return Z}return null}function c(G){let Q=new Set,U=[/\bimport\s+(?:type\s+)?[^"'`]*?\bfrom\s*["'`]([^"'`]+)["'`]/g,/\bexport\s+[^"'`]*?\bfrom\s*["'`]([^"'`]+)["'`]/g,/\bimport\s*\(\s*["'`]([^"'`]+)["'`]\s*\)/g,/\brequire\s*\(\s*["'`]([^"'`]+)["'`]\s*\)/g];for(let Y of U)for(let Z of G.matchAll(Y)){let $=Z[1];if($)Q.add($)}return[...Q]}function JG(G){return O(G)!==".ts"}function g(G,Q,U=new Set){if(U.has(G)||!_(G))return;if(U.add(G),!I.has(O(G)))return;let Y=C(G,"utf8"),Z=JG(G);for(let $ of c(Y)){if($.startsWith("node:")||y.has($))continue;if(D($)){if(!Z)continue;if(Object.hasOwn(S,$)||Object.hasOwn(S,J($))||V(G,$)||d($)&&f($)||Q&&f($))continue;throw Error(`Cannot find module '${J($)}'`)}let X=l(G,$);if(X)g(X,Q,U)}}function n(G,Q=new Set,U=new Set){if(Q.has(G)||!_(G))return U;if(Q.add(G),!I.has(O(G)))return U;let Y=C(G,"utf8");for(let Z of c(Y)){if(U.add(Z),D(Z))continue;let $=l(G,Z);if($)n($,Q,U)}return U}function CG(G,Q){let U=b(G),Y={},Z=n(G),$=new Set(qG);for(let[X,q]of Object.entries(S)){try{U.resolve(X);continue}catch{}Y[X]=q}for(let X of Z)if(D(X)&&(d(X)||Q))$.add(X);for(let X of $){if(Object.hasOwn(Y,X)||V(G,X))continue;let q=T(X);if(q)Y[X]=q}if(!Q)return Y;for(let X of Z){if(!D(X)||Object.hasOwn(Y,X)||V(G,X)||X.startsWith("node:")||y.has(X))continue;let q=T(X);if(q)Y[X]=q}return Y}function IG(G){let Q=O(G);return Q===".ts"||Q===".tsx"||Q===".mts"||Q===".cts"}var F;function OG(){if(F!==void 0)return F;let G=u("jiti");if(!G)return F=null,null;let Q=K(G,"dist","babel.cjs");if(!_(Q))return F=null,null;try{let Y=b(Q)(Q);F=typeof Y==="function"?Y:null}catch{F=null}return F}async function o(G,Q={}){let U=!FG(G);g(G,U);let Y=CG(G,U),Z=LG(Y),$=await import("jiti"),X=typeof $==="function"?$:typeof $.default==="function"?$.default:void 0;if(!X)throw Error("Unable to load jiti");let q=Object.entries(Z).filter(([,W])=>IG(W)).map(([W])=>W),w=OG(),A=w?(W)=>w({...W,interopDefault:!0}):void 0;return await X(G,{alias:Z,cache:Q.useCache,requireCache:Q.useCache,esmResolve:!0,interopDefault:!1,nativeModules:[...y],transformModules:q,tryNative:!1,...A?{transform:A}:{}}).import(G,{})}function p(G,Q){if(!G)return!0;if(G.providerIds?.length){if(!Q?.providerId||!G.providerIds.includes(Q.providerId))return!1}if(G.modelIds?.length){if(!Q?.modelId||!G.modelIds.includes(Q.modelId))return!1}return!0}function z(G){return typeof G==="object"&&G!==null}function s(G){return Array.isArray(G)&&G.every((Q)=>typeof Q==="string")}function BG(G,Q){if(!z(G))throw Error(`Invalid plugin module: ${Q}`);if(typeof G.name!=="string"||!G.name)throw Error(`Invalid plugin name: ${Q}`);if(!z(G.manifest))throw Error(`Invalid plugin manifest: ${Q}`);if(Object.hasOwn(G.manifest,"providerIds")&&!s(G.manifest.providerIds))throw Error(`Invalid plugin manifest.providerIds: ${Q}`);if(Object.hasOwn(G.manifest,"modelIds")&&!s(G.manifest.modelIds))throw Error(`Invalid plugin manifest.modelIds: ${Q}`)}function DG(G){if(!z(G))throw Error("Plugin setup context must be an object");if(G.session!==void 0&&!z(G.session))throw Error("Plugin setup context session must be an object");if(G.client!==void 0&&!z(G.client))throw Error("Plugin setup context client must be an object");if(G.user!==void 0&&!z(G.user))throw Error("Plugin setup context user must be an object");if(G.workspaceInfo!==void 0&&!z(G.workspaceInfo))throw Error("Plugin setup context workspaceInfo must be an object");if(G.automation!==void 0&&!z(G.automation))throw Error("Plugin setup context automation must be an object");if(G.automation!==void 0&&typeof G.automation.ingestEvent!=="function")throw Error("Plugin setup context automation.ingestEvent must be a function");if(G.logger!==void 0&&!z(G.logger))throw Error("Plugin setup context logger must be an object")}var t=0,H=new Map,v=new Map;function HG(G){let Q=G instanceof Error?G.message:String(G),U=G instanceof Error?G.stack:void 0;return{message:Q,stack:U}}function k(G,Q,U,Y){if(!process.send)return;process.send({type:"response",id:G,ok:Q,result:U,error:Y})}function x(G,Q){if(!process.send)return;process.send({type:"event",name:G,payload:Q})}globalThis.__clinePluginHost={emitEvent:x};globalThis.__clineSessionEnv={cwd:void 0,workspaceInfo:void 0};function i(G){if(!G||typeof G!=="object")return{};return G}function NG(G){if(!G||typeof G!=="object")return;let Q={...G};if(Q.error instanceof Error)Q.error={name:Q.error.name,message:Q.error.message,stack:Q.error.stack};return Q}function EG(G){let Q=(U,Y,Z)=>{x("plugin_log",{level:U,pluginName:G,message:Y,metadata:NG(Z)})};return{debug:(U,Y)=>Q("debug",U,Y),log:(U,Y)=>Q("log",U,Y),error:(U,Y)=>Q("error",U,Y)}}function j(G,Q){let U=`${G}:${Q}`,Y=(v.get(U)??0)+1;return v.set(U,Y),`${G}_${Q}_${Y}`}function SG(G){let Q=typeof G.eventType==="string"?G.eventType.trim():"",U=typeof G.source==="string"?G.source.trim():"";if(!Q)throw Error("Automation event type contribution requires eventType");if(!U)throw Error("Automation event type contribution requires source");return{...G,eventType:Q,source:U,examples:G.examples?[...G.examples]:void 0,metadata:G.metadata?i(G.metadata):void 0}}function N(G){let Q=H.get(G);if(!Q)throw Error(`Unknown sandbox plugin id: ${G}`);return Q}async function VG(G){let Q;try{let U=await o(G.pluginPath);if(Q=U.default??U[G.exportName],BG(Q,G.pluginPath),Q.manifest=jG(Q.manifest),!p(Q.manifest,G.targeting))return{type:"skipped"};let Y={tools:[],commands:[],messageBuilders:[],providers:[],automationEventTypes:[],shortcuts:[],flags:[]},Z={tools:new Map,commands:new Map,messageBuilders:new Map},$={registerTool:(X)=>{let q=j(G.pluginId,"tool");Z.tools.set(q,X.execute),Y.tools.push({id:q,name:X.name,description:X.description,inputSchema:X.inputSchema,timeoutMs:X.timeoutMs,retryable:X.retryable})},registerCommand:(X)=>{let q=j(G.pluginId,"command");if(typeof X.handler==="function")Z.commands.set(q,X.handler);Y.commands.push({id:q,name:X.name,description:X.description})},registerMessageBuilder:(X)=>{let q=j(G.pluginId,"builder");Z.messageBuilders.set(q,X.build),Y.messageBuilders.push({id:q,name:X.name})},registerProvider:(X)=>{Y.providers.push({id:j(G.pluginId,"provider"),name:X.name,description:X.description,metadata:i(X.metadata)})},registerAutomationEventType:(X)=>{Y.automationEventTypes.push({id:j(G.pluginId,"automation_event"),...SG(X)})}};if(typeof Q.setup==="function")try{let X={...G.setupCtxBase,...G.loggerEnabled?{logger:EG(Q.name)}:{},...Q.manifest.capabilities.includes("automationEvents")?{automation:{ingestEvent:(q)=>{x("automation_event",q)}}}:{}};DG(X),await Q.setup($,X)}catch(X){return{type:"failure",failure:{pluginPath:G.pluginPath,pluginName:Q.name,phase:"setup",message:X instanceof Error?X.message:String(X),stack:X instanceof Error?X.stack:void 0}}}return{type:"loaded",state:{plugin:Q,handlers:Z},descriptor:{pluginId:G.pluginId,pluginPath:G.pluginPath,name:Q.name,manifest:Q.manifest,hooks:Q.hooks?Object.entries(Q.hooks).filter(([,X])=>typeof X==="function").map(([X])=>X):void 0,contributions:Y}}}catch(U){return{type:"failure",failure:{pluginPath:G.pluginPath,pluginName:Q?.name,phase:"load",message:U instanceof Error?U.message:String(U),stack:U instanceof Error?U.stack:void 0}}}}async function TG(G){if(H.clear(),t=0,v.clear(),G.cwd)try{process.chdir(G.cwd)}catch{}let Q=globalThis.__clineSessionEnv;if(Q)Q.cwd=G.cwd,Q.workspaceInfo=G.workspaceInfo;let U=[],Y=[],Z=[],$=G.exportName||"plugin",X=new Map,q={providerId:G.providerId,modelId:G.modelId},w={session:G.session,client:G.client,user:G.user,workspaceInfo:G.workspaceInfo},A=await Promise.all((G.pluginPaths||[]).map((L)=>{let W=`plugin_${++t}`;return VG({pluginPath:L,pluginId:W,exportName:$,targeting:q,setupCtxBase:w,loggerEnabled:G.loggerEnabled})}));for(let L of A){if(L.type==="skipped")continue;if(L.type==="failure"){Y.push(L.failure);continue}let{descriptor:W,state:r}=L,E=X.get(W.name);if(E!==void 0){let B=U[E];if(!B)X.delete(W.name);else{Z.push({type:"duplicate_plugin_override",pluginName:W.name,pluginPath:W.pluginPath,overriddenPluginPath:B.pluginPath,message:`Plugin "${W.name}" from ${W.pluginPath} overrides ${B.pluginPath}`}),H.delete(B.pluginId),U.splice(E,1),X.clear();for(let[a,e]of U.entries())X.set(e.name,a)}}H.set(W.pluginId,r),X.set(W.name,U.length),U.push(W)}return{plugins:U,failures:Y,warnings:Z}}async function bG(G){let U=N(G.pluginId).plugin.hooks?.[G.hookName];if(typeof U!=="function")return;return await U(G.payload)}async function yG(G){let U=N(G.pluginId).handlers.tools.get(G.contributionId);if(typeof U!=="function")throw Error("Unknown sandbox tool contribution");return await U(G.input,G.context)}async function RG(G){let U=N(G.pluginId).handlers.commands.get(G.contributionId);if(typeof U!=="function")return"";return await U(G.input)}async function kG(G){let U=N(G.pluginId).handlers.messageBuilders.get(G.contributionId);if(typeof U!=="function")return[];return await U(G.messages)}var vG={initialize:TG,invokeHook:bG,executeTool:yG,executeCommand:RG,buildMessages:kG};process.on("message",async(G)=>{if(!G||G.type!=="call")return;let Q=vG[G.method];if(!Q){k(G.id,!1,void 0,{message:`Unknown method: ${String(G.method)}`});return}try{let U=await Q(G.args||{});k(G.id,!0,U)}catch(U){k(G.id,!1,void 0,HG(U))}});