tjs-lang 0.5.4 → 0.6.0
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/CLAUDE.md +33 -13
- package/README.md +4 -4
- package/bin/dev.ts +5 -1
- package/demo/docs.json +14 -2
- package/demo/index.html +2 -2
- package/demo/src/capabilities.ts +109 -2
- package/demo/src/demo-nav.ts +137 -203
- package/demo/src/imports.ts +43 -9
- package/demo/src/index.ts +179 -29
- package/demo/src/playground-shared.ts +11 -4
- package/demo/src/playground.ts +2 -2
- package/demo/src/tjs-playground.ts +294 -11
- package/demo/src/ts-playground.ts +239 -0
- package/dist/index.js +135 -127
- package/dist/index.js.map +6 -5
- package/dist/src/cli/commands/emit.d.ts +3 -0
- package/dist/src/lang/emitters/dts.d.ts +48 -0
- package/dist/src/lang/emitters/from-ts.d.ts +2 -0
- package/dist/src/lang/index.d.ts +1 -0
- package/dist/tjs-batteries.js +3 -3
- package/dist/tjs-batteries.js.map +2 -2
- package/dist/tjs-full.js +135 -127
- package/dist/tjs-full.js.map +6 -5
- package/dist/tjs-transpiler.js +2 -349
- package/dist/tjs-transpiler.js.map +4 -19
- package/package.json +1 -1
- package/src/cli/commands/emit.ts +26 -0
- package/src/cli/tjs.ts +4 -1
- package/src/lang/codegen.test.ts +55 -0
- package/src/lang/emitters/dts.test.ts +406 -0
- package/src/lang/emitters/dts.ts +588 -0
- package/src/lang/emitters/from-ts.ts +244 -20
- package/src/lang/index.ts +5 -0
- package/src/lang/typescript-syntax.test.ts +358 -0
package/dist/index.js
CHANGED
|
@@ -1,63 +1,63 @@
|
|
|
1
|
-
var
|
|
2
|
-
`),$=this.line-1,
|
|
3
|
-
`)}}class
|
|
4
|
-
`)Y="normal";
|
|
5
|
-
`){
|
|
6
|
-
`),H=[];for(let Y=0;Y<
|
|
7
|
-
`)}function
|
|
8
|
-
`)
|
|
9
|
-
`,Y);if(
|
|
10
|
-
`||Z[
|
|
11
|
-
`),I;if(
|
|
12
|
-
${
|
|
1
|
+
var B8=Object.defineProperty;var R8=(Z,X)=>()=>(X||Z((X={exports:{}}).exports,X),X.exports);var M8=(Z)=>Z;function w8(Z,X){this[Z]=M8.bind(null,X)}var F8=(Z,X)=>{for(var $ in X)B8(Z,$,{get:X[$],enumerable:!0,configurable:!0,set:w8.bind(X,$)})};var j8=(Z,X)=>()=>(Z&&(X=Z(Z=0)),X);var j4=((Z)=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(Z,{get:(X,$)=>(typeof require<"u"?require:X)[$]}):Z)(function(Z){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+Z+'" is not supported')});var z7=R8(($K,aZ)=>{aZ.exports={name:"tjs-lang",version:"0.6.0",description:"Type-safe JavaScript dialect with runtime validation, sandboxed VM execution, and AI agent orchestration. Transpiles TypeScript to validated JS with fuel-metered execution for untrusted code.",keywords:["typescript","transpiler","runtime-validation","type-safety","sandbox","virtual-machine","wasm-alternative","ai-agents","llm","orchestration","security","fuel-metering","capability-based","json-ast","untrusted-code"],license:"Apache-2.0",main:"./dist/index.js",exports:{".":{bun:"./src/index.ts",default:"./dist/index.js"},"./eval":{bun:"./src/lang/eval.ts",default:"./dist/lang/eval.js"},"./lang":{bun:"./src/lang/index.ts",default:"./dist/lang/index.js"},"./lang/eval":{bun:"./src/lang/eval.ts",default:"./dist/lang/eval.js"},"./lang/from-ts":{bun:"./src/lang/emitters/from-ts.ts",default:"./dist/lang/emitters/from-ts.js"},"./src":"./src/index.ts","./editors/monaco":"./editors/monaco/ajs-monarch.js","./editors/codemirror":"./editors/codemirror/ajs-language.js","./editors/ace":"./editors/ace/ajs-mode.js"},bin:{tjs:"./src/cli/tjs.ts",tjsx:"./src/cli/tjsx.ts","tjs-playground":"./src/cli/playground.ts","create-tjs-app":"./src/cli/create-app.ts","ajs-install-vscode":"./bin/install-vscode.sh","ajs-install-cursor":"./bin/install-cursor.sh"},type:"module",files:["dist","src","docs","editors","bin","demo","tjs-lang.svg","CONTEXT.md","CLAUDE.md"],sideEffects:!1,repository:{type:"git",url:"https://github.com/tonioloewald/tjs-lang.git"},devDependencies:{"@codemirror/lang-javascript":"^6.2.4","@codemirror/state":"^6.5.3","@codemirror/view":"^6.39.9","@happy-dom/global-registrator":"^20.1.0","@types/bun":"latest","@types/jsdom":"^21.1.7","@typescript-eslint/eslint-plugin":"^5.62.0","@typescript-eslint/parser":"^5.62.0","acorn-walk":"^8.3.4",chokidar:"^4.0.3",codemirror:"^6.0.2",eslint:"^8.57.1","firebase-admin":"^13.6.0","firebase-functions":"^7.0.5",marked:"^9.1.6",prettier:"^2.8.8",tosijs:"^1.2.0","tosijs-ui":"^1.2.0",typescript:"^5.6.2",valibot:"^0.36.0",vitest:"^2.0.5"},scripts:{format:"bun eslint src --fix && bun prettier --write .",lint:"eslint src","build:grammars":"bun editors/build-grammars.ts","test:fast":"SKIP_LLM_TESTS=1 SKIP_BENCHMARKS=1 bun test","test:llm":"bun test src/batteries/models.integration.test.ts",bench:"bun bin/benchmarks.ts",make:"rm -rf dist && bun format && bun run build:grammars && tsc -p tsconfig.build.json && bun scripts/build.ts","build:bundles":"bun scripts/build.ts",typecheck:"tsc --noEmit",latest:"rm -rf node_modules && bun install",docs:"node bin/docs.js",dev:"bun run bin/dev.ts","build:demo":"bun scripts/build-demo.ts","build:cli":"bun build src/cli/tjs.ts --compile --outfile=dist/tjs && bun build src/cli/tjsx.ts --compile --outfile=dist/tjsx","functions:build":"cd functions && npm run build","functions:deploy":"cd functions && npm run deploy","functions:serve":"cd functions && npm run serve","deploy:hosting":"firebase deploy --only hosting",deploy:"npm run build:demo && npm run functions:deploy && firebase deploy --only hosting",start:"bun run build:demo && bun run dev"},dependencies:{"@codemirror/lang-css":"^6.3.1","@codemirror/lang-html":"^6.4.11","@codemirror/lang-markdown":"^6.5.0","@codemirror/theme-one-dark":"^6.1.3",acorn:"^8.15.0",firebase:"^10.12.0","tosijs-schema":"^1.2.0"}}});var Y6={};F8(Y6,{sep:()=>Z8,resolve:()=>I4,relative:()=>c7,posix:()=>X8,parse:()=>e7,normalize:()=>H6,join:()=>n7,isAbsolute:()=>p7,format:()=>t7,extname:()=>r7,dirname:()=>s7,delimiter:()=>$8,default:()=>t$,basename:()=>a7,_makeLong:()=>o7});function R1(Z){if(typeof Z!=="string")throw TypeError("Path must be a string. Received "+JSON.stringify(Z))}function i7(Z,X){var $="",Q=0,K=-1,H=0,Y;for(var z=0;z<=Z.length;++z){if(z<Z.length)Y=Z.charCodeAt(z);else if(Y===47)break;else Y=47;if(Y===47){if(K===z-1||H===1);else if(K!==z-1&&H===2){if($.length<2||Q!==2||$.charCodeAt($.length-1)!==46||$.charCodeAt($.length-2)!==46){if($.length>2){var W=$.lastIndexOf("/");if(W!==$.length-1){if(W===-1)$="",Q=0;else $=$.slice(0,W),Q=$.length-1-$.lastIndexOf("/");K=z,H=0;continue}}else if($.length===2||$.length===1){$="",Q=0,K=z,H=0;continue}}if(X){if($.length>0)$+="/..";else $="..";Q=2}}else{if($.length>0)$+="/"+Z.slice(K+1,z);else $=Z.slice(K+1,z);Q=z-K-1}K=z,H=0}else if(Y===46&&H!==-1)++H;else H=-1}return $}function r$(Z,X){var $=X.dir||X.root,Q=X.base||(X.name||"")+(X.ext||"");if(!$)return Q;if($===X.root)return $+Q;return $+Z+Q}function I4(){var Z="",X=!1,$;for(var Q=arguments.length-1;Q>=-1&&!X;Q--){var K;if(Q>=0)K=arguments[Q];else{if($===void 0)$=process.cwd();K=$}if(R1(K),K.length===0)continue;Z=K+"/"+Z,X=K.charCodeAt(0)===47}if(Z=i7(Z,!X),X)if(Z.length>0)return"/"+Z;else return"/";else if(Z.length>0)return Z;else return"."}function H6(Z){if(R1(Z),Z.length===0)return".";var X=Z.charCodeAt(0)===47,$=Z.charCodeAt(Z.length-1)===47;if(Z=i7(Z,!X),Z.length===0&&!X)Z=".";if(Z.length>0&&$)Z+="/";if(X)return"/"+Z;return Z}function p7(Z){return R1(Z),Z.length>0&&Z.charCodeAt(0)===47}function n7(){if(arguments.length===0)return".";var Z;for(var X=0;X<arguments.length;++X){var $=arguments[X];if(R1($),$.length>0)if(Z===void 0)Z=$;else Z+="/"+$}if(Z===void 0)return".";return H6(Z)}function c7(Z,X){if(R1(Z),R1(X),Z===X)return"";if(Z=I4(Z),X=I4(X),Z===X)return"";var $=1;for(;$<Z.length;++$)if(Z.charCodeAt($)!==47)break;var Q=Z.length,K=Q-$,H=1;for(;H<X.length;++H)if(X.charCodeAt(H)!==47)break;var Y=X.length,z=Y-H,W=K<z?K:z,G=-1,J=0;for(;J<=W;++J){if(J===W){if(z>W){if(X.charCodeAt(H+J)===47)return X.slice(H+J+1);else if(J===0)return X.slice(H+J)}else if(K>W){if(Z.charCodeAt($+J)===47)G=J;else if(J===0)G=0}break}var L=Z.charCodeAt($+J),_=X.charCodeAt(H+J);if(L!==_)break;else if(L===47)G=J}var U="";for(J=$+G+1;J<=Q;++J)if(J===Q||Z.charCodeAt(J)===47)if(U.length===0)U+="..";else U+="/..";if(U.length>0)return U+X.slice(H+G);else{if(H+=G,X.charCodeAt(H)===47)++H;return X.slice(H)}}function o7(Z){return Z}function s7(Z){if(R1(Z),Z.length===0)return".";var X=Z.charCodeAt(0),$=X===47,Q=-1,K=!0;for(var H=Z.length-1;H>=1;--H)if(X=Z.charCodeAt(H),X===47){if(!K){Q=H;break}}else K=!1;if(Q===-1)return $?"/":".";if($&&Q===1)return"//";return Z.slice(0,Q)}function a7(Z,X){if(X!==void 0&&typeof X!=="string")throw TypeError('"ext" argument must be a string');R1(Z);var $=0,Q=-1,K=!0,H;if(X!==void 0&&X.length>0&&X.length<=Z.length){if(X.length===Z.length&&X===Z)return"";var Y=X.length-1,z=-1;for(H=Z.length-1;H>=0;--H){var W=Z.charCodeAt(H);if(W===47){if(!K){$=H+1;break}}else{if(z===-1)K=!1,z=H+1;if(Y>=0)if(W===X.charCodeAt(Y)){if(--Y===-1)Q=H}else Y=-1,Q=z}}if($===Q)Q=z;else if(Q===-1)Q=Z.length;return Z.slice($,Q)}else{for(H=Z.length-1;H>=0;--H)if(Z.charCodeAt(H)===47){if(!K){$=H+1;break}}else if(Q===-1)K=!1,Q=H+1;if(Q===-1)return"";return Z.slice($,Q)}}function r7(Z){R1(Z);var X=-1,$=0,Q=-1,K=!0,H=0;for(var Y=Z.length-1;Y>=0;--Y){var z=Z.charCodeAt(Y);if(z===47){if(!K){$=Y+1;break}continue}if(Q===-1)K=!1,Q=Y+1;if(z===46){if(X===-1)X=Y;else if(H!==1)H=1}else if(X!==-1)H=-1}if(X===-1||Q===-1||H===0||H===1&&X===Q-1&&X===$+1)return"";return Z.slice(X,Q)}function t7(Z){if(Z===null||typeof Z!=="object")throw TypeError('The "pathObject" argument must be of type Object. Received type '+typeof Z);return r$("/",Z)}function e7(Z){R1(Z);var X={root:"",dir:"",base:"",ext:"",name:""};if(Z.length===0)return X;var $=Z.charCodeAt(0),Q=$===47,K;if(Q)X.root="/",K=1;else K=0;var H=-1,Y=0,z=-1,W=!0,G=Z.length-1,J=0;for(;G>=K;--G){if($=Z.charCodeAt(G),$===47){if(!W){Y=G+1;break}continue}if(z===-1)W=!1,z=G+1;if($===46){if(H===-1)H=G;else if(J!==1)J=1}else if(H!==-1)J=-1}if(H===-1||z===-1||J===0||J===1&&H===z-1&&H===Y+1){if(z!==-1)if(Y===0&&Q)X.base=X.name=Z.slice(1,z);else X.base=X.name=Z.slice(Y,z)}else{if(Y===0&&Q)X.name=Z.slice(1,H),X.base=Z.slice(1,z);else X.name=Z.slice(Y,H),X.base=Z.slice(Y,z);X.ext=Z.slice(H,z)}if(Y>0)X.dir=Z.slice(0,Y-1);else if(Q)X.dir="/";return X}var Z8="/",$8=":",X8,t$;var z6=j8(()=>{X8=((Z)=>(Z.posix=Z,Z))({resolve:I4,normalize:H6,isAbsolute:p7,join:n7,relative:c7,_makeLong:o7,dirname:s7,basename:a7,extname:r7,format:t7,parse:e7,sep:Z8,delimiter:$8,win32:null,posix:null}),t$=X8});import*as l6 from"acorn";class u extends Error{line;column;source;filename;constructor(Z,X,$,Q){let K=`${Q||"<source>"}:${X.line}:${X.column}`;super(`${Z} at ${K}`);this.name="TranspileError",this.line=X.line,this.column=X.column,this.source=$,this.filename=Q}}class Q1 extends u{constructor(Z,X,$,Q){super(Z,X,$,Q);this.name="SyntaxError"}formatWithContext(Z=2){if(!this.source)return this.message;let X=this.source.split(`
|
|
2
|
+
`),$=this.line-1,Q=Math.max(0,$-Z),K=Math.min(X.length-1,$+Z),H=[],Y=String(K+1).length;for(let z=Q;z<=K;z++){let W=String(z+1).padStart(Y),G=z===$?">":" ";if(H.push(`${G} ${W} | ${X[z]}`),z===$){let J=" ".repeat(Y+4+this.column);H.push(`${J}^ ${this.message.split(" at ")[0]}`)}}return H.join(`
|
|
3
|
+
`)}}class P8 extends u{expected;received;suggestion;constructor(Z,X,$){super(Z,X,$?.source,$?.filename);this.name="TypeError",this.expected=$?.expected,this.received=$?.received,this.suggestion=$?.suggestion}}function W1(Z){return{depth:Z.depth+1,locals:new Map,parent:Z,parameters:Z.parameters,atoms:Z.atoms,warnings:Z.warnings,source:Z.source,filename:Z.filename,options:Z.options}}function V8(Z,X){if(X.locals.has(Z))return X.locals.get(Z);if(X.parameters.has(Z))return X.parameters.get(Z)?.type;if(X.parent)return V8(Z,X.parent);return}function m(Z){if(Z.loc)return{line:Z.loc.start.line,column:Z.loc.start.column};return{line:1,column:0}}function C0(Z,X){let $="",Q=0,K,H,Y="normal",z=[],W=[{type:"top-level",braceDepth:0}],G=0,J=()=>W[W.length-1]?.type||"top-level",L=()=>{let _=W[W.length-1];return _?.type==="class-body"&&G===_.braceDepth+1};while(Q<Z.length){let _=Z[Q],U=Z[Q+1];switch(Y){case"single-string":if($+=_,_==="\\"&&Q+1<Z.length){$+=U,Q+=2;continue}if(_==="'")Y="normal";Q++;continue;case"double-string":if($+=_,_==="\\"&&Q+1<Z.length){$+=U,Q+=2;continue}if(_==='"')Y="normal";Q++;continue;case"template-string":if($+=_,_==="\\"&&Q+1<Z.length){$+=U,Q+=2;continue}if(_==="$"&&U==="{"){$+=U,Q+=2,z.push(1),Y="normal";continue}if(_==="`")Y="normal";Q++;continue;case"line-comment":if($+=_,_===`
|
|
4
|
+
`)Y="normal";Q++;continue;case"block-comment":if($+=_,_==="*"&&U==="/"){$+=U,Q+=2,Y="normal";continue}Q++;continue;case"regex":if($+=_,_==="\\"&&Q+1<Z.length){$+=U,Q+=2;continue}if(_==="["){Q++;while(Q<Z.length&&Z[Q]!=="]")if($+=Z[Q],Z[Q]==="\\"&&Q+1<Z.length)$+=Z[Q+1],Q+=2;else Q++;if(Q<Z.length)$+=Z[Q],Q++;continue}if(_==="/"){Q++;while(Q<Z.length&&/[gimsuy]/.test(Z[Q]))$+=Z[Q],Q++;Y="normal";continue}Q++;continue;case"normal":if(z.length>0){if(_==="{")z[z.length-1]++;else if(_==="}"){if(z[z.length-1]--,z[z.length-1]===0){z.pop(),$+=_,Q++,Y="template-string";continue}}}if(_==="'"){$+=_,Q++,Y="single-string";continue}if(_==='"'){$+=_,Q++,Y="double-string";continue}if(_==="`"){$+=_,Q++,Y="template-string";continue}if(_==="/"&&U==="/"){$+=_+U,Q+=2,Y="line-comment";continue}if(_==="/"&&U==="*"){$+=_+U,Q+=2,Y="block-comment";continue}if(_==="/"){let I=$.trimEnd();if(!I[I.length-1]||/[=(!,;:{[&|?+\-*%<>~^]$/.test(I)||/\b(return|case|throw|in|of|typeof|instanceof|new|delete|void)\s*$/.test(I)){$+=_,Q++,Y="regex";continue}}break}if(_==="{"){G++,$+=_,Q++;continue}if(_==="}"){G--;let I=W[W.length-1];if(I&&G===I.braceDepth)W.pop();$+=_,Q++;continue}let D=Z.slice(Q).match(/^class\s+\w+(?:\s+extends\s+\w+)?\s*\{/);if(D){let I=D[0].slice(0,-1);$+=I,Q+=I.length,W.push({type:"class-body",braceDepth:G});continue}let R=Z.slice(Q).match(/^function\s+(\w+)\s*\(/);if(R){let I=R[1],V=R[0].length,F=Z[Q+V],j=null,B=Q+V;if(F==="?"||F==="!")if(j=F,B++,j==="!")X.unsafeFunctions.add(I);else X.safeFunctions.add(I);$+=`function ${I}(`,Q=B;let P=j0(Z,Q,"(",")");if(!P){$+=Z[Q],Q++;continue}let{content:C,endPos:O}=P;Q=O;let T=P4(C,X,!0);$+=T+")";let k=Q;while(k<Z.length&&/\s/.test(Z[k]))k++;let g=Z.slice(k,k+2);if(g==="->"||g==="-?"||g==="-!"){k+=2;while(k<Z.length&&/\s/.test(Z[k]))k++;let l=F0(Z,k);if(l){let{type:a,endPos:v}=l;if(K===void 0){if(K=a,g==="-?")H="safe";else if(g==="-!")H="unsafe"}Q=v}}continue}let M=Z.slice(Q).match(/^(constructor|(?:get|set)\s+\w+|async\s+\w+|\w+)\s*\(/);if(M&&L()){let I=M[1],V=M[0].length,F=Q+V;$+=I+"(",Q=F;let j=j0(Z,Q,"(",")");if(!j){$+=Z[Q],Q++;continue}let{content:B,endPos:P}=j;Q=P;let C=P4(B,X,!0);$+=C+")";let O=Q;while(O<Z.length&&/\s/.test(Z[O]))O++;if(Z.slice(O,O+2)==="->"){O+=2;while(O<Z.length&&/\s/.test(Z[O]))O++;let k=F0(Z,O);if(k)Q=k.endPos}else if(Z[O]===":"){O++;while(O<Z.length&&/\s/.test(Z[O]))O++;let k=F0(Z,O);if(k)Q=k.endPos}continue}if(Z[Q]==="("){let I=j0(Z,Q+1,"(",")");if(!I){$+=Z[Q],Q++;continue}let{content:V,endPos:F}=I,j=F;while(j<Z.length&&/\s/.test(Z[j]))j++;let B,P=Z.slice(j,j+2);if(P==="->"||P==="-?"||P==="-!"){j+=2;while(j<Z.length&&/\s/.test(Z[j]))j++;let C=F0(Z,j);if(C){B=C.type,j=C.endPos;while(j<Z.length&&/\s/.test(Z[j]))j++}}if(Z.slice(j,j+2)==="=>"){let C=null,O=V,T=V.trimStart();if(T.startsWith("?")&&(T.length===1||/\s/.test(T[1])))C="?",O=T.slice(1);else if(T.startsWith("!")&&(T.length===1||/\s/.test(T[1])))C="!",O=T.slice(1);let k=P4(O,X,!1);$+=`(${C==="?"?"/* safe */ ":C==="!"?"/* unsafe */ ":""}${k})`,Q=F;while(Q<j&&/\s/.test(Z[Q]))$+=Z[Q],Q++;if(B)Q=j}else{let C=C0(V,X);$+=`(${C.source})`,Q=F}continue}$+=Z[Q],Q++}return{source:$,returnType:K,returnSafety:H}}function j0(Z,X,$,Q){let K=1,H=X,Y=!1,z="";while(H<Z.length&&K>0){let W=Z[H];if(!Y&&(W==="'"||W==='"'||W==="`"))Y=!0,z=W;else if(Y&&W===z&&Z[H-1]!=="\\")Y=!1;else if(!Y){if(W===$)K++;else if(W===Q)K--}H++}if(K!==0)return null;return{content:Z.slice(X,H-1),endPos:H}}function M6(Z,X){let $=X;while($<Z.length&&/\s/.test(Z[$]))$++;if($>=Z.length)return null;let Q=$,K=Z[$];if(K==="{"||K==="["){let Y=K==="{"?"}":"]",z=j0(Z,$+1,K,Y);if(!z)return null;return{value:Z.slice(Q,z.endPos),endPos:z.endPos}}if(K==="'"||K==='"'||K==="`"){$++;while($<Z.length){if(Z[$]===K&&Z[$-1]!=="\\")return $++,{value:Z.slice(Q,$),endPos:$};$++}return null}if(/[-+\d]/.test(K)){while($<Z.length&&/[\d.eE+-]/.test(Z[$]))$++;return{value:Z.slice(Q,$),endPos:$}}let H=Z.slice($).match(/^(true|false|null|undefined)\b/);if(H)return{value:H[1],endPos:$+H[1].length};return null}function t1(Z){return Z.replace(/(?<!\|)\|(?!\|)/g," || ")}function F0(Z,X){let $=X,Q=0,K=!1,H="",Y=!1,z=(W)=>({type:t1(Z.slice(X,W).trim()),endPos:W});while($<Z.length){let W=Z[$];if(!K&&(W==="'"||W==='"'||W==="`")){K=!0,H=W,Y=!0,$++;continue}if(K){if(W===H&&Z[$-1]!=="\\"){if(K=!1,$++,Q===0){let G=$;while(G<Z.length&&/\s/.test(Z[G]))G++;if(Z[G]==="{"){if(!Z.slice(G+1).match(/^\s*(\w+)\s*:/))return z($)}if(Z[G]!=="|"&&Z[G]!=="&")return z($)}continue}$++;continue}if(W==="{"||W==="["||W==="("){Q++,Y=!0,$++;continue}if(W==="}"||W==="]"||W===")"){if(Q--,Q===0){$++;let G=$;while(G<Z.length&&/\s/.test(Z[G]))G++;if(Z[G]==="|"||Z[G]==="&")continue;return z($)}$++;continue}if(Q===0&&W==="{"){if(Y)return z($);if(Z.slice($+1).match(/^\s*(\w+)\s*:/)){Q++,Y=!0,$++;continue}return z($)}if(Q===0&&(W==="|"||W==="&")){if($++,$<Z.length&&Z[$]==="|")$++;while($<Z.length&&/\s/.test(Z[$]))$++;continue}if(Q===0&&(/\d/.test(W)||W==="-"&&/\d/.test(Z[$+1]))){let G=$;if(Z[G]==="-")G++;while(G<Z.length&&/\d/.test(Z[G]))G++;if(G<Z.length&&Z[G]==="."&&/\d/.test(Z[G+1])){G++;while(G<Z.length&&/\d/.test(Z[G]))G++}if(G<Z.length&&(Z[G]==="e"||Z[G]==="E")){if(G++,G<Z.length&&(Z[G]==="+"||Z[G]==="-"))G++;while(G<Z.length&&/\d/.test(Z[G]))G++}Y=!0,$=G;while($<Z.length&&/\s/.test(Z[$]))$++;if($<Z.length&&Z[$]==="{")return{type:t1(Z.slice(X,G).trim()),endPos:G};if(Z[$]!=="|"&&Z[$]!=="&")return{type:t1(Z.slice(X,G).trim()),endPos:G};continue}if(Q===0&&/[a-zA-Z_]/.test(W)){let G=$;while(G<Z.length&&/\w/.test(Z[G]))G++;Y=!0,$=G;while($<Z.length&&/\s/.test(Z[$]))$++;if($<Z.length&&Z[$]==="{"){if(!Z.slice($+1).match(/^\s*(\w+)\s*:/)){let L=G;while(L>X&&/\s/.test(Z[L-1]))L--;return{type:t1(Z.slice(X,L).trim()),endPos:G}}}if(Z[$]!=="|"&&Z[$]!=="&")return{type:t1(Z.slice(X,G).trim()),endPos:G};continue}$++}if(Y)return z($);return null}function O0(Z){let X=[],$="",Q=0,K=!1,H=!1,Y=0;while(Y<Z.length){let z=Z[Y],W=Z[Y+1];if(!H&&z==="/"&&W==="/"){K=!0,$+="//",Y+=2;continue}if(!K&&z==="/"&&W==="*"){H=!0,$+="/*",Y+=2;continue}if(K&&z===`
|
|
5
|
+
`){K=!1,$+=z,Y++;continue}if(H&&z==="*"&&W==="/"){H=!1,$+="*/",Y+=2;continue}if(K||H){$+=z,Y++;continue}if(z==="("||z==="{"||z==="[")Q++,$+=z;else if(z===")"||z==="}"||z==="]")Q--,$+=z;else if(z===","&&Q===0)X.push($),$="";else $+=z;Y++}if($.trim())X.push($);return X}function P4(Z,X,$){let Q=C0(Z,{originalSource:Z,requiredParams:X.requiredParams,unsafeFunctions:X.unsafeFunctions,safeFunctions:X.safeFunctions}).source,K=O0(Q),H=!1,Y=new Set,z=(G)=>{if($&&/^\w+$/.test(G)){if(Y.has(G))throw Error(`Duplicate parameter name '${G}'`);Y.add(G)}};return K.map((G)=>{let J=G.trim();if(!J)return G;if($&&J.startsWith("{")&&J.endsWith("}")){let U=J.slice(1,-1);return`{ ${R6(U,X)} }`}if($&&J.startsWith("[")&&J.endsWith("]")){let U=J.slice(1,-1);return`[ ${R6(U,X)} ]`}let L=J.match(/^(\w+)\s*\?\s*:\s*(.+)$/);if(L){let[,U,D]=L;return z(U),H=!0,`${U} = ${D}`}if(!C8(J)){let U=J.match(/^(\w+)\s*=/);if(U)z(U[1]);return H=!0,G}let _=O8(J);if(_!==-1){let U=J.slice(0,_).trim(),D=J.slice(_+1).trim();if(z(U),H&&$&&/^\w+$/.test(U))throw Error(`Required parameter '${U}' cannot follow optional parameter`);if($&&/^\w+$/.test(U))X.requiredParams.add(U);return`${U} = ${D}`}return G}).join(",")}function R6(Z,X){return O0(Z).map((K)=>{let H=K.trim();if(!H)return K;let Y=H.match(/^(\w+)\s*:\s*(\{[\s\S]*\})$/);if(Y){let[,G,J]=Y;X.requiredParams.add(G);let L=P0(J);return`${G} = ${L}`}let z=H.match(/^(\w+)\s*:\s*(\[[\s\S]*\])$/);if(z){let[,G,J]=z;X.requiredParams.add(G);let L=V0(J);return`${G} = ${L}`}let W=H.match(/^(\w+)\s*:\s*([\s\S]+)$/);if(W){let[,G,J]=W;return X.requiredParams.add(G),`${G} = ${J}`}return K}).join(", ")}function P0(Z){let X=Z.slice(1,-1).trim();return`{ ${O0(X).map((K)=>{let H=K.trim();if(!H)return K;let Y=H.match(/^(\w+)\s*:\s*(\{[\s\S]*\})$/);if(Y){let[,L,_]=Y;return`${L}: ${P0(_)}`}let z=H.match(/^(\w+)\s*=\s*(\{[\s\S]*\})$/);if(z){let[,L,_]=z;return`${L}: ${P0(_)}`}let W=H.match(/^(\w+)\s*:\s*(\[[\s\S]*\])$/);if(W){let[,L,_]=W;return`${L}: ${V0(_)}`}let G=H.match(/^(\w+)\s*=\s*(\[[\s\S]*\])$/);if(G){let[,L,_]=G;return`${L}: ${V0(_)}`}let J=H.match(/^(\w+)\s*=\s*([\s\S]+)$/);if(J){let[,L,_]=J;return`${L}: ${_}`}return K}).join(", ")} }`}function V0(Z){let X=Z.slice(1,-1).trim();return`[ ${O0(X).map((K)=>{let H=K.trim();if(!H)return K;if(H.startsWith("{")&&H.endsWith("}"))return P0(H);if(H.startsWith("[")&&H.endsWith("]"))return V0(H);return K}).join(", ")} ]`}function C8(Z){let X=0,$=!1,Q=!1,K=!1,H="";for(let Y=0;Y<Z.length;Y++){let z=Z[Y];if(!K&&(z==="'"||z==='"'||z==="`")){K=!0,H=z;continue}if(K){if(z===H&&Z[Y-1]!=="\\")K=!1;continue}if(z==="("||z==="{"||z==="[")X++;else if(z===")"||z==="}"||z==="]")X--;else if(X===0){if(z===":")$=!0;if(z==="="&&Z[Y+1]!==">")Q=!0}}return $&&!Q}function O8(Z){let X=0,$=!1,Q="";for(let K=0;K<Z.length;K++){let H=Z[K];if(!$&&(H==="'"||H==='"'||H==="`")){$=!0,Q=H;continue}if($){if(H===Q&&Z[K-1]!=="\\")$=!1;continue}if(H==="("||H==="{"||H==="[")X++;else if(H===")"||H==="}"||H==="]")X--;else if(X===0&&H===":")return K}return-1}function P6(Z){let X="",$=0;while($<Z.length){let Q=Z.slice($).match(/^\btry\s*\{/);if(Q){let H=$+Q[0].length-1+1,Y=1,z=H;while(z<Z.length&&Y>0){let G=Z[z];if(G==="{")Y++;else if(G==="}")Y--;z++}if(Y!==0){X+=Z[$],$++;continue}if(Z.slice(z).match(/^\s*(catch|finally)\b/))X+=Z.slice($,z),$=z;else{let G=Z.slice(H,z-1);X+=`try {${G}} catch (__try_err) { return new (__tjs?.MonadicError ?? Error)(__try_err?.message || String(__try_err), 'try', undefined, undefined, __tjs?.getStack?.()) }`,$=z}}else X+=Z[$],$++}return X}function V6(Z){let X=[],$="",Q=0,K=0;while(Q<Z.length){let H=Z.slice(Q).match(/^\bwasm\s*\{/);if(H){let Y=Q,z=Q+H[0].length,W=1,G=z;while(G<Z.length&&W>0){let P=Z[G];if(P==="{")W++;else if(P==="}")W--;G++}if(W!==0){$+=Z[Q],Q++;continue}let J=Z.slice(z,G-1),L,_=G,U=Z.slice(G).match(/^\s*fallback\s*\{/);if(U){let P=G+U[0].length;W=1;let C=P;while(C<Z.length&&W>0){let O=Z[C];if(O==="{")W++;else if(O==="}")W--;C++}if(W===0)L=Z.slice(P,C-1),_=C}let R=E8(J).map((P)=>{let C=T8(Z,Y,P);return C?`${P}: ${C}`:P}),M={id:`__tjs_wasm_${K}`,body:J,fallback:L,captures:R,start:Y,end:_};X.push(M);let I=L??J,V=R.map((P)=>P.split(":")[0].trim()),F=V.length>0?V.join(", "):"",j=V.length>0?`globalThis.${M.id}(${F})`:`globalThis.${M.id}()`,B=`(globalThis.${M.id} ? ${j} : (() => {${I}})())`;$+=B,Q=_,K++}else $+=Z[Q],Q++}return{source:$,blocks:X}}function N8(Z){return Z.startsWith("f32x4_")||Z.startsWith("v128_")}function E8(Z){let X=Z.replace(/\/\/[^\n]*/g,"").replace(/\/\*[\s\S]*?\*\//g,""),$=new Set,Q=/\.([a-zA-Z_$][a-zA-Z0-9_$]*)\b/g,K;while((K=Q.exec(X))!==null)$.add(K[1]);let H=/(?<!\.)(\b[a-zA-Z_$][a-zA-Z0-9_$]*)\b/g,Y=new Set;while((K=H.exec(X))!==null)Y.add(K[1]);for(let _ of $){if(!Y.has(_))continue;let U=new RegExp(`(?<!\\.)\\b${_}\\b`,"g"),D=new RegExp(`\\.${_}\\b`,"g"),R=X.match(U)?.length||0,M=X.match(D)?.length||0;if(R<=M)Y.delete(_)}let z=new Set,W=/\b(?:let|const|var)\s+([a-zA-Z_$][a-zA-Z0-9_$]*)/g;while((K=W.exec(X))!==null)z.add(K[1]);let G=/\bfor\s*\(\s*(?:let|const|var)\s+([a-zA-Z_$][a-zA-Z0-9_$]*)/g;while((K=G.exec(X))!==null)z.add(K[1]);let J=new Set(["if","else","for","while","do","switch","case","break","continue","return","function","let","const","var","new","this","true","false","null","undefined","typeof","instanceof","in","of","try","catch","finally","throw","async","await","class","extends","super","import","export","default","from","as","static","get","set","yield","console","Math","Array","Object","String","Number","Boolean","Date","JSON","Promise","Map","Set","WeakMap","WeakSet","Float32Array","Float64Array","Int8Array","Int16Array","Int32Array","Uint8Array","Uint16Array","Uint32Array","BigInt64Array","BigUint64Array","ArrayBuffer","DataView","Error","TypeError","RangeError","length","push","pop","shift","unshift","slice","splice","map","filter","reduce","forEach","find","findIndex","indexOf","includes","globalThis","window","document","Infinity","NaN","isNaN","isFinite","parseInt","parseFloat","encodeURI","decodeURI","eval","wasmBuffer"]),L=[];for(let _ of Y)if(!z.has(_)&&!J.has(_)&&!N8(_))L.push(_);return L.sort()}function T8(Z,X,$){let Q=Z.slice(0,X),K=/function\s+\w+\s*\(([^)]*)\)\s*(?:->.*?)?\s*\{[^}]*$/,H=Q.match(K);if(!H){let Y=/(?:const|let|var)?\s*\w+\s*=\s*(?:async\s*)?\(([^)]*)\)\s*(?:=>|->)?\s*\{[^}]*$/,z=Q.match(Y);if(!z)return;return w6(z[1],$)}return w6(H[1],$)}function w6(Z,X){let $=Z.split(",").map((Q)=>Q.trim());for(let Q of $){let K=Q.match(new RegExp(`^${X}\\s*:\\s*([A-Za-z][A-Za-z0-9]*)`));if(K)return K[1];let H=Q.match(new RegExp(`^${X}\\s*=\\s*(Float32Array|Float64Array|Int32Array|Uint8Array|Int8Array|Int16Array|Uint16Array|Uint32Array)`));if(H)return H[1]}return}function C6(Z){let $=new RegExp(`([\\w][\\w.\\[\\]()]*|null|undefined|true|false|\\d+(?:\\.\\d+)?|'[^']*'|"[^"]*")\\s+IsNot\\s+([\\w][\\w.\\[\\]()]*|null|undefined|true|false|\\d+(?:\\.\\d+)?|'[^']*'|"[^"]*")`,"g");Z=Z.replace($,"IsNot($1, $2)");let Q=new RegExp(`([\\w][\\w.\\[\\]()]*|null|undefined|true|false|\\d+(?:\\.\\d+)?|'[^']*'|"[^"]*")\\s+Is\\s+([\\w][\\w.\\[\\]()]*|null|undefined|true|false|\\d+(?:\\.\\d+)?|'[^']*'|"[^"]*")`,"g");return Z=Z.replace(Q,"Is($1, $2)"),Z}function O6(Z){let X=/^[\s]*[([/+\-`]/,$=/[{([,;:+\-*/%=&|?<>!~^]\s*$|^\s*$/,Q=/\b(return|throw|yield|await|case|default|extends|new|typeof|void|delete|in|of|instanceof)\s*$/,K=Z.split(`
|
|
6
|
+
`),H=[];for(let Y=0;Y<K.length;Y++){let z=K[Y],W=Y>0?K[Y-1]:"";if(Y>0&&X.test(z)){let G=W.replace(/\/\/.*$/,"").replace(/\/\*.*\*\/\s*$/,"");if(!$.test(G)&&!Q.test(G)){let J=z.match(/^(\s*)/),L=J?J[1]:"",_=z.slice(L.length);H.push(L+";"+_);continue}}H.push(z)}return H.join(`
|
|
7
|
+
`)}function N6(Z){let X=[],$=0,Q="normal",K=[];while($<Z.length){let Y=Z[$],z=Z[$+1];switch(Q){case"single-string":if(Y==="\\"&&$+1<Z.length){$+=2;continue}if(Y==="'")Q="normal";$++;continue;case"double-string":if(Y==="\\"&&$+1<Z.length){$+=2;continue}if(Y==='"')Q="normal";$++;continue;case"template-string":if(Y==="\\"&&$+1<Z.length){$+=2;continue}if(Y==="$"&&z==="{"){$+=2,K.push(1),Q="normal";continue}if(Y==="`")Q="normal";$++;continue;case"line-comment":if(Y===`
|
|
8
|
+
`)Q="normal";$++;continue;case"block-comment":if(Y==="*"&&z==="/"){$+=2,Q="normal";continue}$++;continue;case"regex":if(Y==="\\"&&$+1<Z.length){$+=2;continue}if(Y==="["){$++;while($<Z.length&&Z[$]!=="]")if(Z[$]==="\\"&&$+1<Z.length)$+=2;else $++;if($<Z.length)$++;continue}if(Y==="/"){$++;while($<Z.length&&/[gimsuy]/.test(Z[$]))$++;Q="normal";continue}$++;continue;case"normal":if(K.length>0){if(Y==="{")K[K.length-1]++;else if(Y==="}"){if(K[K.length-1]--,K[K.length-1]===0){K.pop(),$++,Q="template-string";continue}}}if(Y==="'"){$++,Q="single-string";continue}if(Y==='"'){$++,Q="double-string";continue}if(Y==="`"){$++,Q="template-string";continue}if(Y==="/"&&z==="/"){$+=2,Q="line-comment";continue}if(Y==="/"&&z==="*"){$+=2,Q="block-comment";continue}if(Y==="/"){let W=$-1;while(W>=0&&/\s/.test(Z[W]))W--;let G=W>=0?Z[W]:"";if(!G||/[=(!,;:{[&|?+\-*%<>~^]/.test(G)||W>=5&&/\b(return|case|throw|in|of|typeof|instanceof|new|delete|void)$/.test(Z.slice(Math.max(0,W-10),W+1))){$++,Q="regex";continue}}if(Y==="="&&z==="="&&Z[$+2]!=="="&&Z[$-1]!=="!"){X.push({pos:$,op:"=="}),$+=2;continue}if(Y==="!"&&z==="="&&Z[$+2]!=="="){X.push({pos:$,op:"!="}),$+=2;continue}break}$++}if(X.length===0)return Z;let H=Z;for(let Y=X.length-1;Y>=0;Y--){let{pos:z,op:W}=X[Y],G=W==="=="?"Is":"IsNot",J=S8(H,z),L=k8(H,z+2),_=H.slice(J,z).trim(),U=H.slice(z+2,L).trim();if(_&&U){let D=H.slice(0,J),R=H.slice(L),I=/[a-zA-Z0-9_$]$/.test(D)?" ":"";H=`${D}${I}${G}(${_}, ${U})${R}`}}return H}function S8(Z,X){let $=X-1;while($>=0&&/\s/.test(Z[$]))$--;if($<0)return 0;let Q=0,K=!1,H="";while($>=0){let Y=Z[$],z=$>0?Z[$-1]:"";if(K){if(Y===H&&z!=="\\")K=!1;$--;continue}if((Y==='"'||Y==="'"||Y==="`")&&z!=="\\"){K=!0,H=Y,$--;continue}if(Y===")"||Y==="]"){Q++,$--;continue}if(Y==="("||Y==="["){if(Q>0){Q--,$--;continue}return $+1}if(Q>0){$--;continue}if(Y===";"||Y==="{"||Y==="}")return $+1;if(/[a-z]/.test(Y)){let W=$+1,G=$;while(G>0&&/[a-z]/i.test(Z[G-1]))G--;let J=Z.slice(G,W),L=G>0?Z[G-1]:"";if(!/[a-zA-Z0-9_$]/.test(L)){if(["return","throw","case","typeof","void","delete","await","yield","new"].includes(J))return W}}if(Y===">"&&z==="=")return $+1;if(Y==="="&&z!=="="&&z!=="!"&&z!=="<"&&z!==">")return $+1;if(Y==="&"&&z==="&")return $+1;if(Y==="|"&&z==="|")return $+1;if(Y==="?"||Y===":")return $+1;if(Y===",")return $+1;$--}return 0}function k8(Z,X){let $=X;while($<Z.length&&/\s/.test(Z[$]))$++;if($>=Z.length)return Z.length;let Q=0,K=!1,H="";while($<Z.length){let Y=Z[$],z=$+1<Z.length?Z[$+1]:"";if(K){if(Y===H&&Z[$-1]!=="\\")K=!1;$++;continue}if((Y==='"'||Y==="'"||Y==="`")&&Z[$-1]!=="\\"){K=!0,H=Y,$++;continue}if(Y==="("||Y==="["||Y==="{"){Q++,$++;continue}if(Y===")"||Y==="]"||Y==="}"){if(Q>0){Q--,$++;continue}return $}if(Q>0){$++;continue}if(Y===";")return $;if(Y==="&"&&z==="&")return $;if(Y==="|"&&z==="|")return $;if(Y==="?")return $;if(Y===":")return $;if(Y===",")return $;if((Y==="="||Y==="!")&&z==="="&&Z[$+2]!=="=")return $;$++}return Z.length}function E6(Z){let X="",$=0;while($<Z.length){let Q=Z.slice($).match(/^\bType\s+([A-Z][a-zA-Z0-9_]*)\s*/);if(Q){let K=Q[1],H=$+Q[0].length,Y=K,z=!1,W=Z.slice(H).match(/^(['"`])([^]*?)\1\s*/);if(W){let _=H+W[0].length,U=Z[_],D=U===void 0||_>=Z.length||U!=="="&&U!=="{";if(U==="="||U==="{")Y=W[2],z=!0,H=_;else if(D){let R=W[0].trim(),M=W[0].slice(R.length);X+=`const ${K} = Type('${K}', ${R})${M}`,$=_;continue}}let G,J=H,L=Z.slice(H).match(/^=\s*/);if(L){H+=L[0].length;let _=Z.slice(H).match(/^(\+?\d+(?:\.\d+)?|['"`][^'"`]*['"`]|\{[^}]*\}|\[[^\]]*\]|true|false|null)/);if(_){G=_[0],H+=_[0].length,J=H;let U=Z.slice(H).match(/^\s*/);if(U)H+=U[0].length}}if(Z[H]==="{"){let _=H+1,U=1,D=_;while(D<Z.length&&U>0){let B=Z[D];if(B==="{")U++;else if(B==="}")U--;D++}if(U!==0){X+=Z[$],$++;continue}let R=Z.slice(_,D-1).trim(),M=D,I=R.match(/description\s*:\s*(['"`])([^]*?)\1/);if(I&&!z)Y=I[2];let V,F=R.match(/example\s*:\s*/);if(F){let B=F.index+F[0].length,P=M6(R,B);if(P)V=P.value.trim()}let j=R.match(/predicate\s*\(([^)]*)\)\s*\{([^]*)\}/);if(j&&V){let B=j[1].trim(),P=j[2].trim(),C=G?`, ${G}`:"";X+=`const ${K} = Type('${Y}', (${B}) => { if (!globalThis.__tjs?.validate(${B}, globalThis.__tjs?.infer(${V}))) return false; ${P} }, ${V}${C})`}else if(j){let B=j[1].trim(),P=j[2].trim(),C=G?`, undefined, ${G}`:"";X+=`const ${K} = Type('${Y}', (${B}) => { ${P} }${C})`}else if(V){let B=G?`, ${G}`:"";X+=`const ${K} = Type('${Y}', undefined, ${V}${B})`}else if(G)X+=`const ${K} = Type('${Y}', ${G})`;else X+=`const ${K} = Type('${Y}')`;$=M;continue}else if(G){X+=`const ${K} = Type('${Y}', ${G})`,$=J;continue}else if(!W){let _=Z.slice(H).match(/^(['"`][^]*?['"`]|\+?\d+(?:\.\d+)?|true|false|null|\{[^]*?\}|\[[^]*?\])/);if(_){let U=_[0];X+=`const ${K} = Type('${K}', ${U})`,$=H+_[0].length;continue}}}X+=Z[$],$++}return X}function T6(Z){let X="",$=0;while($<Z.length){let Q=Z.slice($).match(/^\bGeneric\s+([A-Z][a-zA-Z0-9_]*)\s*<([^>]+)>\s*\{/);if(Q){let K=Q[1],H=Q[2],z=$+Q[0].length-1+1,W=1,G=z;while(G<Z.length&&W>0){let M=Z[G];if(M==="{")W++;else if(M==="}")W--;G++}if(W!==0){X+=Z[$],$++;continue}let J=Z.slice(z,G-1).trim(),L=G,_=H.split(",").map((M)=>{let I=M.trim().split("=").map((V)=>V.trim());if(I.length===2)return`['${I[0]}', ${I[1]}]`;return`'${I[0]}'`}),U=J.match(/description\s*:\s*(['"`])([^]*?)\1/),D=J.match(/predicate\s*\(([^)]*)\)\s*\{([^]*)\}/),R=U?U[2]:K;if(D){let M=D[1].trim().split(",").map((B)=>B.trim()),I=D[2].trim(),V=M[0]||"x",F=M.slice(1),j=F.map((B)=>`check${B}`);F.forEach((B,P)=>{I=I.replace(new RegExp(`\\b${B}\\s*\\(`,"g"),`${j[P]}(`)}),X+=`const ${K} = Generic([${_.join(", ")}], (${V}, ${j.join(", ")}) => { ${I} }, '${R}')`}else X+=`const ${K} = Generic([${_.join(", ")}], () => true, '${R}')`;$=L;continue}X+=Z[$],$++}return X}function S6(Z){let X="",$=0;while($<Z.length){let Q=Z.slice($).match(/^\bUnion\s+([A-Z][a-zA-Z0-9_]*)\s+(['"`])([^]*?)\2\s*/);if(Q){let K=Q[1],H=Q[3],Y=$+Q[0].length;if(Z[Y]==="{"){let z=Y+1,W=1,G=z;while(G<Z.length&&W>0){let U=Z[G];if(U==="{")W++;else if(U==="}")W--;G++}if(W!==0){X+=Z[$],$++;continue}let J=Z.slice(z,G-1).trim(),L=G,_=F6(J);X+=`const ${K} = Union('${H}', [${_.join(", ")}])`,$=L;continue}else{let z=Z.indexOf(`
|
|
9
|
+
`,Y);if(z===-1)z=Z.length;let W=Z.slice(Y,z).trim();if(W){let G=F6(W);X+=`const ${K} = Union('${H}', [${G.join(", ")}])`,$=z;continue}}}X+=Z[$],$++}return X}function F6(Z){let X=[],$=Z.split("|").map((Q)=>Q.trim());for(let Q of $){if(!Q)continue;X.push(Q)}return X}function k6(Z){let X="",$=0;while($<Z.length){let Q=Z.slice($).match(/^\bEnum\s+([A-Z][a-zA-Z0-9_]*)\s+(['"`])([^]*?)\2\s*\{/);if(Q){let K=Q[1],H=Q[3],z=$+Q[0].length-1+1,W=1,G=z;while(G<Z.length&&W>0){let D=Z[G];if(D==="{")W++;else if(D==="}")W--;G++}if(W!==0){X+=Z[$],$++;continue}let J=Z.slice(z,G-1).trim(),L=G,U=g8(J).map(([D,R])=>`${D}: ${R}`).join(", ");X+=`const ${K} = Enum('${H}', { ${U} })`,$=L;continue}X+=Z[$],$++}return X}function g8(Z){let X=[],$=0,Q=Z.split(/[\n,]/).map((K)=>K.trim()).filter((K)=>K&&!K.startsWith("//"));for(let K of Q){let H=K.match(/^([A-Za-z_][A-Za-z0-9_]*)\s*(?:=\s*(.+))?$/);if(H){let Y=H[1],z=H[2]?.trim();if(z!==void 0){X.push([Y,z]);let W=Number(z);if(!isNaN(W))$=W+1}else X.push([Y,String($)]),$++}}return X}function g6(Z){let X=new Map,$="",Q=0;while(Q<Z.length){let K=Z.slice(Q),H=K.match(/^(\s*)extend\s+([A-Z]\w*)\s*\{/);if(!H){if(Q===0||Z[Q-1]===`
|
|
10
|
+
`||Z[Q-1]===";"||Z[Q-1]==="}"){let F=K.match(/^(\s*)extend\s+([A-Z]\w*)\s*\{/)}$+=Z[Q],Q++;continue}let Y=H[1],z=H[2],W=Q+H[0].length-1,G=Z0(Z,W),J=Z.slice(W+1,G-1).trim(),L=[],_=0,U=Z.slice(W+1,G-1);while(_<U.length){let F=U.slice(_).match(/^(\s*)(async\s+)?(\w+)\s*\(/);if(!F){_++;continue}let j=F[1],B=!!F[2],P=F[3],C=_+F[0].length-1,O=1,T=C+1;while(T<U.length&&O>0){if(U[T]==="(")O++;if(U[T]===")")O--;T++}let k=U.slice(C+1,T-1),g=T;while(g<U.length&&/\s/.test(U[g]))g++;if(U[g]==="="&&U[g+1]===">"){let o=e1(Z,W+1+_);throw new Q1(`Arrow functions are not allowed in extend blocks (method '${P}' in extend ${z}). Use regular function syntax instead, as extension methods need 'this' binding.`,o)}if(U[g]!=="{"){_++;continue}let l=Z0(U,g),a=U.slice(_,l).trim(),v=k.split(",").map((o)=>o.trim()).filter((o)=>o.length>0).map((o)=>{let D1=o.match(/^(\w+)\s*:\s*(.+)$/);if(D1)return`${D1[1]} = ${D1[2]}`;return o}).join(", "),y=B?"async ":"",Z1=U.slice(g+1,l-1);L.push({name:P,isAsync:B,fullText:`${P}: ${y}function(${v}) {${Z1}}`}),_=l}let D=!X.has(z);if(D)X.set(z,new Set);let R=X.get(z);for(let V of L)R.add(V.name);let M=L.map((V)=>` ${V.fullText}`).join(`,
|
|
11
|
+
`),I;if(D)I=`${Y}const __ext_${z} = {
|
|
12
|
+
${M}
|
|
13
13
|
${Y}}
|
|
14
|
-
`;else I=`${Y}Object.assign(__ext_${
|
|
15
|
-
${
|
|
14
|
+
`;else I=`${Y}Object.assign(__ext_${z}, {
|
|
15
|
+
${M}
|
|
16
16
|
${Y}})
|
|
17
|
-
`;for(let V of L)I+=`${Y}if (__tjs?.registerExtension) { __tjs.registerExtension('${
|
|
18
|
-
`;$+=I,
|
|
19
|
-
`)$++,
|
|
20
|
-
`)H=!1;
|
|
21
|
-
${
|
|
17
|
+
`;for(let V of L)I+=`${Y}if (__tjs?.registerExtension) { __tjs.registerExtension('${z}', '${V.name}', __ext_${z}.${V.name}) }
|
|
18
|
+
`;$+=I,Q=G}if(Q<=Z.length&&$.length<Z.length);return{source:$,extensions:X}}function $0(Z,X){if(X.size===0)return Z;let $=new Map;for(let[K,H]of X)for(let Y of H){if(!$.has(Y))$.set(Y,[]);$.get(Y).push(K)}let Q=Z;for(let[K,H]of $){if(!H.includes("String"))continue;let Y=new RegExp(`('(?:[^'\\\\]|\\\\.)*')\\.(${K})\\((\\))?`,"g");Q=Q.replace(Y,(G,J,L,_)=>{return _?`__ext_String.${L}.call(${J})`:`__ext_String.${L}.call(${J}, `});let z=new RegExp(`("(?:[^"\\\\]|\\\\.)*")\\.(${K})\\((\\))?`,"g");Q=Q.replace(z,(G,J,L,_)=>{return _?`__ext_String.${L}.call(${J})`:`__ext_String.${L}.call(${J}, `});let W=new RegExp("(`(?:[^`\\\\]|\\\\.)*`)\\."+K+"\\((\\))?","g");Q=Q.replace(W,(G,J,L)=>{return L?`__ext_String.${K}.call(${J})`:`__ext_String.${K}.call(${J}, `})}for(let[K,H]of $){if(!H.includes("Array"))continue;let Y=`].${K}(`,z=0,W;while((W=Q.indexOf(Y,z))!==-1){let G=1,J=W-1,L=!1;while(J>=0&&G>0){let _=Q[J];if(L){if(_===L&&(J===0||Q[J-1]!=="\\"))L=!1}else{if(_==="]")G++;if(_==="[")G--;if(_==="'"||_==='"'||_==="`")L=_}J--}if(G===0){let _=Q.slice(J+1,W+1),U=Q.slice(0,J+1),D=Q.slice(W+Y.length);if(D[0]===")")Q=`${U}__ext_Array.${K}.call(${_})${D.slice(1)}`;else Q=`${U}__ext_Array.${K}.call(${_}, ${D}`}z=W+1}}for(let[K,H]of $){if(!H.includes("Number"))continue;let Y=new RegExp(`(\\d+(?:\\.\\d+)?)\\.(${K})\\((\\))?`,"g");Q=Q.replace(Y,(z,W,G,J)=>{return J?`__ext_Number.${G}.call(${W})`:`__ext_Number.${G}.call(${W}, `})}return Q}function e1(Z,X){let $=1,Q=0;for(let K=0;K<X&&K<Z.length;K++)if(Z[K]===`
|
|
19
|
+
`)$++,Q=0;else Q++;return{line:$,column:Q}}function b6(Z,X){let $=X.trim();if(/^['"`]/.test($))return`typeof ${Z} === 'string'`;if($==="true"||$==="false")return`typeof ${Z} === 'boolean'`;if($==="null")return`${Z} === null`;if($==="undefined")return`${Z} === undefined`;if($.startsWith("["))return`Array.isArray(${Z})`;if($.startsWith("{"))return`(typeof ${Z} === 'object' && ${Z} !== null && !Array.isArray(${Z}))`;if(/^\+\d+/.test($))return`(typeof ${Z} === 'number' && Number.isInteger(${Z}) && ${Z} >= 0)`;if(/^-?\d+\.\d+/.test($))return`typeof ${Z} === 'number'`;if(/^-?\d+$/.test($))return`(typeof ${Z} === 'number' && Number.isInteger(${Z}))`;return"true"}function N0(Z){let X=Z.trim();if(/^['"`]/.test(X))return"string";if(X==="true"||X==="false")return"boolean";if(X==="null")return"null";if(X==="undefined")return"undefined";if(X.startsWith("["))return"array";if(X.startsWith("{"))return"object";if(/^\+\d+/.test(X))return"non-negative-integer";if(/^-?\d+\.\d+/.test(X))return"number";if(/^-?\d+$/.test(X))return"integer";return"any"}function V4(Z,X){let $=[],Q=0,K="",H=!1;for(let z=0;z<Z.length;z++){let W=Z[z];if(!H&&(W==="'"||W==='"'||W==="`")){H=W,K+=W;continue}if(H){if(K+=W,W==="\\"){if(z++,z<Z.length)K+=Z[z];continue}if(W===H)H=!1;continue}if(W==="("||W==="["||W==="{"){Q++,K+=W;continue}if(W===")"||W==="]"||W==="}"){Q--,K+=W;continue}if(W===","&&Q===0){let G=j6(K.trim(),X);if(G)$.push(G);K="";continue}K+=W}let Y=K.trim();if(Y){let z=j6(Y,X);if(z)$.push(z)}return $}function j6(Z,X){let $=Z.replace(/^\/\*\s*unsafe\s*\*\/\s*/,"");if($.startsWith("..."))return null;let Q=$.indexOf("=");if(Q===-1)return{name:$.trim(),defaultValue:"",required:!0};let K=$.slice(0,Q).trim(),H=$.slice(Q+1).trim();return{name:K,defaultValue:H,required:X.has(K)}}function Z0(Z,X){let $=1,Q=X+1,K=!1,H=!1,Y=!1;while(Q<Z.length&&$>0){let z=Z[Q],W=Q+1<Z.length?Z[Q+1]:"";if(H){if(z===`
|
|
20
|
+
`)H=!1;Q++;continue}if(Y){if(z==="*"&&W==="/"){Y=!1,Q+=2;continue}Q++;continue}if(K){if(z==="\\"){Q+=2;continue}if(z===K)K=!1;Q++;continue}if(z==="/"&&W==="/"){H=!0,Q+=2;continue}if(z==="/"&&W==="*"){Y=!0,Q+=2;continue}if(z==="'"||z==='"'||z==="`"){K=z,Q++;continue}if(z==="{")$++;if(z==="}")$--;Q++}return Q}function v6(Z,X){let $=new Set,Q=/(?:^|(?<=[\n;{}]))\s*(export\s+)?(async\s+)?function\s+(\w+)\s*\(/gm,K=new Map,H,Y=[];while((H=Q.exec(Z))!==null){let L=!!H[1],_=!!H[2],U=H[3],D=H.index,R=D,I=H[0].indexOf("function");if(I>=0)R=D+I;Y.push({name:U,fullMatchStart:D,funcKeywordStart:R,exported:L,isAsync:_})}for(let L of Y)if(!K.has(L.name))K.set(L.name,[]);let z=new Map;for(let L of Y)z.set(L.name,(z.get(L.name)||0)+1);let W=new Set;for(let[L,_]of z)if(_>1)W.add(L);if(W.size===0)return{source:Z,polymorphicNames:$};for(let L of Y){if(!W.has(L.name))continue;let _=Z.indexOf("(",L.funcKeywordStart);if(_===-1)continue;let U=1,D=_+1;while(D<Z.length&&U>0){if(Z[D]==="(")U++;if(Z[D]===")")U--;D++}let R=D-1,M=Z.slice(_+1,R),I=D;while(I<Z.length&&Z[I]!=="{")I++;if(I>=Z.length)continue;let V=Z0(Z,I),F=L.fullMatchStart;while(F>0&&Z[F-1]===" ")F--;let j=K.get(L.name),B=V4(M,X);if(M.includes("...")){let C=e1(Z,L.funcKeywordStart);throw new Q1(`Rest parameters are not supported in polymorphic function '${L.name}'. Use separate function names instead.`,C)}j.push({index:j.length+1,start:F,end:V,text:Z.slice(F,V),exported:L.exported,isAsync:L.isAsync,params:B})}for(let[L,_]of K){if(_.length<2)continue;let U=_.filter((D)=>D.isAsync).length;if(U>0&&U<_.length){let D=e1(Z,_[0].start);throw new Q1(`Polymorphic function '${L}': all variants must be either sync or async, not mixed.`,D)}for(let D=0;D<_.length;D++)for(let R=D+1;R<_.length;R++){let M=_[D],I=_[R];if(M.params.length!==I.params.length)continue;let V=!0;for(let F=0;F<M.params.length;F++){let j=M.params[F].defaultValue?N0(M.params[F].defaultValue):"any",B=I.params[F].defaultValue?N0(I.params[F].defaultValue):"any";if(j!==B){V=!1;break}}if(V){let F=e1(Z,I.start);throw new Q1(`Polymorphic function '${L}': variants ${D+1} and ${R+1} have ambiguous signatures (same parameter types at every position). Overloads must differ by arity or parameter types.`,F)}}}let G=[];for(let[L,_]of K){if(_.length<2)continue;for(let U of _)G.push({name:L,variant:U})}G.sort((L,_)=>_.variant.start-L.variant.start);let J=Z;for(let{name:L,variant:_}of G){let U=_.isAsync?"async ":"",D=_.text.replace(new RegExp(`(?:export\\s+)?${U?U.replace(/\s+$/,"\\s+"):""}function\\s+${L}\\s*\\(`),`${U}function ${L}$$${_.index}(`);J=J.slice(0,_.start)+D+J.slice(_.end)}for(let[L,_]of K){if(_.length<2)continue;$.add(L);let U=_[0].isAsync,D=_.some((j)=>j.exported),R=U?"async ":"",M=D?"export ":"",I=[..._].sort((j,B)=>{if(j.params.length!==B.params.length)return 0;let P=0,C=0;for(let O of j.params){let T=O.defaultValue?N0(O.defaultValue):"any";if(T==="non-negative-integer")P+=3;else if(T==="integer")P+=2;else if(T!=="any")P+=1}for(let O of B.params){let T=O.defaultValue?N0(O.defaultValue):"any";if(T==="non-negative-integer")C+=3;else if(T==="integer")C+=2;else if(T!=="any")C+=1}return C-P}),V=[];for(let j of I){let B=[`__args.length === ${j.params.length}`],P=[];for(let C=0;C<j.params.length;C++){let O=j.params[C];if(P.push(`__args[${C}]`),O.defaultValue){let T=b6(`__args[${C}]`,O.defaultValue);if(T!=="true")B.push(T)}}V.push(` if (${B.join(" && ")}) return ${L}$${j.index}(${P.join(", ")})`)}let F=`
|
|
21
|
+
${M}${R}function ${L}(...__args) {
|
|
22
22
|
${V.join(`
|
|
23
23
|
`)}
|
|
24
24
|
return __tjs.typeError('${L}', 'no matching overload', __args)
|
|
25
25
|
}
|
|
26
|
-
`;J+=
|
|
27
|
-
${
|
|
28
|
-
`.repeat(V),H=
|
|
29
|
-
`)T--;
|
|
30
|
-
function ${
|
|
31
|
-
const __obj = Object.create(${
|
|
32
|
-
;(function() {${
|
|
33
|
-
return __obj`,
|
|
26
|
+
`;J+=F}return{source:J,polymorphicNames:$}}function f6(Z){return Z.replace(/(?<=^|[;\n{])\s*([A-Z][a-zA-Z0-9_]*)\s*=(?!=)/gm,(X,$)=>{return X.replace($,`const ${$}`)})}function y6(Z,X=!1){let $=[],Q=[],K="",H=0;while(H<Z.length){let Y=Z.slice(H).match(/^\btest\s+/);if(Y){let z=H,W=H+Y[0].length,G,J=Z.slice(W).match(/^(['"`])([^]*?)\1\s*/);if(J)G=J[2],W+=J[0].length;if(Z[W]==="{"){let L=W+1,_=1,U=L;while(U<Z.length&&_>0){let D=Z[U];if(D==="{")_++;else if(D==="}")_--;U++}if(_===0){let D=Z.slice(L,U-1).trim(),R=U,M=(Z.slice(0,z).match(/\n/g)||[]).length+1;if($.push({description:G,body:D,start:z,end:R,line:M}),!X)try{Function(D)()}catch(F){let j=G||`test at line ${M}`;Q.push(`Test failed: ${j} (line ${M})
|
|
27
|
+
${F.message||F}`)}let V=(Z.slice(z,R).match(/\n/g)||[]).length;K+=`
|
|
28
|
+
`.repeat(V),H=R;continue}}}K+=Z[H],H++}return{source:K,tests:$,errors:Q}}function h6(Z,X){let $=new Set,Q=/\bclass\s+(\w+)(\s+extends\s+\w+)?\s*\{/g,K,H=[];while((K=Q.exec(Z))!==null){let z=K[1],W=K[2]?.trim()||"",G=K.index+K[0].length-1,J=Z0(Z,G),L=Z.slice(G,J);H.push({className:z,extendsClause:W,bodyStart:G,bodyEnd:J,body:L})}let Y=Z;for(let z=H.length-1;z>=0;z--){let{className:W,extendsClause:G,bodyStart:J,bodyEnd:L,body:_}=H[z],U=/\bconstructor\s*\(/g,D,R=[];while((D=U.exec(_))!==null)R.push(D.index);if(R.length<2)continue;$.add(W);let M=[];for(let C=0;C<R.length;C++){let O=R[C],T=_.indexOf("(",O),k=1,g=T+1;while(g<_.length&&k>0){if(_[g]==="(")k++;if(_[g]===")")k--;g++}let l=_.slice(T+1,g-1),a=g;while(a<_.length&&_[a]!=="{")a++;let v=Z0(_,a),y=_.slice(a+1,v-1);M.push({index:C+1,paramStr:l,bodyText:y,fullStart:O,fullEnd:v})}let I=_.slice(0,M[0].fullEnd),V=M[M.length-1].fullEnd;I+=_.slice(V);let F=_;for(let C=M.length-1;C>=1;C--){let O=M[C],T=O.fullStart;while(T>0&&F[T-1]===" ")T--;if(T>0&&F[T-1]===`
|
|
29
|
+
`)T--;F=F.slice(0,T)+F.slice(O.fullEnd)}let j="";for(let C=1;C<M.length;C++){let O=M[C],T=V4(O.paramStr,X);if(O.paramStr.includes("...")){let g=e1(Z,J+O.fullStart);throw new Q1(`Rest parameters are not supported in polymorphic constructors for '${W}'.`,g)}j+=`
|
|
30
|
+
function ${W}$ctor$${O.index}(${O.paramStr}) {`,j+=`
|
|
31
|
+
const __obj = Object.create(${W}.prototype)`,j+=`
|
|
32
|
+
;(function() {${O.bodyText}}).call(__obj)`,j+=`
|
|
33
|
+
return __obj`,j+=`
|
|
34
34
|
}
|
|
35
|
-
`}let
|
|
36
|
-
function ${
|
|
37
|
-
`,B
|
|
35
|
+
`}let B=[];for(let C=0;C<M.length;C++){let O=M[C],T=V4(O.paramStr,X),k=[`a.length === ${T.length}`];for(let g=0;g<T.length;g++){let l=T[g];if(l.defaultValue){let a=b6(`a[${g}]`,l.defaultValue);if(a!=="true")k.push(a)}}if(C===0)B.push(` if (${k.join(" && ")}) return Reflect.construct(t, a)`);else{let g=T.map((l,a)=>`a[${a}]`).join(", ");B.push(` if (${k.join(" && ")}) return ${W}$ctor$${O.index}(${g})`)}}j+=`
|
|
36
|
+
function ${W}$dispatch(t, a) {
|
|
37
|
+
`,j+=B.join(`
|
|
38
38
|
`)+`
|
|
39
|
-
`,
|
|
40
|
-
`,
|
|
41
|
-
`,Y=Y.slice(0,J)+
|
|
42
|
-
`),
|
|
43
|
-
`);return $.description=_.trim(),$}}let H=K.match(/\/\*\*[\s\S]*?\*\/\s*$/);if(!H)return $;let Y=H[0],G=Y.match(/\/\*\*\s*\n?\s*\*?\s*([^@\n][^\n]*)/m);if(G)$.description=G[1].trim();let z=/@param\s+(?:\{[^}]+\}\s+)?(\w+)\s*-?\s*(.*)/g,W;while((W=z.exec(Y))!==null)$.params[W[1]]=W[2].trim();return $}import{parseExpressionAt as E8}from"acorn";function G1(Z){switch(Z.type){case"Literal":{let X=Z.value;if(X===null)return{kind:"null"};if(typeof X==="string")return{kind:"string"};if(typeof X==="number"){let $=Z.raw;if($&&$.includes("."))return{kind:"number"};return{kind:"integer"}}if(typeof X==="boolean")return{kind:"boolean"};return{kind:"any"}}case"ArrayExpression":{let X=Z.elements;if(X.length===0)return{kind:"array",items:{kind:"any"}};return{kind:"array",items:G1(X[0])}}case"ObjectExpression":{let X=Z.properties,$={};for(let K of X)if(K.type==="Property"&&K.key.type==="Identifier"){let Q=K.key.name;$[Q]=G1(K.value)}return{kind:"object",shape:$}}case"LogicalExpression":{let{operator:X,left:$,right:K}=Z;if(X==="||")return G1($);if(X==="&&")return G1(K);if(X==="??")return G1(K);return{kind:"any"}}case"BinaryExpression":{let{operator:X,left:$,right:K}=Z;if(X==="|"){let Q=G1($),H=G1(K);if(H.kind==="null")return{...Q,nullable:!0};if(Q.kind==="null")return{...H,nullable:!0};return{kind:"union",members:[Q,H]}}return{kind:"any"}}case"Identifier":{if(Z.name==="undefined")return{kind:"undefined"};return{kind:"any"}}case"UnaryExpression":{let{operator:X,argument:$}=Z;if(X==="+"&&$.type==="Literal"){if(typeof $.value==="number")return{kind:"non-negative-integer"}}if(X==="-"&&$.type==="Literal"){if(typeof $.value==="number"){let Q=$.raw;if(Q&&Q.includes("."))return{kind:"number"};return{kind:"integer"}}}return{kind:"any"}}default:return{kind:"any"}}}function P1(Z,X){if(Z.type==="Identifier")return{name:Z.name,type:{kind:"any"},required:!0};if(Z.type==="AssignmentPattern"){let{left:$,right:K}=Z;if($.type!=="Identifier")throw new u("Only simple parameter names are supported",d(Z));let Q=$.name,H=X?.has(Q)??!1,Y=G1(K),G=R1(K);return{name:Q,type:Y,required:H,default:H?null:G,example:G,loc:{start:Z.start,end:Z.end}}}if(Z.type==="ObjectPattern"){let $=Z.properties,K={},Q={};for(let H of $)if(H.type==="Property"){let Y=H.key.type==="Identifier"?H.key.name:String(H.key.value);if(H.value.type==="Identifier")K[Y]={kind:"any"},Q[Y]={name:Y,type:{kind:"any"},required:!0};else if(H.value.type==="AssignmentPattern"){let G=P1(H.value,X),z=X?.has(Y)??!1;K[Y]=G.type,Q[Y]={name:Y,type:G.type,required:z,default:z?null:G.example,example:G.example}}}return{name:"__destructured__",type:{kind:"object",shape:K,destructuredParams:Q},required:!0}}throw new u(`Unsupported parameter pattern: ${Z.type}`,d(Z))}function R1(Z){switch(Z.type){case"Literal":return Z.value;case"ArrayExpression":return Z.elements.map((X)=>X?R1(X):null);case"ObjectExpression":{let X={};for(let $ of Z.properties)if($.type==="Property"&&$.key.type==="Identifier")X[$.key.name]=R1($.value);return X}case"UnaryExpression":if(Z.operator==="-"){let X=R1(Z.argument);return typeof X==="number"?-X:void 0}if(Z.operator==="+"){let X=R1(Z.argument);return typeof X==="number"?+X:void 0}return;case"BinaryExpression":{let{operator:X,left:$}=Z;if(X==="|")return R1($);return}case"LogicalExpression":{let{operator:X,left:$,right:K}=Z;if(X==="&&"){if($.type==="Literal"&&$.value===null)return null}if(X==="||")return R1($)??R1(K);if(X==="??")return R1($)??R1(K);return}default:return}}function u6(Z){try{let X=E8(Z,0,{ecmaVersion:2022});return G1(X)}catch{return{kind:"any"}}}function j4(Z){switch(Z.kind){case"string":return Z.nullable?"string | null":"string";case"number":return Z.nullable?"number | null":"number";case"integer":return Z.nullable?"integer | null":"integer";case"non-negative-integer":return Z.nullable?"non-negative integer | null":"non-negative integer";case"boolean":return Z.nullable?"boolean | null":"boolean";case"null":return"null";case"any":return"any";case"array":{let X=Z.items?j4(Z.items):"any";return Z.nullable?`${X}[] | null`:`${X}[]`}case"object":{if(!Z.shape||Object.keys(Z.shape).length===0)return Z.nullable?"object | null":"object";let X=Object.entries(Z.shape).map(([$,K])=>`${$}: ${j4(K)}`).join(", ");return Z.nullable?`{ ${X} } | null`:`{ ${X} }`}case"union":return Z.members?.map(j4).join(" | ")||"any";default:return"any"}}function E0(Z){switch(Z.kind){case"string":return{type:"string"};case"number":return{type:"number"};case"boolean":return{type:"boolean"};case"null":return{};case"undefined":return{};case"any":return{};case"array":return{type:"array",items:Z.items?E0(Z.items):{}};case"object":if(Z.shape){let X={};for(let[$,K]of Object.entries(Z.shape))X[$]=E0(K);return{type:"object",properties:X,additionalProperties:!1}}return{type:"object"};case"union":if(Z.members)return{oneOf:Z.members.map(E0)};return{};default:return{}}}function T8(Z){let X={},$=[];for(let[K,Q]of Object.entries(Z))if(X[K]=E0(Q.type),Q.required)$.push(K);return{type:"object",properties:X,required:$.length>0?$:void 0,additionalProperties:!1}}function K0(Z,X,$,K={},Q){let H=Z0(X,Z),Y=new Map;for(let w of Z.params){let I=P1(w,Q);if(I.name==="__destructured__"&&I.type.kind==="object"&&I.type.destructuredParams)for(let[V,A]of Object.entries(I.type.destructuredParams))Y.set(V,{...A,description:H.params[V]});else I.description=H.params[I.name],Y.set(I.name,I)}let G;if($)G=u6($);let z={depth:0,locals:new Map,parameters:Y,atoms:new Set(Object.keys(K.atoms||{})),warnings:[],source:X,filename:K.filename||"<source>",options:K},W=B1(Z.body,z),J=[],L=[],_=[];for(let[w,I]of Y.entries())if(I.required)L.push(w);else if(I.default!==void 0)_.push({name:w,defaultValue:I.default});else L.push(w);if(L.length>0)J.push({op:"varsImport",keys:L});for(let{name:w,defaultValue:I}of _)J.push({op:"varsImport",keys:[w]}),J.push({op:"if",condition:{$expr:"binary",op:"==",left:{$expr:"ident",name:w},right:{$expr:"literal",value:null}},then:[{op:"varSet",key:w,value:I}]});J.push(...W);let U=Object.fromEntries(Y),R={name:Z.id?.name||"anonymous",description:H.description,parameters:U,returns:G},M=T8(U);return{ast:{op:"seq",steps:J,inputSchema:M},signature:R,warnings:z.warnings}}function B1(Z,X){let $=[];for(let K of Z.body){let Q=$0(K,X);if(Q)if(Array.isArray(Q))$.push(...Q);else $.push(Q)}return $}function $0(Z,X){switch(Z.type){case"VariableDeclaration":return S8(Z,X);case"ExpressionStatement":return k8(Z,X);case"IfStatement":return b8(Z,X);case"WhileStatement":return v8(Z,X);case"ForOfStatement":return f8(Z,X);case"TryStatement":return y8(Z,X);case"ReturnStatement":return h8(Z,X);case"ThrowStatement":throw new u("'throw' is not supported in AsyncJS. Use Error('message') to trigger error flow",d(Z),X.source,X.filename);case"BlockStatement":return{op:"scope",steps:B1(Z,z1(X))};case"EmptyStatement":return null;default:throw new u(`Unsupported statement type: ${Z.type}`,d(Z),X.source,X.filename)}}function S8(Z,X){let $=[],K=Z.kind==="const",Q=K?"constSet":"varSet";for(let H of Z.declarations){if(H.id.type!=="Identifier")throw new u("Only simple variable names are supported",d(H),X.source,X.filename);let Y=H.id.name;if(H.init){let{step:G,resultVar:z}=S1(H.init,X,Y,K);if(G)$.push(G);else if(z!==Y)$.push({op:Q,key:Y,value:z});let W=G1(H.init);X.locals.set(Y,W)}else{if(K)throw new u("const declarations must be initialized",d(H),X.source,X.filename);$.push({op:"varSet",key:Y,value:null}),X.locals.set(Y,{kind:"any",nullable:!0})}}return $}function k8(Z,X){let $=Z.expression;if($.type==="AssignmentExpression")return g8($,X);if($.type==="CallExpression"){let{step:K,resultVar:Q}=S1($,X);if(K)return K;if(Q)return{op:"varSet",key:"_",value:Q};return null}return X.warnings.push({message:"Expression statement has no effect",line:d(Z).line,column:d(Z).column}),null}function g8(Z,X){if(Z.left.type!=="Identifier")throw new u("Only simple variable assignment is supported",d(Z),X.source,X.filename);let $=Z.left.name,{step:K,resultVar:Q}=S1(Z.right,X,$);if(K)return K;return{op:"varSet",key:$,value:Q}}function b8(Z,X){let $=x(Z.test,X),K=Z.consequent.type==="BlockStatement"?B1(Z.consequent,z1(X)):[$0(Z.consequent,X)].filter(Boolean),Q;if(Z.alternate)Q=Z.alternate.type==="BlockStatement"?B1(Z.alternate,z1(X)):[$0(Z.alternate,X)].filter(Boolean);return{op:"if",condition:$,then:K,...Q&&{else:Q}}}function v8(Z,X){let $=x(Z.test,X),K=Z.body.type==="BlockStatement"?B1(Z.body,z1(X)):[$0(Z.body,X)].filter(Boolean);return{op:"while",condition:$,body:K}}function f8(Z,X){let $;if(Z.left.type==="VariableDeclaration"){let Y=Z.left.declarations[0];if(Y.id.type!=="Identifier")throw new u("Only simple variable names are supported in for...of",d(Z.left),X.source,X.filename);$=Y.id.name}else if(Z.left.type==="Identifier")$=Z.left.name;else throw new u("Unsupported for...of left-hand side",d(Z.left),X.source,X.filename);let K=r(Z.right,X),Q=z1(X);Q.locals.set($,{kind:"any"});let H=Z.body.type==="BlockStatement"?B1(Z.body,Q):[$0(Z.body,Q)].filter(Boolean);return{op:"map",items:K,as:$,steps:H}}function y8(Z,X){let $=B1(Z.block,z1(X)),K,Q;if(Z.handler){let H=z1(X);if(Z.handler.param?.type==="Identifier")Q=Z.handler.param.name,H.locals.set(Q,{kind:"any"});K=B1(Z.handler.body,H)}return{op:"try",try:$,...K&&{catch:K},...Q&&{catchParam:Q}}}function h8(Z,X){if(!Z.argument)return{op:"return",value:{}};let{step:$,resultVar:K}=S1(Z.argument,X,"__returnVal__");if($)return[$,{op:"return",value:K}];return{op:"return",value:r(Z.argument,X)}}var m6=new Set(["Math","JSON","Array","Object","String","Number","console","Date","Schema"]),x8=new Set(["parseInt","parseFloat","isNaN","isFinite","encodeURI","decodeURI","encodeURIComponent","decodeURIComponent","Set","Date","filter"]),X0=new Set(["RegExp","Promise","Map","WeakSet","WeakMap","Symbol","Proxy","Reflect","Function","eval","setTimeout","setInterval","fetch","require","import","process","window","document","global","globalThis"]),u8=new Set(["toUpperCase","toLowerCase","trim","trimStart","trimEnd","charAt","charCodeAt","codePointAt","concat","includes","indexOf","lastIndexOf","startsWith","endsWith","slice","substring","substr","replace","replaceAll","match","search","padStart","padEnd","repeat","normalize","localeCompare","toString","valueOf","at","reverse","sort","fill","copyWithin","flat","flatMap","every","some","forEach","add","remove","has","clear","toArray","union","intersection","diff","format","isBefore","isAfter"]);function d8(Z){if(Z.callee.type==="Identifier"){let X=Z.callee.name;return x8.has(X)||X0.has(X)}if(Z.callee.type==="MemberExpression"){let X=Z.callee;if(X.object.type==="Identifier"){let $=X.object.name;if(m6.has($)||X0.has($))return!0}if(X.property.type==="Identifier"){let $=X.property.name;if(u8.has($))return!0}}return!1}function m8(Z){if(Z.object.type==="Identifier"){let X=Z.object.name;return m6.has(X)||X0.has(X)}return!1}var d6={RegExp:"RegExp is not available. Use string methods or the regexMatch atom.",Promise:"Promise is not needed. All operations are implicitly async.",Map:"Map is not available. Use plain objects instead.",WeakSet:"WeakSet is not available.",WeakMap:"WeakMap is not available.",Symbol:"Symbol is not available.",Proxy:"Proxy is not available.",Reflect:"Reflect is not available.",Function:"Function constructor is not available. Define functions normally.",eval:"eval is not available. Code is compiled, not evaluated.",setTimeout:"setTimeout is not available. Use the delay atom.",setInterval:"setInterval is not available. Use while loops with delay.",fetch:"fetch is not available. Use the httpFetch atom.",require:"require is not available. Atoms must be registered with the VM.",import:"import is not available. Atoms must be registered with the VM.",process:"process is not available. AsyncJS runs in a sandboxed environment.",window:"window is not available. AsyncJS runs in a sandboxed environment.",document:"document is not available. AsyncJS runs in a sandboxed environment.",global:"global is not available. AsyncJS runs in a sandboxed environment.",globalThis:"globalThis is not available. Use builtins directly."};function l8(Z){if(Z.callee.type==="Identifier"){let X=Z.callee.name;if(X0.has(X))return d6[X]||`${X} is not available in AsyncJS.`}if(Z.callee.type==="MemberExpression"){let X=Z.callee;if(X.object.type==="Identifier"){let $=X.object.name;if(X0.has($))return d6[$]||`${$} is not available in AsyncJS.`}}return null}function l6(Z){return{Date:" Use Date() or Date('2024-01-15') instead - no 'new' needed.",Set:" Use Set([items]) instead - no 'new' needed.",Map:" Use plain objects instead of Map.",Array:" Use array literals like [1, 2, 3] instead.",Object:" Use object literals like { key: value } instead.",Error:" Return an error object like { error: 'message' } instead.",RegExp:" Use string methods or the regexMatch atom.",Promise:" Not needed - all operations are implicitly async.",WeakSet:" WeakSet is not available.",WeakMap:" WeakMap is not available."}[Z]||" Use factory functions or object literals instead."}function S1(Z,X,$,K){let Q=K?"constSet":"varSet";if(Z.type==="ChainExpression")return S1(Z.expression,X,$,K);if(Z.type==="NewExpression"){let Y=Z,G="constructor";if(Y.callee.type==="Identifier")G=Y.callee.name;let z=l6(G);throw new u(`The 'new' keyword is not supported in AsyncJS.${z}`,d(Z),X.source,X.filename)}if(Z.type==="CallExpression"){let Y=l8(Z);if(Y)throw new u(Y,d(Z),X.source,X.filename)}if(Z.type==="CallExpression"&&d8(Z)){let Y=x(Z,X);if($)return{step:{op:Q,key:$,value:Y},resultVar:$};return{step:null,resultVar:Y}}if(Z.type==="MemberExpression"&&m8(Z)){let Y=x(Z,X);if($)return{step:{op:Q,key:$,value:Y},resultVar:$};return{step:null,resultVar:Y}}if(Z.type==="CallExpression")return i8(Z,X,$,K);if(Z.type==="TemplateLiteral")return n8(Z,X,$,K);if(Z.type==="BinaryExpression"||Z.type==="LogicalExpression"||Z.type==="UnaryExpression"){let Y=x(Z,X);if($)return{step:{op:Q,key:$,value:Y},resultVar:$};return{step:null,resultVar:Y}}return{step:null,resultVar:r(Z,X)}}function i8(Z,X,$,K){let Q,H=!1,Y;if(Z.callee.type==="Identifier")Q=Z.callee.name;else if(Z.callee.type==="MemberExpression"){let z=Z.callee;if(z.property.type==="Identifier")Q=z.property.name,H=!0,Y=r(z.object,X);else throw new u("Computed method names are not supported",d(Z),X.source,X.filename)}else throw new u("Only named function calls are supported",d(Z),X.source,X.filename);if(H)return p8(Q,Y,Z.arguments,X,$,K);if(Q==="console"&&Z.callee.type==="MemberExpression");let G=c8(Z,X);return{step:{op:Q,...G,...$&&{result:$},...$&&K&&{resultConst:!0}},resultVar:$}}function p8(Z,X,$,K,Q,H){switch(Z){case"map":if($.length>0&&($[0].type==="ArrowFunctionExpression"||$[0].type==="FunctionExpression")){let Y=$[0],G=Y.params[0],z=G?.type==="Identifier"?G.name:"item",W=z1(K);W.locals.set(z,{kind:"any"});let J;if(Y.body.type==="BlockStatement")J=B1(Y.body,W);else{let{step:L,resultVar:_}=S1(Y.body,W,"result");J=L?[L]:[{op:"varSet",key:"result",value:_}]}return{step:{op:"map",items:X,as:z,steps:J,...Q&&{result:Q},...Q&&H&&{resultConst:!0}},resultVar:Q}}break;case"filter":if($.length>0&&($[0].type==="ArrowFunctionExpression"||$[0].type==="FunctionExpression")){let Y=$[0],G=Y.params[0],z=G?.type==="Identifier"?G.name:"item",W=z1(K);W.locals.set(z,{kind:"any"});let J;if(Y.body.type==="BlockStatement")throw new u("filter callback must be an expression, not a block",d($[0]),K.source,K.filename);else J=x(Y.body,W);return{step:{op:"filter",items:X,as:z,condition:J,...Q&&{result:Q},...Q&&H&&{resultConst:!0}},resultVar:Q}}break;case"find":if($.length>0&&($[0].type==="ArrowFunctionExpression"||$[0].type==="FunctionExpression")){let Y=$[0],G=Y.params[0],z=G?.type==="Identifier"?G.name:"item",W=z1(K);W.locals.set(z,{kind:"any"});let J;if(Y.body.type==="BlockStatement")throw new u("find callback must be an expression, not a block",d($[0]),K.source,K.filename);else J=x(Y.body,W);return{step:{op:"find",items:X,as:z,condition:J,...Q&&{result:Q},...Q&&H&&{resultConst:!0}},resultVar:Q}}break;case"reduce":if($.length>=2&&($[0].type==="ArrowFunctionExpression"||$[0].type==="FunctionExpression")){let Y=$[0],G=Y.params[0],z=Y.params[1],W=G?.type==="Identifier"?G.name:"acc",J=z?.type==="Identifier"?z.name:"item",L=z1(K);L.locals.set(W,{kind:"any"}),L.locals.set(J,{kind:"any"});let _;if(Y.body.type==="BlockStatement")_=B1(Y.body,L);else{let{step:R,resultVar:M}=S1(Y.body,L,"result");_=R?[R]:[{op:"varSet",key:"result",value:M}]}let U=r($[1],K);return{step:{op:"reduce",items:X,as:J,accumulator:W,initial:U,steps:_,...Q&&{result:Q},...Q&&H&&{resultConst:!0}},resultVar:Q}}break;case"slice":break;case"push":return{step:{op:"push",list:X,item:r($[0],K),...Q&&{result:Q},...Q&&H&&{resultConst:!0}},resultVar:Q};case"join":return{step:{op:"join",list:X,sep:$.length>0?r($[0],K):"",...Q&&{result:Q},...Q&&H&&{resultConst:!0}},resultVar:Q};case"split":return{step:{op:"split",str:X,sep:$.length>0?r($[0],K):"",...Q&&{result:Q},...Q&&H&&{resultConst:!0}},resultVar:Q}}return K.warnings.push({message:`Unknown method '${Z}' - treating as atom call`,line:0,column:0}),{step:{op:Z,receiver:X,args:$.map((Y)=>r(Y,K)),...Q&&{result:Q},...Q&&H&&{resultConst:!0}},resultVar:Q}}function n8(Z,X,$,K){let Q="",H={};for(let Y=0;Y<Z.quasis.length;Y++)if(Q+=Z.quasis[Y].value.cooked||Z.quasis[Y].value.raw,Y<Z.expressions.length){let G=Z.expressions[Y],z=`_${Y}`;H[z]=r(G,X),Q+=`{{${z}}}`}return{step:{op:"template",tmpl:Q,vars:H,...$&&{result:$},...$&&K&&{resultConst:!0}},resultVar:$}}function x(Z,X){switch(Z.type){case"Literal":return{$expr:"literal",value:Z.value};case"Identifier":return{$expr:"ident",name:Z.name};case"MemberExpression":{let $=Z,K=x($.object,X),Q=$.optional===!0;if($.computed){let Y=$.property;if(Y.type==="Literal")return{$expr:"member",object:K,property:String(Y.value),computed:!0,...Q&&{optional:!0}};throw new u("Computed member access with variables not yet supported",d(Z),X.source,X.filename)}let H=$.property.name;return{$expr:"member",object:K,property:H,...Q&&{optional:!0}}}case"ChainExpression":return x(Z.expression,X);case"BinaryExpression":{let $=Z;return{$expr:"binary",op:$.operator,left:x($.left,X),right:x($.right,X)}}case"LogicalExpression":{let $=Z;return{$expr:"logical",op:$.operator,left:x($.left,X),right:x($.right,X)}}case"UnaryExpression":{let $=Z;return{$expr:"unary",op:$.operator,argument:x($.argument,X)}}case"ConditionalExpression":{let $=Z;return{$expr:"conditional",test:x($.test,X),consequent:x($.consequent,X),alternate:x($.alternate,X)}}case"ArrayExpression":return{$expr:"array",elements:Z.elements.filter((K)=>K!==null).map((K)=>x(K,X))};case"ObjectExpression":{let $=Z,K=[];for(let Q of $.properties)if(Q.type==="Property"){let H=Q.key.type==="Identifier"?Q.key.name:String(Q.key.value);K.push({key:H,value:x(Q.value,X)})}return{$expr:"object",properties:K}}case"CallExpression":{let $=Z;if($.callee.type==="MemberExpression"){let K=$.callee,Q=K.property.type==="Identifier"?K.property.name:String(K.property.value),H=K.optional===!0||$.optional===!0;return{$expr:"methodCall",object:x(K.object,X),method:Q,arguments:$.arguments.map((Y)=>x(Y,X)),...H&&{optional:!0}}}if($.callee.type==="Identifier")return{$expr:"call",callee:$.callee.name,arguments:$.arguments.map((Q)=>x(Q,X))};throw new u("Complex function calls in expressions should be lifted to statements",d(Z),X.source,X.filename)}case"NewExpression":{let $=Z,K="constructor";if($.callee.type==="Identifier")K=$.callee.name;let Q=l6(K);throw new u(`The 'new' keyword is not supported in AsyncJS.${Q}`,d(Z),X.source,X.filename)}case"TemplateLiteral":throw new u("Template literals inside expressions are not supported. Assign to a variable first: const msg = `hello ${name}`; then use msg",d(Z),X.source,X.filename);default:throw new u(`Unsupported expression type in condition: ${Z.type}`,d(Z),X.source,X.filename)}}function r(Z,X){switch(Z.type){case"Literal":return Z.value;case"Identifier":return Z.name;case"MemberExpression":{let $=Z;if($.optional===!0)return x(Z,X);let Q=r($.object,X);if(Q&&typeof Q==="object"&&Q.$expr){let Y=$.computed?String($.property.value):$.property.name;return{$expr:"member",object:Q,property:Y,...$.computed&&{computed:!0}}}if($.computed)return`${Q}[${r($.property,X)}]`;let H=$.property.name;if(typeof Q==="string")return`${Q}.${H}`;if(Q&&Q.$kind==="arg")return{$kind:"arg",path:`${Q.path}.${H}`};return`${Q}.${H}`}case"ChainExpression":return r(Z.expression,X);case"ArrayExpression":return Z.elements.map(($)=>$?r($,X):null);case"ObjectExpression":{let $={};for(let K of Z.properties)if(K.type==="Property"){let Q=K.key.type==="Identifier"?K.key.name:String(K.key.value);$[Q]=r(K.value,X)}return $}case"TemplateLiteral":return x(Z,X);case"CallExpression":return x(Z,X);case"BinaryExpression":case"LogicalExpression":case"UnaryExpression":case"ConditionalExpression":return x(Z,X);default:return null}}function c8(Z,X){if(Z.arguments.length===1&&Z.arguments[0].type==="ObjectExpression"){let $=Z.arguments[0],K={};for(let Q of $.properties)if(Q.type==="Property"){let H=Q.key.type==="Identifier"?Q.key.name:String(Q.key.value);K[H]=r(Q.value,X)}return K}return{args:Z.arguments.map(($)=>r($,X))}}import{parseExpressionAt as jZ}from"acorn";function o8(Z,X){let $=X;while($>0&&Z[$-1]!==`
|
|
44
|
-
`)$--;if(Z.slice($,X).includes("//"))return!0;let
|
|
39
|
+
`,j+=` return __tjs.typeError('${W}', 'no matching constructor', a)
|
|
40
|
+
`,j+=`}
|
|
41
|
+
`,Y=Y.slice(0,J)+F+Y.slice(L);let P=J+F.length;Y=Y.slice(0,P)+j+Y.slice(P)}return{source:Y,polyCtorClasses:$}}function x6(Z,X=new Set){let $=/\bclass\s+(\w+)(\s+extends\s+\w+)?\s*\{/g,Q="",K=0,H;while((H=$.exec(Z))!==null){let Y=H[1],z=H[2]||"",W=H.index,G=W+H[0].length-1,J=1,L=G+1;while(L<Z.length&&J>0){let _=Z[L];if(_==="{")J++;else if(_==="}")J--;L++}if(J===0){let _=L,U=Z.slice(G,_);if(Q+=Z.slice(K,W),Q+=`let ${Y} = class ${Y}${z} ${U}; `,X.has(Y))Q+=`${Y} = new Proxy(${Y}, { apply(t, _, a) { return ${Y}$dispatch(t, a) }, construct(t, a) { return ${Y}$dispatch(t, a) } });`;else Q+=`${Y} = new Proxy(${Y}, { apply(t, _, a) { return Reflect.construct(t, a) } });`;K=_}}return Q+=Z.slice(K),Q}function u6(Z){let X=[{pattern:/\bnew\s+Date\b/,message:"new Date() is not allowed in TjsDate mode. Use Timestamp.now() or Timestamp.from()"},{pattern:/\bDate\.now\b/,message:"Date.now() is not allowed in TjsDate mode. Use Timestamp.now()"},{pattern:/\bDate\.parse\b/,message:"Date.parse() is not allowed in TjsDate mode. Use Timestamp.parse()"},{pattern:/\bDate\.UTC\b/,message:"Date.UTC() is not allowed in TjsDate mode. Use Timestamp.from()"}];for(let{pattern:$,message:Q}of X)if($.test(Z))throw Error(Q);return Z}function d6(Z){if(/(?<![A-Za-z_$])\beval\s*\(/.test(Z))throw Error("eval() is not allowed in TjsNoeval mode. Use Eval() from TJS runtime for safe evaluation.");if(/\bnew\s+Function\s*\(/.test(Z))throw Error("new Function() is not allowed in TjsNoeval mode. Use SafeFunction() from TJS runtime.");return Z}function E0(Z,X={}){let $=Z,Q,K=new Set,H=new Set,Y=new Set,z={tjsEquals:!1,tjsClass:!1,tjsDate:!1,tjsNoeval:!1,tjsStandard:!1,tjsSafeEval:!1},W=Z.match(/^(\s*(?:\/\/[^\n]*\n|\/\*[\s\S]*?\*\/\s*)*)\s*safety\s+(none|inputs|all)\b/);if(W)Q=W[2],Z=Z.replace(/^(\s*(?:\/\/[^\n]*\n|\/\*[\s\S]*?\*\/\s*)*)\s*safety\s+(none|inputs|all)\s*/,"$1");let G=/^(\s*(?:\/\/[^\n]*\n|\/\*[\s\S]*?\*\/\s*)*)\s*(TjsStrict|TjsEquals|TjsClass|TjsDate|TjsNoeval|TjsStandard|TjsSafeEval)\b/,J;while(J=Z.match(G)){let F=J[2];if(F==="TjsStrict")z.tjsEquals=!0,z.tjsClass=!0,z.tjsDate=!0,z.tjsNoeval=!0,z.tjsStandard=!0;else if(F==="TjsEquals")z.tjsEquals=!0;else if(F==="TjsClass")z.tjsClass=!0;else if(F==="TjsDate")z.tjsDate=!0;else if(F==="TjsNoeval")z.tjsNoeval=!0;else if(F==="TjsStandard")z.tjsStandard=!0;else if(F==="TjsSafeEval")z.tjsSafeEval=!0;Z=Z.replace(new RegExp(`^(\\s*(?:\\/\\/[^\\n]*\\n|\\/\\*[\\s\\S]*?\\*\\/\\s*)*)\\s*${F}\\s*`),"$1")}if(z.tjsStandard)Z=O6(Z);if(Z=C6(Z),z.tjsEquals&&!X.vmTarget)Z=N6(Z);Z=E6(Z),Z=T6(Z),Z=S6(Z),Z=k6(Z),Z=f6(Z);let{source:L,returnType:_,returnSafety:U}=C0(Z,{originalSource:$,requiredParams:K,unsafeFunctions:H,safeFunctions:Y});Z=L;let D=g6(Z);Z=D.source,Z=P6(Z);let R=v6(Z,K);Z=R.source;let M=V6(Z);Z=M.source;let I=y6(Z,X.dangerouslySkipTests);Z=I.source;let V=h6(Z,K);Z=V.source;for(let F of V.polyCtorClasses)H.add(`${F}$dispatch`);if(z.tjsClass)Z=x6(Z,V.polyCtorClasses);if(z.tjsDate)Z=u6(Z);if(z.tjsNoeval)Z=d6(Z);return Z=$0(Z,D.extensions),{source:Z,returnType:_,returnSafety:U,moduleSafety:Q,tjsModes:z,originalSource:$,requiredParams:K,unsafeFunctions:H,safeFunctions:Y,wasmBlocks:M.blocks,tests:I.tests,testErrors:I.errors,polymorphicNames:R.polymorphicNames,extensions:D.extensions}}function M1(Z,X={}){let{filename:$="<source>",colonShorthand:Q=!0,vmTarget:K=!1}=X,{source:H,returnType:Y,returnSafety:z,moduleSafety:W,originalSource:G,requiredParams:J,unsafeFunctions:L,safeFunctions:_,wasmBlocks:U,tests:D,testErrors:R}=Q?E0(Z,{vmTarget:K}):{source:Z,returnType:void 0,returnSafety:void 0,moduleSafety:void 0,originalSource:Z,requiredParams:new Set,unsafeFunctions:new Set,safeFunctions:new Set,wasmBlocks:[],tests:[],testErrors:[]};try{return{ast:l6.parse(H,{ecmaVersion:2022,sourceType:"module",locations:!0,allowReturnOutsideFunction:!1}),returnType:Y,returnSafety:z,moduleSafety:W,originalSource:G,requiredParams:J,unsafeFunctions:L,safeFunctions:_,wasmBlocks:U,tests:D,testErrors:R}}catch(M){let I=M.loc||{line:1,column:0};throw new Q1(M.message.replace(/\s*\(\d+:\d+\)$/,""),I,G,$)}}function T0(Z,X){for(let Q of Z.body){if(Q.type==="ImportDeclaration")throw new Q1("Imports are not supported. All atoms must be registered with the VM.",Q.loc?.start||{line:1,column:0},void 0,X);if(Q.type==="ExportNamedDeclaration"||Q.type==="ExportDefaultDeclaration")throw new Q1("Exports are not supported. The function is automatically exported.",Q.loc?.start||{line:1,column:0},void 0,X);if(Q.type==="ClassDeclaration")throw new Q1("Classes are not supported. Agent99 uses functional composition.",Q.loc?.start||{line:1,column:0},void 0,X)}let $=Z.body.filter((Q)=>Q.type==="FunctionDeclaration");if($.length===0)throw new Q1("Source must contain a function declaration",{line:1,column:0},void 0,X);if($.length>1){let Q=$[1];throw new Q1("Only a single function per agent is allowed",Q.loc?.start||{line:1,column:0},void 0,X)}return $[0]}function X0(Z,X){let $={params:{}};if(!X.loc)return $;let Q=Z.substring(0,X.start),K=[...Q.matchAll(/\/\*#([\s\S]*?)\*\//g)];if(K.length>0){let J=K[K.length-1],L=Q.substring(J.index+J[0].length);if(/^(?:\s|\/\/[^\n]*)*$/.test(L)){let _=J[1],U=_.split(`
|
|
42
|
+
`),D=U.filter((R)=>R.trim().length>0).reduce((R,M)=>{let I=M.match(/^(\s*)/)?.[1].length||0;return Math.min(R,I)},1/0);if(D>0&&D<1/0)_=U.map((R)=>R.slice(D)).join(`
|
|
43
|
+
`);return $.description=_.trim(),$}}let H=Q.match(/\/\*\*[\s\S]*?\*\/\s*$/);if(!H)return $;let Y=H[0],z=Y.match(/\/\*\*\s*\n?\s*\*?\s*([^@\n][^\n]*)/m);if(z)$.description=z[1].trim();let W=/@param\s+(?:\{[^}]+\}\s+)?(\w+)\s*-?\s*(.*)/g,G;while((G=W.exec(Y))!==null)$.params[G[1]]=G[2].trim();return $}import{parseExpressionAt as b8}from"acorn";function z1(Z){switch(Z.type){case"Literal":{let X=Z.value;if(X===null)return{kind:"null"};if(typeof X==="string")return{kind:"string"};if(typeof X==="number"){let $=Z.raw;if($&&$.includes("."))return{kind:"number"};return{kind:"integer"}}if(typeof X==="boolean")return{kind:"boolean"};return{kind:"any"}}case"ArrayExpression":{let X=Z.elements;if(X.length===0)return{kind:"array",items:{kind:"any"}};return{kind:"array",items:z1(X[0])}}case"ObjectExpression":{let X=Z.properties,$={};for(let Q of X)if(Q.type==="Property"&&Q.key.type==="Identifier"){let K=Q.key.name;$[K]=z1(Q.value)}return{kind:"object",shape:$}}case"LogicalExpression":{let{operator:X,left:$,right:Q}=Z;if(X==="||")return z1($);if(X==="&&")return z1(Q);if(X==="??")return z1(Q);return{kind:"any"}}case"BinaryExpression":{let{operator:X,left:$,right:Q}=Z;if(X==="|"){let K=z1($),H=z1(Q);if(H.kind==="null")return{...K,nullable:!0};if(K.kind==="null")return{...H,nullable:!0};return{kind:"union",members:[K,H]}}return{kind:"any"}}case"Identifier":{if(Z.name==="undefined")return{kind:"undefined"};return{kind:"any"}}case"UnaryExpression":{let{operator:X,argument:$}=Z;if(X==="+"&&$.type==="Literal"){if(typeof $.value==="number")return{kind:"non-negative-integer"}}if(X==="-"&&$.type==="Literal"){if(typeof $.value==="number"){let K=$.raw;if(K&&K.includes("."))return{kind:"number"};return{kind:"integer"}}}return{kind:"any"}}default:return{kind:"any"}}}function P1(Z,X){if(Z.type==="Identifier")return{name:Z.name,type:{kind:"any"},required:!0};if(Z.type==="AssignmentPattern"){let{left:$,right:Q}=Z;if($.type!=="Identifier")throw new u("Only simple parameter names are supported",m(Z));let K=$.name,H=X?.has(K)??!1,Y=z1(Q),z=A1(Q);return{name:K,type:Y,required:H,default:H?null:z,example:z,loc:{start:Z.start,end:Z.end}}}if(Z.type==="ObjectPattern"){let $=Z.properties,Q={},K={};for(let H of $)if(H.type==="Property"){let Y=H.key.type==="Identifier"?H.key.name:String(H.key.value);if(H.value.type==="Identifier")Q[Y]={kind:"any"},K[Y]={name:Y,type:{kind:"any"},required:!0};else if(H.value.type==="AssignmentPattern"){let z=P1(H.value,X),W=X?.has(Y)??!1;Q[Y]=z.type,K[Y]={name:Y,type:z.type,required:W,default:W?null:z.example,example:z.example}}}return{name:"__destructured__",type:{kind:"object",shape:Q,destructuredParams:K},required:!0}}throw new u(`Unsupported parameter pattern: ${Z.type}`,m(Z))}function A1(Z){switch(Z.type){case"Literal":return Z.value;case"ArrayExpression":return Z.elements.map((X)=>X?A1(X):null);case"ObjectExpression":{let X={};for(let $ of Z.properties)if($.type==="Property"&&$.key.type==="Identifier")X[$.key.name]=A1($.value);return X}case"UnaryExpression":if(Z.operator==="-"){let X=A1(Z.argument);return typeof X==="number"?-X:void 0}if(Z.operator==="+"){let X=A1(Z.argument);return typeof X==="number"?+X:void 0}return;case"BinaryExpression":{let{operator:X,left:$}=Z;if(X==="|")return A1($);return}case"LogicalExpression":{let{operator:X,left:$,right:Q}=Z;if(X==="&&"){if($.type==="Literal"&&$.value===null)return null}if(X==="||")return A1($)??A1(Q);if(X==="??")return A1($)??A1(Q);return}default:return}}function m6(Z){try{let X=b8(Z,0,{ecmaVersion:2022});return z1(X)}catch{return{kind:"any"}}}function C4(Z){switch(Z.kind){case"string":return Z.nullable?"string | null":"string";case"number":return Z.nullable?"number | null":"number";case"integer":return Z.nullable?"integer | null":"integer";case"non-negative-integer":return Z.nullable?"non-negative integer | null":"non-negative integer";case"boolean":return Z.nullable?"boolean | null":"boolean";case"null":return"null";case"any":return"any";case"array":{let X=Z.items?C4(Z.items):"any";return Z.nullable?`${X}[] | null`:`${X}[]`}case"object":{if(!Z.shape||Object.keys(Z.shape).length===0)return Z.nullable?"object | null":"object";let X=Object.entries(Z.shape).map(([$,Q])=>`${$}: ${C4(Q)}`).join(", ");return Z.nullable?`{ ${X} } | null`:`{ ${X} }`}case"union":return Z.members?.map(C4).join(" | ")||"any";default:return"any"}}function S0(Z){switch(Z.kind){case"string":return{type:"string"};case"number":return{type:"number"};case"boolean":return{type:"boolean"};case"null":return{};case"undefined":return{};case"any":return{};case"array":return{type:"array",items:Z.items?S0(Z.items):{}};case"object":if(Z.shape){let X={};for(let[$,Q]of Object.entries(Z.shape))X[$]=S0(Q);return{type:"object",properties:X,additionalProperties:!1}}return{type:"object"};case"union":if(Z.members)return{oneOf:Z.members.map(S0)};return{};default:return{}}}function v8(Z){let X={},$=[];for(let[Q,K]of Object.entries(Z))if(X[Q]=S0(K.type),K.required)$.push(Q);return{type:"object",properties:X,required:$.length>0?$:void 0,additionalProperties:!1}}function H0(Z,X,$,Q={},K){let H=X0(X,Z),Y=new Map;for(let M of Z.params){let I=P1(M,K);if(I.name==="__destructured__"&&I.type.kind==="object"&&I.type.destructuredParams)for(let[V,F]of Object.entries(I.type.destructuredParams))Y.set(V,{...F,description:H.params[V]});else I.description=H.params[I.name],Y.set(I.name,I)}let z;if($)z=m6($);let W={depth:0,locals:new Map,parameters:Y,atoms:new Set(Object.keys(Q.atoms||{})),warnings:[],source:X,filename:Q.filename||"<source>",options:Q},G=I1(Z.body,W),J=[],L=[],_=[];for(let[M,I]of Y.entries())if(I.required)L.push(M);else if(I.default!==void 0)_.push({name:M,defaultValue:I.default});else L.push(M);if(L.length>0)J.push({op:"varsImport",keys:L});for(let{name:M,defaultValue:I}of _)J.push({op:"varsImport",keys:[M]}),J.push({op:"if",condition:{$expr:"binary",op:"==",left:{$expr:"ident",name:M},right:{$expr:"literal",value:null}},then:[{op:"varSet",key:M,value:I}]});J.push(...G);let U=Object.fromEntries(Y),D={name:Z.id?.name||"anonymous",description:H.description,parameters:U,returns:z},R=v8(U);return{ast:{op:"seq",steps:J,inputSchema:R},signature:D,warnings:W.warnings}}function I1(Z,X){let $=[];for(let Q of Z.body){let K=Q0(Q,X);if(K)if(Array.isArray(K))$.push(...K);else $.push(K)}return $}function Q0(Z,X){switch(Z.type){case"VariableDeclaration":return f8(Z,X);case"ExpressionStatement":return y8(Z,X);case"IfStatement":return x8(Z,X);case"WhileStatement":return u8(Z,X);case"ForOfStatement":return d8(Z,X);case"TryStatement":return l8(Z,X);case"ReturnStatement":return m8(Z,X);case"ThrowStatement":throw new u("'throw' is not supported in AsyncJS. Use Error('message') to trigger error flow",m(Z),X.source,X.filename);case"BlockStatement":return{op:"scope",steps:I1(Z,W1(X))};case"EmptyStatement":return null;default:throw new u(`Unsupported statement type: ${Z.type}`,m(Z),X.source,X.filename)}}function f8(Z,X){let $=[],Q=Z.kind==="const",K=Q?"constSet":"varSet";for(let H of Z.declarations){if(H.id.type!=="Identifier")throw new u("Only simple variable names are supported",m(H),X.source,X.filename);let Y=H.id.name;if(H.init){let{step:z,resultVar:W}=S1(H.init,X,Y,Q);if(z)$.push(z);else if(W!==Y)$.push({op:K,key:Y,value:W});let G=z1(H.init);X.locals.set(Y,G)}else{if(Q)throw new u("const declarations must be initialized",m(H),X.source,X.filename);$.push({op:"varSet",key:Y,value:null}),X.locals.set(Y,{kind:"any",nullable:!0})}}return $}function y8(Z,X){let $=Z.expression;if($.type==="AssignmentExpression")return h8($,X);if($.type==="CallExpression"){let{step:Q,resultVar:K}=S1($,X);if(Q)return Q;if(K)return{op:"varSet",key:"_",value:K};return null}return X.warnings.push({message:"Expression statement has no effect",line:m(Z).line,column:m(Z).column}),null}function h8(Z,X){if(Z.left.type!=="Identifier")throw new u("Only simple variable assignment is supported",m(Z),X.source,X.filename);let $=Z.left.name,{step:Q,resultVar:K}=S1(Z.right,X,$);if(Q)return Q;return{op:"varSet",key:$,value:K}}function x8(Z,X){let $=x(Z.test,X),Q=Z.consequent.type==="BlockStatement"?I1(Z.consequent,W1(X)):[Q0(Z.consequent,X)].filter(Boolean),K;if(Z.alternate)K=Z.alternate.type==="BlockStatement"?I1(Z.alternate,W1(X)):[Q0(Z.alternate,X)].filter(Boolean);return{op:"if",condition:$,then:Q,...K&&{else:K}}}function u8(Z,X){let $=x(Z.test,X),Q=Z.body.type==="BlockStatement"?I1(Z.body,W1(X)):[Q0(Z.body,X)].filter(Boolean);return{op:"while",condition:$,body:Q}}function d8(Z,X){let $;if(Z.left.type==="VariableDeclaration"){let Y=Z.left.declarations[0];if(Y.id.type!=="Identifier")throw new u("Only simple variable names are supported in for...of",m(Z.left),X.source,X.filename);$=Y.id.name}else if(Z.left.type==="Identifier")$=Z.left.name;else throw new u("Unsupported for...of left-hand side",m(Z.left),X.source,X.filename);let Q=r(Z.right,X),K=W1(X);K.locals.set($,{kind:"any"});let H=Z.body.type==="BlockStatement"?I1(Z.body,K):[Q0(Z.body,K)].filter(Boolean);return{op:"map",items:Q,as:$,steps:H}}function l8(Z,X){let $=I1(Z.block,W1(X)),Q,K;if(Z.handler){let H=W1(X);if(Z.handler.param?.type==="Identifier")K=Z.handler.param.name,H.locals.set(K,{kind:"any"});Q=I1(Z.handler.body,H)}return{op:"try",try:$,...Q&&{catch:Q},...K&&{catchParam:K}}}function m8(Z,X){if(!Z.argument)return{op:"return",value:{}};let{step:$,resultVar:Q}=S1(Z.argument,X,"__returnVal__");if($)return[$,{op:"return",value:Q}];return{op:"return",value:r(Z.argument,X)}}var p6=new Set(["Math","JSON","Array","Object","String","Number","console","Date","Schema"]),i8=new Set(["parseInt","parseFloat","isNaN","isFinite","encodeURI","decodeURI","encodeURIComponent","decodeURIComponent","Set","Date","filter"]),K0=new Set(["RegExp","Promise","Map","WeakSet","WeakMap","Symbol","Proxy","Reflect","Function","eval","setTimeout","setInterval","fetch","require","import","process","window","document","global","globalThis"]),p8=new Set(["toUpperCase","toLowerCase","trim","trimStart","trimEnd","charAt","charCodeAt","codePointAt","concat","includes","indexOf","lastIndexOf","startsWith","endsWith","slice","substring","substr","replace","replaceAll","match","search","padStart","padEnd","repeat","normalize","localeCompare","toString","valueOf","at","reverse","sort","fill","copyWithin","flat","flatMap","every","some","forEach","add","remove","has","clear","toArray","union","intersection","diff","format","isBefore","isAfter"]);function n8(Z){if(Z.callee.type==="Identifier"){let X=Z.callee.name;return i8.has(X)||K0.has(X)}if(Z.callee.type==="MemberExpression"){let X=Z.callee;if(X.object.type==="Identifier"){let $=X.object.name;if(p6.has($)||K0.has($))return!0}if(X.property.type==="Identifier"){let $=X.property.name;if(p8.has($))return!0}}return!1}function c8(Z){if(Z.object.type==="Identifier"){let X=Z.object.name;return p6.has(X)||K0.has(X)}return!1}var i6={RegExp:"RegExp is not available. Use string methods or the regexMatch atom.",Promise:"Promise is not needed. All operations are implicitly async.",Map:"Map is not available. Use plain objects instead.",WeakSet:"WeakSet is not available.",WeakMap:"WeakMap is not available.",Symbol:"Symbol is not available.",Proxy:"Proxy is not available.",Reflect:"Reflect is not available.",Function:"Function constructor is not available. Define functions normally.",eval:"eval is not available. Code is compiled, not evaluated.",setTimeout:"setTimeout is not available. Use the delay atom.",setInterval:"setInterval is not available. Use while loops with delay.",fetch:"fetch is not available. Use the httpFetch atom.",require:"require is not available. Atoms must be registered with the VM.",import:"import is not available. Atoms must be registered with the VM.",process:"process is not available. AsyncJS runs in a sandboxed environment.",window:"window is not available. AsyncJS runs in a sandboxed environment.",document:"document is not available. AsyncJS runs in a sandboxed environment.",global:"global is not available. AsyncJS runs in a sandboxed environment.",globalThis:"globalThis is not available. Use builtins directly."};function o8(Z){if(Z.callee.type==="Identifier"){let X=Z.callee.name;if(K0.has(X))return i6[X]||`${X} is not available in AsyncJS.`}if(Z.callee.type==="MemberExpression"){let X=Z.callee;if(X.object.type==="Identifier"){let $=X.object.name;if(K0.has($))return i6[$]||`${$} is not available in AsyncJS.`}}return null}function n6(Z){return{Date:" Use Date() or Date('2024-01-15') instead - no 'new' needed.",Set:" Use Set([items]) instead - no 'new' needed.",Map:" Use plain objects instead of Map.",Array:" Use array literals like [1, 2, 3] instead.",Object:" Use object literals like { key: value } instead.",Error:" Return an error object like { error: 'message' } instead.",RegExp:" Use string methods or the regexMatch atom.",Promise:" Not needed - all operations are implicitly async.",WeakSet:" WeakSet is not available.",WeakMap:" WeakMap is not available."}[Z]||" Use factory functions or object literals instead."}function S1(Z,X,$,Q){let K=Q?"constSet":"varSet";if(Z.type==="ChainExpression")return S1(Z.expression,X,$,Q);if(Z.type==="NewExpression"){let Y=Z,z="constructor";if(Y.callee.type==="Identifier")z=Y.callee.name;let W=n6(z);throw new u(`The 'new' keyword is not supported in AsyncJS.${W}`,m(Z),X.source,X.filename)}if(Z.type==="CallExpression"){let Y=o8(Z);if(Y)throw new u(Y,m(Z),X.source,X.filename)}if(Z.type==="CallExpression"&&n8(Z)){let Y=x(Z,X);if($)return{step:{op:K,key:$,value:Y},resultVar:$};return{step:null,resultVar:Y}}if(Z.type==="MemberExpression"&&c8(Z)){let Y=x(Z,X);if($)return{step:{op:K,key:$,value:Y},resultVar:$};return{step:null,resultVar:Y}}if(Z.type==="CallExpression")return s8(Z,X,$,Q);if(Z.type==="TemplateLiteral")return r8(Z,X,$,Q);if(Z.type==="BinaryExpression"||Z.type==="LogicalExpression"||Z.type==="UnaryExpression"){let Y=x(Z,X);if($)return{step:{op:K,key:$,value:Y},resultVar:$};return{step:null,resultVar:Y}}return{step:null,resultVar:r(Z,X)}}function s8(Z,X,$,Q){let K,H=!1,Y;if(Z.callee.type==="Identifier")K=Z.callee.name;else if(Z.callee.type==="MemberExpression"){let W=Z.callee;if(W.property.type==="Identifier")K=W.property.name,H=!0,Y=r(W.object,X);else throw new u("Computed method names are not supported",m(Z),X.source,X.filename)}else throw new u("Only named function calls are supported",m(Z),X.source,X.filename);if(H)return a8(K,Y,Z.arguments,X,$,Q);if(K==="console"&&Z.callee.type==="MemberExpression");let z=t8(Z,X);return{step:{op:K,...z,...$&&{result:$},...$&&Q&&{resultConst:!0}},resultVar:$}}function a8(Z,X,$,Q,K,H){switch(Z){case"map":if($.length>0&&($[0].type==="ArrowFunctionExpression"||$[0].type==="FunctionExpression")){let Y=$[0],z=Y.params[0],W=z?.type==="Identifier"?z.name:"item",G=W1(Q);G.locals.set(W,{kind:"any"});let J;if(Y.body.type==="BlockStatement")J=I1(Y.body,G);else{let{step:L,resultVar:_}=S1(Y.body,G,"result");J=L?[L]:[{op:"varSet",key:"result",value:_}]}return{step:{op:"map",items:X,as:W,steps:J,...K&&{result:K},...K&&H&&{resultConst:!0}},resultVar:K}}break;case"filter":if($.length>0&&($[0].type==="ArrowFunctionExpression"||$[0].type==="FunctionExpression")){let Y=$[0],z=Y.params[0],W=z?.type==="Identifier"?z.name:"item",G=W1(Q);G.locals.set(W,{kind:"any"});let J;if(Y.body.type==="BlockStatement")throw new u("filter callback must be an expression, not a block",m($[0]),Q.source,Q.filename);else J=x(Y.body,G);return{step:{op:"filter",items:X,as:W,condition:J,...K&&{result:K},...K&&H&&{resultConst:!0}},resultVar:K}}break;case"find":if($.length>0&&($[0].type==="ArrowFunctionExpression"||$[0].type==="FunctionExpression")){let Y=$[0],z=Y.params[0],W=z?.type==="Identifier"?z.name:"item",G=W1(Q);G.locals.set(W,{kind:"any"});let J;if(Y.body.type==="BlockStatement")throw new u("find callback must be an expression, not a block",m($[0]),Q.source,Q.filename);else J=x(Y.body,G);return{step:{op:"find",items:X,as:W,condition:J,...K&&{result:K},...K&&H&&{resultConst:!0}},resultVar:K}}break;case"reduce":if($.length>=2&&($[0].type==="ArrowFunctionExpression"||$[0].type==="FunctionExpression")){let Y=$[0],z=Y.params[0],W=Y.params[1],G=z?.type==="Identifier"?z.name:"acc",J=W?.type==="Identifier"?W.name:"item",L=W1(Q);L.locals.set(G,{kind:"any"}),L.locals.set(J,{kind:"any"});let _;if(Y.body.type==="BlockStatement")_=I1(Y.body,L);else{let{step:D,resultVar:R}=S1(Y.body,L,"result");_=D?[D]:[{op:"varSet",key:"result",value:R}]}let U=r($[1],Q);return{step:{op:"reduce",items:X,as:J,accumulator:G,initial:U,steps:_,...K&&{result:K},...K&&H&&{resultConst:!0}},resultVar:K}}break;case"slice":break;case"push":return{step:{op:"push",list:X,item:r($[0],Q),...K&&{result:K},...K&&H&&{resultConst:!0}},resultVar:K};case"join":return{step:{op:"join",list:X,sep:$.length>0?r($[0],Q):"",...K&&{result:K},...K&&H&&{resultConst:!0}},resultVar:K};case"split":return{step:{op:"split",str:X,sep:$.length>0?r($[0],Q):"",...K&&{result:K},...K&&H&&{resultConst:!0}},resultVar:K}}return Q.warnings.push({message:`Unknown method '${Z}' - treating as atom call`,line:0,column:0}),{step:{op:Z,receiver:X,args:$.map((Y)=>r(Y,Q)),...K&&{result:K},...K&&H&&{resultConst:!0}},resultVar:K}}function r8(Z,X,$,Q){let K="",H={};for(let Y=0;Y<Z.quasis.length;Y++)if(K+=Z.quasis[Y].value.cooked||Z.quasis[Y].value.raw,Y<Z.expressions.length){let z=Z.expressions[Y],W=`_${Y}`;H[W]=r(z,X),K+=`{{${W}}}`}return{step:{op:"template",tmpl:K,vars:H,...$&&{result:$},...$&&Q&&{resultConst:!0}},resultVar:$}}function x(Z,X){switch(Z.type){case"Literal":return{$expr:"literal",value:Z.value};case"Identifier":return{$expr:"ident",name:Z.name};case"MemberExpression":{let $=Z,Q=x($.object,X),K=$.optional===!0;if($.computed){let Y=$.property;if(Y.type==="Literal")return{$expr:"member",object:Q,property:String(Y.value),computed:!0,...K&&{optional:!0}};throw new u("Computed member access with variables not yet supported",m(Z),X.source,X.filename)}let H=$.property.name;return{$expr:"member",object:Q,property:H,...K&&{optional:!0}}}case"ChainExpression":return x(Z.expression,X);case"BinaryExpression":{let $=Z;return{$expr:"binary",op:$.operator,left:x($.left,X),right:x($.right,X)}}case"LogicalExpression":{let $=Z;return{$expr:"logical",op:$.operator,left:x($.left,X),right:x($.right,X)}}case"UnaryExpression":{let $=Z;return{$expr:"unary",op:$.operator,argument:x($.argument,X)}}case"ConditionalExpression":{let $=Z;return{$expr:"conditional",test:x($.test,X),consequent:x($.consequent,X),alternate:x($.alternate,X)}}case"ArrayExpression":return{$expr:"array",elements:Z.elements.filter((Q)=>Q!==null).map((Q)=>x(Q,X))};case"ObjectExpression":{let $=Z,Q=[];for(let K of $.properties)if(K.type==="Property"){let H=K.key.type==="Identifier"?K.key.name:String(K.key.value);Q.push({key:H,value:x(K.value,X)})}return{$expr:"object",properties:Q}}case"CallExpression":{let $=Z;if($.callee.type==="MemberExpression"){let Q=$.callee,K=Q.property.type==="Identifier"?Q.property.name:String(Q.property.value),H=Q.optional===!0||$.optional===!0;return{$expr:"methodCall",object:x(Q.object,X),method:K,arguments:$.arguments.map((Y)=>x(Y,X)),...H&&{optional:!0}}}if($.callee.type==="Identifier")return{$expr:"call",callee:$.callee.name,arguments:$.arguments.map((K)=>x(K,X))};throw new u("Complex function calls in expressions should be lifted to statements",m(Z),X.source,X.filename)}case"NewExpression":{let $=Z,Q="constructor";if($.callee.type==="Identifier")Q=$.callee.name;let K=n6(Q);throw new u(`The 'new' keyword is not supported in AsyncJS.${K}`,m(Z),X.source,X.filename)}case"TemplateLiteral":throw new u("Template literals inside expressions are not supported. Assign to a variable first: const msg = `hello ${name}`; then use msg",m(Z),X.source,X.filename);default:throw new u(`Unsupported expression type in condition: ${Z.type}`,m(Z),X.source,X.filename)}}function r(Z,X){switch(Z.type){case"Literal":return Z.value;case"Identifier":return Z.name;case"MemberExpression":{let $=Z;if($.optional===!0)return x(Z,X);let K=r($.object,X);if(K&&typeof K==="object"&&K.$expr){let Y=$.computed?String($.property.value):$.property.name;return{$expr:"member",object:K,property:Y,...$.computed&&{computed:!0}}}if($.computed)return`${K}[${r($.property,X)}]`;let H=$.property.name;if(typeof K==="string")return`${K}.${H}`;if(K&&K.$kind==="arg")return{$kind:"arg",path:`${K.path}.${H}`};return`${K}.${H}`}case"ChainExpression":return r(Z.expression,X);case"ArrayExpression":return Z.elements.map(($)=>$?r($,X):null);case"ObjectExpression":{let $={};for(let Q of Z.properties)if(Q.type==="Property"){let K=Q.key.type==="Identifier"?Q.key.name:String(Q.key.value);$[K]=r(Q.value,X)}return $}case"TemplateLiteral":return x(Z,X);case"CallExpression":return x(Z,X);case"BinaryExpression":case"LogicalExpression":case"UnaryExpression":case"ConditionalExpression":return x(Z,X);default:return null}}function t8(Z,X){if(Z.arguments.length===1&&Z.arguments[0].type==="ObjectExpression"){let $=Z.arguments[0],Q={};for(let K of $.properties)if(K.type==="Property"){let H=K.key.type==="Identifier"?K.key.name:String(K.key.value);Q[H]=r(K.value,X)}return Q}return{args:Z.arguments.map(($)=>r($,X))}}import{parseExpressionAt as NZ}from"acorn";function e8(Z,X){let $=X;while($>0&&Z[$-1]!==`
|
|
44
|
+
`)$--;if(Z.slice($,X).includes("//"))return!0;let K=0,H=!1;while(K<X)if(!H&&Z.slice(K,K+2)==="/*")H=!0,K+=2;else if(H&&Z.slice(K,K+2)==="*/")H=!1,K+=2;else K++;return H}function ZZ(Z){let X=[],$=/\/\*test\s+(['"`])([^'"`]*)\1\s*\{([\s\S]*?)\}\s*\*\/|\/\*test\s*\{([\s\S]*?)\}\s*\*\//g,Q;while((Q=$.exec(Z))!==null){let K=Q[2]||`embedded test ${X.length+1}`,H=(Q[3]||Q[4]||"").trim();X.push({description:K,body:H,line:O4(Z,Q.index)})}return X}function N4(Z){let X=[],$=[],Q=ZZ(Z);X.push(...Q);let K=/test\s+(['"`])([^'"`]*)\1\s*\{|test\s*\(\s*(['"`])([^'"`]*)\3\s*\)\s*\{|test\s*\{/g,H=/mock\s*\{/g,Y=Z,z,W=[];while((z=K.exec(Z))!==null){let _=z.index;if(e8(Z,_))continue;let U=z[2]||z[4]||`test ${X.length+1}`,D=z.index+z[0].length,R=c6(Z,D-1);if(R===-1)continue;let M=Z.slice(D,R).trim();X.push({description:U,body:M,line:O4(Z,_)}),W.push({start:_,end:R+1,desc:U})}let G=[];while((z=H.exec(Z))!==null){let _=z.index,U=z.index+z[0].length,D=c6(Z,U-1);if(D===-1)continue;let R=Z.slice(U,D).trim();$.push({body:R,line:O4(Z,_)}),G.push({start:_,end:D+1})}let J=[...W,...G].sort((_,U)=>U.start-_.start);for(let _ of J)Y=Y.slice(0,_.start)+Y.slice(_.end);Y=Y.replace(/\n\s*\n\s*\n/g,`
|
|
45
45
|
|
|
46
|
-
`).trim();let L
|
|
47
|
-
`).length}function
|
|
46
|
+
`).trim();let L=$Z(X,$);return{code:Y,tests:X,mocks:$,testRunner:L}}function c6(Z,X){let $=0,Q=null,K=!1;for(let H=X;H<Z.length;H++){let Y=Z[H];if(K){K=!1;continue}if(Y==="\\"){K=!0;continue}if(!Q&&(Y==='"'||Y==="'"||Y==="`")){Q=Y;continue}if(Q===Y){Q=null;continue}if(Q)continue;if(Y==="{")$++;if(Y==="}"){if($--,$===0)return H}}return-1}function O4(Z,X){return Z.slice(0,X).split(`
|
|
47
|
+
`).length}function $Z(Z,X){if(Z.length===0)return"// No tests defined";let $=X.map((K)=>K.body).join(`
|
|
48
48
|
`);return`(async () => {
|
|
49
49
|
const __results = []
|
|
50
50
|
|
|
51
|
-
${Z.map((
|
|
52
|
-
// Test ${H+1}: ${
|
|
51
|
+
${Z.map((K,H)=>`
|
|
52
|
+
// Test ${H+1}: ${K.description}
|
|
53
53
|
try {
|
|
54
54
|
${$}
|
|
55
55
|
await (async () => {
|
|
56
|
-
${
|
|
56
|
+
${K.body}
|
|
57
57
|
})()
|
|
58
|
-
__results.push({ description: ${JSON.stringify(
|
|
58
|
+
__results.push({ description: ${JSON.stringify(K.description)}, passed: true })
|
|
59
59
|
} catch (__e) {
|
|
60
|
-
__results.push({ description: ${JSON.stringify(
|
|
60
|
+
__results.push({ description: ${JSON.stringify(K.description)}, passed: false, error: __e.message })
|
|
61
61
|
}`).join(`
|
|
62
62
|
`)}
|
|
63
63
|
|
|
@@ -67,13 +67,13 @@ const __failed = __results.filter(r => !r.passed).length
|
|
|
67
67
|
|
|
68
68
|
// Return summary
|
|
69
69
|
return { passed: __passed, failed: __failed, results: __results }
|
|
70
|
-
})()`.trim()}var
|
|
70
|
+
})()`.trim()}var o6=`
|
|
71
71
|
function assert(condition, message) {
|
|
72
72
|
if (!condition) {
|
|
73
73
|
throw new Error(message || 'Assertion failed')
|
|
74
74
|
}
|
|
75
75
|
}
|
|
76
|
-
`,
|
|
76
|
+
`,s6=`
|
|
77
77
|
function expect(actual) {
|
|
78
78
|
const deepEqual = (a, b) => {
|
|
79
79
|
if (a === b) return true
|
|
@@ -164,40 +164,40 @@ function expect(actual) {
|
|
|
164
164
|
}
|
|
165
165
|
}
|
|
166
166
|
}
|
|
167
|
-
`,
|
|
168
|
-
`+
|
|
169
|
-
`),
|
|
170
|
-
${
|
|
171
|
-
${Y}${
|
|
172
|
-
${H}}`}return String(Z)}function
|
|
167
|
+
`,XZ=o6+`
|
|
168
|
+
`+s6;function QZ(Z,X,$=0.000000001){if(Z===X)return!0;if(typeof Z==="number"&&typeof X==="number"){if(!Number.isInteger(Z)||!Number.isInteger(X)){let Q=Math.abs(Z-X),K=Math.max(Math.abs(Z),Math.abs(X),1);return Q/K<$}}return!1}function E4(Z,X){if(Z===X)return!0;if(typeof Z==="number"&&typeof X==="number"&&Number.isNaN(Z)&&Number.isNaN(X))return!0;if(QZ(Z,X))return!0;if(Z===null||X===null)return Z===X;if(Z===void 0||X===void 0)return Z===X;if(typeof Z!==typeof X)return!1;if(typeof Z!=="object")return!1;if(Array.isArray(Z)&&Array.isArray(X)){if(Z.length!==X.length)return!1;return Z.every((K,H)=>E4(K,X[H]))}if(Array.isArray(Z)!==Array.isArray(X))return!1;let $=Object.keys(Z),Q=Object.keys(X);if($.length!==Q.length)return!1;return $.every((K)=>E4(Z[K],X[K]))}function T4(Z,X,$=""){if(X===null){if(Z===null)return{matches:!0};return{matches:!1,error:`Expected null at '${$}', got ${k1(Z)}`}}if(X===void 0){if(Z===void 0)return{matches:!0};return{matches:!1,error:`Expected undefined at '${$}', got ${k1(Z)}`}}if(typeof X==="number"){if(typeof Z==="number")return{matches:!0};return{matches:!1,error:`Expected number at '${$}', got ${k1(Z)}`}}if(typeof X==="string"){if(typeof Z==="string")return{matches:!0};return{matches:!1,error:`Expected string at '${$}', got ${k1(Z)}`}}if(typeof X==="boolean"){if(typeof Z==="boolean")return{matches:!0};return{matches:!1,error:`Expected boolean at '${$}', got ${k1(Z)}`}}if(Array.isArray(X)){if(!Array.isArray(Z))return{matches:!1,error:`Expected array at '${$}', got ${k1(Z)}`};if(X.length===0)return{matches:!0};let Q=X[0];for(let K=0;K<Z.length;K++){let H=T4(Z[K],Q,`${$}[${K}]`);if(!H.matches)return H}return{matches:!0}}if(typeof X==="object"&&X!==null){if(typeof Z!=="object"||Z===null||Array.isArray(Z))return{matches:!1,error:`Expected object at '${$}', got ${k1(Z)}`};for(let Q of Object.keys(X)){let K=$?`${$}.${Q}`:Q;if(!(Q in Z))return{matches:!1,error:`Missing property '${K}'`};let H=T4(Z[Q],X[Q],K);if(!H.matches)return H}return{matches:!0}}if(Z===X)return{matches:!0};return{matches:!1,error:`Type mismatch at '${$}'`}}function k1(Z){if(Z===null)return"null";if(Z===void 0)return"undefined";if(Array.isArray(Z))return"array";return typeof Z}function Y0(Z,X=0){if(Z===null)return"null";if(Z===void 0)return"undefined";if(typeof Z==="string")return JSON.stringify(Z);if(typeof Z==="number")return String(Z);if(typeof Z==="boolean")return String(Z);if(Array.isArray(Z)){if(Z.length===0)return"[]";if(Z.length<=3)return`[${Z.map(($)=>Y0($,X)).join(", ")}]`;return`[${Z.slice(0,3).map(($)=>Y0($,X)).join(", ")}, ...]`}if(typeof Z==="object"){let $=Object.entries(Z);if($.length===0)return"{}";let Q=(W)=>/^[a-zA-Z_$][a-zA-Z0-9_$]*$/.test(W)?W:JSON.stringify(W);if($.length<=2)return`{${$.map(([G,J])=>`${Q(G)}: ${Y0(J,X)}`).join(", ")}}`;let K=" ".repeat(X+1),H=" ".repeat(X),Y=$.slice(0,8).map(([W,G])=>`${K}${Q(W)}: ${Y0(G,X+1)}`).join(`,
|
|
169
|
+
`),z=$.length>8?`,
|
|
170
|
+
${K}...`:"";return`{
|
|
171
|
+
${Y}${z}
|
|
172
|
+
${H}}`}return String(Z)}function KZ(Z){let X=Z.replace(/\/\*[\s\S]*?\*\//g,($)=>{let Q=$.split(`
|
|
173
173
|
`).length-1;return`
|
|
174
|
-
`.repeat(
|
|
175
|
-
`)}function
|
|
176
|
-
`).length;if(
|
|
177
|
-
`),_=Z.map((
|
|
178
|
-
// Test ${
|
|
174
|
+
`.repeat(Q)});return X=X.replace(/\/\/[^\n]*/g,""),X}function k0(Z){let X=Z.replace(/^import\s+.*?from\s+['"][^'"]+['"];?\s*$/gm,"");return X=X.replace(/^import\s+['"][^'"]+['"];?\s*$/gm,""),X=X.replace(/^export\s+default\s+/gm,""),X=X.replace(/^export\s+/gm,""),X=X.replace(/^(\s*)((?:const|let|var)\s+\w+\s*=\s*)?await\s+.+$/gm,"$1/* top-level await removed for test execution */"),X}function g0(Z){let X=Z.replace(/^const __tjs = globalThis\.__tjs\?\.createRuntime\?\.\(\) \?\? globalThis\.__tjs;\n?/m,"");return X=X.replace(/^const \{ (?:Is|IsNot|Is, IsNot) \} = __tjs \?\? \{\};\n?/m,""),X}function HZ(Z){if(Object.keys(Z).length===0)return"";let X=[];for(let[$,Q]of Object.entries(Z)){let K=k0(Q);K=g0(K),X.push(`// Resolved import: ${$}`),X.push(K)}return X.join(`
|
|
175
|
+
`)}function YZ(Z){let X={},$=Z.trim();if(!$.startsWith("{")||!$.includes("="))try{return{pattern:Function(`return ${Z}`)(),defaults:X}}catch{return null}let Q="",K=0,H=0;while(H<$.length){let Y=$[H];if(Y==="{"||Y==="["||Y==="(")K++,Q+=Y,H++;else if(Y==="}"||Y==="]"||Y===")")K--,Q+=Y,H++;else if(Y==="'"||Y==='"'||Y==="`"){let z=Y;Q+=Y,H++;while(H<$.length&&$[H]!==z){if($[H]==="\\")Q+=$[H++];Q+=$[H++]}if(H<$.length)Q+=$[H++]}else if(K===1&&Y==="="){let G=(Q.slice(Q.lastIndexOf("{")+1).split(",").pop()||"").match(/\s*(\w+)\s*$/);if(G){let J=H+1;while(J<$.length&&/\s/.test($[J]))J++;let L="",_=0;while(J<$.length){let U=$[J];if(U==="{"||U==="["||U==="(")_++;else if(U==="}"||U==="]"||U===")"){if(_===0)break;_--}else if(U===","&&_===0)break;L+=U,J++}try{X[G[1]]=Function(`return ${L.trim()}`)()}catch{}Q+=":",H++;continue}Q+=Y,H++}else Q+=Y,H++}try{return{pattern:Function(`return ${Q}`)(),defaults:X}}catch{return null}}function a6(Z){let X=[],$=KZ(Z),Q=/(async\s+)?function\s+(\w+)\s*\(([^)]*)\)\s*(-[>?])\s*/g,K;while((K=Q.exec($))!==null){let H=!!K[1],Y=K[2],z=K[3],W=K[4],G=$.slice(0,K.index).split(`
|
|
176
|
+
`).length;if(W==="-!")continue;let J=$.slice(K.index+K[0].length),L=S4(J);if(!L)continue;let _=zZ(z);if(z.trim()&&_.length===0)continue;try{let U=YZ(L);if(!U)continue;let D=_.map((R)=>Function(`return ${R}`)());X.push({funcName:Y,args:D,expected:U.pattern,defaults:Object.keys(U.defaults).length>0?U.defaults:void 0,line:G,isAsync:H})}catch{}}return X}function r6(Z,X,$,Q,K={},H=new Map){let Y=[];if(Z.length===0&&$.length===0)return Y;let z=Q.match(/^import\s+.*?from\s+['"]([^'"]+)['"];?\s*$/gm)||[],W=z.length>0&&z.some((F)=>{let j=F.match(/from\s+['"]([^'"]+)['"]/);return j&&!(j[1]in K)}),G=k0(Q);G=g0(G);let J=HZ(K),L=X.map((F)=>F.body).join(`
|
|
177
|
+
`),_=Z.map((F,j)=>{let B=H.size>0?$0(F.body,H):F.body;return`
|
|
178
|
+
// Test ${j}: ${F.description}
|
|
179
179
|
try {
|
|
180
|
-
${
|
|
181
|
-
__testResults.push({ idx: ${
|
|
180
|
+
${B}
|
|
181
|
+
__testResults.push({ idx: ${j}, passed: true });
|
|
182
182
|
} catch (e) {
|
|
183
|
-
__testResults.push({ idx: ${
|
|
183
|
+
__testResults.push({ idx: ${j}, passed: false, error: e.message || String(e) });
|
|
184
184
|
}
|
|
185
185
|
`}).join(`
|
|
186
|
-
`),U=$.filter((
|
|
187
|
-
// Signature test ${
|
|
186
|
+
`),U=$.filter((F)=>!F.isAsync),D=$.filter((F)=>F.isAsync),R=U.map((F,j)=>`
|
|
187
|
+
// Signature test ${j}: ${F.funcName}
|
|
188
188
|
try {
|
|
189
|
-
let __actual = ${
|
|
190
|
-
const __expected = ${JSON.stringify(
|
|
191
|
-
const __defaults = ${JSON.stringify(
|
|
189
|
+
let __actual = ${F.funcName}(${F.args.map((B)=>JSON.stringify(B)).join(", ")});
|
|
190
|
+
const __expected = ${JSON.stringify(F.expected)};${F.defaults?`
|
|
191
|
+
const __defaults = ${JSON.stringify(F.defaults)};
|
|
192
192
|
if (typeof __actual === 'object' && __actual !== null) __actual = Object.assign({}, __defaults, __actual);`:""}
|
|
193
|
-
const __typeResult = __typeMatches(__actual, __expected, '${
|
|
193
|
+
const __typeResult = __typeMatches(__actual, __expected, '${F.funcName}');
|
|
194
194
|
if (__typeResult.matches) {
|
|
195
|
-
__sigTestResults.push({ idx: ${
|
|
195
|
+
__sigTestResults.push({ idx: ${j}, passed: true });
|
|
196
196
|
} else {
|
|
197
|
-
__sigTestResults.push({ idx: ${
|
|
197
|
+
__sigTestResults.push({ idx: ${j}, passed: false, error: __typeResult.error || 'Type mismatch: got ' + __format(__actual) });
|
|
198
198
|
}
|
|
199
199
|
} catch (e) {
|
|
200
|
-
__sigTestResults.push({ idx: ${
|
|
200
|
+
__sigTestResults.push({ idx: ${j}, passed: false, error: e.message || String(e) });
|
|
201
201
|
}
|
|
202
202
|
`).join(`
|
|
203
203
|
`),V=`
|
|
@@ -274,29 +274,29 @@ ${H}}`}return String(Z)}function e8(Z){let X=Z.replace(/\/\*[\s\S]*?\*\//g,($)=>
|
|
|
274
274
|
${J}
|
|
275
275
|
|
|
276
276
|
// Execute the module code ONCE
|
|
277
|
-
${
|
|
277
|
+
${G}
|
|
278
278
|
${L}
|
|
279
279
|
|
|
280
280
|
// Run explicit test blocks
|
|
281
281
|
${_}
|
|
282
282
|
|
|
283
283
|
// Run signature tests
|
|
284
|
-
${
|
|
284
|
+
${R}
|
|
285
285
|
|
|
286
286
|
} finally {
|
|
287
287
|
${"globalThis.__tjs = __saved_tjs;"}
|
|
288
288
|
}
|
|
289
289
|
return { testResults: __testResults, sigTestResults: __sigTestResults };
|
|
290
|
-
`;try{let
|
|
291
|
-
`)}var g0={Int8Array:{elementType:"i32",bytesPerElement:1,loadOp:q.i32_load8_s,storeOp:q.i32_store8},Uint8Array:{elementType:"i32",bytesPerElement:1,loadOp:q.i32_load8_u,storeOp:q.i32_store8},Uint8ClampedArray:{elementType:"i32",bytesPerElement:1,loadOp:q.i32_load8_u,storeOp:q.i32_store8},Int16Array:{elementType:"i32",bytesPerElement:2,loadOp:q.i32_load16_s,storeOp:q.i32_store16},Uint16Array:{elementType:"i32",bytesPerElement:2,loadOp:q.i32_load16_u,storeOp:q.i32_store16},Int32Array:{elementType:"i32",bytesPerElement:4,loadOp:q.i32_load,storeOp:q.i32_store},Uint32Array:{elementType:"i32",bytesPerElement:4,loadOp:q.i32_load,storeOp:q.i32_store},Float32Array:{elementType:"f32",bytesPerElement:4,loadOp:q.f32_load,storeOp:q.f32_store},Float64Array:{elementType:"f64",bytesPerElement:8,loadOp:q.f64_load,storeOp:q.f64_store}};function zZ(Z){let X={params:Z,locals:new Map,nextLocalIndex:Z.length,localTypes:[],warnings:[],errors:[],loopDepth:0,needsMathImports:new Set,needsMemory:!1,hasReturn:!1,wat:[],watIndent:1};return Z.forEach(($,K)=>{X.locals.set($.name,{index:K,type:$.type})}),X}function k0(Z,X,$){if(Z.locals.has(X))return Z.errors.push(`Duplicate local declaration: ${X}`),Z.locals.get(X).index;let K=Z.nextLocalIndex++;return Z.locals.set(X,{index:K,type:$}),Z.localTypes.push($),K}function g1(Z,X){return Z.locals.get(X)}function d1(Z,X){switch(Z.type){case"ExpressionStatement":{let $=Z.expression;return[...h($,X),q.drop]}case"ReturnStatement":{let $=Z;if(X.hasReturn=!0,!$.argument)return[q.return];let K=h($.argument,X),Q=m($.argument,X);if(Q==="i32")K.push(q.f64_convert_i32_s);else if(Q==="f32")K.push(q.f64_promote_f32);return K.push(q.return),K}case"VariableDeclaration":{let $=Z,K=[];for(let Q of $.declarations){if(Q.id.type!=="Identifier"){X.errors.push("Destructuring not supported in WASM blocks");continue}let H=Q.id.name,Y="f64";if(Q.init)Y=m(Q.init,X);let G=k0(X,H,Y);if(Q.init)K.push(...h(Q.init,X)),K.push(q.local_set,...f(G))}return K}case"ForStatement":return WZ(Z,X);case"IfStatement":return JZ(Z,X);case"BlockStatement":{let $=Z,K=[];for(let Q of $.body)K.push(...d1(Q,X));return K}default:return X.errors.push(`Unsupported statement type: ${Z.type}`),[]}}function WZ(Z,X){let $=[];if(Z.init)if(Z.init.type==="VariableDeclaration")$.push(...d1(Z.init,X));else $.push(...h(Z.init,X));if($.push(q.block,q1.void),$.push(q.loop,q1.void),Z.test)$.push(...h(Z.test,X)),$.push(q.i32_eqz),$.push(q.br_if,1);if(X.loopDepth++,Z.body)$.push(...d1(Z.body,X));if(X.loopDepth--,Z.update)$.push(...h(Z.update,X)),$.push(q.drop);return $.push(q.br,0),$.push(q.end),$.push(q.end),$}function JZ(Z,X){let $=[];if($.push(...h(Z.test,X)),$.push(q.if,q1.void),$.push(...d1(Z.consequent,X)),Z.alternate)$.push(q.else),$.push(...d1(Z.alternate,X));return $.push(q.end),$}function m(Z,X){switch(Z.type){case"Literal":{let $=Z;if(typeof $.value==="number"){if($.raw&&($.raw.includes(".")||$.raw.includes("e")))return"f64";if(Number.isInteger($.value)&&$.value>=-2147483648&&$.value<=2147483647)return"i32";return"f64"}return"f64"}case"Identifier":return g1(X,Z.name)?.type??"f64";case"BinaryExpression":case"AssignmentExpression":{let $=Z;if(["<",">","<=",">=","==","!=","===","!=="].includes($.operator))return"i32";if(["|","&","^","<<",">>",">>>"].includes($.operator))return"i32";let K=m($.left,X),Q=m($.right,X);if(K==="v128"||Q==="v128")return"v128";if(K==="f64"||Q==="f64")return"f64";if(K==="f32"||Q==="f32")return"f32";return"i32"}case"UnaryExpression":{let $=Z;if($.operator==="!")return"i32";return m($.argument,X)}case"MemberExpression":{let $=Z;if($.object.type==="Identifier"){if(g1(X,$.object.name)){let Q=X.params.find((H)=>H.name===$.object.name);if(Q?.arrayType){let H=g0[Q.arrayType];if(H)return H.elementType}}}return"f64"}case"CallExpression":{let $=Z;if($.callee.type==="MemberExpression"){let K=$.callee;if(K.object.type==="Identifier"&&K.object.name==="Math")return"f64"}if($.callee.type==="Identifier"){let K=$.callee.name;if(K==="f32x4_extract_lane")return"f32";if(K.startsWith("f32x4_")||K==="v128_load")return"v128"}return"f64"}default:return"f64"}}function h(Z,X){switch(Z.type){case"Literal":{let $=Z;if(typeof $.value==="number"){let K=m(Z,X);if(K==="i32")return[q.i32_const,...z0($.value|0)];else if(K==="f32")return[q.f32_const,...S4($.value)];else return[q.f64_const,...W1($.value)]}return X.errors.push(`Unsupported literal type: ${typeof $.value}`),[q.f64_const,...W1(0)]}case"Identifier":{let $=Z.name,K=g1(X,$);if(K)return[q.local_get,...f(K.index)];return X.errors.push(`Unknown identifier: ${$}`),[q.f64_const,...W1(0)]}case"BinaryExpression":return _Z(Z,X);case"UnaryExpression":return LZ(Z,X);case"AssignmentExpression":return UZ(Z,X);case"UpdateExpression":return qZ(Z,X);case"MemberExpression":return DZ(Z,X);case"CallExpression":return BZ(Z,X);case"SequenceExpression":{let $=Z,K=[];for(let Q=0;Q<$.expressions.length;Q++)if(K.push(...h($.expressions[Q],X)),Q<$.expressions.length-1)K.push(q.drop);return K}default:return X.errors.push(`Unsupported expression type: ${Z.type}`),[q.f64_const,...W1(0)]}}function _Z(Z,X){let $=h(Z.left,X),K=h(Z.right,X),Q=m(Z,X),H=m(Z.left,X),Y=m(Z.right,X),G=["<",">","<=",">=","==","===","!=","!=="].includes(Z.operator),z;if(H==="f64"||Y==="f64")z="f64";else if(H==="f32"||Y==="f32")z="f32";else z="i32";if(!G&&Q==="f64")z="f64";let W=$,J=K;if(z==="f64"){if(H==="i32")W=[...$,q.f64_convert_i32_s];else if(H==="f32")W=[...$,q.f64_promote_f32];if(Y==="i32")J=[...K,q.f64_convert_i32_s];else if(Y==="f32")J=[...K,q.f64_promote_f32]}else if(z==="f32"){if(H==="i32")W=[...$,q.f32_convert_i32_s];if(Y==="i32")J=[...K,q.f32_convert_i32_s]}let _={"+":{i32:q.i32_add,f32:q.f32_add,f64:q.f64_add},"-":{i32:q.i32_sub,f32:q.f32_sub,f64:q.f64_sub},"*":{i32:q.i32_mul,f32:q.f32_mul,f64:q.f64_mul},"/":{i32:q.i32_div_s,f32:q.f32_div,f64:q.f64_div},"%":{i32:q.i32_rem_s},"<":{i32:q.i32_lt_s,f32:q.f32_lt,f64:q.f64_lt},">":{i32:q.i32_gt_s,f32:q.f32_gt,f64:q.f64_gt},"<=":{i32:q.i32_le_s,f32:q.f32_le,f64:q.f64_le},">=":{i32:q.i32_ge_s,f32:q.f32_ge,f64:q.f64_ge},"==":{i32:q.i32_eq,f32:q.f32_eq,f64:q.f64_eq},"===":{i32:q.i32_eq,f32:q.f32_eq,f64:q.f64_eq},"!=":{i32:q.i32_ne,f32:q.f32_ne,f64:q.f64_ne},"!==":{i32:q.i32_ne,f32:q.f32_ne,f64:q.f64_ne},"|":{i32:q.i32_or},"&":{i32:q.i32_and},"^":{i32:q.i32_xor},"<<":{i32:q.i32_shl},">>":{i32:q.i32_shr_s},">>>":{i32:q.i32_shr_u}}[Z.operator];if(!_)return X.errors.push(`Unsupported operator: ${Z.operator}`),[q.f64_const,...W1(0)];let U=_[z]??_.f64??_.i32;if(U===void 0)return X.errors.push(`Operator ${Z.operator} not supported for type ${z}`),[q.f64_const,...W1(0)];return[...W,...J,U]}function LZ(Z,X){let $=h(Z.argument,X),K=m(Z.argument,X);switch(Z.operator){case"-":if(K==="i32")return[q.i32_const,0,...$,q.i32_sub];else if(K==="f32")return[...$,q.f32_neg];else return[...$,q.f64_neg];case"!":return[...$,q.i32_eqz];case"~":return[...$,q.i32_const,...z0(-1),q.i32_xor];default:return X.errors.push(`Unsupported unary operator: ${Z.operator}`),$}}function UZ(Z,X){if(Z.left.type==="MemberExpression")return RZ(Z.left,Z.right,Z.operator,X);if(Z.left.type!=="Identifier")return X.errors.push("Assignment target must be identifier or array element"),[];let $=Z.left.name,K=g1(X,$);if(!K)return X.errors.push(`Unknown variable: ${$}`),[];let Q=[];if(Z.operator==="="){Q.push(...h(Z.right,X));let H=m(Z.right,X);if(K.type==="f64"&&H==="i32")Q.push(q.f64_convert_i32_s);else if(K.type==="f64"&&H==="f32")Q.push(q.f64_promote_f32);else if(K.type==="i32"&&H==="f64")Q.push(q.i32_trunc_f64_s);else if(K.type==="i32"&&H==="f32")Q.push(q.i32_trunc_f32_s);else if(K.type==="f32"&&H==="i32")Q.push(q.f32_convert_i32_s);else if(K.type==="f32"&&H==="f64")Q.push(q.f32_demote_f64)}else{let H=m(Z.right,X),Y=K.type;if(H==="f64"||K.type==="f64")Y="f64";else if(H==="f32"||K.type==="f32")Y="f32";if(Q.push(q.local_get,...f(K.index)),Y==="f64"&&K.type==="i32")Q.push(q.f64_convert_i32_s);else if(Y==="f64"&&K.type==="f32")Q.push(q.f64_promote_f32);else if(Y==="f32"&&K.type==="i32")Q.push(q.f32_convert_i32_s);if(Q.push(...h(Z.right,X)),Y==="f64"&&H==="i32")Q.push(q.f64_convert_i32_s);else if(Y==="f64"&&H==="f32")Q.push(q.f64_promote_f32);else if(Y==="f32"&&H==="i32")Q.push(q.f32_convert_i32_s);let G=Z.operator.slice(0,-1),W={"+":{i32:q.i32_add,f32:q.f32_add,f64:q.f64_add},"-":{i32:q.i32_sub,f32:q.f32_sub,f64:q.f64_sub},"*":{i32:q.i32_mul,f32:q.f32_mul,f64:q.f64_mul},"/":{i32:q.i32_div_s,f32:q.f32_div,f64:q.f64_div}}[G]?.[Y];if(!W)return X.errors.push(`Unsupported compound assignment: ${Z.operator}`),[];if(Q.push(W),K.type==="i32"&&Y==="f64")Q.push(q.i32_trunc_f64_s);else if(K.type==="i32"&&Y==="f32")Q.push(q.i32_trunc_f32_s);else if(K.type==="f32"&&Y==="f64")Q.push(q.f32_demote_f64)}return Q.push(q.local_tee,...f(K.index)),Q}function qZ(Z,X){if(Z.argument.type!=="Identifier")return X.errors.push("Update expression argument must be identifier"),[];let $=Z.argument.name,K=g1(X,$);if(!K)return X.errors.push(`Unknown variable: ${$}`),[];let Q=[],H=K.type==="i32";if(Z.prefix){if(Q.push(q.local_get,...f(K.index)),H)Q.push(q.i32_const,1),Q.push(Z.operator==="++"?q.i32_add:q.i32_sub);else Q.push(q.f64_const,...W1(1)),Q.push(Z.operator==="++"?q.f64_add:q.f64_sub);Q.push(q.local_tee,...f(K.index))}else{if(Q.push(q.local_get,...f(K.index)),Q.push(q.local_get,...f(K.index)),H)Q.push(q.i32_const,1),Q.push(Z.operator==="++"?q.i32_add:q.i32_sub);else Q.push(q.f64_const,...W1(1)),Q.push(Z.operator==="++"?q.f64_add:q.f64_sub);Q.push(q.local_set,...f(K.index))}return Q}function DZ(Z,X){if(Z.object.type!=="Identifier")return X.errors.push("Array access requires identifier"),[];let $=Z.object.name,K=X.params.find((W)=>W.name===$);if(!K?.isArray||!K.arrayType)return X.errors.push(`${$} is not a typed array parameter`),[];let Q=g0[K.arrayType];if(!Q)return X.errors.push(`Unknown array type: ${K.arrayType}`),[];X.needsMemory=!0;let H=[],Y=g1(X,$);if(!Y)return X.errors.push(`Unknown array: ${$}`),[];if(H.push(q.local_get,...f(Y.index)),!Z.computed||!Z.property)return X.errors.push("Array access requires computed index"),[];let G=h(Z.property,X),z=m(Z.property,X);if(H.push(...G),z==="f64")H.push(q.i32_trunc_f64_s);if(Q.bytesPerElement>1)H.push(q.i32_const,...z0(Q.bytesPerElement)),H.push(q.i32_mul);return H.push(q.i32_add),H.push(Q.loadOp,0,0),H}function RZ(Z,X,$,K){if(Z.object.type!=="Identifier")return K.errors.push("Array store requires identifier"),[];let Q=Z.object.name,H=K.params.find((R)=>R.name===Q);if(!H?.isArray||!H.arrayType)return K.errors.push(`${Q} is not a typed array parameter`),[];let Y=g0[H.arrayType];if(!Y)return K.errors.push(`Unknown array type: ${H.arrayType}`),[];K.needsMemory=!0;let G=[],z=g1(K,Q);if(!z)return[];if(!Z.computed||!Z.property)return K.errors.push("Array store requires computed index"),[];let W=h(Z.property,K),J=m(Z.property,K),L=()=>{let R=[];if(R.push(q.local_get,...f(z.index)),R.push(...W),J==="f64")R.push(q.i32_trunc_f64_s);if(Y.bytesPerElement>1)R.push(q.i32_const,...z0(Y.bytesPerElement)),R.push(q.i32_mul);return R.push(q.i32_add),R};if($==="=")G.push(...h(X,K));else{let R=k0(K,`__addr_${K.nextLocalIndex}`,"i32");G.push(...L()),G.push(q.local_tee,...f(R)),G.push(Y.loadOp,0,0),G.push(...h(X,K));let M=m(X,K);if(Y.elementType==="f32"&&M==="f64")G.push(q.f32_demote_f64);else if(Y.elementType==="f64"&&M==="f32")G.push(q.f64_promote_f32);else if(Y.elementType==="f32"&&M==="i32")G.push(q.f32_convert_i32_s);else if(Y.elementType==="f64"&&M==="i32")G.push(q.f64_convert_i32_s);else if(Y.elementType==="i32"&&M==="f64")G.push(q.i32_trunc_f64_s);else if(Y.elementType==="i32"&&M==="f32")G.push(q.i32_trunc_f32_s);let w=$.slice(0,-1),I={"+":Y.elementType==="i32"?q.i32_add:Y.elementType==="f32"?q.f32_add:q.f64_add,"-":Y.elementType==="i32"?q.i32_sub:Y.elementType==="f32"?q.f32_sub:q.f64_sub,"*":Y.elementType==="i32"?q.i32_mul:Y.elementType==="f32"?q.f32_mul:q.f64_mul};G.push(I[w]??q.f64_add);let V=k0(K,`__val_${K.nextLocalIndex}`,Y.elementType);return G.push(q.local_set,...f(V)),G.push(q.local_get,...f(R)),G.push(q.local_get,...f(V)),G.push(Y.storeOp,0,0),G.push(q.local_get,...f(V)),G}let _=m(X,K);if(Y.elementType==="f32"&&_==="f64")G.push(q.f32_demote_f64);else if(Y.elementType==="f64"&&_==="f32")G.push(q.f64_promote_f32);else if(Y.elementType==="i32"&&_==="f64")G.push(q.i32_trunc_f64_s);let U=k0(K,`__tmp_${K.nextLocalIndex}`,Y.elementType);if(G.push(q.local_set,...f(U)),G.push(q.local_get,...f(z.index)),G.push(...W),J==="f64")G.push(q.i32_trunc_f64_s);if(Y.bytesPerElement>1)G.push(q.i32_const,...z0(Y.bytesPerElement)),G.push(q.i32_mul);return G.push(q.i32_add),G.push(q.local_get,...f(U)),G.push(Y.storeOp,0,0),G.push(q.local_get,...f(U)),G}function BZ(Z,X){if(Z.callee.type==="MemberExpression"){let $=Z.callee;if($.object.type==="Identifier"&&$.object.name==="Math"&&$.property.type==="Identifier"){let K=$.property.name;return AZ(K,Z.arguments,X)}}if(Z.callee.type==="Identifier"){let $=Z.callee.name;if($.startsWith("f32x4_")||$.startsWith("v128_"))return IZ($,Z.arguments,X)}return X.errors.push(`Unsupported function call: ${Z.callee.type}`),[q.f64_const,...W1(0)]}function IZ(Z,X,$){$.needsMemory=!0;let K=[];switch(Z){case"v128_load":case"f32x4_load":{if(K.push(...h(X[0],$)),m(X[0],$)==="f64")K.push(q.i32_trunc_f64_s);K.push(...h(X[1],$));let H=m(X[1],$);if(H==="f64")K.push(q.i32_trunc_f64_s);else if(H==="f32")K.push(q.i32_trunc_f32_s);return K.push(q.i32_add),K.push(...s6(t.v128_load,2,0)),K}case"v128_store":case"f32x4_store":{if(K.push(...h(X[0],$)),m(X[0],$)==="f64")K.push(q.i32_trunc_f64_s);K.push(...h(X[1],$));let H=m(X[1],$);if(H==="f64")K.push(q.i32_trunc_f64_s);else if(H==="f32")K.push(q.i32_trunc_f32_s);return K.push(q.i32_add),K.push(...h(X[2],$)),K.push(...s6(t.v128_store,2,0)),K.push(q.i32_const,0),K}case"f32x4_splat":{K.push(...h(X[0],$));let Q=m(X[0],$);if(Q==="i32")K.push(q.f32_convert_i32_s);else if(Q==="f64")K.push(q.f32_demote_f64);return K.push(...E4(t.f32x4_splat)),K}case"f32x4_extract_lane":{K.push(...h(X[0],$));let Q=X[1].value;if(!Number.isInteger(Q)||Q<0||Q>3)return $.errors.push(`f32x4_extract_lane: lane must be 0-3, got ${Q}`),[q.f32_const,...S4(0)];return K.push(G0,...f(t.f32x4_extract_lane),Q),K}case"f32x4_replace_lane":{K.push(...h(X[0],$));let Q=X[1].value;if(!Number.isInteger(Q)||Q<0||Q>3)return $.errors.push(`f32x4_replace_lane: lane must be 0-3, got ${Q}`),[q.f32_const,...S4(0)];K.push(...h(X[2],$));let H=m(X[2],$);if(H==="i32")K.push(q.f32_convert_i32_s);else if(H==="f64")K.push(q.f32_demote_f64);return K.push(G0,...f(t.f32x4_replace_lane),Q),K}case"f32x4_add":case"f32x4_sub":case"f32x4_mul":case"f32x4_div":{K.push(...h(X[0],$)),K.push(...h(X[1],$));let Q={f32x4_add:t.f32x4_add,f32x4_sub:t.f32x4_sub,f32x4_mul:t.f32x4_mul,f32x4_div:t.f32x4_div};return K.push(...E4(Q[Z])),K}case"f32x4_neg":case"f32x4_sqrt":{K.push(...h(X[0],$));let Q={f32x4_neg:t.f32x4_neg,f32x4_sqrt:t.f32x4_sqrt};return K.push(...E4(Q[Z])),K}default:return $.errors.push(`Unknown SIMD intrinsic: ${Z}`),[q.f64_const,...W1(0)]}}function AZ(Z,X,$){let K=[];for(let G of X){K.push(...h(G,$));let z=m(G,$);if(z==="i32")K.push(q.f64_convert_i32_s);else if(z==="f32")K.push(q.f64_promote_f32)}let H={abs:q.f64_abs,ceil:q.f64_ceil,floor:q.f64_floor,trunc:q.f64_trunc,sqrt:q.f64_sqrt,min:q.f64_min,max:q.f64_max}[Z];if(H!==void 0)return K.push(H),K;if(["sin","cos","tan","asin","acos","atan","atan2","exp","log","pow"].includes(Z))return $.needsMathImports.add(Z),$.errors.push(`Math.${Z} requires JS import (not yet implemented)`),[q.f64_const,...W1(0)];return $.errors.push(`Unknown Math method: ${Z}`),[q.f64_const,...W1(0)]}function r6(Z){let X=Z.split(":").map((H)=>H.trim()),$=X[0];if(X.length===1)return{name:$,type:"f64"};let K=X[1];if(g0[K])return{name:$,type:"i32",isArray:!0,arrayType:K};return{name:$,type:{i32:"i32",i64:"i64",f32:"f32",f64:"f64",number:"f64",int:"i32"}[K]??"f64"}}function FZ(Z,X,$,K,Q){let H=[0,97,115,109,1,0,0,0],Y=Z.map((V)=>q1[V.type]),G=Q?[1,q1.f64]:[0],z=Y0(H0.type,[1,96,...f(Z.length),...Y,...G]),W=[],J=[];if(K)J=Y0(H0.import,[1,...T4("env"),...T4("memory"),2,0,1]);let L=Y0(H0.function,[1,0]),_=Y0(H0.export,[1,...T4("compute"),0,0]),U=[];if($.length>0){let V=$[0],A=1;for(let B=1;B<$.length;B++)if($[B]===V)A++;else U.push([...f(A),q1[V]]),V=$[B],A=1;U.push([...f(A),q1[V]])}let M=[...[...f(U.length),...U.flat()],...X,q.end],w=Y0(H0.code,[1,...f(M.length),...M]),I=[...H,...z];if(J.length>0)I.push(...J);return I.push(...L,..._,...w),I}function b0(Z){try{let X=Z.captures.map(r6),$;try{let W=`function __wasm__(${X.map((J)=>J.name).join(", ")}) { ${Z.body} }`;$=a6.parse(W,{ecmaVersion:2022})}catch(W){return{bytes:new Uint8Array,warnings:[],success:!1,error:`Parse error: ${W.message}`}}let Q=$.body[0].body.body,H=zZ(X),Y=[];for(let W of Q)Y.push(...d1(W,H));if(H.errors.length>0)return{bytes:new Uint8Array,warnings:H.warnings,success:!1,error:H.errors.join("; ")};let G=FZ(X,Y,H.localTypes,H.needsMemory,H.hasReturn),z=GZ(Y,X,H.localTypes);return{bytes:new Uint8Array(G),warnings:H.warnings,success:!0,needsMemory:H.needsMemory,wat:z}}catch(X){return{bytes:new Uint8Array,warnings:[],success:!1,error:X.message}}}async function t6(Z,X){let $={};if(X)$.env={memory:X};let K=await WebAssembly.compile(Z);return WebAssembly.instantiate(K,$)}async function MZ(Z){let X=b0(Z);if(!X.success)return{fn:()=>0,success:!1,error:X.error};try{let $;if(X.needsMemory)$=new WebAssembly.Memory({initial:256});let Q=(await t6(X.bytes,$)).exports.compute,H=Z.captures.map(r6);if(!H.some((z)=>z.isArray))return{fn:Q,memory:$,success:!0};return{fn:(...z)=>{if(!$)throw Error("Memory not initialized");let W=new Uint8Array($.buffer),J=0,L=[];for(let U=0;U<H.length;U++){let R=H[U],M=z[U];if(R.isArray&&M instanceof Object&&"buffer"in M){let w=M,I=new Uint8Array(w.buffer,w.byteOffset,w.byteLength);W.set(I,J),L.push(J),J+=I.length,J=J+15&-16}else L.push(M)}let _=Q(...L);J=0;for(let U=0;U<H.length;U++){let R=H[U],M=z[U];if(R.isArray&&M instanceof Object&&"buffer"in M){let w=M,I=new Uint8Array(w.buffer,w.byteOffset,w.byteLength);I.set(W.slice(J,J+I.length)),J+=I.length,J=J+15&-16}}return _},memory:$,success:!0}}catch($){return{fn:()=>0,success:!1,error:$.message}}}async function e6(Z){let X=await MZ(Z);if(!X.success)return console.warn(`WASM compilation failed for ${Z.id}:`,X.error),!1;return globalThis[Z.id]=X.fn,!0}async function wZ(Z){let X=0,$=0,K=[];for(let Q of Z)if(await e6(Q))X++;else $++,K.push(`Failed to compile ${Q.id}`);return{compiled:X,failed:$,errors:K}}function Z7(Z){let X=[],$=[];for(let G of Z){let z=b0(G);if(z.success){let W=btoa(String.fromCharCode(...z.bytes));$.push({id:G.id,base64:W,captures:G.captures,needsMemory:z.needsMemory??!1,wat:z.wat??""}),X.push({id:G.id,success:!0,byteLength:z.bytes.length})}else X.push({id:G.id,success:!1,error:z.error})}if($.length===0)return{code:"",results:X};let K=$.map((G)=>{let z=G.wat.split(`
|
|
292
|
-
`).map((
|
|
293
|
-
* WASM: ${
|
|
294
|
-
${
|
|
290
|
+
`;try{let F=Function("__deepEqual","__format","__typeMatches",V),{testResults:j,sigTestResults:B}=F(E4,Y0,T4);for(let P of j){let C=Z[P.idx],O=W&&!P.passed&&P.error&&/is not defined$/.test(P.error);Y.push({description:C.description,passed:O?!0:P.passed,error:O?void 0:P.error,line:C.line})}for(let P of B){let C=U[P.idx],O=W&&!P.passed&&P.error&&/is not defined$/.test(P.error);Y.push({description:`${C.funcName} signature example`,passed:O?!0:P.passed,error:O?void 0:P.error,isSignatureTest:!0,line:C.line})}}catch(F){let j=W&&F instanceof ReferenceError;for(let B of Z)Y.push({description:B.description,passed:j,error:j?void 0:`Module execution failed: ${F.message}`,line:B.line});for(let B of U)Y.push({description:`${B.funcName} signature example`,passed:j,error:j?void 0:`Module execution failed: ${F.message}`,isSignatureTest:!0,line:B.line})}for(let F of D)Y.push({description:`${F.funcName} signature example`,passed:!0,isSignatureTest:!0,line:F.line});return Y}function S4(Z){let X="",$=0,Q=!1;for(let H=0;H<Z.length;H++){let Y=Z[H];if(Y==="{"||Y==="["||Y==="("){if(Y==="{"&&$===0&&Q)break;$++,X+=Y,Q=!0}else if(Y==="}"||Y==="]"||Y===")")$--,X+=Y;else if(!/\s/.test(Y))X+=Y,Q=!0;else X+=Y}return X.trim()||null}function zZ(Z){if(!Z.trim())return[];let X=[],$=WZ(Z);for(let Q of $){let K=Q.match(/(?:\(\s*[?!]\s*)?(\w+)\s*[:=]\s*(.+?)(?:\))?$/);if(K)X.push(K[2].trim());else return[]}return X}function WZ(Z){let X=[],$="",Q=0;for(let K of Z){if(K==="("||K==="["||K==="{")Q++;else if(K===")"||K==="]"||K==="}")Q--;else if(K===","&&Q===0){X.push($.trim()),$="";continue}$+=K}if($.trim())X.push($.trim());return X}import*as e6 from"acorn";var q1={i32:127,i64:126,f32:125,f64:124,v128:123,funcref:112,externref:111,void:64},z0={custom:0,type:1,import:2,function:3,table:4,memory:5,global:6,export:7,start:8,element:9,code:10,data:11},q={unreachable:0,nop:1,block:2,loop:3,if:4,else:5,end:11,br:12,br_if:13,br_table:14,return:15,call:16,call_indirect:17,drop:26,select:27,local_get:32,local_set:33,local_tee:34,global_get:35,global_set:36,i32_load:40,i64_load:41,f32_load:42,f64_load:43,i32_load8_s:44,i32_load8_u:45,i32_load16_s:46,i32_load16_u:47,i32_store:54,i64_store:55,f32_store:56,f64_store:57,i32_store8:58,i32_store16:59,memory_size:63,memory_grow:64,i32_const:65,i64_const:66,f32_const:67,f64_const:68,i32_eqz:69,i32_eq:70,i32_ne:71,i32_lt_s:72,i32_lt_u:73,i32_gt_s:74,i32_gt_u:75,i32_le_s:76,i32_le_u:77,i32_ge_s:78,i32_ge_u:79,i64_eqz:80,i64_eq:81,i64_ne:82,i64_lt_s:83,i64_lt_u:84,i64_gt_s:85,i64_gt_u:86,i64_le_s:87,i64_le_u:88,i64_ge_s:89,i64_ge_u:90,f32_eq:91,f32_ne:92,f32_lt:93,f32_gt:94,f32_le:95,f32_ge:96,f64_eq:97,f64_ne:98,f64_lt:99,f64_gt:100,f64_le:101,f64_ge:102,i32_clz:103,i32_ctz:104,i32_popcnt:105,i32_add:106,i32_sub:107,i32_mul:108,i32_div_s:109,i32_div_u:110,i32_rem_s:111,i32_rem_u:112,i32_and:113,i32_or:114,i32_xor:115,i32_shl:116,i32_shr_s:117,i32_shr_u:118,i32_rotl:119,i32_rotr:120,i64_add:124,i64_sub:125,i64_mul:126,i64_div_s:127,f32_abs:139,f32_neg:140,f32_ceil:141,f32_floor:142,f32_trunc:143,f32_nearest:144,f32_sqrt:145,f32_add:146,f32_sub:147,f32_mul:148,f32_div:149,f32_min:150,f32_max:151,f32_copysign:152,f64_abs:153,f64_neg:154,f64_ceil:155,f64_floor:156,f64_trunc:157,f64_nearest:158,f64_sqrt:159,f64_add:160,f64_sub:161,f64_mul:162,f64_div:163,f64_min:164,f64_max:165,f64_copysign:166,i32_wrap_i64:167,i32_trunc_f32_s:168,i32_trunc_f32_u:169,i32_trunc_f64_s:170,i32_trunc_f64_u:171,i64_extend_i32_s:172,i64_extend_i32_u:173,f32_convert_i32_s:178,f32_convert_i32_u:179,f32_convert_i64_s:180,f32_demote_f64:182,f64_convert_i32_s:183,f64_convert_i32_u:184,f64_convert_i64_s:185,f64_promote_f32:187,i32_reinterpret_f32:188,f32_reinterpret_i32:190,f64_reinterpret_i64:191,i32_extend8_s:192,i32_extend16_s:193},GZ=Object.fromEntries(Object.entries(q).map(([Z,X])=>[X,Z.replace(/_/g,".")])),G0=253,t={v128_load:0,v128_store:11,v128_const:12,f32x4_splat:19,f32x4_extract_lane:31,f32x4_replace_lane:32,f32x4_neg:225,f32x4_sqrt:227,f32x4_add:228,f32x4_sub:229,f32x4_mul:230,f32x4_div:231},JZ=Object.fromEntries(Object.entries(t).map(([Z,X])=>[X,Z.replace(/_/g,".")]));function k4(Z){return[G0,...f(Z)]}function t6(Z,X,$){return[G0,...f(Z),...f(X),...f($)]}function f(Z){let X=[];do{let $=Z&127;if(Z>>>=7,Z!==0)$|=128;X.push($)}while(Z!==0);return X}function J0(Z){let X=[],$=!0;while($){let Q=Z&127;if(Z>>=7,Z===0&&(Q&64)===0||Z===-1&&(Q&64)!==0)$=!1;else Q|=128;X.push(Q)}return X}function b4(Z){let X=new ArrayBuffer(4);return new Float32Array(X)[0]=Z,[...new Uint8Array(X)]}function G1(Z){let X=new ArrayBuffer(8);return new Float64Array(X)[0]=Z,[...new Uint8Array(X)]}function g4(Z){let X=new TextEncoder().encode(Z);return[...f(X.length),...X]}function W0(Z,X){return[Z,...f(X.length),...X]}function V1(Z,X){let $=0,Q=0,K=X;while(K<Z.length){let H=Z[K];if($|=(H&127)<<Q,K++,(H&128)===0)break;Q+=7}return[$,K-X]}function _Z(Z,X){let $=new ArrayBuffer(8),Q=new Uint8Array($);for(let K=0;K<8;K++)Q[K]=Z[X+K];return new Float64Array($)[0]}function LZ(Z,X,$){let Q=[],K=1,H=()=>" ".repeat(K),Y=X.map((G,J)=>`(param $${G.name} ${G.type})`).join(" "),z=$.map((G,J)=>`(local $L${X.length+J} ${G})`).join(" ");if(Q.push(`(func (export "compute") ${Y} (result f64)`),z)Q.push(` ${z}`);let W=0;while(W<Z.length){let G=Z[W],J=GZ[G]||`unknown(0x${G.toString(16)})`;if(W++,G===q.local_get||G===q.local_set||G===q.local_tee){let[L,_]=V1(Z,W);W+=_;let U=L<X.length?`$${X[L].name}`:`$L${L}`;Q.push(`${H()}${J} ${U}`)}else if(G===q.br||G===q.br_if){let[L,_]=V1(Z,W);W+=_,Q.push(`${H()}${J} ${L}`)}else if(G===q.i32_const){let[L,_]=V1(Z,W);W+=_,Q.push(`${H()}i32.const ${L}`)}else if(G===q.f32_const){let L=new ArrayBuffer(4),_=new Uint8Array(L);for(let D=0;D<4;D++)_[D]=Z[W+D];let U=new Float32Array(L)[0];W+=4,Q.push(`${H()}f32.const ${U}`)}else if(G===q.f64_const){let L=_Z(Z,W);W+=8,Q.push(`${H()}f64.const ${L}`)}else if(G===q.block||G===q.loop){let L=Z[W];W++,Q.push(`${H()}${J}${L===q1.void?"":` (result ${L===q1.f64?"f64":"i32"})`}`),K++}else if(G===q.if){let L=Z[W];W++,Q.push(`${H()}if${L===q1.void?"":` (result ${L===q1.f64?"f64":"i32"})`}`),K++}else if(G===q.else)K--,Q.push(`${H()}else`),K++;else if(G===q.end)K=Math.max(1,K-1),Q.push(`${H()}end`);else if(G===q.f64_load||G===q.f64_store||G===q.f32_load||G===q.f32_store||G===q.i32_load||G===q.i32_store){let[L,_]=V1(Z,W);W+=_;let[U,D]=V1(Z,W);W+=D,Q.push(`${H()}${J}${U?` offset=${U}`:""}`)}else if(G===G0){let[L,_]=V1(Z,W);W+=_;let U=JZ[L]||`simd.unknown(0x${L.toString(16)})`;if(L===t.v128_load||L===t.v128_store){let[D,R]=V1(Z,W);W+=R;let[M,I]=V1(Z,W);W+=I,Q.push(`${H()}${U}${M?` offset=${M}`:""}`)}else if(L===t.v128_const){let D=Z.slice(W,W+16);W+=16,Q.push(`${H()}v128.const ${D.map((R)=>"0x"+R.toString(16).padStart(2,"0")).join(" ")}`)}else if(L===t.f32x4_extract_lane||L===t.f32x4_replace_lane){let D=Z[W];W++,Q.push(`${H()}${U} ${D}`)}else Q.push(`${H()}${U}`)}else Q.push(`${H()}${J}`)}return Q.push(")"),Q.join(`
|
|
291
|
+
`)}var v0={Int8Array:{elementType:"i32",bytesPerElement:1,loadOp:q.i32_load8_s,storeOp:q.i32_store8},Uint8Array:{elementType:"i32",bytesPerElement:1,loadOp:q.i32_load8_u,storeOp:q.i32_store8},Uint8ClampedArray:{elementType:"i32",bytesPerElement:1,loadOp:q.i32_load8_u,storeOp:q.i32_store8},Int16Array:{elementType:"i32",bytesPerElement:2,loadOp:q.i32_load16_s,storeOp:q.i32_store16},Uint16Array:{elementType:"i32",bytesPerElement:2,loadOp:q.i32_load16_u,storeOp:q.i32_store16},Int32Array:{elementType:"i32",bytesPerElement:4,loadOp:q.i32_load,storeOp:q.i32_store},Uint32Array:{elementType:"i32",bytesPerElement:4,loadOp:q.i32_load,storeOp:q.i32_store},Float32Array:{elementType:"f32",bytesPerElement:4,loadOp:q.f32_load,storeOp:q.f32_store},Float64Array:{elementType:"f64",bytesPerElement:8,loadOp:q.f64_load,storeOp:q.f64_store}};function UZ(Z){let X={params:Z,locals:new Map,nextLocalIndex:Z.length,localTypes:[],warnings:[],errors:[],loopDepth:0,needsMathImports:new Set,needsMemory:!1,hasReturn:!1,wat:[],watIndent:1};return Z.forEach(($,Q)=>{X.locals.set($.name,{index:Q,type:$.type})}),X}function b0(Z,X,$){if(Z.locals.has(X))return Z.errors.push(`Duplicate local declaration: ${X}`),Z.locals.get(X).index;let Q=Z.nextLocalIndex++;return Z.locals.set(X,{index:Q,type:$}),Z.localTypes.push($),Q}function g1(Z,X){return Z.locals.get(X)}function d1(Z,X){switch(Z.type){case"ExpressionStatement":{let $=Z.expression;return[...h($,X),q.drop]}case"ReturnStatement":{let $=Z;if(X.hasReturn=!0,!$.argument)return[q.return];let Q=h($.argument,X),K=i($.argument,X);if(K==="i32")Q.push(q.f64_convert_i32_s);else if(K==="f32")Q.push(q.f64_promote_f32);return Q.push(q.return),Q}case"VariableDeclaration":{let $=Z,Q=[];for(let K of $.declarations){if(K.id.type!=="Identifier"){X.errors.push("Destructuring not supported in WASM blocks");continue}let H=K.id.name,Y="f64";if(K.init)Y=i(K.init,X);let z=b0(X,H,Y);if(K.init)Q.push(...h(K.init,X)),Q.push(q.local_set,...f(z))}return Q}case"ForStatement":return qZ(Z,X);case"IfStatement":return DZ(Z,X);case"BlockStatement":{let $=Z,Q=[];for(let K of $.body)Q.push(...d1(K,X));return Q}default:return X.errors.push(`Unsupported statement type: ${Z.type}`),[]}}function qZ(Z,X){let $=[];if(Z.init)if(Z.init.type==="VariableDeclaration")$.push(...d1(Z.init,X));else $.push(...h(Z.init,X));if($.push(q.block,q1.void),$.push(q.loop,q1.void),Z.test)$.push(...h(Z.test,X)),$.push(q.i32_eqz),$.push(q.br_if,1);if(X.loopDepth++,Z.body)$.push(...d1(Z.body,X));if(X.loopDepth--,Z.update)$.push(...h(Z.update,X)),$.push(q.drop);return $.push(q.br,0),$.push(q.end),$.push(q.end),$}function DZ(Z,X){let $=[];if($.push(...h(Z.test,X)),$.push(q.if,q1.void),$.push(...d1(Z.consequent,X)),Z.alternate)$.push(q.else),$.push(...d1(Z.alternate,X));return $.push(q.end),$}function i(Z,X){switch(Z.type){case"Literal":{let $=Z;if(typeof $.value==="number"){if($.raw&&($.raw.includes(".")||$.raw.includes("e")))return"f64";if(Number.isInteger($.value)&&$.value>=-2147483648&&$.value<=2147483647)return"i32";return"f64"}return"f64"}case"Identifier":return g1(X,Z.name)?.type??"f64";case"BinaryExpression":case"AssignmentExpression":{let $=Z;if(["<",">","<=",">=","==","!=","===","!=="].includes($.operator))return"i32";if(["|","&","^","<<",">>",">>>"].includes($.operator))return"i32";let Q=i($.left,X),K=i($.right,X);if(Q==="v128"||K==="v128")return"v128";if(Q==="f64"||K==="f64")return"f64";if(Q==="f32"||K==="f32")return"f32";return"i32"}case"UnaryExpression":{let $=Z;if($.operator==="!")return"i32";return i($.argument,X)}case"MemberExpression":{let $=Z;if($.object.type==="Identifier"){if(g1(X,$.object.name)){let K=X.params.find((H)=>H.name===$.object.name);if(K?.arrayType){let H=v0[K.arrayType];if(H)return H.elementType}}}return"f64"}case"CallExpression":{let $=Z;if($.callee.type==="MemberExpression"){let Q=$.callee;if(Q.object.type==="Identifier"&&Q.object.name==="Math")return"f64"}if($.callee.type==="Identifier"){let Q=$.callee.name;if(Q==="f32x4_extract_lane")return"f32";if(Q.startsWith("f32x4_")||Q==="v128_load")return"v128"}return"f64"}default:return"f64"}}function h(Z,X){switch(Z.type){case"Literal":{let $=Z;if(typeof $.value==="number"){let Q=i(Z,X);if(Q==="i32")return[q.i32_const,...J0($.value|0)];else if(Q==="f32")return[q.f32_const,...b4($.value)];else return[q.f64_const,...G1($.value)]}return X.errors.push(`Unsupported literal type: ${typeof $.value}`),[q.f64_const,...G1(0)]}case"Identifier":{let $=Z.name,Q=g1(X,$);if(Q)return[q.local_get,...f(Q.index)];return X.errors.push(`Unknown identifier: ${$}`),[q.f64_const,...G1(0)]}case"BinaryExpression":return AZ(Z,X);case"UnaryExpression":return IZ(Z,X);case"AssignmentExpression":return BZ(Z,X);case"UpdateExpression":return RZ(Z,X);case"MemberExpression":return MZ(Z,X);case"CallExpression":return FZ(Z,X);case"SequenceExpression":{let $=Z,Q=[];for(let K=0;K<$.expressions.length;K++)if(Q.push(...h($.expressions[K],X)),K<$.expressions.length-1)Q.push(q.drop);return Q}default:return X.errors.push(`Unsupported expression type: ${Z.type}`),[q.f64_const,...G1(0)]}}function AZ(Z,X){let $=h(Z.left,X),Q=h(Z.right,X),K=i(Z,X),H=i(Z.left,X),Y=i(Z.right,X),z=["<",">","<=",">=","==","===","!=","!=="].includes(Z.operator),W;if(H==="f64"||Y==="f64")W="f64";else if(H==="f32"||Y==="f32")W="f32";else W="i32";if(!z&&K==="f64")W="f64";let G=$,J=Q;if(W==="f64"){if(H==="i32")G=[...$,q.f64_convert_i32_s];else if(H==="f32")G=[...$,q.f64_promote_f32];if(Y==="i32")J=[...Q,q.f64_convert_i32_s];else if(Y==="f32")J=[...Q,q.f64_promote_f32]}else if(W==="f32"){if(H==="i32")G=[...$,q.f32_convert_i32_s];if(Y==="i32")J=[...Q,q.f32_convert_i32_s]}let _={"+":{i32:q.i32_add,f32:q.f32_add,f64:q.f64_add},"-":{i32:q.i32_sub,f32:q.f32_sub,f64:q.f64_sub},"*":{i32:q.i32_mul,f32:q.f32_mul,f64:q.f64_mul},"/":{i32:q.i32_div_s,f32:q.f32_div,f64:q.f64_div},"%":{i32:q.i32_rem_s},"<":{i32:q.i32_lt_s,f32:q.f32_lt,f64:q.f64_lt},">":{i32:q.i32_gt_s,f32:q.f32_gt,f64:q.f64_gt},"<=":{i32:q.i32_le_s,f32:q.f32_le,f64:q.f64_le},">=":{i32:q.i32_ge_s,f32:q.f32_ge,f64:q.f64_ge},"==":{i32:q.i32_eq,f32:q.f32_eq,f64:q.f64_eq},"===":{i32:q.i32_eq,f32:q.f32_eq,f64:q.f64_eq},"!=":{i32:q.i32_ne,f32:q.f32_ne,f64:q.f64_ne},"!==":{i32:q.i32_ne,f32:q.f32_ne,f64:q.f64_ne},"|":{i32:q.i32_or},"&":{i32:q.i32_and},"^":{i32:q.i32_xor},"<<":{i32:q.i32_shl},">>":{i32:q.i32_shr_s},">>>":{i32:q.i32_shr_u}}[Z.operator];if(!_)return X.errors.push(`Unsupported operator: ${Z.operator}`),[q.f64_const,...G1(0)];let U=_[W]??_.f64??_.i32;if(U===void 0)return X.errors.push(`Operator ${Z.operator} not supported for type ${W}`),[q.f64_const,...G1(0)];return[...G,...J,U]}function IZ(Z,X){let $=h(Z.argument,X),Q=i(Z.argument,X);switch(Z.operator){case"-":if(Q==="i32")return[q.i32_const,0,...$,q.i32_sub];else if(Q==="f32")return[...$,q.f32_neg];else return[...$,q.f64_neg];case"!":return[...$,q.i32_eqz];case"~":return[...$,q.i32_const,...J0(-1),q.i32_xor];default:return X.errors.push(`Unsupported unary operator: ${Z.operator}`),$}}function BZ(Z,X){if(Z.left.type==="MemberExpression")return wZ(Z.left,Z.right,Z.operator,X);if(Z.left.type!=="Identifier")return X.errors.push("Assignment target must be identifier or array element"),[];let $=Z.left.name,Q=g1(X,$);if(!Q)return X.errors.push(`Unknown variable: ${$}`),[];let K=[];if(Z.operator==="="){K.push(...h(Z.right,X));let H=i(Z.right,X);if(Q.type==="f64"&&H==="i32")K.push(q.f64_convert_i32_s);else if(Q.type==="f64"&&H==="f32")K.push(q.f64_promote_f32);else if(Q.type==="i32"&&H==="f64")K.push(q.i32_trunc_f64_s);else if(Q.type==="i32"&&H==="f32")K.push(q.i32_trunc_f32_s);else if(Q.type==="f32"&&H==="i32")K.push(q.f32_convert_i32_s);else if(Q.type==="f32"&&H==="f64")K.push(q.f32_demote_f64)}else{let H=i(Z.right,X),Y=Q.type;if(H==="f64"||Q.type==="f64")Y="f64";else if(H==="f32"||Q.type==="f32")Y="f32";if(K.push(q.local_get,...f(Q.index)),Y==="f64"&&Q.type==="i32")K.push(q.f64_convert_i32_s);else if(Y==="f64"&&Q.type==="f32")K.push(q.f64_promote_f32);else if(Y==="f32"&&Q.type==="i32")K.push(q.f32_convert_i32_s);if(K.push(...h(Z.right,X)),Y==="f64"&&H==="i32")K.push(q.f64_convert_i32_s);else if(Y==="f64"&&H==="f32")K.push(q.f64_promote_f32);else if(Y==="f32"&&H==="i32")K.push(q.f32_convert_i32_s);let z=Z.operator.slice(0,-1),G={"+":{i32:q.i32_add,f32:q.f32_add,f64:q.f64_add},"-":{i32:q.i32_sub,f32:q.f32_sub,f64:q.f64_sub},"*":{i32:q.i32_mul,f32:q.f32_mul,f64:q.f64_mul},"/":{i32:q.i32_div_s,f32:q.f32_div,f64:q.f64_div}}[z]?.[Y];if(!G)return X.errors.push(`Unsupported compound assignment: ${Z.operator}`),[];if(K.push(G),Q.type==="i32"&&Y==="f64")K.push(q.i32_trunc_f64_s);else if(Q.type==="i32"&&Y==="f32")K.push(q.i32_trunc_f32_s);else if(Q.type==="f32"&&Y==="f64")K.push(q.f32_demote_f64)}return K.push(q.local_tee,...f(Q.index)),K}function RZ(Z,X){if(Z.argument.type!=="Identifier")return X.errors.push("Update expression argument must be identifier"),[];let $=Z.argument.name,Q=g1(X,$);if(!Q)return X.errors.push(`Unknown variable: ${$}`),[];let K=[],H=Q.type==="i32";if(Z.prefix){if(K.push(q.local_get,...f(Q.index)),H)K.push(q.i32_const,1),K.push(Z.operator==="++"?q.i32_add:q.i32_sub);else K.push(q.f64_const,...G1(1)),K.push(Z.operator==="++"?q.f64_add:q.f64_sub);K.push(q.local_tee,...f(Q.index))}else{if(K.push(q.local_get,...f(Q.index)),K.push(q.local_get,...f(Q.index)),H)K.push(q.i32_const,1),K.push(Z.operator==="++"?q.i32_add:q.i32_sub);else K.push(q.f64_const,...G1(1)),K.push(Z.operator==="++"?q.f64_add:q.f64_sub);K.push(q.local_set,...f(Q.index))}return K}function MZ(Z,X){if(Z.object.type!=="Identifier")return X.errors.push("Array access requires identifier"),[];let $=Z.object.name,Q=X.params.find((G)=>G.name===$);if(!Q?.isArray||!Q.arrayType)return X.errors.push(`${$} is not a typed array parameter`),[];let K=v0[Q.arrayType];if(!K)return X.errors.push(`Unknown array type: ${Q.arrayType}`),[];X.needsMemory=!0;let H=[],Y=g1(X,$);if(!Y)return X.errors.push(`Unknown array: ${$}`),[];if(H.push(q.local_get,...f(Y.index)),!Z.computed||!Z.property)return X.errors.push("Array access requires computed index"),[];let z=h(Z.property,X),W=i(Z.property,X);if(H.push(...z),W==="f64")H.push(q.i32_trunc_f64_s);if(K.bytesPerElement>1)H.push(q.i32_const,...J0(K.bytesPerElement)),H.push(q.i32_mul);return H.push(q.i32_add),H.push(K.loadOp,0,0),H}function wZ(Z,X,$,Q){if(Z.object.type!=="Identifier")return Q.errors.push("Array store requires identifier"),[];let K=Z.object.name,H=Q.params.find((D)=>D.name===K);if(!H?.isArray||!H.arrayType)return Q.errors.push(`${K} is not a typed array parameter`),[];let Y=v0[H.arrayType];if(!Y)return Q.errors.push(`Unknown array type: ${H.arrayType}`),[];Q.needsMemory=!0;let z=[],W=g1(Q,K);if(!W)return[];if(!Z.computed||!Z.property)return Q.errors.push("Array store requires computed index"),[];let G=h(Z.property,Q),J=i(Z.property,Q),L=()=>{let D=[];if(D.push(q.local_get,...f(W.index)),D.push(...G),J==="f64")D.push(q.i32_trunc_f64_s);if(Y.bytesPerElement>1)D.push(q.i32_const,...J0(Y.bytesPerElement)),D.push(q.i32_mul);return D.push(q.i32_add),D};if($==="=")z.push(...h(X,Q));else{let D=b0(Q,`__addr_${Q.nextLocalIndex}`,"i32");z.push(...L()),z.push(q.local_tee,...f(D)),z.push(Y.loadOp,0,0),z.push(...h(X,Q));let R=i(X,Q);if(Y.elementType==="f32"&&R==="f64")z.push(q.f32_demote_f64);else if(Y.elementType==="f64"&&R==="f32")z.push(q.f64_promote_f32);else if(Y.elementType==="f32"&&R==="i32")z.push(q.f32_convert_i32_s);else if(Y.elementType==="f64"&&R==="i32")z.push(q.f64_convert_i32_s);else if(Y.elementType==="i32"&&R==="f64")z.push(q.i32_trunc_f64_s);else if(Y.elementType==="i32"&&R==="f32")z.push(q.i32_trunc_f32_s);let M=$.slice(0,-1),I={"+":Y.elementType==="i32"?q.i32_add:Y.elementType==="f32"?q.f32_add:q.f64_add,"-":Y.elementType==="i32"?q.i32_sub:Y.elementType==="f32"?q.f32_sub:q.f64_sub,"*":Y.elementType==="i32"?q.i32_mul:Y.elementType==="f32"?q.f32_mul:q.f64_mul};z.push(I[M]??q.f64_add);let V=b0(Q,`__val_${Q.nextLocalIndex}`,Y.elementType);return z.push(q.local_set,...f(V)),z.push(q.local_get,...f(D)),z.push(q.local_get,...f(V)),z.push(Y.storeOp,0,0),z.push(q.local_get,...f(V)),z}let _=i(X,Q);if(Y.elementType==="f32"&&_==="f64")z.push(q.f32_demote_f64);else if(Y.elementType==="f64"&&_==="f32")z.push(q.f64_promote_f32);else if(Y.elementType==="i32"&&_==="f64")z.push(q.i32_trunc_f64_s);let U=b0(Q,`__tmp_${Q.nextLocalIndex}`,Y.elementType);if(z.push(q.local_set,...f(U)),z.push(q.local_get,...f(W.index)),z.push(...G),J==="f64")z.push(q.i32_trunc_f64_s);if(Y.bytesPerElement>1)z.push(q.i32_const,...J0(Y.bytesPerElement)),z.push(q.i32_mul);return z.push(q.i32_add),z.push(q.local_get,...f(U)),z.push(Y.storeOp,0,0),z.push(q.local_get,...f(U)),z}function FZ(Z,X){if(Z.callee.type==="MemberExpression"){let $=Z.callee;if($.object.type==="Identifier"&&$.object.name==="Math"&&$.property.type==="Identifier"){let Q=$.property.name;return PZ(Q,Z.arguments,X)}}if(Z.callee.type==="Identifier"){let $=Z.callee.name;if($.startsWith("f32x4_")||$.startsWith("v128_"))return jZ($,Z.arguments,X)}return X.errors.push(`Unsupported function call: ${Z.callee.type}`),[q.f64_const,...G1(0)]}function jZ(Z,X,$){$.needsMemory=!0;let Q=[];switch(Z){case"v128_load":case"f32x4_load":{if(Q.push(...h(X[0],$)),i(X[0],$)==="f64")Q.push(q.i32_trunc_f64_s);Q.push(...h(X[1],$));let H=i(X[1],$);if(H==="f64")Q.push(q.i32_trunc_f64_s);else if(H==="f32")Q.push(q.i32_trunc_f32_s);return Q.push(q.i32_add),Q.push(...t6(t.v128_load,2,0)),Q}case"v128_store":case"f32x4_store":{if(Q.push(...h(X[0],$)),i(X[0],$)==="f64")Q.push(q.i32_trunc_f64_s);Q.push(...h(X[1],$));let H=i(X[1],$);if(H==="f64")Q.push(q.i32_trunc_f64_s);else if(H==="f32")Q.push(q.i32_trunc_f32_s);return Q.push(q.i32_add),Q.push(...h(X[2],$)),Q.push(...t6(t.v128_store,2,0)),Q.push(q.i32_const,0),Q}case"f32x4_splat":{Q.push(...h(X[0],$));let K=i(X[0],$);if(K==="i32")Q.push(q.f32_convert_i32_s);else if(K==="f64")Q.push(q.f32_demote_f64);return Q.push(...k4(t.f32x4_splat)),Q}case"f32x4_extract_lane":{Q.push(...h(X[0],$));let K=X[1].value;if(!Number.isInteger(K)||K<0||K>3)return $.errors.push(`f32x4_extract_lane: lane must be 0-3, got ${K}`),[q.f32_const,...b4(0)];return Q.push(G0,...f(t.f32x4_extract_lane),K),Q}case"f32x4_replace_lane":{Q.push(...h(X[0],$));let K=X[1].value;if(!Number.isInteger(K)||K<0||K>3)return $.errors.push(`f32x4_replace_lane: lane must be 0-3, got ${K}`),[q.f32_const,...b4(0)];Q.push(...h(X[2],$));let H=i(X[2],$);if(H==="i32")Q.push(q.f32_convert_i32_s);else if(H==="f64")Q.push(q.f32_demote_f64);return Q.push(G0,...f(t.f32x4_replace_lane),K),Q}case"f32x4_add":case"f32x4_sub":case"f32x4_mul":case"f32x4_div":{Q.push(...h(X[0],$)),Q.push(...h(X[1],$));let K={f32x4_add:t.f32x4_add,f32x4_sub:t.f32x4_sub,f32x4_mul:t.f32x4_mul,f32x4_div:t.f32x4_div};return Q.push(...k4(K[Z])),Q}case"f32x4_neg":case"f32x4_sqrt":{Q.push(...h(X[0],$));let K={f32x4_neg:t.f32x4_neg,f32x4_sqrt:t.f32x4_sqrt};return Q.push(...k4(K[Z])),Q}default:return $.errors.push(`Unknown SIMD intrinsic: ${Z}`),[q.f64_const,...G1(0)]}}function PZ(Z,X,$){let Q=[];for(let z of X){Q.push(...h(z,$));let W=i(z,$);if(W==="i32")Q.push(q.f64_convert_i32_s);else if(W==="f32")Q.push(q.f64_promote_f32)}let H={abs:q.f64_abs,ceil:q.f64_ceil,floor:q.f64_floor,trunc:q.f64_trunc,sqrt:q.f64_sqrt,min:q.f64_min,max:q.f64_max}[Z];if(H!==void 0)return Q.push(H),Q;if(["sin","cos","tan","asin","acos","atan","atan2","exp","log","pow"].includes(Z))return $.needsMathImports.add(Z),$.errors.push(`Math.${Z} requires JS import (not yet implemented)`),[q.f64_const,...G1(0)];return $.errors.push(`Unknown Math method: ${Z}`),[q.f64_const,...G1(0)]}function Z7(Z){let X=Z.split(":").map((H)=>H.trim()),$=X[0];if(X.length===1)return{name:$,type:"f64"};let Q=X[1];if(v0[Q])return{name:$,type:"i32",isArray:!0,arrayType:Q};return{name:$,type:{i32:"i32",i64:"i64",f32:"f32",f64:"f64",number:"f64",int:"i32"}[Q]??"f64"}}function VZ(Z,X,$,Q,K){let H=[0,97,115,109,1,0,0,0],Y=Z.map((V)=>q1[V.type]),z=K?[1,q1.f64]:[0],W=W0(z0.type,[1,96,...f(Z.length),...Y,...z]),G=[],J=[];if(Q)J=W0(z0.import,[1,...g4("env"),...g4("memory"),2,0,1]);let L=W0(z0.function,[1,0]),_=W0(z0.export,[1,...g4("compute"),0,0]),U=[];if($.length>0){let V=$[0],F=1;for(let j=1;j<$.length;j++)if($[j]===V)F++;else U.push([...f(F),q1[V]]),V=$[j],F=1;U.push([...f(F),q1[V]])}let R=[...[...f(U.length),...U.flat()],...X,q.end],M=W0(z0.code,[1,...f(R.length),...R]),I=[...H,...W];if(J.length>0)I.push(...J);return I.push(...L,..._,...M),I}function f0(Z){try{let X=Z.captures.map(Z7),$;try{let G=`function __wasm__(${X.map((J)=>J.name).join(", ")}) { ${Z.body} }`;$=e6.parse(G,{ecmaVersion:2022})}catch(G){return{bytes:new Uint8Array,warnings:[],success:!1,error:`Parse error: ${G.message}`}}let K=$.body[0].body.body,H=UZ(X),Y=[];for(let G of K)Y.push(...d1(G,H));if(H.errors.length>0)return{bytes:new Uint8Array,warnings:H.warnings,success:!1,error:H.errors.join("; ")};let z=VZ(X,Y,H.localTypes,H.needsMemory,H.hasReturn),W=LZ(Y,X,H.localTypes);return{bytes:new Uint8Array(z),warnings:H.warnings,success:!0,needsMemory:H.needsMemory,wat:W}}catch(X){return{bytes:new Uint8Array,warnings:[],success:!1,error:X.message}}}async function $7(Z,X){let $={};if(X)$.env={memory:X};let Q=await WebAssembly.compile(Z);return WebAssembly.instantiate(Q,$)}async function CZ(Z){let X=f0(Z);if(!X.success)return{fn:()=>0,success:!1,error:X.error};try{let $;if(X.needsMemory)$=new WebAssembly.Memory({initial:256});let K=(await $7(X.bytes,$)).exports.compute,H=Z.captures.map(Z7);if(!H.some((W)=>W.isArray))return{fn:K,memory:$,success:!0};return{fn:(...W)=>{if(!$)throw Error("Memory not initialized");let G=new Uint8Array($.buffer),J=0,L=[];for(let U=0;U<H.length;U++){let D=H[U],R=W[U];if(D.isArray&&R instanceof Object&&"buffer"in R){let M=R,I=new Uint8Array(M.buffer,M.byteOffset,M.byteLength);G.set(I,J),L.push(J),J+=I.length,J=J+15&-16}else L.push(R)}let _=K(...L);J=0;for(let U=0;U<H.length;U++){let D=H[U],R=W[U];if(D.isArray&&R instanceof Object&&"buffer"in R){let M=R,I=new Uint8Array(M.buffer,M.byteOffset,M.byteLength);I.set(G.slice(J,J+I.length)),J+=I.length,J=J+15&-16}}return _},memory:$,success:!0}}catch($){return{fn:()=>0,success:!1,error:$.message}}}async function X7(Z){let X=await CZ(Z);if(!X.success)return console.warn(`WASM compilation failed for ${Z.id}:`,X.error),!1;return globalThis[Z.id]=X.fn,!0}async function OZ(Z){let X=0,$=0,Q=[];for(let K of Z)if(await X7(K))X++;else $++,Q.push(`Failed to compile ${K.id}`);return{compiled:X,failed:$,errors:Q}}function Q7(Z){let X=[],$=[];for(let z of Z){let W=f0(z);if(W.success){let G=btoa(String.fromCharCode(...W.bytes));$.push({id:z.id,base64:G,captures:z.captures,needsMemory:W.needsMemory??!1,wat:W.wat??""}),X.push({id:z.id,success:!0,byteLength:W.bytes.length})}else X.push({id:z.id,success:!1,error:W.error})}if($.length===0)return{code:"",results:X};let Q=$.map((z)=>{let W=z.wat.split(`
|
|
292
|
+
`).map((G)=>` * ${G}`);return`/**
|
|
293
|
+
* WASM: ${z.id}
|
|
294
|
+
${W.join(`
|
|
295
295
|
`)}
|
|
296
296
|
*/`}).join(`
|
|
297
|
-
`),
|
|
297
|
+
`),K=$.map((z)=>`{id:${JSON.stringify(z.id)},b64:${JSON.stringify(z.base64)},c:${JSON.stringify(z.captures)},m:${z.needsMemory}}`).join(","),H=$.some((z)=>z.needsMemory);return{code:`${Q}
|
|
298
298
|
;(async()=>{
|
|
299
|
-
const __wasmBlocks=[${
|
|
299
|
+
const __wasmBlocks=[${K}];
|
|
300
300
|
const __b64ToBytes=s=>{const b=atob(s),a=new Uint8Array(b.length);for(let i=0;i<b.length;i++)a[i]=b.charCodeAt(i);return a};
|
|
301
301
|
const __parseType=c=>{const m=c.match(/^(\\w+)\\s*:\\s*(\\w+)$/);if(!m)return{n:c,t:'f64',a:false};const[,n,ts]=m;const at={Float32Array:'f32',Float64Array:'f64',Int32Array:'i32',Uint8Array:'i32'};if(at[ts])return{n,t:'i32',a:true,at:ts};return{n,t:'f64',a:false}};
|
|
302
302
|
${H?`const __wasmMem=new WebAssembly.Memory({initial:1024});
|
|
@@ -325,81 +325,89 @@ for(const{id,b64,c,m}of __wasmBlocks){
|
|
|
325
325
|
const ab=new Uint8Array(a.buffer,a.byteOffset,a.byteLength);off=(off+15)&~15;ab.set(mv.slice(off,off+ab.length));off+=ab.length}}
|
|
326
326
|
return r};
|
|
327
327
|
}})();
|
|
328
|
-
`.trim(),results:X}}function
|
|
329
|
-
`),suffix:"} finally { __tjs.popStack(); }"}}let Y=Object.entries(X.params);if(Y.length===0)return null;for(let[
|
|
330
|
-
`),suffix:"} finally { __tjs.popStack(); }"}}function
|
|
331
|
-
${
|
|
328
|
+
`.trim(),results:X}}function EZ(Z,X,$){if(!Z||!X)return!1;let Q=new RegExp(`function\\s+${X}\\s*\\([^)]*?\\b${$}\\s*([=:])`,"s"),K=Z.match(Q);if(!K)return!1;return K[1]===":"}function TZ(Z,X,$,Q,K){let H=[],Y=X0(X,Z),z={},W=!1,G,J;if(Z.params.length===1&&(Z.params[0].type==="ObjectPattern"||Z.params[0].type==="AssignmentPattern"&&Z.params[0].left.type==="ObjectPattern")){W=!0;let U=Z.params[0],D=U.type==="ObjectPattern"?U:U.left,R=P1(D,$);if(R.type.kind==="object"&&R.type.destructuredParams){G={},J=new Set;for(let[M,I]of Object.entries(R.type.destructuredParams))if(z[M]={...I,description:Y.params[M]},G[M]=I.type,I.required)J.add(M)}}else for(let U of Z.params)if(U.type==="Identifier"){let D=P1(U,$);z[U.name]={...D,required:$.has(U.name),description:Y.params[U.name]}}else if(U.type==="AssignmentPattern"&&U.left.type==="Identifier"){let D=P1(U,$),R=EZ(K||"",Z.id?.name||"",U.left.name);z[U.left.name]={...D,required:R,default:R?null:D.example??D.default,description:Y.params[U.left.name]}}else if(U.type==="ObjectPattern"){let D=P1(U,$);if(D.type.kind==="object"&&D.type.destructuredParams)for(let[R,M]of Object.entries(D.type.destructuredParams))z[R]={...M,description:Y.params[R]}}let L;if(Q)try{let U=Q.includes("=")?K7(Q):Q,D=NZ(U,0,{ecmaVersion:2022});L=z1(D)}catch{L={kind:"any"},H.push(`Could not parse return type: ${Q}`)}return{types:{name:Z.id?.name||"anonymous",params:z,returns:L,description:Y.description,isDestructuredParam:W,destructuredShape:G,destructuredRequired:J},warnings:H}}function SZ(Z,X,$){let Q=[],K=$?`${$}:`:"",H=$?`${$}:${Z}`:Z;if(X.isDestructuredParam&&X.destructuredShape){let z=X.destructuredShape,W=X.destructuredRequired||new Set,G=Object.keys(z);if(G.length===0)return null;for(let J of G)Q.push(`if (${J} instanceof Error) return ${J};`);for(let[J,L]of Object.entries(z)){let _=W.has(J),U=`${K}${Z}.${J}`,D=v4(J,L);if(D){let R=L.kind;if(_)Q.push(`if (${D}) return __tjs.typeError('${U}', '${R}', ${J});`);else Q.push(`if (${J} !== undefined && ${D}) return __tjs.typeError('${U}', '${R}', ${J});`)}}if(Q.length===0)return null;return Q.unshift(`__tjs.pushStack('${H}');`),Q.unshift("try {"),{preamble:Q.join(`
|
|
329
|
+
`),suffix:"} finally { __tjs.popStack(); }"}}let Y=Object.entries(X.params);if(Y.length===0)return null;for(let[z]of Y)Q.push(`if (${z} instanceof Error) return ${z};`);for(let[z,W]of Y){let G=`${K}${Z}.${z}`,J=v4(z,W.type);if(J){let L=W.type.kind==="union"?W.type.members.map((_)=>_.kind).join(" | "):W.type.kind;if(W.required)Q.push(`if (${J}) return __tjs.typeError('${G}', '${L}', ${z});`);else Q.push(`if (${z} !== undefined && ${J}) return __tjs.typeError('${G}', '${L}', ${z});`)}}if(Q.length===0)return null;return Q.unshift(`__tjs.pushStack('${H}');`),Q.unshift("try {"),{preamble:Q.join(`
|
|
330
|
+
`),suffix:"} finally { __tjs.popStack(); }"}}function K7(Z){let X="",$=0;for(let Q=0;Q<Z.length;Q++){let K=Z[Q];if(K==="{"||K==="["||K==="(")$++,X+=K;else if(K==="}"||K==="]"||K===")")$--,X+=K;else if(K==="'"||K==='"'||K==="`"){X+=K,Q++;while(Q<Z.length&&Z[Q]!==K){if(Z[Q]==="\\")X+=Z[Q++];X+=Z[Q++]}if(Q<Z.length)X+=Z[Q]}else if($===1&&K==="="&&Z[Q-1]!=="!"&&Z[Q+1]!=="=")X+=":";else X+=K}return X}function kZ(Z,X){let Q=new RegExp(`function\\s+${X}\\s*\\([^)]*\\)\\s*(-[>?!])\\s*`,"g").exec(Z);if(!Q)return null;let K=Z.slice(Q.index+Q[0].length);return S4(K)}function gZ(Z,X){let Q=new RegExp(`function\\s+${X}\\s*\\([^)]*\\)\\s*-([>?!])`,"g").exec(Z);if(!Q)return;let K=Q[1];if(K==="?")return"safe";if(K==="!")return"unsafe";return}function bZ(Z){let X=Z.match(/^\/\*\s*tjs\s*<-\s*([^*]+?)\s*\*\//);return X?X[1].trim():void 0}function vZ(Z,X){let $=new RegExp(`\\/\\*\\s*line\\s+(\\d+)\\s*\\*\\/\\s*(?:async\\s+)?function\\s+${X}\\s*\\(`,"m"),Q=Z.match($);return Q?parseInt(Q[1],10):void 0}function L0(Z,X={}){let{filename:$="<source>",runTests:Q=!0,debug:K=!1,resolvedImports:H={}}=X,Y=[],W=bZ(Z)||$,{code:G,tests:J,mocks:L,testRunner:_}=N4(Z),{ast:U,originalSource:D,requiredParams:R,unsafeFunctions:M}=M1(G,{filename:$,colonShorthand:!0}),I=fZ(U),V=E0(G),F={},j=[],B=[];for(let v of I){let y=v.id?.name||"anonymous",Z1=kZ(G,y),o;if(Z1&&Z1.includes("="))try{let Y1=Z1.matchAll(/(\w+)\s*=\s*/g),L1=K7(Z1),T1=Function(`return ${L1}`)(),U1={};for(let I8 of Y1){let F4=I8[1];if(F4 in T1)U1[F4]=T1[F4]}if(Object.keys(U1).length>0)o=U1}catch{}let{types:D1,warnings:L8}=TZ(v,D,R,Z1,G);Y.push(...L8),F[y]=D1;for(let Y1 of v.params)if(Y1.type==="AssignmentPattern"){let L1=Y1.left?.name||Y1.left?.value,T1=L1?D1.params[L1]:null;if(T1?.required&&T1.default===null)B.push({start:Y1.left.end,end:Y1.right.end});else{let U1=Y1.right;if(U1.type==="BinaryExpression"&&U1.operator==="|")B.push({start:U1.left.end,end:U1.end})}}let I6=V.moduleSafety==="none"||M.has(y),U8=V.safeFunctions.has(y),q8=gZ(G,y),D8=vZ(Z,y),u1={file:W,line:D8??v.loc?.start.line??0,column:v.loc?.start.column??0},A8={unsafe:I6,safe:U8,returnSafety:q8},B6=V.polymorphicNames.has(y),w4;if(B6){let Y1=[];for(let T1 of I){let U1=T1.id?.name||"";if(U1.startsWith(y+"$"))Y1.push(U1)}let L1={polymorphic:!0,variants:Y1};if(u1)L1.source=`${u1.file}:${u1.line}`;w4=`${y}.__tjs = ${JSON.stringify(L1,null,2)}`}else w4=yZ(y,D1,A8,{debug:K,source:u1,returnDefaults:o});if(j.push({position:v.end,text:`
|
|
331
|
+
${w4}`}),!I6&&!B6){let Y1=`${u1.file}:${u1.line}`,L1=SZ(y,D1,Y1);if(L1&&v.body&&v.body.start!==void 0)j.push({position:v.body.start+1,text:`
|
|
332
332
|
${L1.preamble}
|
|
333
|
-
`}),
|
|
333
|
+
`}),j.push({position:v.body.end-1,text:`
|
|
334
334
|
${L1.suffix}
|
|
335
|
-
`})}}
|
|
336
|
-
`;if(T||
|
|
337
|
-
`}
|
|
338
|
-
`+
|
|
335
|
+
`})}}B.sort((v,y)=>y.start-v.start);let P=V.source;for(let{start:v,end:y}of B)P=P.slice(0,v)+P.slice(y);for(let v of j){let y=0;for(let Z1 of B)if(Z1.start<v.position)y+=Z1.end-Z1.start;v.position-=y}j.sort((v,y)=>y.position-v.position);for(let{position:v,text:y}of j)P=P.slice(0,v)+y+P.slice(v);let C=P.includes("__tjs.typeError("),O=P.includes("__tjs.pushStack("),T=P.includes("Is("),k=P.includes("IsNot("),g=V.tjsModes.tjsSafeEval;if(C||O||T||k||g){let v=`const __tjs = globalThis.__tjs?.createRuntime?.() ?? globalThis.__tjs;
|
|
336
|
+
`;if(T||k){let y=[T&&"Is",k&&"IsNot"].filter(Boolean).join(", ");v+=`const { ${y} } = __tjs ?? {};
|
|
337
|
+
`}P=v+P}if(g)P=`import { Eval, SafeFunction } from 'tjs-lang';
|
|
338
|
+
`+P;let l;if(Q){let v=a6(Z);l=r6(J,L,v,P,H,V.extensions);let y=l.filter((Z1)=>!Z1.passed);if(y.length>0&&Q===!0){let Z1=y.map((o)=>{if(o.isSignatureTest)return` Function signature example is inconsistent:
|
|
339
339
|
${o.error}`;let D1=o.line?` (line ${o.line})`:"";return` Test '${o.description}'${D1} failed:
|
|
340
340
|
${o.error}`});throw Error(`Transpile-time test failures:
|
|
341
341
|
${Z1.join(`
|
|
342
|
-
`)}`)}}if(
|
|
343
|
-
`+j;a=v.results}return{code:j,types:A,metadata:A,warnings:Y.length>0?Y:void 0,testRunner:J.length>0?_:void 0,testCount:J.length>0?J.length:void 0,testResults:c,wasmCompiled:a}}function SZ(Z){let X=[];for(let $ of Z.body)if($.type==="FunctionDeclaration")X.push($);else if($.type==="ExportNamedDeclaration"&&$.declaration?.type==="FunctionDeclaration")X.push($.declaration);else if($.type==="ExportDefaultDeclaration"&&$.declaration?.type==="FunctionDeclaration")X.push($.declaration);return X}function W0(Z){let X={kind:Z.kind};if(Z.nullable)X.nullable=!0;if(Z.items)X.items=W0(Z.items);if(Z.shape)X.shape=Object.fromEntries(Object.entries(Z.shape).map(([$,K])=>[$,W0(K)]));if(Z.members)X.members=Z.members.map(W0);return X}function kZ(Z,X,$={},K={}){let Q={};for(let[Y,G]of Object.entries(X.params)){if(Q[Y]={type:W0(G.type),required:G.required},G.default!==void 0)Q[Y].default=G.default;if(G.description)Q[Y].description=G.description}let H={params:Q};if(X.returns){if(H.returns={type:W0(X.returns)},K.returnDefaults)H.returns.defaults=K.returnDefaults;if($.returnSafety==="safe")H.safeReturn=!0;else if($.returnSafety==="unsafe")H.unsafeReturn=!0}if(X.description)H.description=X.description;if($.unsafe)H.unsafe=!0;if($.safe)H.safe=!0;if(K.source){let{file:Y,line:G}=K.source;H.source=`${Y}:${G}`}return`${Z}.__tjs = ${JSON.stringify(H,null,2)}`}function k4(Z,X){switch(X.kind){case"string":return`typeof ${Z} !== 'string'`;case"number":return`typeof ${Z} !== 'number'`;case"integer":return`(typeof ${Z} !== 'number' || !Number.isInteger(${Z}))`;case"non-negative-integer":return`(typeof ${Z} !== 'number' || !Number.isInteger(${Z}) || ${Z} < 0)`;case"boolean":return`typeof ${Z} !== 'boolean'`;case"null":return`${Z} !== null`;case"undefined":return`${Z} !== undefined`;case"array":return`!Array.isArray(${Z})`;case"object":return`(typeof ${Z} !== 'object' || ${Z} === null || Array.isArray(${Z}))`;case"union":{let $=X.members.map((K)=>k4(Z,K)).filter((K)=>K!==null);if($.length===0)return null;return`(${$.join(" && ")})`}case"any":return null;default:return null}}import F from"typescript";import{validate as Q7,s as e0}from"tosijs-schema";import{validate as g4,s as v0}from"tosijs-schema";function C1(Z){return Z!==null&&typeof Z==="object"&&"__runtimeType"in Z&&Z.__runtimeType===!0}function X7(Z){return Z!==null&&typeof Z==="object"&&"schema"in Z&&typeof Z.schema==="object"}function gZ(Z){return Z!==null&&typeof Z==="object"&&"type"in Z&&typeof Z.type==="string"}function p(Z,X,$,K){let Q,H,Y,G=$,z=K;if(typeof Z==="string")if(Q=Z,typeof X==="function"){if(H=X,G!==void 0)Y=v0.infer(G)}else if(X===void 0&&G!==void 0)Y=v0.infer(G);else if(X7(X))Y=X;else if(gZ(X))Y=X;else if(X!==void 0)G=X,z=G,Y=v0.infer(G);else throw Error("Type(description) requires a predicate, schema, or example");else{if(X7(Z))Y=Z;else Y=Z;Q=bZ(Y)}let W;if(Y){let L=Y?.schema??Y;if(L&&typeof L==="object"&&Array.isArray(L.examples))W=L.examples}if(G===void 0&&W&&W.length>0)G=W[0];return{description:Q,check:(L)=>{if(H)return H(L);if(Y)return g4(L,Y);return!1},schema:Y,predicate:H,example:G,examples:W,default:z,__runtimeType:!0}}function bZ(Z){let X=Z?.schema??Z;if(X&&typeof X==="object"&&"type"in X){let $=X;switch($.type){case"string":if($.format)return`string (${$.format})`;if($.pattern)return`string matching ${$.pattern}`;if($.minLength!==void 0&&$.maxLength!==void 0)return`string (${$.minLength}-${$.maxLength} chars)`;return"string";case"number":case"integer":if($.minimum!==void 0&&$.maximum!==void 0)return`${$.type} (${$.minimum}-${$.maximum})`;if($.minimum!==void 0)return`${$.type} >= ${$.minimum}`;if($.maximum!==void 0)return`${$.type} <= ${$.maximum}`;return $.type;case"boolean":return"boolean";case"array":return"array";case"object":return"object";case"null":return"null"}}return"value"}var f0=p("string",(Z)=>typeof Z==="string"),y0=p("number",(Z)=>typeof Z==="number"),h0=p("boolean",(Z)=>typeof Z==="boolean"),x0=p("integer",(Z)=>typeof Z==="number"&&Number.isInteger(Z)),u0=p("positive integer",(Z)=>typeof Z==="number"&&Number.isInteger(Z)&&Z>0),d0=p("non-empty string",(Z)=>typeof Z==="string"&&Z.length>0),m0=p("email address",(Z)=>typeof Z==="string"&&/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(Z)),b4=(Z)=>{try{return new URL(Z),!0}catch{return!1}},l0=p("URL",(Z)=>typeof Z==="string"&&b4(Z)),i0=p("UUID",(Z)=>typeof Z==="string"&&/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(Z)),v4=(Z)=>{let X=new Date(Z);return!isNaN(X.getTime())&&Z.includes("T")},f4=(Z)=>{if(!/^\d{4}-\d{2}-\d{2}$/.test(Z))return!1;let X=new Date(Z+"T00:00:00Z");return!isNaN(X.getTime())},y4=p("ISO 8601 timestamp",(Z)=>typeof Z==="string"&&v4(Z)),h4=p("date (YYYY-MM-DD)",(Z)=>typeof Z==="string"&&f4(Z));function p0(Z){return p(`${Z.description} or null`,(X)=>X===null||Z.check(X))}function n0(Z){return p(`${Z.description} (optional)`,(X)=>X===null||X===void 0||Z.check(X))}function c0(Z,X,...$){if(typeof Z==="string"&&Array.isArray(X)){let H=Z,Y=X,G=new Set(Y);return{description:H,check:(W)=>G.has(W),__runtimeType:!0,values:Y}}let K=[];if(C1(Z))K.push(Z);if(C1(X))K.push(X);K.push(...$);let Q=K.map((H)=>H.description).join(" | ");return p(Q,(H)=>K.some((Y)=>Y.check(H)))}function o0(Z){return p(`array of ${Z.description}`,(X)=>Array.isArray(X)&&X.every(($)=>Z.check($)))}function vZ(Z){if(C1(Z))return($)=>Z.check($);if(Z&&typeof Z==="object"&&"schema"in Z)return($)=>g4($,Z);let X=v0.infer(Z);return($)=>g4($,X)}function m1(Z,X,$){let K=[],Q=[];for(let Y of Z)if(typeof Y==="string")K.push(Y),Q.push(void 0);else K.push(Y[0]),Q.push(Y[1]);let H=(...Y)=>{let G=K.map((W,J)=>{let L=J<Y.length?Y[J]:Q[J];if(L===void 0)return()=>!0;return vZ(L)}),z=$;return K.forEach((W,J)=>{let L=J<Y.length?Y[J]:Q[J],_="any";if(C1(L))_=L.description;else if(L!==void 0)_=typeof L==="string"?"string":JSON.stringify(L);z=z.replace(new RegExp(`\\b${W}\\b`,"g"),_)}),p(z,(W)=>X(W,...G))};return H.params=K,H.description=$,H}var s0=m1(["T","U"],(Z,X,$)=>Array.isArray(Z)&&Z.length===2&&X(Z[0])&&$(Z[1]),"Pair<T, U>"),a0=m1(["V"],(Z,X)=>typeof Z==="object"&&Z!==null&&!Array.isArray(Z)&&Object.values(Z).every(X),"Record<string, V>");function r0(Z,X){let $=Object.values(X),K=new Set($),Q=Object.keys(X),H={};for(let[G,z]of Object.entries(X))H[z]=G;return{description:Z,check:(G)=>K.has(G),__runtimeType:!0,members:X,names:H,values:$,keys:Q}}var yZ=K7(),$1=yZ.version,_0=Symbol.for("tjs.equals");function Z4(Z){let[X=0,$=0,K=0]=Z.split(".").map(Number);return{major:X,minor:$,patch:K}}function x4(Z,X){let $=Z4(Z),K=Z4(X);if($.major!==K.major)return $.major<K.major?-1:1;if($.minor!==K.minor)return $.minor<K.minor?-1:1;if($.patch!==K.patch)return $.patch<K.patch?-1:1;return 0}function u4(Z,X){let $=Z4(Z),K=Z4(X);return $.major===K.major}class f1 extends Error{path;expected;actual;callStack;constructor(Z,X,$,K,Q){super(Z);if(this.name="MonadicError",this.path=X,this.expected=$,this.actual=K,this.callStack=Q,Error.captureStackTrace)Error.captureStackTrace(this,f1)}}function hZ(Z,X,$){let K=$===null?"null":typeof $,Q=Q1.debug?G7():void 0;return new f1(`Expected ${X} for '${Z}', got ${K}`,Z,X,K,Q)}function H7(Z){return Z instanceof f1}var d4={debug:!1,safety:"inputs",requireReturnTypes:!1,maxStackSize:100},Q1={...d4},w1=[],i1=0;function xZ(){i1++}function uZ(){if(i1>0)i1--}function dZ(){return i1>0}function mZ(Z){Q1={...Q1,...Z}}function lZ(){return{...Q1}}function Y7(Z){if(Q1.debug&&Z){w1.push(Z);let X=Q1.maxStackSize??100;while(w1.length>X)w1.shift()}}function t0(){if(Q1.debug)w1.pop()}function G7(){return[...w1]}function iZ(){Q1={...d4},w1.length=0,i1=0}function L0(Z,X){if(Z!==null&&typeof Z==="object"&&typeof Z[_0]==="function")return Z[_0](X);if(X!==null&&typeof X==="object"&&typeof X[_0]==="function")return X[_0](Z);if(Z!==null&&typeof Z==="object"&&typeof Z.Equals==="function")return Z.Equals(X);if(X!==null&&typeof X==="object"&&typeof X.Equals==="function")return X.Equals(Z);if(Z===X)return!0;if((Z===null||Z===void 0)&&(X===null||X===void 0))return!0;if(Z===null||Z===void 0||X===null||X===void 0)return!1;if(typeof Z!==typeof X)return!1;if(typeof Z!=="object")return!1;if(Array.isArray(Z)&&Array.isArray(X)){if(Z.length!==X.length)return!1;return Z.every((Q,H)=>L0(Q,X[H]))}if(Array.isArray(Z)!==Array.isArray(X))return!1;let $=Object.keys(Z),K=Object.keys(X);if($.length!==K.length)return!1;return $.every((Q)=>L0(Z[Q],X[Q]))}function z7(Z,X){return!L0(Z,X)}function M1(Z){return Z!==null&&typeof Z==="object"&&Z.$error===!0}function I1(Z,X){let $={$error:!0,message:Z,...X};if(Q1.debug&&w1.length>0){let K=X?.path?[...w1,X.path]:[...w1];$.stack=K}return $}function m4(Z,X){if(Z.length===0)return I1("Unknown error");if(Z.length===1)return Z[0];let $=Z.map((Q)=>{if(Q.path){let H=Q.path.split(".");return H[H.length-1]}return"unknown"}).join(", "),K=`Multiple parameter errors in ${X||"function"}: ${$}`;return I1(K,{path:X,errors:Z})}function l1(Z){if(Z===null)return"null";if(Z===void 0)return"undefined";if(Array.isArray(Z))return"array";let X=typeof Z;if(X!=="object")return X;let $=Z.constructor?.name;if($&&$!=="Object")return $;return"object"}function W7(Z,X){if(Z===null||Z===void 0)return!1;if(typeof Z!=="object"&&typeof Z!=="function")return!1;let $=Z;while($!==null){if($.constructor?.name===X)return!0;$=Object.getPrototypeOf($)}return!1}function v1(Z,X,$){if(M1(Z))return Z;if(typeof X==="object"&&X!==null&&"check"in X){if(X.check(Z))return null;return I1(`Expected ${X.description} but got ${l1(Z)}`,{path:$,expected:X.description,actual:l1(Z)})}let K=l1(Z);if(X==="any")return null;if(X===K)return null;if(X==="number"&&K==="number")return null;if(X==="integer"&&K==="number"&&Number.isInteger(Z))return null;if(X==="non-negative-integer"&&K==="number"&&Number.isInteger(Z)&&Z>=0)return null;if(X==="object"&&K==="object")return null;return I1(`Expected ${X} but got ${K}`,{path:$,expected:X,actual:K})}function l4(Z,X,$){for(let[K,Q]of Object.entries(X.params)){let H=Z[K];if(M1(H))return H;if(Q.required&&H===void 0){let G=typeof Q.type==="string"?Q.type:Q.type.description;return I1(`Missing required parameter '${K}'`,{path:$?`${$}.${K}`:K,expected:G,actual:"undefined",loc:Q.loc})}if(H===void 0)continue;let Y=v1(H,Q.type,$?`${$}.${K}`:K);if(Y){if(Q.loc)Y.loc=Q.loc;return Y}}return null}function i4(Z,X){if(Z.__tjs=X,!(!X.polymorphic&&(X.safe||X.safeReturn||Q1.safety!=="none"&&!X.unsafe||X.returns&&Q1.safety==="all"&&!X.unsafeReturn)))return Z;let K=!!X.returns,Q=!!X.unsafe,H=!!X.safe,Y=!!X.unsafeReturn,G=!!X.safeReturn,z=X.returns?.defaults,W=Object.entries(X.params),J=W.length,L=Z.name||X.name||"anonymous",_=function(...U){if(i1>0)return Z.apply(this,U);let R=H||!Q&&Q1.safety!=="none",M=K&&(G||!Y&&Q1.safety==="all");if(!R&&!M)return Z.apply(this,U);if(U.length>0&&M1(U[0]))return U[0];if(R){let w=U.length===1&&typeof U[0]==="object"&&U[0]!==null&&!Array.isArray(U[0]),I=[];if(!w)for(let V=0;V<J;V++){let[A,B]=W[V],P=U[V];if(M1(P)){I.push(P);continue}if(B.required&&P===void 0){I.push(I1(`Missing required parameter '${A}'`,{path:`${L}.${A}`,expected:typeof B.type==="string"?B.type:B.type?.description||"value",actual:"undefined",loc:B.loc}));continue}if(P!==void 0){let j=v1(P,B.type,`${L}.${A}`);if(j){if(B.loc)j.loc=B.loc;I.push(j)}}}else{let V=U[0];for(let A=0;A<J;A++){let[B,P]=W[A],j=V[B];if(M1(j)){I.push(j);continue}if(P.required&&j===void 0){I.push(I1(`Missing required parameter '${B}'`,{path:`${L}.${B}`,expected:typeof P.type==="string"?P.type:P.type?.description||"value",actual:"undefined",loc:P.loc}));continue}if(j!==void 0){let C=v1(j,P.type,`${L}.${B}`);if(C){if(P.loc)C.loc=P.loc;I.push(C)}}}}if(I.length>0)return m4(I,L)}Y7(L);try{let w=Z.apply(this,U);if(M&&X.returns&&!M1(w)){let I=z&&typeof w==="object"&&w!==null?Object.assign({},z,w):w,V=v1(I,X.returns.type,`${L}()`);if(V)return t0(),V}return t0(),w}catch(w){return t0(),I1(w.message||String(w),{path:L,cause:w})}};return Object.defineProperty(_,"name",{value:Z.name}),_.__tjs=X,_}function J7(Z){let X=new Proxy(Z,{construct($,K,Q){return Reflect.construct($,K,Q)},apply($,K,Q){return Reflect.construct($,Q)}});Object.defineProperty(X,"name",{value:Z.name});for(let $ of Object.getOwnPropertyNames(Z))if($!=="length"&&$!=="name"&&$!=="prototype")Object.defineProperty(X,$,Object.getOwnPropertyDescriptor(Z,$));return X}function pZ(){let Z={...Q1},X=[],$=0;function K(I){Z={...Z,...I}}function Q(){return{...Z}}function H(I){if(Z.debug&&I){X.push(I);let V=Z.maxStackSize??100;while(X.length>V)X.shift()}}function Y(){if(Z.debug)X.pop()}function G(){return[...X]}function z(){Z={...d4},X.length=0,$=0}function W(){$++}function J(){if($>0)$--}function L(){return $>0}let _=new Map;function U(I,V,A){if(!_.has(I))_.set(I,new Map);_.get(I).set(V,A)}function R(I,V){let A=typeof I,B;if(I===null||I===void 0)return;if(A==="string")B="String";else if(A==="number")B="Number";else if(A==="boolean")B="Boolean";else if(Array.isArray(I))B="Array";else if(A==="object")B=I.constructor?.name||"Object";else return;let P=B;while(P){let C=_.get(P);if(C?.has(V))return C.get(V);if(A==="object"&&!Array.isArray(I)){if(P=Object.getPrototypeOf(P===B?I:Object.getPrototypeOf(I))?.constructor?.name,P==="Object"||P===B)break}else break}let j=_.get("Object");if(j?.has(V))return j.get(V);return}function M(I,V,A){let B=A===null?"null":typeof A,P=Z.debug?G():void 0;return new f1(`Expected ${V} for '${I}', got ${B}`,I,V,B,P)}function w(I,V){let A={$error:!0,message:I,...V};if(Z.debug&&X.length>0){let B=V?.path?[...X,V.path]:[...X];A.stack=B}return A}return{version:$1,MonadicError:f1,typeError:M,isMonadicError:H7,isError:M1,error:w,composeErrors:m4,typeOf:l1,isNativeType:W7,checkType:v1,validateArgs:l4,wrap:i4,wrapClass:J7,compareVersions:x4,versionsCompatible:u4,configure:K,getConfig:Q,pushStack:H,popStack:Y,getStack:G,resetRuntime:z,enterUnsafe:W,exitUnsafe:J,isUnsafeMode:L,validate:Q7,infer:e0.infer.bind(e0),Type:p,isRuntimeType:C1,Union:c0,Generic:m1,Enum:r0,Nullable:p0,Optional:n0,TArray:o0,TString:f0,TNumber:y0,TBoolean:h0,TInteger:x0,TPositiveInt:u0,TNonEmptyString:d0,TEmail:m0,TUrl:l0,TUuid:i0,TPair:s0,TRecord:a0,Is:L0,IsNot:z7,tjsEquals:_0,registerExtension:U,resolveExtension:R}}var b1={version:$1,MonadicError:f1,typeError:hZ,isMonadicError:H7,isError:M1,error:I1,composeErrors:m4,typeOf:l1,isNativeType:W7,checkType:v1,validateArgs:l4,wrap:i4,wrapClass:J7,compareVersions:x4,versionsCompatible:u4,configure:mZ,getConfig:lZ,pushStack:Y7,popStack:t0,getStack:G7,resetRuntime:iZ,enterUnsafe:xZ,exitUnsafe:uZ,isUnsafeMode:dZ,createRuntime:pZ,validate:Q7,infer:e0.infer.bind(e0),Type:p,isRuntimeType:C1,Union:c0,Generic:m1,Enum:r0,Nullable:p0,Optional:n0,TArray:o0,TString:f0,TNumber:y0,TBoolean:h0,TInteger:x0,TPositiveInt:u0,TNonEmptyString:d0,TEmail:m0,TUrl:l0,TUuid:i0,Timestamp:y4,LegalDate:h4,TPair:s0,TRecord:a0,Is:L0,IsNot:z7};function nZ(){let Z=globalThis;if(Z.__tjs){let X=Z.__tjs.version;if(typeof X!=="string")return Z.__tjs=b1,b1;let $=x4($1,X);if($===0)return Z.__tjs;if(u4($1,X))if($>0)console.info(`TJS runtime: upgrading ${X} → ${$1}`),Z.__tjs=b1;else console.info(`TJS runtime: keeping ${X} (newer than ${$1})`);else if(console.warn(`TJS runtime version conflict: ${X} vs ${$1} (major version mismatch)`),$>0)console.warn(`Upgrading to ${$1} - check for breaking changes`),Z.__tjs=b1;return Z.__tjs}return Z.__tjs=b1,b1}function cZ(Z){return`
|
|
342
|
+
`)}`)}}if(Q==="only")return{code:"",types:F,metadata:F,testResults:l,testCount:l?.length};let a;if(V.wasmBlocks.length>0){a=[];let v=Q7(V.wasmBlocks);if(v.code)P=v.code+`
|
|
343
|
+
`+P;a=v.results}return{code:P,types:F,metadata:F,warnings:Y.length>0?Y:void 0,testRunner:J.length>0?_:void 0,testCount:J.length>0?J.length:void 0,testResults:l,wasmCompiled:a}}function fZ(Z){let X=[];for(let $ of Z.body)if($.type==="FunctionDeclaration")X.push($);else if($.type==="ExportNamedDeclaration"&&$.declaration?.type==="FunctionDeclaration")X.push($.declaration);else if($.type==="ExportDefaultDeclaration"&&$.declaration?.type==="FunctionDeclaration")X.push($.declaration);return X}function _0(Z){let X={kind:Z.kind};if(Z.nullable)X.nullable=!0;if(Z.items)X.items=_0(Z.items);if(Z.shape)X.shape=Object.fromEntries(Object.entries(Z.shape).map(([$,Q])=>[$,_0(Q)]));if(Z.members)X.members=Z.members.map(_0);return X}function yZ(Z,X,$={},Q={}){let K={};for(let[Y,z]of Object.entries(X.params)){if(K[Y]={type:_0(z.type),required:z.required},z.default!==void 0)K[Y].default=z.default;if(z.description)K[Y].description=z.description}let H={params:K};if(X.returns){if(H.returns={type:_0(X.returns)},Q.returnDefaults)H.returns.defaults=Q.returnDefaults;if($.returnSafety==="safe")H.safeReturn=!0;else if($.returnSafety==="unsafe")H.unsafeReturn=!0}if(X.description)H.description=X.description;if($.unsafe)H.unsafe=!0;if($.safe)H.safe=!0;if(Q.source){let{file:Y,line:z}=Q.source;H.source=`${Y}:${z}`}return`${Z}.__tjs = ${JSON.stringify(H,null,2)}`}function v4(Z,X){switch(X.kind){case"string":return`typeof ${Z} !== 'string'`;case"number":return`typeof ${Z} !== 'number'`;case"integer":return`(typeof ${Z} !== 'number' || !Number.isInteger(${Z}))`;case"non-negative-integer":return`(typeof ${Z} !== 'number' || !Number.isInteger(${Z}) || ${Z} < 0)`;case"boolean":return`typeof ${Z} !== 'boolean'`;case"null":return`${Z} !== null`;case"undefined":return`${Z} !== undefined`;case"array":return`!Array.isArray(${Z})`;case"object":return`(typeof ${Z} !== 'object' || ${Z} === null || Array.isArray(${Z}))`;case"union":{let $=X.members.map((Q)=>v4(Z,Q)).filter((Q)=>Q!==null);if($.length===0)return null;return`(${$.join(" && ")})`}case"any":return null;default:return null}}function l1(Z){let X;switch(Z.kind){case"string":X="string";break;case"number":case"integer":case"non-negative-integer":X="number";break;case"boolean":X="boolean";break;case"null":return"null";case"undefined":return"undefined";case"any":X="any";break;case"array":if(Z.items){let $=l1(Z.items);X=$.includes("|")?`(${$})[]`:`${$}[]`}else X="any[]";break;case"object":if(Z.shape&&Object.keys(Z.shape).length>0)X=`{ ${Object.entries(Z.shape).map(([Q,K])=>`${Q}: ${l1(K)}`).join("; ")} }`;else X="Record<string, any>";break;case"union":if(Z.members&&Z.members.length>0)return Z.members.map(l1).join(" | ");X="any";break;default:X="any"}if(Z.nullable)return`${X} | null`;return X}function hZ(Z,X,$,Q){let K=Object.entries(X.params).map(([z,W])=>{let G=!W.required,J=l1(W.type);return G?`${z}?: ${J}`:`${z}: ${J}`}).join(", "),H=X.returns?l1(X.returns):"any";return`${$?Q?"export default function":"export declare function":"declare function"} ${Z}(${K}): ${H};`}function xZ(Z){let X=new Map,$,Q=/^[ \t]*export\s+(default\s+)?function\s+(\w+)/gm;while(($=Q.exec(Z))!==null)X.set($[2],{exported:!0,isDefault:!!$[1]});let K=/^[ \t]*export\s+(default\s+)?class\s+(\w+)/gm;while(($=K.exec(Z))!==null)X.set($[2],{exported:!0,isDefault:!!$[1]});let H=/^[ \t]*export\s+(default\s+)?(?:const|let|var)\s+(\w+)/gm;while(($=H.exec(Z))!==null)X.set($[2],{exported:!0,isDefault:!!$[1]});let Y=/^[ \t]*export\s+Type\s+(\w+)/gm;while(($=Y.exec(Z))!==null)X.set($[1],{exported:!0,isDefault:!1});let z=/^[ \t]*export\s+Generic\s+(\w+)/gm;while(($=z.exec(Z))!==null)X.set($[1],{exported:!0,isDefault:!1});let W=/^[ \t]*export\s*\{([^}]+)\}/gm;while(($=W.exec(Z))!==null){let G=$[1].split(",").map((J)=>J.trim().split(/\s+as\s+/));for(let J of G){let L=J.length>1?J[1]:J[0];if(L&&/^\w+$/.test(L))X.set(L,{exported:!0,isDefault:!1})}}return X}function uZ(Z){let X=new Map,$=/^[ \t]*(?:export\s+(?:default\s+)?)?class\s+(\w+)(?:\s+extends\s+\w+)?\s*\{/gm,Q;while((Q=$.exec(Z))!==null){let K=Q[1],H=Q.index+Q[0].length-1,Y=1,z=H+1;while(z<Z.length&&Y>0){if(Z[z]==="{")Y++;else if(Z[z]==="}")Y--;z++}let W=Z.slice(H+1,z-1),G=W.indexOf("constructor"),J="";if(G!==-1){let D=W.indexOf("(",G);if(D!==-1){let R=1,M=D+1;while(M<W.length&&R>0){if(W[M]==="(")R++;else if(W[M]===")")R--;M++}J=W.slice(D+1,M-1).trim()}}let L=[],_=/^\s+(\w+)\s*\(/gm,U;while((U=_.exec(W))!==null){let D=U[1];if(D==="constructor"||D==="get"||D==="set")continue;let R=U.index+U[0].length-1,M=1,I=R+1;while(I<W.length&&M>0){if(W[I]==="(")M++;else if(W[I]===")")M--;I++}let V=W.slice(R+1,I-1).trim(),F=W.slice(I).match(/^\s*->\s*(.+?)\s*\{/),j=F?F[1].trim():null;L.push({name:D,params:V,returnType:j})}X.set(K,{name:K,constructorParams:J,methods:L})}return X}function dZ(Z){let X=[],$=0,Q="";for(let K of Z){if(K==="{"||K==="["||K==="(")$++;else if(K==="}"||K==="]"||K===")")$--;if(K===","&&$===0)X.push(Q.trim()),Q="";else Q+=K}if(Q.trim())X.push(Q.trim());return X}function H7(Z){if(!Z.trim())return"";return dZ(Z).map((X)=>{let $=X.match(/^(\w+)\s*:\s*(.+)$/);if($){let K=$[1],H=y0($[2].trim());return`${K}: ${H}`}let Q=X.match(/^(\w+)\s*=\s*(.+)$/);if(Q){let K=Q[1],H=y0(Q[2].trim());return`${K}?: ${H}`}if(X.startsWith("{"))return"options: any";return`${X}: any`}).join(", ")}function lZ(Z){let X=new Map,$,Q=/^[ \t]*(?:export\s+)?Type\s+(\w+)\s*=\s*(.+)$/gm;while(($=Q.exec(Z))!==null)X.set($[1],$[2].trim());let K=/^[ \t]*(?:export\s+)?Type\s+(\w+)\s+([^{=].*)$/gm;while(($=K.exec(Z))!==null)if(!X.has($[1]))X.set($[1],$[2].trim());let H=/^[ \t]*(?:export\s+)?Type\s+(\w+)\s*\{[^}]*example\s*:\s*(.+?)(?:\n|\s*[,}])/gm;while(($=H.exec(Z))!==null)X.set($[1],$[2].trim());return X}function mZ(Z){let X=new Map,$=/^[ \t]*(?:export\s+)?Generic\s+(\w+)\s*<([^>]+)>/gm,Q;while((Q=$.exec(Z))!==null){let K=Q[1],H=Q[2].split(",").map((Y)=>{return Y.trim().split(/\s*=/)[0].trim()});X.set(K,{typeParams:H})}return X}function iZ(Z,X,$={}){let Q=[],K=xZ(X),H=lZ(X),Y=uZ(X),z=mZ(X),W=K.size>0,G=new Set;for(let[J,L]of Object.entries(Z.types)){if(J.includes("$"))continue;let _=K.get(J),U=W?!!_?.exported:!0,D=_?.isDefault??!1;if(!U)continue;if(L.description)Q.push(`/** ${L.description} */`);Q.push(hZ(J,L,!0,D)),G.add(J)}for(let[J,L]of Y){if(G.has(J))continue;let _=K.get(J);if(!(W?!!_?.exported:!0))continue;let D=L.constructorParams?H7(L.constructorParams):"";if(Q.push(`export declare function ${J}(${D}): any;`),D||L.methods.length>0){if(Q.push(`export declare class ${J} {`),L.constructorParams)Q.push(` constructor(${D});`);for(let R of L.methods){let M=R.params?H7(R.params):"";Q.push(` ${R.name}(${M}): any;`)}Q.push("}")}G.add(J)}for(let[J,L]of H){if(G.has(J))continue;let _=K.get(J);if(!(W?!!_?.exported:!0))continue;let D=y0(L);Q.push(`export declare const ${J}: { check(value: any): boolean; default: ${D}; (value: any): boolean; };`),G.add(J)}for(let[J,L]of z){if(G.has(J))continue;let _=K.get(J);if(!(W?!!_?.exported:!0))continue;let D=L.typeParams.map((R)=>"...args: any[]");Q.push(`export declare function ${J}(...args: any[]): { check(value: any): boolean; (value: any): boolean; };`),G.add(J)}if($.moduleName){let J=Q.map((L)=>` ${L}`).join(`
|
|
344
|
+
`);return`declare module '${$.moduleName}' {
|
|
345
|
+
${J}
|
|
346
|
+
}
|
|
347
|
+
`}return Q.join(`
|
|
348
|
+
`)+`
|
|
349
|
+
`}function y0(Z){let X=Z.trim();if(pZ(X)){let $=nZ(X).map((Q)=>y0(Q.trim()));return[...new Set($)].join(" | ")}if(/^['"]/.test(X))return"string";if(X==="true"||X==="false")return"boolean";if(X==="null")return"null";if(X==="undefined")return"undefined";if(/^[+-]?\d+\.\d+$/.test(X))return"number";if(/^[+-]?\d+$/.test(X))return"number";if(X.startsWith("["))return"any[]";if(X.startsWith("{"))return"Record<string, any>";return"any"}function pZ(Z){let X=0,$=null;for(let Q of Z){if($){if(Q===$)$=null;continue}if(Q==="'"||Q==='"'||Q==="`"){$=Q;continue}if(Q==="{"||Q==="["||Q==="(")X++;else if(Q==="}"||Q==="]"||Q===")")X--;else if(Q==="|"&&X===0)return!0}return!1}function nZ(Z){let X=[],$=0,Q=null,K="";for(let H of Z){if(Q){if(K+=H,H===Q)Q=null;continue}if(H==="'"||H==='"'||H==="`"){Q=H,K+=H;continue}if(H==="{"||H==="["||H==="(")$++;else if(H==="}"||H==="]"||H===")")$--;if(H==="|"&&$===0)X.push(K),K="";else K+=H}if(K)X.push(K);return X}import w from"typescript";import{validate as W7,s as X4}from"tosijs-schema";import{validate as f4,s as h0}from"tosijs-schema";function C1(Z){return Z!==null&&typeof Z==="object"&&"__runtimeType"in Z&&Z.__runtimeType===!0}function Y7(Z){return Z!==null&&typeof Z==="object"&&"schema"in Z&&typeof Z.schema==="object"}function cZ(Z){return Z!==null&&typeof Z==="object"&&"type"in Z&&typeof Z.type==="string"}function n(Z,X,$,Q){let K,H,Y,z=$,W=Q;if(typeof Z==="string")if(K=Z,typeof X==="function"){if(H=X,z!==void 0)Y=h0.infer(z)}else if(X===void 0&&z!==void 0)Y=h0.infer(z);else if(Y7(X))Y=X;else if(cZ(X))Y=X;else if(X!==void 0)z=X,W=z,Y=h0.infer(z);else throw Error("Type(description) requires a predicate, schema, or example");else{if(Y7(Z))Y=Z;else Y=Z;K=oZ(Y)}let G;if(Y){let L=Y?.schema??Y;if(L&&typeof L==="object"&&Array.isArray(L.examples))G=L.examples}if(z===void 0&&G&&G.length>0)z=G[0];return{description:K,check:(L)=>{if(H)return H(L);if(Y)return f4(L,Y);return!1},schema:Y,predicate:H,example:z,examples:G,default:W,__runtimeType:!0}}function oZ(Z){let X=Z?.schema??Z;if(X&&typeof X==="object"&&"type"in X){let $=X;switch($.type){case"string":if($.format)return`string (${$.format})`;if($.pattern)return`string matching ${$.pattern}`;if($.minLength!==void 0&&$.maxLength!==void 0)return`string (${$.minLength}-${$.maxLength} chars)`;return"string";case"number":case"integer":if($.minimum!==void 0&&$.maximum!==void 0)return`${$.type} (${$.minimum}-${$.maximum})`;if($.minimum!==void 0)return`${$.type} >= ${$.minimum}`;if($.maximum!==void 0)return`${$.type} <= ${$.maximum}`;return $.type;case"boolean":return"boolean";case"array":return"array";case"object":return"object";case"null":return"null"}}return"value"}var x0=n("string",(Z)=>typeof Z==="string"),u0=n("number",(Z)=>typeof Z==="number"),d0=n("boolean",(Z)=>typeof Z==="boolean"),l0=n("integer",(Z)=>typeof Z==="number"&&Number.isInteger(Z)),m0=n("positive integer",(Z)=>typeof Z==="number"&&Number.isInteger(Z)&&Z>0),i0=n("non-empty string",(Z)=>typeof Z==="string"&&Z.length>0),p0=n("email address",(Z)=>typeof Z==="string"&&/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(Z)),y4=(Z)=>{try{return new URL(Z),!0}catch{return!1}},n0=n("URL",(Z)=>typeof Z==="string"&&y4(Z)),c0=n("UUID",(Z)=>typeof Z==="string"&&/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(Z)),h4=(Z)=>{let X=new Date(Z);return!isNaN(X.getTime())&&Z.includes("T")},x4=(Z)=>{if(!/^\d{4}-\d{2}-\d{2}$/.test(Z))return!1;let X=new Date(Z+"T00:00:00Z");return!isNaN(X.getTime())},u4=n("ISO 8601 timestamp",(Z)=>typeof Z==="string"&&h4(Z)),d4=n("date (YYYY-MM-DD)",(Z)=>typeof Z==="string"&&x4(Z));function o0(Z){return n(`${Z.description} or null`,(X)=>X===null||Z.check(X))}function s0(Z){return n(`${Z.description} (optional)`,(X)=>X===null||X===void 0||Z.check(X))}function a0(Z,X,...$){if(typeof Z==="string"&&Array.isArray(X)){let H=Z,Y=X,z=new Set(Y);return{description:H,check:(G)=>z.has(G),__runtimeType:!0,values:Y}}let Q=[];if(C1(Z))Q.push(Z);if(C1(X))Q.push(X);Q.push(...$);let K=Q.map((H)=>H.description).join(" | ");return n(K,(H)=>Q.some((Y)=>Y.check(H)))}function r0(Z){return n(`array of ${Z.description}`,(X)=>Array.isArray(X)&&X.every(($)=>Z.check($)))}function sZ(Z){if(C1(Z))return($)=>Z.check($);if(Z&&typeof Z==="object"&&"schema"in Z)return($)=>f4($,Z);let X=h0.infer(Z);return($)=>f4($,X)}function m1(Z,X,$){let Q=[],K=[];for(let Y of Z)if(typeof Y==="string")Q.push(Y),K.push(void 0);else Q.push(Y[0]),K.push(Y[1]);let H=(...Y)=>{let z=Q.map((G,J)=>{let L=J<Y.length?Y[J]:K[J];if(L===void 0)return()=>!0;return sZ(L)}),W=$;return Q.forEach((G,J)=>{let L=J<Y.length?Y[J]:K[J],_="any";if(C1(L))_=L.description;else if(L!==void 0)_=typeof L==="string"?"string":JSON.stringify(L);W=W.replace(new RegExp(`\\b${G}\\b`,"g"),_)}),n(W,(G)=>X(G,...z))};return H.params=Q,H.description=$,H}var t0=m1(["T","U"],(Z,X,$)=>Array.isArray(Z)&&Z.length===2&&X(Z[0])&&$(Z[1]),"Pair<T, U>"),e0=m1(["V"],(Z,X)=>typeof Z==="object"&&Z!==null&&!Array.isArray(Z)&&Object.values(Z).every(X),"Record<string, V>");function Z4(Z,X){let $=Object.values(X),Q=new Set($),K=Object.keys(X),H={};for(let[z,W]of Object.entries(X))H[W]=z;return{description:Z,check:(z)=>Q.has(z),__runtimeType:!0,members:X,names:H,values:$,keys:K}}var rZ=z7(),$1=rZ.version,U0=Symbol.for("tjs.equals");function Q4(Z){let[X=0,$=0,Q=0]=Z.split(".").map(Number);return{major:X,minor:$,patch:Q}}function l4(Z,X){let $=Q4(Z),Q=Q4(X);if($.major!==Q.major)return $.major<Q.major?-1:1;if($.minor!==Q.minor)return $.minor<Q.minor?-1:1;if($.patch!==Q.patch)return $.patch<Q.patch?-1:1;return 0}function m4(Z,X){let $=Q4(Z),Q=Q4(X);return $.major===Q.major}class f1 extends Error{path;expected;actual;callStack;constructor(Z,X,$,Q,K){super(Z);if(this.name="MonadicError",this.path=X,this.expected=$,this.actual=Q,this.callStack=K,Error.captureStackTrace)Error.captureStackTrace(this,f1)}}function tZ(Z,X,$){let Q=$===null?"null":typeof $,K=K1.debug?_7():void 0;return new f1(`Expected ${X} for '${Z}', got ${Q}`,Z,X,Q,K)}function G7(Z){return Z instanceof f1}var i4={debug:!1,safety:"inputs",requireReturnTypes:!1,maxStackSize:100},K1={...i4},F1=[],p1=0;function eZ(){p1++}function Z5(){if(p1>0)p1--}function $5(){return p1>0}function X5(Z){K1={...K1,...Z}}function Q5(){return{...K1}}function J7(Z){if(K1.debug&&Z){F1.push(Z);let X=K1.maxStackSize??100;while(F1.length>X)F1.shift()}}function $4(){if(K1.debug)F1.pop()}function _7(){return[...F1]}function K5(){K1={...i4},F1.length=0,p1=0}function q0(Z,X){if(Z!==null&&typeof Z==="object"&&typeof Z[U0]==="function")return Z[U0](X);if(X!==null&&typeof X==="object"&&typeof X[U0]==="function")return X[U0](Z);if(Z!==null&&typeof Z==="object"&&typeof Z.Equals==="function")return Z.Equals(X);if(X!==null&&typeof X==="object"&&typeof X.Equals==="function")return X.Equals(Z);if(Z===X)return!0;if((Z===null||Z===void 0)&&(X===null||X===void 0))return!0;if(Z===null||Z===void 0||X===null||X===void 0)return!1;if(typeof Z!==typeof X)return!1;if(typeof Z!=="object")return!1;if(Array.isArray(Z)&&Array.isArray(X)){if(Z.length!==X.length)return!1;return Z.every((K,H)=>q0(K,X[H]))}if(Array.isArray(Z)!==Array.isArray(X))return!1;let $=Object.keys(Z),Q=Object.keys(X);if($.length!==Q.length)return!1;return $.every((K)=>q0(Z[K],X[K]))}function L7(Z,X){return!q0(Z,X)}function w1(Z){return Z!==null&&typeof Z==="object"&&Z.$error===!0}function B1(Z,X){let $={$error:!0,message:Z,...X};if(K1.debug&&F1.length>0){let Q=X?.path?[...F1,X.path]:[...F1];$.stack=Q}return $}function p4(Z,X){if(Z.length===0)return B1("Unknown error");if(Z.length===1)return Z[0];let $=Z.map((K)=>{if(K.path){let H=K.path.split(".");return H[H.length-1]}return"unknown"}).join(", "),Q=`Multiple parameter errors in ${X||"function"}: ${$}`;return B1(Q,{path:X,errors:Z})}function i1(Z){if(Z===null)return"null";if(Z===void 0)return"undefined";if(Array.isArray(Z))return"array";let X=typeof Z;if(X!=="object")return X;let $=Z.constructor?.name;if($&&$!=="Object")return $;return"object"}function U7(Z,X){if(Z===null||Z===void 0)return!1;if(typeof Z!=="object"&&typeof Z!=="function")return!1;let $=Z;while($!==null){if($.constructor?.name===X)return!0;$=Object.getPrototypeOf($)}return!1}function v1(Z,X,$){if(w1(Z))return Z;if(typeof X==="object"&&X!==null&&"check"in X){if(X.check(Z))return null;return B1(`Expected ${X.description} but got ${i1(Z)}`,{path:$,expected:X.description,actual:i1(Z)})}let Q=i1(Z);if(X==="any")return null;if(X===Q)return null;if(X==="number"&&Q==="number")return null;if(X==="integer"&&Q==="number"&&Number.isInteger(Z))return null;if(X==="non-negative-integer"&&Q==="number"&&Number.isInteger(Z)&&Z>=0)return null;if(X==="object"&&Q==="object")return null;return B1(`Expected ${X} but got ${Q}`,{path:$,expected:X,actual:Q})}function n4(Z,X,$){for(let[Q,K]of Object.entries(X.params)){let H=Z[Q];if(w1(H))return H;if(K.required&&H===void 0){let z=typeof K.type==="string"?K.type:K.type.description;return B1(`Missing required parameter '${Q}'`,{path:$?`${$}.${Q}`:Q,expected:z,actual:"undefined",loc:K.loc})}if(H===void 0)continue;let Y=v1(H,K.type,$?`${$}.${Q}`:Q);if(Y){if(K.loc)Y.loc=K.loc;return Y}}return null}function c4(Z,X){if(Z.__tjs=X,!(!X.polymorphic&&(X.safe||X.safeReturn||K1.safety!=="none"&&!X.unsafe||X.returns&&K1.safety==="all"&&!X.unsafeReturn)))return Z;let Q=!!X.returns,K=!!X.unsafe,H=!!X.safe,Y=!!X.unsafeReturn,z=!!X.safeReturn,W=X.returns?.defaults,G=Object.entries(X.params),J=G.length,L=Z.name||X.name||"anonymous",_=function(...U){if(p1>0)return Z.apply(this,U);let D=H||!K&&K1.safety!=="none",R=Q&&(z||!Y&&K1.safety==="all");if(!D&&!R)return Z.apply(this,U);if(U.length>0&&w1(U[0]))return U[0];if(D){let M=U.length===1&&typeof U[0]==="object"&&U[0]!==null&&!Array.isArray(U[0]),I=[];if(!M)for(let V=0;V<J;V++){let[F,j]=G[V],B=U[V];if(w1(B)){I.push(B);continue}if(j.required&&B===void 0){I.push(B1(`Missing required parameter '${F}'`,{path:`${L}.${F}`,expected:typeof j.type==="string"?j.type:j.type?.description||"value",actual:"undefined",loc:j.loc}));continue}if(B!==void 0){let P=v1(B,j.type,`${L}.${F}`);if(P){if(j.loc)P.loc=j.loc;I.push(P)}}}else{let V=U[0];for(let F=0;F<J;F++){let[j,B]=G[F],P=V[j];if(w1(P)){I.push(P);continue}if(B.required&&P===void 0){I.push(B1(`Missing required parameter '${j}'`,{path:`${L}.${j}`,expected:typeof B.type==="string"?B.type:B.type?.description||"value",actual:"undefined",loc:B.loc}));continue}if(P!==void 0){let C=v1(P,B.type,`${L}.${j}`);if(C){if(B.loc)C.loc=B.loc;I.push(C)}}}}if(I.length>0)return p4(I,L)}J7(L);try{let M=Z.apply(this,U);if(R&&X.returns&&!w1(M)){let I=W&&typeof M==="object"&&M!==null?Object.assign({},W,M):M,V=v1(I,X.returns.type,`${L}()`);if(V)return $4(),V}return $4(),M}catch(M){return $4(),B1(M.message||String(M),{path:L,cause:M})}};return Object.defineProperty(_,"name",{value:Z.name}),_.__tjs=X,_}function q7(Z){let X=new Proxy(Z,{construct($,Q,K){return Reflect.construct($,Q,K)},apply($,Q,K){return Reflect.construct($,K)}});Object.defineProperty(X,"name",{value:Z.name});for(let $ of Object.getOwnPropertyNames(Z))if($!=="length"&&$!=="name"&&$!=="prototype")Object.defineProperty(X,$,Object.getOwnPropertyDescriptor(Z,$));return X}function H5(){let Z={...K1},X=[],$=0;function Q(I){Z={...Z,...I}}function K(){return{...Z}}function H(I){if(Z.debug&&I){X.push(I);let V=Z.maxStackSize??100;while(X.length>V)X.shift()}}function Y(){if(Z.debug)X.pop()}function z(){return[...X]}function W(){Z={...i4},X.length=0,$=0}function G(){$++}function J(){if($>0)$--}function L(){return $>0}let _=new Map;function U(I,V,F){if(!_.has(I))_.set(I,new Map);_.get(I).set(V,F)}function D(I,V){let F=typeof I,j;if(I===null||I===void 0)return;if(F==="string")j="String";else if(F==="number")j="Number";else if(F==="boolean")j="Boolean";else if(Array.isArray(I))j="Array";else if(F==="object")j=I.constructor?.name||"Object";else return;let B=j;while(B){let C=_.get(B);if(C?.has(V))return C.get(V);if(F==="object"&&!Array.isArray(I)){if(B=Object.getPrototypeOf(B===j?I:Object.getPrototypeOf(I))?.constructor?.name,B==="Object"||B===j)break}else break}let P=_.get("Object");if(P?.has(V))return P.get(V);return}function R(I,V,F){let j=F===null?"null":typeof F,B=Z.debug?z():void 0;return new f1(`Expected ${V} for '${I}', got ${j}`,I,V,j,B)}function M(I,V){let F={$error:!0,message:I,...V};if(Z.debug&&X.length>0){let j=V?.path?[...X,V.path]:[...X];F.stack=j}return F}return{version:$1,MonadicError:f1,typeError:R,isMonadicError:G7,isError:w1,error:M,composeErrors:p4,typeOf:i1,isNativeType:U7,checkType:v1,validateArgs:n4,wrap:c4,wrapClass:q7,compareVersions:l4,versionsCompatible:m4,configure:Q,getConfig:K,pushStack:H,popStack:Y,getStack:z,resetRuntime:W,enterUnsafe:G,exitUnsafe:J,isUnsafeMode:L,validate:W7,infer:X4.infer.bind(X4),Type:n,isRuntimeType:C1,Union:a0,Generic:m1,Enum:Z4,Nullable:o0,Optional:s0,TArray:r0,TString:x0,TNumber:u0,TBoolean:d0,TInteger:l0,TPositiveInt:m0,TNonEmptyString:i0,TEmail:p0,TUrl:n0,TUuid:c0,TPair:t0,TRecord:e0,Is:q0,IsNot:L7,tjsEquals:U0,registerExtension:U,resolveExtension:D}}var b1={version:$1,MonadicError:f1,typeError:tZ,isMonadicError:G7,isError:w1,error:B1,composeErrors:p4,typeOf:i1,isNativeType:U7,checkType:v1,validateArgs:n4,wrap:c4,wrapClass:q7,compareVersions:l4,versionsCompatible:m4,configure:X5,getConfig:Q5,pushStack:J7,popStack:$4,getStack:_7,resetRuntime:K5,enterUnsafe:eZ,exitUnsafe:Z5,isUnsafeMode:$5,createRuntime:H5,validate:W7,infer:X4.infer.bind(X4),Type:n,isRuntimeType:C1,Union:a0,Generic:m1,Enum:Z4,Nullable:o0,Optional:s0,TArray:r0,TString:x0,TNumber:u0,TBoolean:d0,TInteger:l0,TPositiveInt:m0,TNonEmptyString:i0,TEmail:p0,TUrl:n0,TUuid:c0,Timestamp:u4,LegalDate:d4,TPair:t0,TRecord:e0,Is:q0,IsNot:L7};function Y5(){let Z=globalThis;if(Z.__tjs){let X=Z.__tjs.version;if(typeof X!=="string")return Z.__tjs=b1,b1;let $=l4($1,X);if($===0)return Z.__tjs;if(m4($1,X))if($>0)console.info(`TJS runtime: upgrading ${X} → ${$1}`),Z.__tjs=b1;else console.info(`TJS runtime: keeping ${X} (newer than ${$1})`);else if(console.warn(`TJS runtime version conflict: ${X} vs ${$1} (major version mismatch)`),$>0)console.warn(`Upgrading to ${$1} - check for breaking changes`),Z.__tjs=b1;return Z.__tjs}return Z.__tjs=b1,b1}function z5(Z){return`
|
|
344
350
|
// TJS runtime wrapper (skips unsafe functions)
|
|
345
351
|
if (typeof ${Z}.__tjs === 'object' && !${Z}.__tjs.unsafe && typeof globalThis.__tjs?.wrap === 'function') {
|
|
346
352
|
${Z} = globalThis.__tjs.wrap(${Z}, ${Z}.__tjs)
|
|
347
353
|
}
|
|
348
|
-
`.trim()}function
|
|
354
|
+
`.trim()}function D7(Z){return`
|
|
349
355
|
// TJS: callable without new
|
|
350
356
|
${Z} = new Proxy(${Z}, { apply(t, _, a) { return Reflect.construct(t, a) } });
|
|
351
|
-
`.trim()}function
|
|
352
|
-
example: { ${
|
|
353
|
-
}`}function
|
|
354
|
-
description: '${
|
|
355
|
-
predicate(${
|
|
356
|
-
}`}function
|
|
357
|
-
${
|
|
357
|
+
`.trim()}function d(Z,X,$,Q){if(!Z)return"undefined";switch(Z.kind){case w.SyntaxKind.StringKeyword:return"''";case w.SyntaxKind.NumberKeyword:return"0.0";case w.SyntaxKind.BooleanKeyword:return"false";case w.SyntaxKind.NullKeyword:return"null";case w.SyntaxKind.UndefinedKeyword:return"undefined";case w.SyntaxKind.VoidKeyword:return"undefined";case w.SyntaxKind.AnyKeyword:return"any";case w.SyntaxKind.UnknownKeyword:return"any";case w.SyntaxKind.NeverKeyword:return"null";case w.SyntaxKind.ArrayType:{let H=d(Z.elementType,X);if(H==="any")H="null";return`[${H}]`}case w.SyntaxKind.TypeReference:{let K=Z,H=K.typeName.getText();if(H==="Array"&&K.typeArguments?.length)return`[${d(K.typeArguments[0],X,$,Q)}]`;if(H==="Promise"){if(K.typeArguments?.length)return d(K.typeArguments[0],X,$,Q);return"undefined"}if(H==="Generator"||H==="AsyncGenerator"||H==="IterableIterator"||H==="AsyncIterableIterator"){if(K.typeArguments?.length)return d(K.typeArguments[0],X,$,Q);return"undefined"}if(H==="Record")return"{}";if(H==="Map")return"new Map()";if(H==="Set")return"new Set()";if(Q?.typeAliases?.has(H)){let Y=Q.visited??new Set;if(Y.has(H))return $?.push(`Circular type reference '${H}' - using 'any'`),"any";Y.add(H);let z=Q.typeAliases.get(H);return d(z,X,$,{...Q,visited:Y})}if(Q?.interfaces?.has(H)){let Y=Q.visited??new Set;if(Y.has(H))return $?.push(`Circular type reference '${H}' - using 'any'`),"any";Y.add(H);let z=Q.interfaces.get(H),W=[];for(let G of z.members)if(w.isPropertySignature(G)&&G.name){let J=G.name.getText(Q.sourceFile),L=d(G.type,X,$,{...Q,visited:Y});if(!!G.questionToken)W.push(`${J} = ${L}`);else W.push(`${J}: ${L}`)}return`{ ${W.join(", ")} }`}if(/^[A-Z]$/.test(H)||["T","K","V","U","TKey","TValue","TItem","TResult"].includes(H))return $?.push(`Generic type parameter '${H}' converted to 'any' - consider specializing`),"any";return $?.push(`Unknown type '${H}' converted to 'any' - may need manual review`),"any"}case w.SyntaxKind.TypeLiteral:{let K=Z,H=[];for(let Y of K.members)if(w.isPropertySignature(Y)&&Y.name){let z=Y.name.getText(),W=d(Y.type,X);if(W==="any")W="null";H.push(`${z}: ${W}`)}return`{ ${H.join(", ")} }`}case w.SyntaxKind.UnionType:{let K=Z,H=(J)=>J.kind===w.SyntaxKind.NullKeyword||w.isLiteralTypeNode(J)&&J.literal.kind===w.SyntaxKind.NullKeyword,Y=(J)=>J.kind===w.SyntaxKind.UndefinedKeyword||w.isLiteralTypeNode(J)&&J.literal.kind===w.SyntaxKind.UndefinedKeyword,z=K.types.filter((J)=>!H(J)&&!Y(J)),W=K.types.some(H),G=K.types.some(Y);if(z.length===1&&(W||G)){let J=d(z[0],X);if(W)return`${J} | null`;if(G)return`${J} | undefined`}if(K.types.length>0)return d(K.types[0],X);return"undefined"}case w.SyntaxKind.LiteralType:{let K=Z;if(w.isStringLiteral(K.literal))return`'${K.literal.text}'`;if(w.isNumericLiteral(K.literal))return K.literal.text;if(K.literal.kind===w.SyntaxKind.TrueKeyword)return"true";if(K.literal.kind===w.SyntaxKind.FalseKeyword)return"false";if(K.literal.kind===w.SyntaxKind.NullKeyword)return"null";return"undefined"}case w.SyntaxKind.ParenthesizedType:return d(Z.type,X);case w.SyntaxKind.FunctionType:return"undefined";case w.SyntaxKind.TupleType:return`[${Z.elements.map((Y)=>{if(w.isNamedTupleMember(Y))return d(Y.type,X);return d(Y,X)}).join(", ")}]`;default:return"undefined"}}function c(Z,X){if(!Z)return{kind:"any"};switch(Z.kind){case w.SyntaxKind.StringKeyword:return{kind:"string"};case w.SyntaxKind.NumberKeyword:return{kind:"number"};case w.SyntaxKind.BooleanKeyword:return{kind:"boolean"};case w.SyntaxKind.NullKeyword:return{kind:"null"};case w.SyntaxKind.UndefinedKeyword:case w.SyntaxKind.VoidKeyword:return{kind:"undefined"};case w.SyntaxKind.ArrayType:return{kind:"array",items:c(Z.elementType,X)};case w.SyntaxKind.TypeLiteral:{let $=Z,Q={};for(let K of $.members)if(w.isPropertySignature(K)&&K.name){let H=K.name.getText();Q[H]=c(K.type,X)}return{kind:"object",shape:Q}}case w.SyntaxKind.UnionType:{let $=Z,Q=$.types.filter((H)=>H.kind!==w.SyntaxKind.NullKeyword&&H.kind!==w.SyntaxKind.UndefinedKeyword),K=$.types.some((H)=>H.kind===w.SyntaxKind.NullKeyword);if(Q.length===1&&K)return{...c(Q[0],X),nullable:!0};return{kind:"union",members:$.types.map((H)=>c(H,X))}}case w.SyntaxKind.IntersectionType:{let $=Z,Q={};for(let K of $.types){let H=c(K,X);if(H.kind==="object"&&H.shape)Object.assign(Q,H.shape)}if(Object.keys(Q).length>0)return{kind:"object",shape:Q};return{kind:"any"}}case w.SyntaxKind.TupleType:{let $=Z,Q=[];for(let K of $.elements)if(w.isNamedTupleMember(K))Q.push(c(K.type,X));else Q.push(c(K,X));return{kind:"tuple",elements:Q}}case w.SyntaxKind.TypeReference:{let $=Z,Q=$.typeName.getText();if(Q==="Array"&&$.typeArguments?.length)return{kind:"array",items:c($.typeArguments[0],X)};if(Q==="Promise"&&$.typeArguments?.length)return c($.typeArguments[0],X);if((Q==="Generator"||Q==="AsyncGenerator"||Q==="IterableIterator"||Q==="AsyncIterableIterator")&&$.typeArguments?.length)return c($.typeArguments[0],X);if($.typeArguments?.length){let K=c($.typeArguments[0],X);if(Q==="Partial")return K;if(Q==="Required")return K;if(Q==="Readonly")return K;if(Q==="Record"&&$.typeArguments.length>=2)return{kind:"object",shape:{"[key]":c($.typeArguments[1],X)}};if(Q==="Pick"||Q==="Omit")return K;if(Q==="NonNullable"){if(K.nullable)return{...K,nullable:!1};return K}if(["ReturnType","Parameters","ConstructorParameters"].includes(Q))return{kind:"any"}}if(X?.typeAliases?.has(Q)){let K=X.visited??new Set;if(K.has(Q))return{kind:"any"};K.add(Q);let H=X.typeAliases.get(Q);return c(H,{...X,visited:K})}if(X?.interfaces?.has(Q)){let K=X.visited??new Set;if(K.has(Q))return{kind:"any"};K.add(Q);let H=X.interfaces.get(Q),Y={};if(H.heritageClauses){for(let z of H.heritageClauses)if(z.token===w.SyntaxKind.ExtendsKeyword)for(let W of z.types){let G=W.expression.getText(X.sourceFile);if(X.interfaces?.has(G)&&!K.has(G)){let J={kind:w.SyntaxKind.TypeReference,typeName:{getText:()=>G}},L=c(J,{...X,visited:K});if(L.kind==="object"&&L.shape)Object.assign(Y,L.shape)}}}for(let z of H.members)if(w.isPropertySignature(z)&&z.name){let W=z.name.getText(X.sourceFile);Y[W]=c(z.type,{...X,visited:K})}return{kind:"object",shape:Y}}return{kind:"any"}}default:return{kind:"any"}}}function W5(Z,X){if(!Z.typeParameters||Z.typeParameters.length===0)return;let $={};for(let Q of Z.typeParameters){let K=Q.name.getText(),H={};if(Q.constraint){let Y=d(Q.constraint,void 0,X);if(Y.startsWith("{"))try{H.constraint=Y}catch{H.constraint=Y}else H.constraint=Y}if(Q.default){let Y=d(Q.default,void 0,X);H.default=Y}$[K]=H}return Object.keys($).length>0?$:void 0}function G5(Z,X,$){let Q=Z.name.getText(X);if(Z.typeParameters&&Z.typeParameters.length>0)return J5(Z,X,$);let K=[];for(let H of Z.members)if(w.isPropertySignature(H)&&H.name){let Y=H.name.getText(X),z=d(H.type,void 0,$);if(z==="any")z="null";K.push(`${Y}: ${z}`)}if(K.length===0)return`Type ${Q} {}`;return`Type ${Q} {
|
|
358
|
+
example: { ${K.join(", ")} }
|
|
359
|
+
}`}function J5(Z,X,$){let Q=Z.name.getText(X),K=[];for(let W of Z.typeParameters||[]){let G=W.name.getText(X);if(W.default){let J=d(W.default,void 0,$);K.push(`${G} = ${J}`)}else K.push(G)}let H=(Z.typeParameters||[]).map((W)=>W.name.getText(X)),Y=["typeof x === 'object'","x !== null"];for(let W of Z.members)if(w.isPropertySignature(W)&&W.name){let G=W.name.getText(X);if(Y.push(`'${G}' in x`),W.type&&w.isTypeReferenceNode(W.type)){let J=W.type.typeName.getText(X);if(H.includes(J))Y.push(`${J}(x.${G})`)}}let z=["x",...H].join(", ");return`Generic ${Q}<${K.join(", ")}> {
|
|
360
|
+
description: '${Q}'
|
|
361
|
+
predicate(${z}) { return ${Y.join(" && ")} }
|
|
362
|
+
}`}function _5(Z,X){if(!w.isUnionTypeNode(Z))return null;let $=[];for(let Q of Z.types)if(w.isLiteralTypeNode(Q))if(w.isStringLiteral(Q.literal))$.push(`'${Q.literal.text}'`);else if(w.isNumericLiteral(Q.literal))$.push(Q.literal.text);else if(Q.literal.kind===w.SyntaxKind.TrueKeyword)$.push("true");else if(Q.literal.kind===w.SyntaxKind.FalseKeyword)$.push("false");else if(Q.literal.kind===w.SyntaxKind.NullKeyword)$.push("null");else return null;else if(Q.kind===w.SyntaxKind.NullKeyword)$.push("null");else if(Q.kind===w.SyntaxKind.UndefinedKeyword)$.push("undefined");else return null;return $.length>0?$:null}function L5(Z,X,$){let Q=Z.name.getText(X),K=[],H=0;for(let Y of Z.members){let z=Y.name.getText(X);if(Y.initializer)if(w.isStringLiteral(Y.initializer))K.push(` ${z} = '${Y.initializer.text}'`);else if(w.isNumericLiteral(Y.initializer)){let W=parseInt(Y.initializer.text,10);K.push(` ${z} = ${W}`),H=W+1}else if(w.isPrefixUnaryExpression(Y.initializer)&&Y.initializer.operator===w.SyntaxKind.MinusToken){let W=Y.initializer.operand;if(w.isNumericLiteral(W)){let G=-parseInt(W.text,10);K.push(` ${z} = ${G}`),H=G+1}}else K.push(` ${z} = ${Y.initializer.getText(X)}`);else K.push(` ${z} = ${H}`),H++}return`Enum ${Q} '${Q}' {
|
|
363
|
+
${K.join(`
|
|
358
364
|
`)}
|
|
359
|
-
}`}function
|
|
365
|
+
}`}function U5(Z,X,$){let Q=Z.name.getText(X);if(Z.typeParameters&&Z.typeParameters.length>0)return q5(Z,X,$);let K=_5(Z.type,X);if(K)return`Union ${Q} '${Q}' ${K.join(" | ")}`;let H=d(Z.type,void 0,$);if(H==="''"||H==="0"||H==="true"||H==="null")return`Type ${Q} ${H}`;return`Type ${Q} {
|
|
360
366
|
example: ${H}
|
|
361
|
-
}`}function
|
|
362
|
-
description: '${
|
|
367
|
+
}`}function q5(Z,X,$){let Q=Z.name.getText(X),K=[];for(let z of Z.typeParameters||[]){let W=z.name.getText(X);if(z.default){let G=d(z.default,void 0,$);K.push(`${W} = ${G}`)}else K.push(W)}let Y=["x",...(Z.typeParameters||[]).map((z)=>z.name.getText(X))].join(", ");return`Generic ${Q}<${K.join(", ")}> {
|
|
368
|
+
description: '${Q}'
|
|
363
369
|
predicate(${Y}) { return true }
|
|
364
|
-
}`}function
|
|
365
|
-
`:"",
|
|
366
|
-
${G.join(`
|
|
370
|
+
}`}function A7(Z,X,$,Q,K){let H=[],Y=n1(Z.parameters,X,Q,H),{line:z}=X.getLineAndCharacterOfPosition(Z.getStart(X)),W=K?`/* line ${z+1} */
|
|
371
|
+
`:"",G=$||(w.isFunctionDeclaration(Z)&&Z.name?Z.name.getText(X):""),J=Z.type?d(Z.type,void 0,Q):"",L=J&&J!=="undefined"&&J!=="any"?` -! ${J}`:"";if(Z.type&&(J==="any"||J==="undefined")){let V=Z.type.getText(X);if(V!=="any"&&V!=="unknown"&&V!=="void")H.push(`return: ${V}`)}let _="";if(Z.body){let V=w.isBlock(Z.body)?Z.body.getText(X):`{ return ${Z.body.getText(X)} }`;_=w.transpileModule(V,{compilerOptions:{target:w.ScriptTarget.ESNext,module:w.ModuleKind.ESNext,removeComments:!1}}).outputText.trim()}else _="{ }";let U=Z.modifiers?.some((V)=>V.kind===w.SyntaxKind.AsyncKeyword),D=!!Z.asteriskToken,R=U?"async ":"",M=D?"function* ":"function ",I=H.length>0?`/* TODO: TS types degraded — ${H.join(", ")} */
|
|
372
|
+
`:"";return`${W}${I}${R}${M}${G}(${Y.join(", ")})${L} ${_}`}function D5(Z,X,$,Q){let K=X.name?.getText($)||"",H=`_${K}_impl`,Y=[],z=n1(X.parameters,$,Q),W="{ }";if(X.body){let U=X.body.getText($);W=w.transpileModule(U,{compilerOptions:{target:w.ScriptTarget.ESNext,module:w.ModuleKind.ESNext,removeComments:!1}}).outputText.trim()}let G=X.modifiers?.some((U)=>U.kind===w.SyntaxKind.AsyncKeyword),J=!!X.asteriskToken,L=G?"async ":"",_=J?"function* ":"function ";Y.push(`${L}${_}${H}(${z.join(", ")}) ${W}`);for(let U of Z){let D=n1(U.parameters,$,Q),R=U.parameters.map((B)=>B.name.getText($)),M=U.type?d(U.type,void 0,Q):"",I=M&&M!=="undefined"&&M!=="any"?` -! ${M}`:"",{line:V}=$.getLineAndCharacterOfPosition(U.getStart($)),F=`/* line ${V+1} */
|
|
373
|
+
`,j=J?"yield* ":"return ";Y.push(`${F}${L}${_}${K}(${D.join(", ")})${I} { ${j}${H}(${R.join(", ")}) }`)}return Y}function A5(Z,X,$){let Q=Z.name?.getText(X)||"Anonymous",K=Z.heritageClauses?.find((G)=>G.token===w.SyntaxKind.ExtendsKeyword)?.types[0]?.getText(X),H=new Map;for(let G of Z.members)if(w.isPropertyDeclaration(G)&&G.name){let J=G.name.getText(X);if(G.modifiers?.some((_)=>_.kind===w.SyntaxKind.PrivateKeyword)&&!J.startsWith("#"))H.set(J,`#${J}`)}let Y=(G)=>{let J=G;for(let[L,_]of H)J=J.replace(new RegExp(`this\\.${L}\\b`,"g"),`this.${_}`);return J},z=[];for(let G of Z.members){if(w.isConstructorDeclaration(G)){let J=n1(G.parameters,X,$),L="{ }";if(G.body){let _=w.transpileModule(G.body.getText(X),{compilerOptions:{target:w.ScriptTarget.ESNext,module:w.ModuleKind.ESNext,removeComments:!1}});L=Y(_.outputText.trim())}z.push(` constructor(${J.join(", ")}) ${L}`)}if(w.isMethodDeclaration(G)&&G.name){let J=G.name.getText(X),L=G.modifiers?.some((B)=>B.kind===w.SyntaxKind.StaticKeyword),_=G.modifiers?.some((B)=>B.kind===w.SyntaxKind.AsyncKeyword),U=n1(G.parameters,X,$),D=G.type?d(G.type,void 0,$):"",R=D&&D!=="undefined"&&D!=="any"?` -! ${D}`:"",M="{ }";if(G.body){let B=w.transpileModule(G.body.getText(X),{compilerOptions:{target:w.ScriptTarget.ESNext,module:w.ModuleKind.ESNext,removeComments:!1}});M=Y(B.outputText.trim())}let I=!!G.asteriskToken,V=L?"static ":"",F=_?"async ":"",j=I?"*":"";z.push(` ${V}${F}${j}${J}(${U.join(", ")})${R} ${M}`)}if(w.isGetAccessorDeclaration(G)&&G.name){let J=G.name.getText(X),L=G.type?d(G.type,void 0,$):"",_=L&&L!=="undefined"&&L!=="any"?` -! ${L}`:"",U="{ }";if(G.body){let D=w.transpileModule(G.body.getText(X),{compilerOptions:{target:w.ScriptTarget.ESNext,module:w.ModuleKind.ESNext,removeComments:!1}});U=Y(D.outputText.trim())}z.push(` get ${J}()${_} ${U}`)}if(w.isSetAccessorDeclaration(G)&&G.name){let J=G.name.getText(X),L=n1(G.parameters,X,$),_="{ }";if(G.body){let U=w.transpileModule(G.body.getText(X),{compilerOptions:{target:w.ScriptTarget.ESNext,module:w.ModuleKind.ESNext,removeComments:!1}});_=Y(U.outputText.trim())}z.push(` set ${J}(${L.join(", ")}) ${_}`)}if(w.isPropertyDeclaration(G)&&G.name){let J=G.name.getText(X),_=G.modifiers?.some((D)=>D.kind===w.SyntaxKind.StaticKeyword)?"static ":"",U=H.get(J)||J;if(G.initializer){let D=w.transpileModule(G.initializer.getText(X),{compilerOptions:{target:w.ScriptTarget.ESNext,module:w.ModuleKind.ESNext,removeComments:!1}});z.push(` ${_}${U} = ${D.outputText.trim()}`)}else z.push(` ${_}${U}`)}}let W=K?` extends ${K}`:"";return`class ${Q}${W} {
|
|
374
|
+
${z.join(`
|
|
367
375
|
`)}
|
|
368
|
-
}`}function
|
|
376
|
+
}`}function n1(Z,X,$,Q){let K=[];for(let H of Z){let Y=H.name.getText(X),z=!!H.questionToken||!!H.initializer,W=d(H.type,void 0,$);if(H.initializer){let G=H.initializer.getText(X);K.push(`${Y} = ${G}`)}else if(W==="any"||W==="undefined"){if(K.push(Y),Q&&H.type){let G=H.type.getText(X);if(G!=="any"&&G!=="unknown")Q.push(`${Y}: ${G}`)}}else if(z)K.push(`${Y}: ${W} | undefined`);else K.push(`${Y}: ${W}`)}return K}function K4(Z,X,$,Q){let K=w.isFunctionDeclaration(Z)&&Z.name?Z.name.getText(X):"anonymous",H={};for(let W of Z.parameters){let G=W.name.getText(X),J=!!W.questionToken||!!W.initializer,L=void 0;if(W.initializer){let _=W.initializer.getText(X);try{L=JSON.parse(_)}catch{L=_}}H[G]={type:c(W.type,Q),required:!J,default:L}}let Y={name:K,params:H,returns:Z.type?c(Z.type,Q):void 0},z=W5(Z,$);if(z)Y.typeParams=z;return Y}function I5(Z,X,$,Q){let K=Z.name?.getText(X)||"anonymous",H={},Y={},z;for(let G of Z.members){if(w.isConstructorDeclaration(G)){let J={};for(let L of G.parameters){let _=L.name.getText(X),U=!!L.questionToken||!!L.initializer,D=void 0;if(L.initializer){let R=L.initializer.getText(X);try{D=JSON.parse(R)}catch{D=R}}J[_]={type:c(L.type,Q),required:!U,default:D}}z={params:J}}if(w.isMethodDeclaration(G)&&G.name){let J=G.name.getText(X),L=G.modifiers?.some((D)=>D.kind===w.SyntaxKind.StaticKeyword),_={};for(let D of G.parameters){let R=D.name.getText(X),M=!!D.questionToken||!!D.initializer,I=void 0;if(D.initializer){let V=D.initializer.getText(X);try{I=JSON.parse(V)}catch{I=V}}_[R]={type:c(D.type,Q),required:!M,default:I}}let U={name:J,params:_,returns:G.type?c(G.type,Q):void 0};if(L)Y[J]=U;else H[J]=U}}let W={name:K,methods:H,staticMethods:Y,constructor:z};if(Z.typeParameters&&Z.typeParameters.length>0){let G={};for(let J of Z.typeParameters){let L=J.name.getText(X),_={};if(J.constraint)_.constraint=d(J.constraint,void 0,$,Q);if(J.default)_.default=d(J.default,void 0,$,Q);G[L]=_}W.typeParams=G}return W}function B5(Z){let X=[],$=/\/\*test\s+(['"`])([^'"`]*)\1\s*\{[\s\S]*?\}\s*\*\/|\/\*test\s*\{[\s\S]*?\}\s*\*\//g,Q;while((Q=$.exec(Z))!==null)X.push(Q[0]);return X}function R5(Z){let X=[],$=/\/\*#[\s\S]*?\*\//g,Q=0,K=null,H=[];for(let z=0;z<Z.length;z++){let W=Z[z],G=z>0?Z[z-1]:"";if(!K&&(W==='"'||W==="'"||W==="`"))K=W;else if(K&&W===K&&G!=="\\")K=null;if(!K){if(W==="{")Q++;if(W==="}")Q--}H[z]=Q}let Y;while((Y=$.exec(Z))!==null)if(H[Y.index]===0)X.push({content:Y[0],index:Y.index});return X}function M5(Z,X={}){let{emitTJS:$=!1,filename:Q="input.ts"}=X,K=[],H=B5(Z),Y=$?R5(Z):[],z=w.createSourceFile(Q,Z,w.ScriptTarget.Latest,!0),W=[],G=new Set,J={},L={},_=new Set,U=(B)=>{for(let P=0;P<Y.length;P++){let C=Y[P];if(!_.has(P)&&C.index<B)W.push(C.content),_.add(P)}},D=new Map,R=new Map;function M(B){if(w.isTypeAliasDeclaration(B))D.set(B.name.getText(z),B.type);if(w.isInterfaceDeclaration(B)){let P=B.name.getText(z),C=R.get(P);if(C){let O=w.factory.updateInterfaceDeclaration(C,C.modifiers,C.name,C.typeParameters,C.heritageClauses,[...C.members,...B.members]);R.set(P,O)}else R.set(P,B)}w.forEachChild(B,M)}M(z);let I={typeAliases:D,interfaces:R,sourceFile:z,warnings:K},V=new Map;for(let B of z.statements)if(w.isFunctionDeclaration(B)&&B.name){let P=B.name.getText(z);if(!V.has(P))V.set(P,{signatures:[],implementation:null});let C=V.get(P);if(B.body)C.implementation=B;else C.signatures.push(B)}for(let[B,P]of V)if(P.signatures.length===0||!P.implementation)V.delete(B);for(let B of z.statements){let P=!1;if($)U(B.getStart(z));if(w.isFunctionDeclaration(B)&&B.name){let C=B.name.getText(z);P=!0;let O=V.get(C);if(O)if(!B.body);else if($)W.push(...D5(O.signatures,B,z,K));else{let T=[];for(let g of O.signatures)T.push(K4(g,z,K,I));let k=K4(B,z,K,I);k.overloads=T,J[C]=k}else if($)W.push(A7(B,z,void 0,K,!0));else J[C]=K4(B,z,K,I)}if(w.isVariableStatement(B)){let C=!1;for(let O of B.declarationList.declarations)if(w.isIdentifier(O.name)&&O.initializer&&(w.isArrowFunction(O.initializer)||w.isFunctionExpression(O.initializer))){C=!0;let T=O.name.getText(z),k=O.initializer;if($)W.push(A7(k,z,T,K,!0));else{let g=K4(k,z,K,I);g.name=T,J[T]=g}}if(!C&&$){let O=w.transpileModule(B.getText(z),{compilerOptions:{target:w.ScriptTarget.ESNext,module:w.ModuleKind.ESNext,removeComments:!1}});W.push(O.outputText.trim())}P=!0}if(w.isInterfaceDeclaration(B)){if(P=!0,$){let C=B.name.getText(z);if(!G.has(C)){G.add(C);let O=R.get(C)||B,T=G5(O,z,K);if(T)W.push(T)}}}if(w.isTypeAliasDeclaration(B)){if(P=!0,$){let C=B.name.getText(z);if(!G.has(C)){G.add(C);let O=U5(B,z,K);if(O)W.push(O)}}}if(w.isEnumDeclaration(B)){if(P=!0,$){let C=B.name.getText(z);if(!G.has(C)){G.add(C);let O=L5(B,z,K);if(O)W.push(O)}}}if(w.isClassDeclaration(B)&&B.name){let C=B.name.getText(z);if(P=!0,$){let O=A5(B,z,K);W.push(O)}else L[C]=I5(B,z,K,I)}if(w.isImportDeclaration(B)){if(P=!0,$){if(!(B.importClause?.isTypeOnly||B.importClause?.namedBindings&&w.isNamedImports(B.importClause.namedBindings)&&B.importClause.namedBindings.elements.every((O)=>O.isTypeOnly))){let T=w.transpileModule(B.getText(z),{compilerOptions:{target:w.ScriptTarget.ESNext,module:w.ModuleKind.ESNext,removeComments:!1}}).outputText.trim();if(T)W.push(T)}}}if(w.isExportDeclaration(B)||w.isExportAssignment(B)){if(P=!0,$){let O=w.transpileModule(B.getText(z),{compilerOptions:{target:w.ScriptTarget.ESNext,module:w.ModuleKind.ESNext,removeComments:!1}}).outputText.trim();if(O)W.push(O)}}if(!P&&$){let O=w.transpileModule(B.getText(z),{compilerOptions:{target:w.ScriptTarget.ESNext,module:w.ModuleKind.ESNext,removeComments:!1}}).outputText.trim();if(O)W.push(O)}}if($){U(1/0);let P=`/* tjs <- ${Q||"unknown"} */
|
|
369
377
|
|
|
370
|
-
`,
|
|
378
|
+
`,C=H.length>0?`
|
|
371
379
|
|
|
372
380
|
`+H.join(`
|
|
373
381
|
|
|
374
|
-
`):"";return{code:P+
|
|
382
|
+
`):"";return{code:P+W.join(`
|
|
375
383
|
|
|
376
|
-
`)+
|
|
377
|
-
${B}.__tjs = ${
|
|
378
|
-
`}for(let[B,P]of Object.entries(L)){let
|
|
379
|
-
${B}.__tjs = ${
|
|
380
|
-
`,
|
|
381
|
-
${
|
|
382
|
-
`}return{code:A,types:J,classes:Object.keys(L).length>0?L:void 0,warnings:Q.length>0?Q:void 0}}import{s as q7}from"tosijs-schema";function D7(Z){if(Z===null)return"null";if(Z===void 0)return"undefined";if(Array.isArray(Z))return"array";return typeof Z}function X4(Z){return q7.infer(Z)}function p4(Z){return X4(Z)}p4.type=D7;p4.infer=X4;var Y5=new Proxy(p4,{get(Z,X){if(X==="type")return D7;if(X==="infer")return X4;return q7[X]},apply(Z,X,$){return X4($[0])}});async function K4(Z){let X=`${$1}:${Z}`;if(typeof crypto<"u"&&crypto.subtle){let Q=new TextEncoder().encode(X),H=await crypto.subtle.digest("SHA-256",Q);return Array.from(new Uint8Array(H)).map((G)=>G.toString(16).padStart(2,"0")).join("")}let $=5381;for(let K=0;K<X.length;K++)$=($<<5)+$+X.charCodeAt(K)>>>0;return $.toString(16)}function G5(Z){let X=`${$1}:${Z}`,$=5381;for(let K=0;K<X.length;K++)$=($<<5)+$+X.charCodeAt(K)>>>0;return $.toString(16)}var z5="tjs-metadata-cache",W5=1,s="modules";class n4{db=null;stats={hits:0,misses:0};pendingOpen=null;async open(){if(this.db)return;if(this.pendingOpen)return this.pendingOpen;this.pendingOpen=this._open(),await this.pendingOpen,this.pendingOpen=null}async _open(){return new Promise((Z,X)=>{if(typeof indexedDB>"u"){Z();return}let $=indexedDB.open(z5,W5);$.onerror=()=>{console.warn("MetadataCache: Failed to open IndexedDB",$.error),Z()},$.onsuccess=()=>{this.db=$.result,Z()},$.onupgradeneeded=(K)=>{let Q=K.target.result;if(!Q.objectStoreNames.contains(s)){let H=Q.createObjectStore(s,{keyPath:"hash"});H.createIndex("timestamp","timestamp"),H.createIndex("version","version")}}})}async get(Z){if(!this.db){this.stats.misses++;return}let X=await K4(Z);return new Promise(($)=>{let H=this.db.transaction(s,"readonly").objectStore(s).get(X);H.onerror=()=>{this.stats.misses++,$(void 0)},H.onsuccess=()=>{let Y=H.result;if(Y&&Y.version!==$1){this.stats.misses++,$(void 0);return}if(Y)this.stats.hits++;else this.stats.misses++;$(Y)}})}async getTranspile(Z){return(await this.get(Z))?.transpile}async getTJS(Z){return(await this.get(Z))?.tjs}async setTranspile(Z,X){await this._set(Z,{transpile:X})}async setTJS(Z,X){await this._set(Z,{tjs:X})}async _set(Z,X){if(!this.db)return;let $=await K4(Z);return new Promise((K,Q)=>{let Y=this.db.transaction(s,"readwrite").objectStore(s),G=Y.get($);G.onsuccess=()=>{let z=G.result,W={hash:$,version:$1,timestamp:Date.now(),transpile:X.transpile??z?.transpile,tjs:X.tjs??z?.tjs},J=Y.put(W);J.onerror=()=>Q(J.error),J.onsuccess=()=>K()},G.onerror=()=>Q(G.error)})}async delete(Z){if(!this.db)return;let X=await K4(Z);return new Promise(($,K)=>{let Y=this.db.transaction(s,"readwrite").objectStore(s).delete(X);Y.onerror=()=>K(Y.error),Y.onsuccess=()=>$()})}async clear(){if(!this.db)return;return new Promise((Z,X)=>{let Q=this.db.transaction(s,"readwrite").objectStore(s).clear();Q.onerror=()=>X(Q.error),Q.onsuccess=()=>{this.stats={hits:0,misses:0},Z()}})}async prune(Z){if(!this.db)return 0;let X=Date.now()-Z;return new Promise(($,K)=>{let Y=this.db.transaction(s,"readwrite").objectStore(s).index("timestamp"),G=IDBKeyRange.upperBound(X),z=0,W=Y.openCursor(G);W.onsuccess=(J)=>{let L=J.target.result;if(L)L.delete(),z++,L.continue();else $(z)},W.onerror=()=>K(W.error)})}async pruneOldVersions(){if(!this.db)return 0;return new Promise((Z,X)=>{let K=this.db.transaction(s,"readwrite").objectStore(s),Q=0,H=K.openCursor();H.onsuccess=(Y)=>{let G=Y.target.result;if(G){if(G.value.version!==$1)G.delete(),Q++;G.continue()}else Z(Q)},H.onerror=()=>X(H.error)})}async getStats(){let Z=await this.count(),X=await this.estimateSize(),$=this.stats.hits+this.stats.misses,K=$>0?this.stats.hits/$:0;return{entries:Z,bytes:X,hits:this.stats.hits,misses:this.stats.misses,hitRate:K}}async count(){if(!this.db)return 0;return new Promise((Z,X)=>{let Q=this.db.transaction(s,"readonly").objectStore(s).count();Q.onerror=()=>X(Q.error),Q.onsuccess=()=>Z(Q.result)})}async estimateSize(){if(!this.db)return 0;if(typeof navigator<"u"&&navigator.storage?.estimate)try{return(await navigator.storage.estimate()).usage??0}catch{}return new Promise((Z,X)=>{let K=this.db.transaction(s,"readonly").objectStore(s),Q=0,H=K.openCursor();H.onsuccess=(Y)=>{let G=Y.target.result;if(G)Q+=JSON.stringify(G.value).length*2,G.continue();else Z(Q)},H.onerror=()=>X(H.error)})}close(){if(this.db)this.db.close(),this.db=null}isAvailable(){return this.db!==null}resetStats(){this.stats={hits:0,misses:0}}}var U0=null;async function Q4(){if(!U0)U0=new n4,await U0.open();return U0}function J5(Z){U0=Z}function H4(Z,X,$,K,Q){if(!$)$=N;(function H(Y,G,z){var W=z||Y.type;if($[W](Y,G,H),X[W])X[W](Y,G)})(Z,K,Q)}function R7(Z,X,$,K,Q){var H=[];if(!$)$=N;(function Y(G,z,W){var J=W||G.type,L=G!==H[H.length-1];if(L)H.push(G);if($[J](G,z,Y),X[J])X[J](G,z||H,H);if(L)H.pop()})(Z,K,Q)}function c4(Z,X,$){$(Z,X)}function y1(Z,X,$){}var N={};N.Program=N.BlockStatement=N.StaticBlock=function(Z,X,$){for(var K=0,Q=Z.body;K<Q.length;K+=1){var H=Q[K];$(H,X,"Statement")}};N.Statement=c4;N.EmptyStatement=y1;N.ExpressionStatement=N.ParenthesizedExpression=N.ChainExpression=function(Z,X,$){return $(Z.expression,X,"Expression")};N.IfStatement=function(Z,X,$){if($(Z.test,X,"Expression"),$(Z.consequent,X,"Statement"),Z.alternate)$(Z.alternate,X,"Statement")};N.LabeledStatement=function(Z,X,$){return $(Z.body,X,"Statement")};N.BreakStatement=N.ContinueStatement=y1;N.WithStatement=function(Z,X,$){$(Z.object,X,"Expression"),$(Z.body,X,"Statement")};N.SwitchStatement=function(Z,X,$){$(Z.discriminant,X,"Expression");for(var K=0,Q=Z.cases;K<Q.length;K+=1){var H=Q[K];$(H,X)}};N.SwitchCase=function(Z,X,$){if(Z.test)$(Z.test,X,"Expression");for(var K=0,Q=Z.consequent;K<Q.length;K+=1){var H=Q[K];$(H,X,"Statement")}};N.ReturnStatement=N.YieldExpression=N.AwaitExpression=function(Z,X,$){if(Z.argument)$(Z.argument,X,"Expression")};N.ThrowStatement=N.SpreadElement=function(Z,X,$){return $(Z.argument,X,"Expression")};N.TryStatement=function(Z,X,$){if($(Z.block,X,"Statement"),Z.handler)$(Z.handler,X);if(Z.finalizer)$(Z.finalizer,X,"Statement")};N.CatchClause=function(Z,X,$){if(Z.param)$(Z.param,X,"Pattern");$(Z.body,X,"Statement")};N.WhileStatement=N.DoWhileStatement=function(Z,X,$){$(Z.test,X,"Expression"),$(Z.body,X,"Statement")};N.ForStatement=function(Z,X,$){if(Z.init)$(Z.init,X,"ForInit");if(Z.test)$(Z.test,X,"Expression");if(Z.update)$(Z.update,X,"Expression");$(Z.body,X,"Statement")};N.ForInStatement=N.ForOfStatement=function(Z,X,$){$(Z.left,X,"ForInit"),$(Z.right,X,"Expression"),$(Z.body,X,"Statement")};N.ForInit=function(Z,X,$){if(Z.type==="VariableDeclaration")$(Z,X);else $(Z,X,"Expression")};N.DebuggerStatement=y1;N.FunctionDeclaration=function(Z,X,$){return $(Z,X,"Function")};N.VariableDeclaration=function(Z,X,$){for(var K=0,Q=Z.declarations;K<Q.length;K+=1){var H=Q[K];$(H,X)}};N.VariableDeclarator=function(Z,X,$){if($(Z.id,X,"Pattern"),Z.init)$(Z.init,X,"Expression")};N.Function=function(Z,X,$){if(Z.id)$(Z.id,X,"Pattern");for(var K=0,Q=Z.params;K<Q.length;K+=1){var H=Q[K];$(H,X,"Pattern")}$(Z.body,X,Z.expression?"Expression":"Statement")};N.Pattern=function(Z,X,$){if(Z.type==="Identifier")$(Z,X,"VariablePattern");else if(Z.type==="MemberExpression")$(Z,X,"MemberPattern");else $(Z,X)};N.VariablePattern=y1;N.MemberPattern=c4;N.RestElement=function(Z,X,$){return $(Z.argument,X,"Pattern")};N.ArrayPattern=function(Z,X,$){for(var K=0,Q=Z.elements;K<Q.length;K+=1){var H=Q[K];if(H)$(H,X,"Pattern")}};N.ObjectPattern=function(Z,X,$){for(var K=0,Q=Z.properties;K<Q.length;K+=1){var H=Q[K];if(H.type==="Property"){if(H.computed)$(H.key,X,"Expression");$(H.value,X,"Pattern")}else if(H.type==="RestElement")$(H.argument,X,"Pattern")}};N.Expression=c4;N.ThisExpression=N.Super=N.MetaProperty=y1;N.ArrayExpression=function(Z,X,$){for(var K=0,Q=Z.elements;K<Q.length;K+=1){var H=Q[K];if(H)$(H,X,"Expression")}};N.ObjectExpression=function(Z,X,$){for(var K=0,Q=Z.properties;K<Q.length;K+=1){var H=Q[K];$(H,X)}};N.FunctionExpression=N.ArrowFunctionExpression=N.FunctionDeclaration;N.SequenceExpression=function(Z,X,$){for(var K=0,Q=Z.expressions;K<Q.length;K+=1){var H=Q[K];$(H,X,"Expression")}};N.TemplateLiteral=function(Z,X,$){for(var K=0,Q=Z.quasis;K<Q.length;K+=1){var H=Q[K];$(H,X)}for(var Y=0,G=Z.expressions;Y<G.length;Y+=1){var z=G[Y];$(z,X,"Expression")}};N.TemplateElement=y1;N.UnaryExpression=N.UpdateExpression=function(Z,X,$){$(Z.argument,X,"Expression")};N.BinaryExpression=N.LogicalExpression=function(Z,X,$){$(Z.left,X,"Expression"),$(Z.right,X,"Expression")};N.AssignmentExpression=N.AssignmentPattern=function(Z,X,$){$(Z.left,X,"Pattern"),$(Z.right,X,"Expression")};N.ConditionalExpression=function(Z,X,$){$(Z.test,X,"Expression"),$(Z.consequent,X,"Expression"),$(Z.alternate,X,"Expression")};N.NewExpression=N.CallExpression=function(Z,X,$){if($(Z.callee,X,"Expression"),Z.arguments)for(var K=0,Q=Z.arguments;K<Q.length;K+=1){var H=Q[K];$(H,X,"Expression")}};N.MemberExpression=function(Z,X,$){if($(Z.object,X,"Expression"),Z.computed)$(Z.property,X,"Expression")};N.ExportNamedDeclaration=N.ExportDefaultDeclaration=function(Z,X,$){if(Z.declaration)$(Z.declaration,X,Z.type==="ExportNamedDeclaration"||Z.declaration.id?"Statement":"Expression");if(Z.source)$(Z.source,X,"Expression")};N.ExportAllDeclaration=function(Z,X,$){if(Z.exported)$(Z.exported,X);$(Z.source,X,"Expression")};N.ImportDeclaration=function(Z,X,$){for(var K=0,Q=Z.specifiers;K<Q.length;K+=1){var H=Q[K];$(H,X)}$(Z.source,X,"Expression")};N.ImportExpression=function(Z,X,$){$(Z.source,X,"Expression")};N.ImportSpecifier=N.ImportDefaultSpecifier=N.ImportNamespaceSpecifier=N.Identifier=N.PrivateIdentifier=N.Literal=y1;N.TaggedTemplateExpression=function(Z,X,$){$(Z.tag,X,"Expression"),$(Z.quasi,X,"Expression")};N.ClassDeclaration=N.ClassExpression=function(Z,X,$){return $(Z,X,"Class")};N.Class=function(Z,X,$){if(Z.id)$(Z.id,X,"Pattern");if(Z.superClass)$(Z.superClass,X,"Expression");$(Z.body,X)};N.ClassBody=function(Z,X,$){for(var K=0,Q=Z.body;K<Q.length;K+=1){var H=Q[K];$(H,X)}};N.MethodDefinition=N.PropertyDefinition=N.Property=function(Z,X,$){if(Z.computed)$(Z.key,X,"Expression");if(Z.value)$(Z.value,X,"Expression")};var L5={unusedVariables:!0,undefinedVariables:!0,unreachableCode:!0,noExplicitNew:!0};function U5(Z,X={}){let $={...L5,...X},K=[],Q;try{Q=F1(Z,{filename:$.filename,colonShorthand:!0}).ast}catch(Y){return{diagnostics:[{severity:"error",message:Y.message,line:Y.loc?.line,column:Y.loc?.column,rule:"parse-error"}],valid:!1}}let H=[B7()];if(R7(Q,{FunctionDeclaration(Y,G,z){let W=B7();H.push(W);for(let J of Y.params)q5(W,J,"parameter");if(Y.id)(H[H.length-2]||H[0]).declarations.set(Y.id.name,{node:Y.id,kind:"function",used:!1})},VariableDeclaration(Y){let G=H[H.length-1];for(let z of Y.declarations)if(z.id.type==="Identifier")G.declarations.set(z.id.name,{node:z.id,kind:Y.kind,used:!1})}}),H4(Q,{Identifier(Y){for(let G=H.length-1;G>=0;G--){let z=H[G].declarations.get(Y.name);if(z){z.used=!0;break}}}}),$.unusedVariables)for(let Y of H)for(let[G,z]of Y.declarations){if(G.startsWith("_"))continue;if(!z.used&&z.kind!=="function")K.push({severity:"warning",message:`'${G}' is declared but never used`,line:z.node.loc?.start?.line,column:z.node.loc?.start?.column,rule:"no-unused-vars"})}if($.unreachableCode)H4(Q,{BlockStatement(Y){let G=!1;for(let z of Y.body){if(G){K.push({severity:"warning",message:"Unreachable code after return statement",line:z.loc?.start?.line,column:z.loc?.start?.column,rule:"no-unreachable"});break}if(z.type==="ReturnStatement")G=!0}}});if($.noExplicitNew)H4(Q,{NewExpression(Y){let G="class";if(Y.callee.type==="Identifier")G=Y.callee.name;else if(Y.callee.type==="MemberExpression"){if(Y.callee.property.type==="Identifier")G=Y.callee.property.name}K.push({severity:"warning",message:`Unnecessary 'new' keyword. In TJS, classes are callable without 'new': ${G}(...) instead of new ${G}(...)`,line:Y.loc?.start?.line,column:Y.loc?.start?.column,rule:"no-explicit-new"})}});return{diagnostics:K,valid:K.filter((Y)=>Y.severity==="error").length===0}}function B7(){return{declarations:new Map}}function q5(Z,X,$){if(X.type==="Identifier")Z.declarations.set(X.name,{node:X,kind:$,used:!1});else if(X.type==="AssignmentPattern"&&X.left.type==="Identifier")Z.declarations.set(X.left.name,{node:X.left,kind:$,used:!1})}function D5(Z){let X=[],$=0,K=null;for(let Q=0;Q<Z.length;Q++){let H=Z[Q],Y=Q>0?Z[Q-1]:"";if(!K&&(H==='"'||H==="'"||H==="`"))K=H;else if(K&&H===K&&Y!=="\\")K=null;if(!K){if(H==="{")$++;if(H==="}")$--}X[Q]=$}return X}function I7(Z){let X=[],$=D5(Z),K=/\/\*#([\s\S]*?)\*\//g,Q=/function\s+(\w+)\s*\(([^)]*)\)\s*(?:(-[>?!])\s*('[^']*'|"[^"]*"|[^\s{]+)|:\s*(\w+))?\s*\{/g,H=[],Y;while((Y=K.exec(Z))!==null){if($[Y.index]!==0)continue;let z=Y[1],W=z.split(`
|
|
383
|
-
`),J=
|
|
384
|
-
`);H.push({type:"doc",index:Y.index,data:
|
|
385
|
-
${
|
|
384
|
+
`)+C,warnings:K.length>0?K:void 0}}let j=w.transpileModule(Z,{compilerOptions:{target:w.ScriptTarget.ESNext,module:w.ModuleKind.ESNext,removeComments:!1}}).outputText;for(let[B,P]of Object.entries(J)){let C={params:Object.fromEntries(Object.entries(P.params).map(([T,k])=>[T,{type:k.type.kind,required:k.required,default:k.default}])),returns:P.returns?{type:P.returns.kind}:void 0};if(P.typeParams)C.typeParams=P.typeParams;let O=JSON.stringify(C,null,2);j+=`
|
|
385
|
+
${B}.__tjs = ${O};
|
|
386
|
+
`}for(let[B,P]of Object.entries(L)){let C={constructor:P.constructor?{params:Object.fromEntries(Object.entries(P.constructor.params??{}).map(([T,k])=>[T,{type:k.type.kind,required:k.required,default:k.default}]))}:void 0,methods:Object.fromEntries(Object.entries(P.methods??{}).map(([T,k])=>[T,{params:Object.fromEntries(Object.entries(k.params??{}).map(([g,l])=>[g,{type:l.type.kind,required:l.required}])),returns:k.returns?{type:k.returns.kind}:void 0}])),staticMethods:Object.fromEntries(Object.entries(P.staticMethods??{}).map(([T,k])=>[T,{params:Object.fromEntries(Object.entries(k.params??{}).map(([g,l])=>[g,{type:l.type.kind,required:l.required}])),returns:k.returns?{type:k.returns.kind}:void 0}]))};if(P.typeParams)C.typeParams=P.typeParams;let O=JSON.stringify(C,null,2);j+=`
|
|
387
|
+
${B}.__tjs = ${O};
|
|
388
|
+
`,j+=`
|
|
389
|
+
${D7(B)}
|
|
390
|
+
`}return{code:j,types:J,classes:Object.keys(L).length>0?L:void 0,warnings:K.length>0?K:void 0}}import{s as I7}from"tosijs-schema";function B7(Z){if(Z===null)return"null";if(Z===void 0)return"undefined";if(Array.isArray(Z))return"array";return typeof Z}function H4(Z){return I7.infer(Z)}function o4(Z){return H4(Z)}o4.type=B7;o4.infer=H4;var w5=new Proxy(o4,{get(Z,X){if(X==="type")return B7;if(X==="infer")return H4;return I7[X]},apply(Z,X,$){return H4($[0])}});async function Y4(Z){let X=`${$1}:${Z}`;if(typeof crypto<"u"&&crypto.subtle){let K=new TextEncoder().encode(X),H=await crypto.subtle.digest("SHA-256",K);return Array.from(new Uint8Array(H)).map((z)=>z.toString(16).padStart(2,"0")).join("")}let $=5381;for(let Q=0;Q<X.length;Q++)$=($<<5)+$+X.charCodeAt(Q)>>>0;return $.toString(16)}function F5(Z){let X=`${$1}:${Z}`,$=5381;for(let Q=0;Q<X.length;Q++)$=($<<5)+$+X.charCodeAt(Q)>>>0;return $.toString(16)}var j5="tjs-metadata-cache",P5=1,s="modules";class s4{db=null;stats={hits:0,misses:0};pendingOpen=null;async open(){if(this.db)return;if(this.pendingOpen)return this.pendingOpen;this.pendingOpen=this._open(),await this.pendingOpen,this.pendingOpen=null}async _open(){return new Promise((Z,X)=>{if(typeof indexedDB>"u"){Z();return}let $=indexedDB.open(j5,P5);$.onerror=()=>{console.warn("MetadataCache: Failed to open IndexedDB",$.error),Z()},$.onsuccess=()=>{this.db=$.result,Z()},$.onupgradeneeded=(Q)=>{let K=Q.target.result;if(!K.objectStoreNames.contains(s)){let H=K.createObjectStore(s,{keyPath:"hash"});H.createIndex("timestamp","timestamp"),H.createIndex("version","version")}}})}async get(Z){if(!this.db){this.stats.misses++;return}let X=await Y4(Z);return new Promise(($)=>{let H=this.db.transaction(s,"readonly").objectStore(s).get(X);H.onerror=()=>{this.stats.misses++,$(void 0)},H.onsuccess=()=>{let Y=H.result;if(Y&&Y.version!==$1){this.stats.misses++,$(void 0);return}if(Y)this.stats.hits++;else this.stats.misses++;$(Y)}})}async getTranspile(Z){return(await this.get(Z))?.transpile}async getTJS(Z){return(await this.get(Z))?.tjs}async setTranspile(Z,X){await this._set(Z,{transpile:X})}async setTJS(Z,X){await this._set(Z,{tjs:X})}async _set(Z,X){if(!this.db)return;let $=await Y4(Z);return new Promise((Q,K)=>{let Y=this.db.transaction(s,"readwrite").objectStore(s),z=Y.get($);z.onsuccess=()=>{let W=z.result,G={hash:$,version:$1,timestamp:Date.now(),transpile:X.transpile??W?.transpile,tjs:X.tjs??W?.tjs},J=Y.put(G);J.onerror=()=>K(J.error),J.onsuccess=()=>Q()},z.onerror=()=>K(z.error)})}async delete(Z){if(!this.db)return;let X=await Y4(Z);return new Promise(($,Q)=>{let Y=this.db.transaction(s,"readwrite").objectStore(s).delete(X);Y.onerror=()=>Q(Y.error),Y.onsuccess=()=>$()})}async clear(){if(!this.db)return;return new Promise((Z,X)=>{let K=this.db.transaction(s,"readwrite").objectStore(s).clear();K.onerror=()=>X(K.error),K.onsuccess=()=>{this.stats={hits:0,misses:0},Z()}})}async prune(Z){if(!this.db)return 0;let X=Date.now()-Z;return new Promise(($,Q)=>{let Y=this.db.transaction(s,"readwrite").objectStore(s).index("timestamp"),z=IDBKeyRange.upperBound(X),W=0,G=Y.openCursor(z);G.onsuccess=(J)=>{let L=J.target.result;if(L)L.delete(),W++,L.continue();else $(W)},G.onerror=()=>Q(G.error)})}async pruneOldVersions(){if(!this.db)return 0;return new Promise((Z,X)=>{let Q=this.db.transaction(s,"readwrite").objectStore(s),K=0,H=Q.openCursor();H.onsuccess=(Y)=>{let z=Y.target.result;if(z){if(z.value.version!==$1)z.delete(),K++;z.continue()}else Z(K)},H.onerror=()=>X(H.error)})}async getStats(){let Z=await this.count(),X=await this.estimateSize(),$=this.stats.hits+this.stats.misses,Q=$>0?this.stats.hits/$:0;return{entries:Z,bytes:X,hits:this.stats.hits,misses:this.stats.misses,hitRate:Q}}async count(){if(!this.db)return 0;return new Promise((Z,X)=>{let K=this.db.transaction(s,"readonly").objectStore(s).count();K.onerror=()=>X(K.error),K.onsuccess=()=>Z(K.result)})}async estimateSize(){if(!this.db)return 0;if(typeof navigator<"u"&&navigator.storage?.estimate)try{return(await navigator.storage.estimate()).usage??0}catch{}return new Promise((Z,X)=>{let Q=this.db.transaction(s,"readonly").objectStore(s),K=0,H=Q.openCursor();H.onsuccess=(Y)=>{let z=Y.target.result;if(z)K+=JSON.stringify(z.value).length*2,z.continue();else Z(K)},H.onerror=()=>X(H.error)})}close(){if(this.db)this.db.close(),this.db=null}isAvailable(){return this.db!==null}resetStats(){this.stats={hits:0,misses:0}}}var D0=null;async function z4(){if(!D0)D0=new s4,await D0.open();return D0}function V5(Z){D0=Z}function W4(Z,X,$,Q,K){if(!$)$=E;(function H(Y,z,W){var G=W||Y.type;if($[G](Y,z,H),X[G])X[G](Y,z)})(Z,Q,K)}function R7(Z,X,$,Q,K){var H=[];if(!$)$=E;(function Y(z,W,G){var J=G||z.type,L=z!==H[H.length-1];if(L)H.push(z);if($[J](z,W,Y),X[J])X[J](z,W||H,H);if(L)H.pop()})(Z,Q,K)}function a4(Z,X,$){$(Z,X)}function y1(Z,X,$){}var E={};E.Program=E.BlockStatement=E.StaticBlock=function(Z,X,$){for(var Q=0,K=Z.body;Q<K.length;Q+=1){var H=K[Q];$(H,X,"Statement")}};E.Statement=a4;E.EmptyStatement=y1;E.ExpressionStatement=E.ParenthesizedExpression=E.ChainExpression=function(Z,X,$){return $(Z.expression,X,"Expression")};E.IfStatement=function(Z,X,$){if($(Z.test,X,"Expression"),$(Z.consequent,X,"Statement"),Z.alternate)$(Z.alternate,X,"Statement")};E.LabeledStatement=function(Z,X,$){return $(Z.body,X,"Statement")};E.BreakStatement=E.ContinueStatement=y1;E.WithStatement=function(Z,X,$){$(Z.object,X,"Expression"),$(Z.body,X,"Statement")};E.SwitchStatement=function(Z,X,$){$(Z.discriminant,X,"Expression");for(var Q=0,K=Z.cases;Q<K.length;Q+=1){var H=K[Q];$(H,X)}};E.SwitchCase=function(Z,X,$){if(Z.test)$(Z.test,X,"Expression");for(var Q=0,K=Z.consequent;Q<K.length;Q+=1){var H=K[Q];$(H,X,"Statement")}};E.ReturnStatement=E.YieldExpression=E.AwaitExpression=function(Z,X,$){if(Z.argument)$(Z.argument,X,"Expression")};E.ThrowStatement=E.SpreadElement=function(Z,X,$){return $(Z.argument,X,"Expression")};E.TryStatement=function(Z,X,$){if($(Z.block,X,"Statement"),Z.handler)$(Z.handler,X);if(Z.finalizer)$(Z.finalizer,X,"Statement")};E.CatchClause=function(Z,X,$){if(Z.param)$(Z.param,X,"Pattern");$(Z.body,X,"Statement")};E.WhileStatement=E.DoWhileStatement=function(Z,X,$){$(Z.test,X,"Expression"),$(Z.body,X,"Statement")};E.ForStatement=function(Z,X,$){if(Z.init)$(Z.init,X,"ForInit");if(Z.test)$(Z.test,X,"Expression");if(Z.update)$(Z.update,X,"Expression");$(Z.body,X,"Statement")};E.ForInStatement=E.ForOfStatement=function(Z,X,$){$(Z.left,X,"ForInit"),$(Z.right,X,"Expression"),$(Z.body,X,"Statement")};E.ForInit=function(Z,X,$){if(Z.type==="VariableDeclaration")$(Z,X);else $(Z,X,"Expression")};E.DebuggerStatement=y1;E.FunctionDeclaration=function(Z,X,$){return $(Z,X,"Function")};E.VariableDeclaration=function(Z,X,$){for(var Q=0,K=Z.declarations;Q<K.length;Q+=1){var H=K[Q];$(H,X)}};E.VariableDeclarator=function(Z,X,$){if($(Z.id,X,"Pattern"),Z.init)$(Z.init,X,"Expression")};E.Function=function(Z,X,$){if(Z.id)$(Z.id,X,"Pattern");for(var Q=0,K=Z.params;Q<K.length;Q+=1){var H=K[Q];$(H,X,"Pattern")}$(Z.body,X,Z.expression?"Expression":"Statement")};E.Pattern=function(Z,X,$){if(Z.type==="Identifier")$(Z,X,"VariablePattern");else if(Z.type==="MemberExpression")$(Z,X,"MemberPattern");else $(Z,X)};E.VariablePattern=y1;E.MemberPattern=a4;E.RestElement=function(Z,X,$){return $(Z.argument,X,"Pattern")};E.ArrayPattern=function(Z,X,$){for(var Q=0,K=Z.elements;Q<K.length;Q+=1){var H=K[Q];if(H)$(H,X,"Pattern")}};E.ObjectPattern=function(Z,X,$){for(var Q=0,K=Z.properties;Q<K.length;Q+=1){var H=K[Q];if(H.type==="Property"){if(H.computed)$(H.key,X,"Expression");$(H.value,X,"Pattern")}else if(H.type==="RestElement")$(H.argument,X,"Pattern")}};E.Expression=a4;E.ThisExpression=E.Super=E.MetaProperty=y1;E.ArrayExpression=function(Z,X,$){for(var Q=0,K=Z.elements;Q<K.length;Q+=1){var H=K[Q];if(H)$(H,X,"Expression")}};E.ObjectExpression=function(Z,X,$){for(var Q=0,K=Z.properties;Q<K.length;Q+=1){var H=K[Q];$(H,X)}};E.FunctionExpression=E.ArrowFunctionExpression=E.FunctionDeclaration;E.SequenceExpression=function(Z,X,$){for(var Q=0,K=Z.expressions;Q<K.length;Q+=1){var H=K[Q];$(H,X,"Expression")}};E.TemplateLiteral=function(Z,X,$){for(var Q=0,K=Z.quasis;Q<K.length;Q+=1){var H=K[Q];$(H,X)}for(var Y=0,z=Z.expressions;Y<z.length;Y+=1){var W=z[Y];$(W,X,"Expression")}};E.TemplateElement=y1;E.UnaryExpression=E.UpdateExpression=function(Z,X,$){$(Z.argument,X,"Expression")};E.BinaryExpression=E.LogicalExpression=function(Z,X,$){$(Z.left,X,"Expression"),$(Z.right,X,"Expression")};E.AssignmentExpression=E.AssignmentPattern=function(Z,X,$){$(Z.left,X,"Pattern"),$(Z.right,X,"Expression")};E.ConditionalExpression=function(Z,X,$){$(Z.test,X,"Expression"),$(Z.consequent,X,"Expression"),$(Z.alternate,X,"Expression")};E.NewExpression=E.CallExpression=function(Z,X,$){if($(Z.callee,X,"Expression"),Z.arguments)for(var Q=0,K=Z.arguments;Q<K.length;Q+=1){var H=K[Q];$(H,X,"Expression")}};E.MemberExpression=function(Z,X,$){if($(Z.object,X,"Expression"),Z.computed)$(Z.property,X,"Expression")};E.ExportNamedDeclaration=E.ExportDefaultDeclaration=function(Z,X,$){if(Z.declaration)$(Z.declaration,X,Z.type==="ExportNamedDeclaration"||Z.declaration.id?"Statement":"Expression");if(Z.source)$(Z.source,X,"Expression")};E.ExportAllDeclaration=function(Z,X,$){if(Z.exported)$(Z.exported,X);$(Z.source,X,"Expression")};E.ImportDeclaration=function(Z,X,$){for(var Q=0,K=Z.specifiers;Q<K.length;Q+=1){var H=K[Q];$(H,X)}$(Z.source,X,"Expression")};E.ImportExpression=function(Z,X,$){$(Z.source,X,"Expression")};E.ImportSpecifier=E.ImportDefaultSpecifier=E.ImportNamespaceSpecifier=E.Identifier=E.PrivateIdentifier=E.Literal=y1;E.TaggedTemplateExpression=function(Z,X,$){$(Z.tag,X,"Expression"),$(Z.quasi,X,"Expression")};E.ClassDeclaration=E.ClassExpression=function(Z,X,$){return $(Z,X,"Class")};E.Class=function(Z,X,$){if(Z.id)$(Z.id,X,"Pattern");if(Z.superClass)$(Z.superClass,X,"Expression");$(Z.body,X)};E.ClassBody=function(Z,X,$){for(var Q=0,K=Z.body;Q<K.length;Q+=1){var H=K[Q];$(H,X)}};E.MethodDefinition=E.PropertyDefinition=E.Property=function(Z,X,$){if(Z.computed)$(Z.key,X,"Expression");if(Z.value)$(Z.value,X,"Expression")};var O5={unusedVariables:!0,undefinedVariables:!0,unreachableCode:!0,noExplicitNew:!0};function N5(Z,X={}){let $={...O5,...X},Q=[],K;try{K=M1(Z,{filename:$.filename,colonShorthand:!0}).ast}catch(Y){return{diagnostics:[{severity:"error",message:Y.message,line:Y.loc?.line,column:Y.loc?.column,rule:"parse-error"}],valid:!1}}let H=[M7()];if(R7(K,{FunctionDeclaration(Y,z,W){let G=M7();H.push(G);for(let J of Y.params)E5(G,J,"parameter");if(Y.id)(H[H.length-2]||H[0]).declarations.set(Y.id.name,{node:Y.id,kind:"function",used:!1})},VariableDeclaration(Y){let z=H[H.length-1];for(let W of Y.declarations)if(W.id.type==="Identifier")z.declarations.set(W.id.name,{node:W.id,kind:Y.kind,used:!1})}}),W4(K,{Identifier(Y){for(let z=H.length-1;z>=0;z--){let W=H[z].declarations.get(Y.name);if(W){W.used=!0;break}}}}),$.unusedVariables)for(let Y of H)for(let[z,W]of Y.declarations){if(z.startsWith("_"))continue;if(!W.used&&W.kind!=="function")Q.push({severity:"warning",message:`'${z}' is declared but never used`,line:W.node.loc?.start?.line,column:W.node.loc?.start?.column,rule:"no-unused-vars"})}if($.unreachableCode)W4(K,{BlockStatement(Y){let z=!1;for(let W of Y.body){if(z){Q.push({severity:"warning",message:"Unreachable code after return statement",line:W.loc?.start?.line,column:W.loc?.start?.column,rule:"no-unreachable"});break}if(W.type==="ReturnStatement")z=!0}}});if($.noExplicitNew)W4(K,{NewExpression(Y){let z="class";if(Y.callee.type==="Identifier")z=Y.callee.name;else if(Y.callee.type==="MemberExpression"){if(Y.callee.property.type==="Identifier")z=Y.callee.property.name}Q.push({severity:"warning",message:`Unnecessary 'new' keyword. In TJS, classes are callable without 'new': ${z}(...) instead of new ${z}(...)`,line:Y.loc?.start?.line,column:Y.loc?.start?.column,rule:"no-explicit-new"})}});return{diagnostics:Q,valid:Q.filter((Y)=>Y.severity==="error").length===0}}function M7(){return{declarations:new Map}}function E5(Z,X,$){if(X.type==="Identifier")Z.declarations.set(X.name,{node:X,kind:$,used:!1});else if(X.type==="AssignmentPattern"&&X.left.type==="Identifier")Z.declarations.set(X.left.name,{node:X.left,kind:$,used:!1})}function T5(Z){let X=[],$=0,Q=null;for(let K=0;K<Z.length;K++){let H=Z[K],Y=K>0?Z[K-1]:"";if(!Q&&(H==='"'||H==="'"||H==="`"))Q=H;else if(Q&&H===Q&&Y!=="\\")Q=null;if(!Q){if(H==="{")$++;if(H==="}")$--}X[K]=$}return X}function w7(Z){let X=[],$=T5(Z),Q=/\/\*#([\s\S]*?)\*\//g,K=/function\s+(\w+)\s*\(([^)]*)\)\s*(?:(-[>?!])\s*('[^']*'|"[^"]*"|[^\s{]+)|:\s*(\w+))?\s*\{/g,H=[],Y;while((Y=Q.exec(Z))!==null){if($[Y.index]!==0)continue;let W=Y[1],G=W.split(`
|
|
391
|
+
`),J=G.filter((L)=>L.trim().length>0).reduce((L,_)=>{let U=_.match(/^(\s*)/)?.[1].length||0;return Math.min(L,U)},1/0);if(J>0&&J<1/0)W=G.map((L)=>L.slice(J)).join(`
|
|
392
|
+
`);H.push({type:"doc",index:Y.index,data:W.trim()})}while((Y=K.exec(Z))!==null){let W=Y[1],G=Y[2],J=Y[3]||"",L=Y[4]||"",_=Y[5]||"",U=`function ${W}(${G})`;if(J)U+=` ${J} ${L}`;else if(_)U+=`: ${_}`;H.push({type:"function",index:Y.index,data:{name:W,signature:U}})}H.sort((W,G)=>W.index-G.index);for(let W of H)if(W.type==="doc")X.push({type:"doc",content:W.data});else X.push({type:"function",name:W.data.name,signature:W.data.signature});let z=X.map((W)=>{if(W.type==="doc")return W.content;else return`\`\`\`tjs
|
|
393
|
+
${W.signature}
|
|
386
394
|
\`\`\``}).join(`
|
|
387
395
|
|
|
388
|
-
`);return{items:X,markdown:
|
|
396
|
+
`);return{items:X,markdown:z}}function S5(Z,X){let $=w7(Z),Q="";for(let K of $.items)if(K.type==="doc")Q+=K.content+`
|
|
389
397
|
|
|
390
|
-
`;else if(
|
|
398
|
+
`;else if(K.type==="function"){let H=X?.[K.name];if(Q+=`## ${K.name}
|
|
391
399
|
|
|
392
|
-
`,
|
|
393
|
-
${
|
|
400
|
+
`,Q+=`\`\`\`tjs
|
|
401
|
+
${K.signature}
|
|
394
402
|
\`\`\`
|
|
395
403
|
|
|
396
|
-
`,H?.params&&Object.keys(H.params).length>0){
|
|
397
|
-
`;for(let[Y,
|
|
398
|
-
`}
|
|
399
|
-
`}if(H?.returns)
|
|
404
|
+
`,H?.params&&Object.keys(H.params).length>0){Q+=`**Parameters:**
|
|
405
|
+
`;for(let[Y,z]of Object.entries(H.params)){let W=z.required?"":" *(optional)*",G=z.type?.kind||"any",J=z.example!==void 0?` (e.g. \`${JSON.stringify(z.example)}\`)`:"";Q+=`- \`${Y}\`: ${G}${W}${J}
|
|
406
|
+
`}Q+=`
|
|
407
|
+
`}if(H?.returns)Q+=`**Returns:** ${H.returns.kind||"void"}
|
|
400
408
|
|
|
401
|
-
`}return K.trim()||"*No documentation available*"}import{s as D,validate as o4,filter as V7}from"tosijs-schema";var Y4=Symbol.for("tjs.equals");function z4(Z,X){if(Z!==null&&typeof Z==="object"&&typeof Z[Y4]==="function")return Z[Y4](X);if(X!==null&&typeof X==="object"&&typeof X[Y4]==="function")return X[Y4](Z);if(Z!==null&&typeof Z==="object"&&typeof Z.Equals==="function")return Z.Equals(X);if(X!==null&&typeof X==="object"&&typeof X.Equals==="function")return X.Equals(Z);if(Z===X)return!0;if((Z===null||Z===void 0)&&(X===null||X===void 0))return!0;if(Z===null||Z===void 0||X===null||X===void 0)return!1;if(typeof Z!==typeof X)return!1;if(typeof Z!=="object")return!1;if(Array.isArray(Z)&&Array.isArray(X)){if(Z.length!==X.length)return!1;return Z.every((Q,H)=>z4(Q,X[H]))}if(Array.isArray(Z)!==Array.isArray(X))return!1;let $=Object.keys(Z),K=Object.keys(X);if($.length!==K.length)return!1;return $.every((Q)=>z4(Z[Q],X[Q]))}class H1{$error=!0;message;op;cause;constructor(Z,X,$){this.message=Z,this.op=X,this.cause=$}toString(){return`AgentError[${this.op}]: ${this.message}`}toJSON(){return{$error:!0,message:this.message,op:this.op}}}function B5(Z){return Z instanceof H1||Z&&Z.$error===!0}var n1=new Map,I5=3600000,A5=102400,s4="proc_";function a4(Z){return typeof Z==="string"&&Z.startsWith(s4)}function r4(Z){let X=n1.get(Z);if(!X)throw Error(`Procedure not found: ${Z}`);if(Date.now()>X.expiresAt)throw n1.delete(Z),Error(`Procedure expired: ${Z}`);return X.ast}function F5(){if(typeof crypto<"u"&&crypto.randomUUID)return s4+crypto.randomUUID();return s4+Math.random().toString(36).slice(2)+Date.now().toString(36)}var C7=new Set(["__proto__","constructor","prototype"]);function A7(Z){if(C7.has(Z))throw Error(`Security Error: Access to '${Z}' is forbidden`)}var M5=new Set(["localhost","127.0.0.1","0.0.0.0","[::1]","metadata.google.internal"]);function w5(Z){try{let X=new URL(Z);if(X.protocol!=="http:"&&X.protocol!=="https:")return!0;let $=X.hostname.toLowerCase();if(M5.has($))return!0;if($.endsWith(".internal")||$.endsWith(".local"))return!0;if($==="169.254.169.254")return!0;if(/^10\./.test($)||/^192\.168\./.test($)||/^172\.(1[6-9]|2\d|3[01])\./.test($))return!0;return!1}catch{return!0}}function j5(Z){if(/\([^)]*[+*][^)]*\)[+*]/.test(Z))return!0;if(/\(([^|)]+)\|\1\)[+*]/.test(Z))return!0;if(/\(\.\*\)\+/.test(Z))return!0;if(/\(\.\+\)\+/.test(Z))return!0;if(/\(\[.*\]\+\)\+/.test(Z))return!0;return!1}function O1(Z){return{...Z,state:Object.create(Z.state)}}function P5(Z,X){let $={},K=new Set([...Object.keys(Z),...Object.keys(X)]);for(let Q of K){let H=Z[Q],Y=X[Q];if(Y!==H)$[Q]=Y}return $}function O(Z,X){if(Z&&typeof Z==="object"&&Z.$kind==="arg")return X.args[Z.path];if(Z&&typeof Z==="object"&&Z.$expr)return i(Z,X);if(typeof Z==="string"){if(Z.startsWith("args.")&&!("args"in X.state))return X.args[Z.replace("args.","")];if(Z.includes(".")){let $=Z.split(".");for(let Q of $)if(C7.has(Q))throw Error(`Security Error: Access to '${Q}' is forbidden`);let K=X.state[$[0]];if(K!==void 0){for(let Q=1;Q<$.length;Q++)K=K?.[$[Q]];return K}}if(Z in X.state)return X.state[Z];return Z}if(Z&&typeof Z==="object"&&!Array.isArray(Z)&&Z.constructor===Object){let $={};for(let K of Object.keys(Z))$[K]=O(Z[K],X);return $}if(Array.isArray(Z))return Z.map(($)=>O($,X));return Z}function h1(Z,X,$){return new Proxy(X,{get(K,Q){if(Q in K)return K[Q];let H=$?.[Q];if(H)throw Error(`${Z}.${Q} is not available. ${H}`);throw Error(`${Z}.${Q} is not supported in AsyncJS. Check docs for available ${Z} methods.`)}})}function p1(Z){if(Z===null)return{type:"null"};if(Z===void 0)return{};if(typeof Z==="object"&&Z!==null&&"type"in Z&&typeof Z.type==="string")return Z;if(typeof Z==="object"&&Z!==null&&"schema"in Z&&typeof Z.schema==="object")return Z.schema;let X=typeof Z;if(X==="string")return{type:"string"};if(X==="number")return Number.isInteger(Z)?{type:"integer"}:{type:"number"};if(X==="boolean")return{type:"boolean"};if(Array.isArray(Z)){if(Z.length===0)return{type:"array"};return{type:"array",items:p1(Z[0])}}if(X==="object"){let $={},K=[];for(let[Q,H]of Object.entries(Z))$[Q]=p1(H),K.push(Q);return{type:"object",properties:$,required:K}}return{}}var j1={Math:h1("Math",{PI:Math.PI,E:Math.E,LN2:Math.LN2,LN10:Math.LN10,LOG2E:Math.LOG2E,LOG10E:Math.LOG10E,SQRT2:Math.SQRT2,SQRT1_2:Math.SQRT1_2,abs:Math.abs,ceil:Math.ceil,floor:Math.floor,round:Math.round,trunc:Math.trunc,sign:Math.sign,sqrt:Math.sqrt,cbrt:Math.cbrt,pow:Math.pow,exp:Math.exp,expm1:Math.expm1,log:Math.log,log2:Math.log2,log10:Math.log10,log1p:Math.log1p,sin:Math.sin,cos:Math.cos,tan:Math.tan,asin:Math.asin,acos:Math.acos,atan:Math.atan,atan2:Math.atan2,sinh:Math.sinh,cosh:Math.cosh,tanh:Math.tanh,asinh:Math.asinh,acosh:Math.acosh,atanh:Math.atanh,hypot:Math.hypot,min:Math.min,max:Math.max,clz32:Math.clz32,imul:Math.imul,fround:Math.fround,random:()=>{if(typeof crypto<"u"&&crypto.getRandomValues){let Z=new Uint32Array(1);return crypto.getRandomValues(Z),Z[0]/4294967296}return Math.random()}}),JSON:h1("JSON",{parse:(Z)=>JSON.parse(Z),stringify:(Z,X,$)=>JSON.stringify(Z,X,$)}),console:h1("console",{log:(...Z)=>{return},warn:(...Z)=>{return},error:(...Z)=>{return},info:(...Z)=>{return}},{table:"Use console.log with JSON.stringify for structured data.",dir:"Use console.log instead.",trace:"Stack traces are not available in AsyncJS."}),Array:h1("Array",{isArray:(Z)=>Array.isArray(Z),from:(Z,X,$)=>Array.from(Z,X,$),of:(...Z)=>Array.of(...Z)},{prototype:"Prototype access is not allowed."}),Object:h1("Object",{keys:(Z)=>Object.keys(Z),values:(Z)=>Object.values(Z),entries:(Z)=>Object.entries(Z),fromEntries:(Z)=>Object.fromEntries(Z),assign:(Z,...X)=>Object.assign({},Z,...X),hasOwn:(Z,X)=>Object.hasOwn(Z,X)},{prototype:"Prototype access is not allowed.",create:"Use object literals instead.",defineProperty:"Property descriptors are not supported.",getPrototypeOf:"Prototype access is not allowed.",setPrototypeOf:"Prototype modification is not allowed."}),String:h1("String",{fromCharCode:(...Z)=>String.fromCharCode(...Z),fromCodePoint:(...Z)=>String.fromCodePoint(...Z)}),Number:h1("Number",{isNaN:Number.isNaN,isFinite:Number.isFinite,isInteger:Number.isInteger,isSafeInteger:Number.isSafeInteger,parseFloat,parseInt,MAX_VALUE:Number.MAX_VALUE,MIN_VALUE:Number.MIN_VALUE,MAX_SAFE_INTEGER:Number.MAX_SAFE_INTEGER,MIN_SAFE_INTEGER:Number.MIN_SAFE_INTEGER,POSITIVE_INFINITY:Number.POSITIVE_INFINITY,NEGATIVE_INFINITY:Number.NEGATIVE_INFINITY,NaN:Number.NaN,EPSILON:Number.EPSILON}),parseInt,parseFloat,isNaN,isFinite,encodeURI,decodeURI,encodeURIComponent,decodeURIComponent,undefined:void 0,null:null,NaN:NaN,Infinity:1/0,filter:(Z,X)=>{let $=p1(X),K=V7(Z,$);if(K instanceof Error)throw K;return K},Schema:{...D,response:(Z,X)=>{let $=X?.schema!=null?X.schema:p1(X);return{type:"json_schema",json_schema:{name:Z,strict:!0,schema:$}}},fromExample:(Z)=>p1(Z),isValid:(Z,X)=>{if(X?.schema!=null)return o4(Z,X);return o4(Z,p1(X))}},Set:(Z=[])=>{let X=[...new globalThis.Set(Z)];return{add($){if(!X.includes($))X.push($);return this},remove($){let K=X.indexOf($);if(K!==-1)X.splice(K,1);return this},clear(){return X.length=0,this},has($){return X.includes($)},get size(){return X.length},toArray(){return[...X]},union($){let K=$?.toArray?.()??$??[];return j1.Set([...X,...K])},intersection($){let K=$?.toArray?.()??$??[];return j1.Set(X.filter((Q)=>K.includes(Q)))},diff($){let K=$?.toArray?.()??$??[];return j1.Set(X.filter((Q)=>!K.includes(Q)))},forEach($){X.forEach($)},map($){return j1.Set(X.map($))},filter($){return j1.Set(X.filter($))},toJSON(){return[...X]}}},Date:(()=>{let Z=($)=>({get value(){return $.toISOString()},get timestamp(){return $.getTime()},get year(){return $.getFullYear()},get month(){return $.getMonth()+1},get day(){return $.getDate()},get hours(){return $.getHours()},get minutes(){return $.getMinutes()},get seconds(){return $.getSeconds()},get dayOfWeek(){return $.getDay()},add({years:K=0,months:Q=0,days:H=0,hours:Y=0,minutes:G=0,seconds:z=0,ms:W=0}={}){let J=new globalThis.Date($.getTime());if(K)J.setFullYear(J.getFullYear()+K);if(Q)J.setMonth(J.getMonth()+Q);if(H)J.setDate(J.getDate()+H);if(Y)J.setHours(J.getHours()+Y);if(G)J.setMinutes(J.getMinutes()+G);if(z)J.setSeconds(J.getSeconds()+z);if(W)J.setMilliseconds(J.getMilliseconds()+W);return Z(J)},diff(K,Q="ms"){let H=typeof K==="object"&&K.timestamp?K.timestamp:new globalThis.Date(K).getTime(),Y=$.getTime()-H;switch(Q){case"seconds":return Y/1000;case"minutes":return Y/60000;case"hours":return Y/3600000;case"days":return Y/86400000;default:return Y}},format(K="ISO"){if(K==="ISO")return $.toISOString();if(K==="date")return $.toISOString().split("T")[0];if(K==="time")return $.toISOString().split("T")[1].split(".")[0];return K.replace("YYYY",String($.getFullYear())).replace("MM",String($.getMonth()+1).padStart(2,"0")).replace("DD",String($.getDate()).padStart(2,"0")).replace("HH",String($.getHours()).padStart(2,"0")).replace("mm",String($.getMinutes()).padStart(2,"0")).replace("ss",String($.getSeconds()).padStart(2,"0"))},isBefore(K){let Q=typeof K==="object"&&K.timestamp?K.timestamp:new globalThis.Date(K).getTime();return $.getTime()<Q},isAfter(K){let Q=typeof K==="object"&&K.timestamp?K.timestamp:new globalThis.Date(K).getTime();return $.getTime()>Q},toString(){return $.toISOString()},toJSON(){return $.toISOString()}}),X=($)=>{let K=$!==void 0?new globalThis.Date($):new globalThis.Date;if(isNaN(K.getTime()))throw Error(`Invalid date: ${$}`);return Z(K)};return X.now=()=>globalThis.Date.now(),X.parse=($)=>Z(new globalThis.Date($)),X})()},G4={RegExp:"RegExp is not available. Use string methods or the regexMatch atom.",Promise:"Promise is not needed. All operations are implicitly async.",Map:"Map is not available. Use plain objects instead.",WeakSet:"WeakSet is not available.",WeakMap:"WeakMap is not available.",Symbol:"Symbol is not available.",Proxy:"Proxy is not available.",Reflect:"Reflect is not available.",Function:"Function constructor is not available. Define functions normally.",eval:"eval is not available. Code is compiled, not evaluated.",setTimeout:"setTimeout is not available. Use the delay atom.",setInterval:"setInterval is not available. Use while loops with delay.",fetch:"fetch is not available. Use the httpFetch atom.",require:"require is not available. Atoms must be registered with the VM.",import:"import is not available. Atoms must be registered with the VM.",process:"process is not available. AsyncJS runs in a sandboxed environment.",window:"window is not available. AsyncJS runs in a sandboxed environment.",document:"document is not available. AsyncJS runs in a sandboxed environment.",global:"global is not available. AsyncJS runs in a sandboxed environment.",globalThis:"globalThis is not available. Use builtins directly."},V5=0.01,F7=0.0001,M7=0.001,C5=new Set(["concat","slice","map","filter","flatMap","flat","toReversed","toSorted","toSpliced","repeat","padStart","padEnd","split","join","replace","replaceAll","substring","substr","trim","trimStart","trimEnd","toLowerCase","toUpperCase","match","matchAll","parse","stringify"]);function i(Z,X){if(Z===null||Z===void 0)return Z;if(typeof Z!=="object"||!("$expr"in Z))return Z;if(X.fuel){if(X.fuel.current-=V5,X.fuel.current<=0)throw Error("Out of Fuel")}switch(Z.$expr){case"literal":return Z.value;case"ident":{if(Z.name in X.state)return X.state[Z.name];if(Z.name in X.args)return X.args[Z.name];if(Z.name in j1)return j1[Z.name];if(Z.name in G4)throw Error(G4[Z.name]);return}case"member":{let $=i(Z.object,X);if(Z.optional&&($===null||$===void 0))return;let K=Z.property;return A7(K),$?.[K]}case"binary":{let $=i(Z.left,X),K=i(Z.right,X);switch(Z.op){case"+":{let Q=$+K;if(typeof Q==="string"&&X.fuel){if(X.fuel.current-=Q.length*F7,X.fuel.current<=0){X.error=new H1("Out of Fuel","expr.concat");return}}return Q}case"-":return $-K;case"*":return $*K;case"/":return $/K;case"%":return $%K;case"**":return $**K;case">":return $>K;case"<":return $<K;case">=":return $>=K;case"<=":return $<=K;case"==":return z4($,K);case"!=":return!z4($,K);case"===":return $===K;case"!==":return $!==K;default:throw Error(`Unknown binary operator: ${Z.op}`)}}case"unary":{let $=i(Z.argument,X);switch(Z.op){case"!":return!$;case"-":return-$;case"+":return+$;case"typeof":return typeof $;default:throw Error(`Unknown unary operator: ${Z.op}`)}}case"logical":{let $=i(Z.left,X);if(Z.op==="&&")return $?i(Z.right,X):$;else if(Z.op==="??")return $??i(Z.right,X);else return $?$:i(Z.right,X)}case"conditional":return i(Z.test,X)?i(Z.consequent,X):i(Z.alternate,X);case"array":return Z.elements.map(($)=>i($,X));case"object":{let $={};for(let K of Z.properties)$[K.key]=i(K.value,X);return $}case"call":{if(Z.callee==="Error"){let K=Z.arguments.map((H)=>i(H,X)),Q=typeof K[0]==="string"?K[0]:"Error";X.error=new H1(Q,"Error");return}if(Z.callee in j1){let K=j1[Z.callee];if(typeof K==="function"){let Q=Z.arguments.map((H)=>i(H,X));return K(...Q)}}if(!X.resolver(Z.callee)){if(Z.callee in G4)throw Error(G4[Z.callee]);throw Error(`Unknown function: ${Z.callee}`)}throw Error(`Atom calls in expressions not yet supported: ${Z.callee}`)}case"methodCall":{let $=i(Z.object,X);if(Z.optional&&($===null||$===void 0))return;let K=Z.method;if(A7(K),$===null||$===void 0)throw Error(`Cannot call method '${K}' on ${$}`);let Q=$[K];if(typeof Q!=="function")throw Error(`'${K}' is not a function`);let H=Z.arguments.map((G)=>i(G,X)),Y=Q.apply($,H);if(X.fuel&&C5.has(K)){let G=0;if(typeof Y==="string")G=Y.length*F7;else if(Array.isArray(Y))G=Y.length*M7;else if(typeof Y==="object"&&Y!==null)G=Object.keys(Y).length*M7;if(X.fuel.current-=G,X.fuel.current<=0){X.error=new H1("Out of Fuel",`expr.${K}`);return}}return Y}default:throw Error(`Unknown expression type: ${Z.$expr}`)}}function S(Z,X,$,K,Q={}){let{docs:H="",timeoutMs:Y=1000,cost:G=1}=typeof Q==="string"?{docs:Q}:Q;return{op:Z,inputSchema:X,outputSchema:$,exec:async(W,J)=>{let{op:L,result:_,...U}=W;if(J.error)return;let R=J.trace?{...J.state}:null,M=J.fuel.current,w,I;try{let V=J.costOverrides?.[Z],A=V!==void 0?V:G,B=typeof A==="function"?A(U,J):A;if((J.fuel.current-=B)<=0){J.error=new H1("Out of Fuel",Z);return}let P,j=async()=>K(W,J);if(w=Y>0?await Promise.race([j(),new Promise((C,E)=>{P=setTimeout(()=>E(Error(`Atom '${Z}' timed out`)),Y)})]).finally(()=>clearTimeout(P)):await j(),W.result){if(J.consts.has(W.result))throw Error(`Cannot reassign const variable '${W.result}'`);if(w!==void 0&&$&&!o4(w,$)){J.error=new H1(`Output validation failed for '${Z}'`,Z);return}if(J.state[W.result]=w,W.resultConst)J.consts.add(W.result)}}catch(V){I=V.message||String(V),J.error=new H1(I,Z,V)}finally{if(J.trace&&R){let V=P5(R,J.state);J.trace.push({op:Z,input:U,stateDiff:V,result:w,error:I,fuelBefore:M,fuelAfter:J.fuel.current,timestamp:new Date().toISOString()})}}},docs:H,timeoutMs:Y,cost:G,create:(W)=>({op:Z,...W})}}var J1=S("seq",D.object({steps:D.array(D.any)}),void 0,async({steps:Z},X)=>{for(let $ of Z){if(X.output!==void 0)return;if(X.error)return;let K=X.resolver($.op);if(!K)throw Error(`Unknown Atom: ${$.op}`);await K.exec($,X)}},{docs:"Sequence",timeoutMs:0,cost:0.1}),O5=S("if",D.object({condition:D.any,then:D.array(D.any),else:D.array(D.any).optional}),void 0,async(Z,X)=>{if(i(Z.condition,X))await J1.exec({op:"seq",steps:Z.then},X);else if(Z.else)await J1.exec({op:"seq",steps:Z.else},X)},{docs:"If/Else",timeoutMs:0,cost:0.1}),N5=S("while",D.object({condition:D.any,body:D.array(D.any)}),void 0,async(Z,X)=>{while(i(Z.condition,X)){if(X.signal?.aborted)throw Error("Execution aborted");if((X.fuel.current-=0.1)<=0)throw Error("Out of Fuel");if(await J1.exec({op:"seq",steps:Z.body},X),X.output!==void 0)return}},{docs:"While Loop",timeoutMs:0,cost:0.1}),E5=S("return",void 0,D.any,async(Z,X)=>{if(X.error)return X.output=X.error,X.error;if("value"in Z){let K=O(Z.value,X);if(K!==void 0&&K!==null&&!B5(K)&&(typeof K!=="object"||Array.isArray(K))){let Q=new H1(`Agent must return an object, got ${Array.isArray(K)?"array":typeof K}`,"return");return X.error=Q,X.output=Q,Q}return X.output=K,K}let $={};if(Z.schema?.properties){for(let K of Object.keys(Z.schema.properties))$[K]=X.state[K];if(Z.filter!==!1){let K=V7($,Z.schema);if(!(K instanceof Error))$=K}}return X.output=$,$},{docs:"Return",cost:0.1}),T5=S("try",D.object({try:D.array(D.any),catch:D.array(D.any).optional,catchParam:D.string.optional}),void 0,async(Z,X)=>{if(await J1.exec({op:"seq",steps:Z.try},X),X.error&&Z.catch){let $=Z.catchParam||"error";X.state[$]=X.error.message,X.state.errorOp=X.error.op,X.error=void 0,await J1.exec({op:"seq",steps:Z.catch},X)}},{docs:"Try/Catch",timeoutMs:0,cost:0.1}),S5=S("Error",D.object({args:D.array(D.any).optional}),void 0,async(Z,X)=>{let $=Z.args?.[0]??"Error";X.error=new H1(String($),"Error")},{docs:"Trigger error flow",cost:0.1}),k5=S("varSet",D.object({key:D.string,value:D.any}),void 0,async({key:Z,value:X},$)=>{if($.consts.has(Z))throw Error(`Cannot reassign const variable '${Z}'`);$.state[Z]=O(X,$)},{docs:"Set Variable",cost:0.1}),g5=S("constSet",D.object({key:D.string,value:D.any}),void 0,async({key:Z,value:X},$)=>{if($.consts.has(Z))throw Error(`Cannot reassign const variable '${Z}'`);if(Z in $.state)throw Error(`Cannot redeclare variable '${Z}' as const`);$.state[Z]=O(X,$),$.consts.add(Z)},{docs:"Set Const Variable (immutable)",cost:0.1}),b5=S("varGet",D.object({key:D.string}),D.any,async({key:Z},X)=>{return O(Z,X)},{docs:"Get Variable",cost:0.1}),v5=S("varsImport",D.object({keys:D.union([D.array(D.string),D.record(D.string)])}),void 0,async({keys:Z},X)=>{if(Array.isArray(Z))for(let $ of Z)X.state[$]=O({$kind:"arg",path:$},X);else for(let[$,K]of Object.entries(Z))X.state[$]=O({$kind:"arg",path:K},X)},{docs:"Import variables from args into the current scope, with optional renaming.",cost:0.2}),f5=S("varsLet",D.record(D.any),void 0,async(Z,X)=>{for(let $ of Object.keys(Z)){if($==="op"||$==="result")continue;X.state[$]=O(Z[$],X)}},{docs:"Initialize a set of variables in the current scope from the step object properties.",cost:0.1}),y5=S("varsExport",D.object({keys:D.union([D.array(D.string),D.record(D.string)])}),D.record(D.any),async({keys:Z},X)=>{let $={};if(Array.isArray(Z))for(let K of Z)$[K]=O(K,X);else for(let[K,Q]of Object.entries(Z))$[K]=O(Q,X);return $},{docs:"Export variables from the current scope, with optional renaming.",cost:0.2}),h5=S("scope",D.object({steps:D.array(D.any)}),void 0,async({steps:Z},X)=>{let $=O1(X);if(await J1.exec({op:"seq",steps:Z},$),$.output!==void 0)X.output=$.output},{docs:"Create new scope",timeoutMs:0,cost:0.1}),x5=S("map",D.object({items:D.array(D.any),as:D.string,steps:D.array(D.any)}),D.array(D.any),async({items:Z,as:X,steps:$},K)=>{let Q=[],H=O(Z,K);if(!Array.isArray(H))throw Error("map: items is not an array");for(let Y of H){if(K.signal?.aborted)throw Error("Execution aborted");let G=O1(K);G.state[X]=Y,await J1.exec({op:"seq",steps:$},G),Q.push(G.state.result??null)}return Q},{docs:"Map Array",timeoutMs:0,cost:1}),u5=S("filter",D.object({items:D.array(D.any),as:D.string,condition:D.any}),D.array(D.any),async({items:Z,as:X,condition:$},K)=>{let Q=[],H=O(Z,K);if(!Array.isArray(H))throw Error("filter: items is not an array");for(let Y of H){if(K.signal?.aborted)throw Error("Execution aborted");let G=O1(K);if(G.state[X]=Y,i($,G))Q.push(Y)}return Q},{docs:"Filter Array",timeoutMs:0,cost:1}),d5=S("reduce",D.object({items:D.array(D.any),as:D.string,accumulator:D.string,initial:D.any,steps:D.array(D.any)}),D.any,async({items:Z,as:X,accumulator:$,initial:K,steps:Q},H)=>{let Y=O(Z,H),G=O(K,H);if(!Array.isArray(Y))throw Error("reduce: items is not an array");let z=G;for(let W of Y){if(H.signal?.aborted)throw Error("Execution aborted");let J=O1(H);J.state[X]=W,J.state[$]=z,await J1.exec({op:"seq",steps:Q},J),z=J.state.result??z}return z},{docs:"Reduce Array",timeoutMs:0,cost:1}),m5=S("find",D.object({items:D.array(D.any),as:D.string,condition:D.any}),D.any,async({items:Z,as:X,condition:$},K)=>{let Q=O(Z,K);if(!Array.isArray(Q))throw Error("find: items is not an array");for(let H of Q){if(K.signal?.aborted)throw Error("Execution aborted");let Y=O1(K);if(Y.state[X]=H,i($,Y))return H}return null},{docs:"Find in Array",timeoutMs:0,cost:1}),l5=S("push",D.object({list:D.array(D.any),item:D.any}),D.array(D.any),async({list:Z,item:X},$)=>{let K=O(Z,$),Q=O(X,$);if(Array.isArray(K))K.push(Q);return K},{docs:"Push to Array",cost:1}),i5=S("len",D.object({list:D.any}),D.number,async({list:Z},X)=>{let $=O(Z,X);return Array.isArray($)||typeof $==="string"?$.length:0},{docs:"Length",cost:1}),p5=S("split",D.object({str:D.string,sep:D.string}),D.array(D.string),async({str:Z,sep:X},$)=>O(Z,$).split(O(X,$)),{docs:"Split String",cost:1}),n5=S("join",D.object({list:D.array(D.string),sep:D.string}),D.string,async({list:Z,sep:X},$)=>O(Z,$).join(O(X,$)),{docs:"Join String",cost:1}),c5=S("template",D.object({tmpl:D.string,vars:D.record(D.any)}),D.string,async({tmpl:Z,vars:X},$)=>{return O(Z,$).replace(/\{\{(\w+)\}\}/g,(Q,H)=>String(O(X[H],$)??""))},{docs:"String Template",cost:1}),o5=S("regexMatch",D.object({pattern:D.string,value:D.any}),D.boolean,async({pattern:Z,value:X},$)=>{if(j5(Z))throw Error(`Suspicious regex pattern rejected (potential ReDoS): ${Z}`);let K=O(X,$);return new RegExp(Z).test(K)},{docs:"Returns true if the value matches the regex pattern.",cost:2}),s5=S("pick",D.object({obj:D.record(D.any),keys:D.array(D.string)}),D.record(D.any),async({obj:Z,keys:X},$)=>{let K=O(Z,$),Q=O(X,$),H={};if(K&&Array.isArray(Q))Q.forEach((Y)=>H[Y]=K[Y]);return H},{docs:"Pick Keys",cost:1}),a5=S("omit",D.object({obj:D.record(D.any),keys:D.array(D.string)}),D.record(D.any),async({obj:Z,keys:X},$)=>{let K=O(Z,$),Q=new Set(O(X,$)),H={};if(K)Object.keys(K).forEach((Y)=>{if(!Q.has(Y))H[Y]=K[Y]});return H},{docs:"Omit Keys",cost:1}),r5=S("merge",D.object({a:D.record(D.any),b:D.record(D.any)}),D.record(D.any),async({a:Z,b:X},$)=>({...O(Z,$),...O(X,$)}),{docs:"Merge Objects",cost:1}),t5=S("keys",D.object({obj:D.record(D.any)}),D.array(D.string),async({obj:Z},X)=>Object.keys(O(Z,X)??{}),{docs:"Object Keys",cost:1}),w7=10,j7="X-Agent-Depth";function e5(Z,X){try{let K=new URL(Z).hostname.toLowerCase();for(let Q of X){let H=Q.toLowerCase();if(H.startsWith("*.")){let Y=H.slice(1);if(K.endsWith(Y)||K===H.slice(2))return!0}else if(K===H)return!0}return!1}catch{return!1}}var Z$=S("httpFetch",D.object({url:D.string,method:D.string.optional,headers:D.record(D.string).optional,body:D.any.optional,responseType:D.string.optional}),D.any,async(Z,X)=>{let $=O(Z.url,X),K=O(Z.method,X),Q=O(Z.headers,X)||{},H=O(Z.body,X),Y=O(Z.responseType,X),G=X.context?.requestDepth??0;if(G>=w7)throw Error(`Agent request depth exceeded (max ${w7}). This prevents recursive agent loops.`);if(X.capabilities.fetch)return X.capabilities.fetch($,{method:K,headers:{...Q,[j7]:String(G+1)},body:H,signal:X.signal,responseType:Y});let z=X.context?.allowedFetchDomains;if(z){if(!e5($,z))throw Error(`Fetch blocked: domain not in allowlist. Allowed: ${z.join(", ")}`)}else{if(w5($))throw Error("Blocked URL: private/internal addresses not allowed in default fetch");try{let J=new URL($).hostname.toLowerCase();if(J!=="localhost"&&J!=="127.0.0.1"&&J!=="[::1]")throw Error("Fetch blocked: no allowedFetchDomains configured. Set ctx.context.allowedFetchDomains or provide a custom fetch capability.")}catch(W){if(W.message.includes("allowedFetchDomains"))throw W;throw Error(`Invalid URL: ${$}`)}}if(typeof globalThis.fetch==="function"){let W=await globalThis.fetch($,{method:K,headers:{...Q,[j7]:String(G+1)},body:H?JSON.stringify(H):void 0,signal:X.signal});if(Y==="dataUrl"){let L=await W.arrayBuffer(),_=new Uint8Array(L),U="";for(let w=0;w<_.length;w++)U+=String.fromCharCode(_[w]);let R=btoa(U);return`data:${W.headers.get("content-type")||"application/octet-stream"};base64,${R}`}let J=W.headers.get("content-type");if(Y==="json"||J&&J.includes("application/json"))return W.json();return W.text()}throw Error("Capability 'fetch' missing and no global fetch available")},{docs:"HTTP Fetch",timeoutMs:30000,cost:5}),$$=S("storeGet",D.object({key:D.string}),D.any,async({key:Z},X)=>{let $=O(Z,X);return X.capabilities.store?.get($)},{docs:"Store Get",cost:5}),X$=S("storeSet",D.object({key:D.string,value:D.any}),void 0,async({key:Z,value:X},$)=>{let K=O(Z,$),Q=O(X,$);return $.capabilities.store?.set(K,Q)},{docs:"Store Set",cost:5}),K$=S("storeQuery",D.object({query:D.any}),D.array(D.any),async({query:Z},X)=>X.capabilities.store?.query?.(O(Z,X))??[],{docs:"Store Query",cost:5}),Q$=S("storeVectorSearch",D.object({collection:D.string.optional,vector:D.array(D.number),k:D.number.optional}),D.array(D.any),async({collection:Z,vector:X,k:$},K)=>K.capabilities.store?.vectorSearch?.(O(Z,K),O(X,K),O($,K))??[],{docs:"Vector Search",cost:(Z,X)=>5+(O(Z.k,X)??5)}),H$=S("llmPredict",D.object({prompt:D.string,options:D.any.optional}),D.string,async({prompt:Z,options:X},$)=>{if(!$.capabilities.llm?.predict)throw Error("Capability 'llm.predict' missing");return $.capabilities.llm.predict(O(Z,$),O(X,$))},{docs:"LLM Predict",timeoutMs:120000,cost:100}),Y$=S("agentRun",D.object({agentId:D.any,input:D.any}),D.any,async({agentId:Z,input:X},$)=>{let K=O(Z,$),Q=O(X,$),H=Q;if(Q&&typeof Q==="object"&&!Array.isArray(Q)){H={};for(let G in Q)H[G]=O(Q[G],$)}if(a4(K)){let G=r4(K),z={...$,args:H,state:{},consts:new Set,output:void 0,error:void 0},W=$.resolver("seq");if(!W)throw Error("seq atom not found");if(await W.exec(G,z),z.error)throw Error(z.error.message||"Sub-agent failed");return z.output}if(K&&typeof K==="object"&&"op"in K){let G={...$,args:H,state:{},consts:new Set,output:void 0,error:void 0},z=$.resolver("seq");if(!z)throw Error("seq atom not found");if(await z.exec(K,G),G.error)throw Error(G.error.message||"Sub-agent failed");return G.output}if(!$.capabilities.agent?.run)throw Error("Capability 'agent.run' missing");let Y=await $.capabilities.agent.run(K,H);if(Y&&typeof Y==="object"&&"fuelUsed"in Y&&typeof Y.fuelUsed==="number"){if(Y.error)throw Error(Y.error.message||"Sub-agent failed");return Y.result}return Y},{docs:"Run Sub-Agent (accepts procedure token, AST, or agent ID)",cost:1}),G$=S("transpileCode",D.object({code:D.string}),D.any,async({code:Z},X)=>{if(!X.capabilities.code?.transpile)throw Error("Capability 'code.transpile' missing. Enable code transpilation by providing the code capability.");let $=O(Z,X);try{return X.capabilities.code.transpile($)}catch(K){throw Error(`Code transpilation failed: ${K.message}`)}},{docs:"Transpile AsyncJS code to AST",cost:1}),P7=10,z$=S("runCode",D.object({code:D.string,args:D.record(D.any).optional}),D.any,async({code:Z,args:X},$)=>{let K=$.runCodeDepth??0;if(K>=P7)throw Error(`runCode recursion limit exceeded (max ${P7}). This prevents infinite loops from dynamically generated code calling runCode.`);if(!$.capabilities.code?.transpile)throw Error("Capability 'code.transpile' missing. Enable dynamic code execution by providing the code capability.");let Q=O(Z,$),H=X?O(X,$):{},Y;try{Y=$.capabilities.code.transpile(Q)}catch(z){throw Error(`Code transpilation failed: ${z.message}`)}if(Y.op!=="seq")throw Error("Transpiled code must be a seq node");let G=O1($);if(G.args=H,G.output=void 0,G.runCodeDepth=K+1,await J1.exec(Y,G),G.error){$.error=G.error;return}return G.output},{docs:"Run dynamically generated AsyncJS code",cost:1}),W$=S("jsonParse",D.object({str:D.string}),D.any,async({str:Z},X)=>JSON.parse(O(Z,X)),{docs:"Parse JSON",cost:1}),J$=S("jsonStringify",D.object({value:D.any}),D.string,async({value:Z},X)=>JSON.stringify(O(Z,X)),{docs:"Stringify JSON",cost:1}),_$=S("xmlParse",D.object({str:D.string}),D.any,async({str:Z},X)=>{if(!X.capabilities.xml?.parse)throw Error("Capability 'xml.parse' missing");return X.capabilities.xml.parse(O(Z,X))},{docs:"Parse XML",cost:1}),L$=S("memoize",D.object({key:D.string.optional,steps:D.array(D.any)}),D.any,async({key:Z,steps:X},$)=>{if(!$.memo)$.memo=new Map;let K=O(Z,$)??await t4.exec({value:X,algorithm:"SHA-256"},$);if($.memo.has(K))return $.memo.get(K);let Q=O1($);await J1.exec({op:"seq",steps:X},Q);let H=Q.output??Q.state.result;return $.memo.set(K,H),H},{docs:"Memoize steps result in memory",cost:1}),U$=S("cache",D.object({key:D.string.optional,steps:D.array(D.any),ttlMs:D.number.optional}),D.any,async({key:Z,steps:X,ttlMs:$},K)=>{if(!K.capabilities.store)throw Error("Capability 'store' missing for caching");let H=`cache:${O(Z,K)??await t4.exec({value:X,algorithm:"SHA-256"},K)}`,Y=await K.capabilities.store.get(H);if(Y)if(typeof Y==="object"&&Y._exp){if(Date.now()<Y._exp)return Y.val}else return Y;let G=O1(K);await J1.exec({op:"seq",steps:X},G);let z=G.output??G.state.result,W=Date.now()+($??86400000);if((K.fuel.current-=5)<=0)throw Error("Out of Fuel");return await K.capabilities.store.set(H,{val:z,_exp:W}),z},{docs:"Cache steps result in store with TTL",cost:5}),q$=S("random",D.object({min:D.number.optional,max:D.number.optional,format:D.string.optional,length:D.number.optional}),D.any,async({min:Z,max:X,format:$,length:K},Q)=>{let H=O($,Q)??"float",Y=O(K,Q)??10,G=O(Z,Q)??0,z=O(X,Q)??1;if(H==="base36"){let U="";if(typeof crypto<"u"&&crypto.getRandomValues){let R=new Uint8Array(Y);crypto.getRandomValues(R);for(let M=0;M<Y;M++)U+="0123456789abcdefghijklmnopqrstuvwxyz"[R[M]%36]}else for(let R=0;R<Y;R++)U+="0123456789abcdefghijklmnopqrstuvwxyz".charAt(Math.floor(Math.random()*36));return U}let W;if(typeof crypto<"u"&&crypto.getRandomValues){let _=new Uint32Array(1);crypto.getRandomValues(_),W=_[0]/4294967296}else W=Math.random();let J=z-G,L=W*J+G;if(H==="integer")return Math.floor(L);return L},{docs:"Generate Random",cost:1}),D$=S("uuid",void 0,D.string,async()=>{if(typeof crypto<"u"&&crypto.randomUUID)return crypto.randomUUID();if(typeof crypto<"u"&&crypto.getRandomValues){let Z=new Uint8Array(16);crypto.getRandomValues(Z),Z[6]=Z[6]&15|64,Z[8]=Z[8]&63|128;let X=Array.from(Z,($)=>$.toString(16).padStart(2,"0")).join("");return`${X.slice(0,8)}-${X.slice(8,12)}-${X.slice(12,16)}-${X.slice(16,20)}-${X.slice(20)}`}return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,(Z)=>{let X=Math.random()*16|0;return(Z==="x"?X:X&3|8).toString(16)})},{docs:"Generate UUID",cost:1}),t4=S("hash",D.object({value:D.any,algorithm:D.string.optional}),D.string,async({value:Z,algorithm:X},$)=>{let K=typeof Z==="string"?Z:JSON.stringify(O(Z,$)),Q=O(X,$)||"SHA-256";if(typeof crypto<"u"&&crypto.subtle){let G=new TextEncoder().encode(K),z=await crypto.subtle.digest(Q,G);return Array.from(new Uint8Array(z)).map((J)=>J.toString(16).padStart(2,"0")).join("")}let H=0;for(let Y=0;Y<K.length;Y++){let G=K.charCodeAt(Y);H=(H<<5)-H+G,H|=0}return String(H)},{docs:"Hash a value",cost:1}),R$=S("consoleLog",D.object({message:D.any}),void 0,async({message:Z},X)=>{let $=O(Z,X);if(X.trace)X.trace.push({op:"console.log",input:{message:$},stateDiff:{},result:$,fuelBefore:X.fuel.current,fuelAfter:X.fuel.current,timestamp:new Date().toISOString()})},{docs:"Log to trace",cost:0.1}),B$=S("consoleWarn",D.object({message:D.any}),void 0,async({message:Z},X)=>{let $=O(Z,X),K=typeof $==="string"?$:JSON.stringify($);if(!X.warnings)X.warnings=[];if(X.warnings.push(K),X.trace)X.trace.push({op:"console.warn",input:{message:$},stateDiff:{},result:$,fuelBefore:X.fuel.current,fuelAfter:X.fuel.current,timestamp:new Date().toISOString()})},{docs:"Add warning",cost:0.1}),I$=S("consoleError",D.object({message:D.any}),void 0,async({message:Z},X)=>{let $=O(Z,X),K=typeof $==="string"?$:JSON.stringify($);X.error=new H1(K,"console.error")},{docs:"Emit error and stop",cost:0.1}),A$=S("storeProcedure",D.object({ast:D.any,ttl:D.number.optional,maxSize:D.number.optional}),D.string,async({ast:Z,ttl:X,maxSize:$},K)=>{let Q=O(Z,K),H=X?O(X,K):I5,Y=$?O($,K):A5;if(!Q||typeof Q!=="object"||!Q.op)throw Error('Invalid AST: must be an object with an "op" property');let G=JSON.stringify(Q);if(G.length>Y)throw Error(`AST too large: ${G.length} bytes exceeds limit of ${Y} bytes. Consider reducing AST size or using a shorter TTL.`);let z=F5(),W=Date.now();return n1.set(z,{ast:Q,createdAt:W,expiresAt:W+H}),z},{docs:"Store an AST and return a token for later execution",cost:1}),F$=S("releaseProcedure",D.object({token:D.string}),D.boolean,async({token:Z},X)=>{let $=O(Z,X);return n1.delete($)},{docs:"Release a stored procedure by token",cost:0.1}),M$=S("clearExpiredProcedures",void 0,D.number,async()=>{let Z=Date.now(),X=0;for(let[$,K]of n1)if(Z>K.expiresAt)n1.delete($),X++;return X},{docs:"Clear all expired procedures and return count",cost:0.5}),W4={seq:J1,if:O5,while:N5,return:E5,try:T5,Error:S5,varSet:k5,constSet:g5,varGet:b5,varsImport:v5,varsLet:f5,varsExport:y5,scope:h5,map:x5,filter:u5,reduce:d5,find:m5,push:l5,len:i5,split:p5,join:n5,template:c5,regexMatch:o5,pick:s5,omit:a5,merge:r5,keys:t5,httpFetch:Z$,storeGet:$$,storeSet:X$,storeQuery:K$,storeVectorSearch:Q$,llmPredict:H$,agentRun:Y$,transpileCode:G$,runCode:z$,jsonParse:W$,jsonStringify:J$,xmlParse:_$,memoize:L$,cache:U$,random:q$,uuid:D$,hash:t4,consoleLog:R$,consoleWarn:B$,consoleError:I$,storeProcedure:A$,releaseProcedure:F$,clearExpiredProcedures:M$};var w$=new Set(["true","false","null","undefined","and","or","not"]);function j$(Z,X){let $=Z.replace(/"[^"]*"/g,'""').replace(/'[^']*'/g,"''"),K=[],Q=/(?<![.])\b([a-zA-Z_][a-zA-Z0-9_]*)\b/g,H;while((H=Q.exec($))!==null)K.push(H[1]);let G=[...new Set(K)].filter((z)=>!w$.has(z)&&!(z in X)&&!new RegExp(`\\b${z}\\s*\\(`).test($));if(G.length>0)console.warn(`[Agent99 Builder] Condition "${Z}" references variables not in vars mapping: ${G.join(", ")}. Add them to vars or use AsyncJS syntax (ajs\`...\`) which handles this automatically.`)}function J4(Z,X){j$(Z,X);let $=P$(Z),K=S7($,0,X);if(K.pos<$.length){let Q=$.slice(K.pos).join(" ");throw Error(`Unsupported condition syntax near '${Q}' in: ${Z}
|
|
402
|
-
Supported: comparisons, &&, ||, !, arithmetic, member access (a.b), literals`)}return K.node}function P$(Z){let X=[],$=0;while($<Z.length){while($<Z.length&&/\s/.test(Z[$]))$++;if($>=Z.length)break;if(Z[$]==='"'||Z[$]==="'"){let K=Z[$++],Q="";while($<Z.length&&Z[$]!==K)if(Z[$]==="\\"&&$+1<Z.length)$++,Q+=Z[$++];else Q+=Z[$++];$++,X.push(JSON.stringify(Q));continue}if(Z.slice($,$+2).match(/^(&&|\|\||==|!=|>=|<=)$/)){X.push(Z.slice($,$+2)),$+=2;continue}if("+-*/%><!().?:[]".includes(Z[$])){X.push(Z[$]),$++;continue}if(/\d/.test(Z[$])){let K="";while($<Z.length&&/[\d.]/.test(Z[$]))K+=Z[$++];X.push(K);continue}if(/[a-zA-Z_]/.test(Z[$])){let K="";while($<Z.length&&/[a-zA-Z0-9_]/.test(Z[$]))K+=Z[$++];X.push(K);continue}$++}return X}function S7(Z,X,$){return V$(Z,X,$)}function V$(Z,X,$){let{node:K,pos:Q}=O7(Z,X,$);while(Z[Q]==="||"){Q++;let{node:H,pos:Y}=O7(Z,Q,$);K={$expr:"logical",op:"||",left:K,right:H},Q=Y}return{node:K,pos:Q}}function O7(Z,X,$){let{node:K,pos:Q}=N7(Z,X,$);while(Z[Q]==="&&"){Q++;let{node:H,pos:Y}=N7(Z,Q,$);K={$expr:"logical",op:"&&",left:K,right:H},Q=Y}return{node:K,pos:Q}}function N7(Z,X,$){let{node:K,pos:Q}=E7(Z,X,$),H=["==","!=",">","<",">=","<="];while(H.includes(Z[Q])){let Y=Z[Q++],{node:G,pos:z}=E7(Z,Q,$);K={$expr:"binary",op:Y,left:K,right:G},Q=z}return{node:K,pos:Q}}function E7(Z,X,$){let{node:K,pos:Q}=T7(Z,X,$);while(Z[Q]==="+"||Z[Q]==="-"){let H=Z[Q++],{node:Y,pos:G}=T7(Z,Q,$);K={$expr:"binary",op:H,left:K,right:Y},Q=G}return{node:K,pos:Q}}function T7(Z,X,$){let{node:K,pos:Q}=e4(Z,X,$);while(Z[Q]==="*"||Z[Q]==="/"||Z[Q]==="%"){let H=Z[Q++],{node:Y,pos:G}=e4(Z,Q,$);K={$expr:"binary",op:H,left:K,right:Y},Q=G}return{node:K,pos:Q}}function e4(Z,X,$){if(Z[X]==="!"||Z[X]==="-"){let K=Z[X++],{node:Q,pos:H}=e4(Z,X,$);return{node:{$expr:"unary",op:K,argument:Q},pos:H}}return C$(Z,X,$)}function C$(Z,X,$){let K=Z[X];if(K==="("){let{node:Q,pos:H}=S7(Z,X+1,$);return{node:Q,pos:H+1}}if(K&&K.startsWith('"'))return{node:{$expr:"literal",value:JSON.parse(K)},pos:X+1};if(K&&/^\d/.test(K))return{node:{$expr:"literal",value:parseFloat(K)},pos:X+1};if(K==="true")return{node:{$expr:"literal",value:!0},pos:X+1};if(K==="false")return{node:{$expr:"literal",value:!1},pos:X+1};if(K==="null")return{node:{$expr:"literal",value:null},pos:X+1};if(K&&/^[a-zA-Z_]/.test(K)){let Q={$expr:"ident",name:K},H=X+1;while(Z[H]==="."){H++;let Y=Z[H++];Q={$expr:"member",object:Q,property:Y}}return{node:Q,pos:H}}return{node:{$expr:"literal",value:null},pos:X+1}}class e{steps=[];atoms;proxy;constructor(Z){return this.atoms=Z,this.proxy=new Proxy(this,{get:(X,$,K)=>{if($ in X)return X[$];if(typeof $==="string"&&$ in X.atoms)return(Q)=>{let H=X.atoms[$];return X.add(H.create(Q)),K};return}}),this.proxy}add(Z){return this.steps.push(Z),this.proxy}as(Z){if(this.steps.length===0)throw Error("No step to capture");let X=this.steps[this.steps.length-1];return X.result=Z,this.proxy}step(Z){return this.add(Z)}return(Z){let X=this.atoms.return;if(!X)throw Error("Atom 'return' not found");let $=Z.schema??Z;return this.add(X.create({schema:$}))}toJSON(){return{op:"seq",steps:[...this.steps]}}varsImport(Z){return this.add(this.atoms.varsImport.create({keys:Z}))}varsExport(Z){return this.add(this.atoms.varsExport.create({keys:Z}))}if(Z,X,$,K){let Q=new e(this.atoms);$(Q);let H;if(K){let z=new e(this.atoms);K(z),H=z.steps}let Y=J4(Z,X),G=this.atoms.if;return this.add(G.create({condition:Y,then:Q.steps,else:H}))}while(Z,X,$){let K=new e(this.atoms);$(K);let Q=J4(Z,X),H=this.atoms.while;return this.add(H.create({condition:Q,body:K.steps}))}scope(Z){let X=new e(this.atoms);Z(X);let $=this.atoms.scope;return this.add($.create({steps:X.steps}))}map(Z,X,$){let K=new e(this.atoms);$(K);let Q=this.atoms.map;return this.add(Q.create({items:Z,as:X,steps:K.steps}))}filter(Z,X,$,K={}){let Q=J4($,K),H=this.atoms.filter;return this.add(H.create({items:Z,as:X,condition:Q}))}find(Z,X,$,K={}){let Q=J4($,K),H=this.atoms.find;return this.add(H.create({items:Z,as:X,condition:Q}))}reduce(Z,X,$,K,Q){let H=new e(this.atoms);Q(H);let Y=this.atoms.reduce;return this.add(Y.create({items:Z,as:X,accumulator:$,initial:K,steps:H.steps}))}memoize(Z,X){let $=new e(this.atoms);Z($);let K=this.atoms.memoize;return this.add(K.create({key:X,steps:$.steps}))}cache(Z,X,$){let K=new e(this.atoms);Z(K);let Q=this.atoms.cache;return this.add(Q.create({key:X,steps:K.steps,ttlMs:$}))}try(Z){let X=new e(this.atoms);Z.try(X);let $;if(Z.catch){let Q=new e(this.atoms);Z.catch(Q),$=Q.steps}let K=this.atoms.try;return this.add(K.create({try:X.steps,catch:$}))}}var O$={take(Z){return new e(W4)},custom(Z){return new e(Z)},args(Z){return{$kind:"arg",path:Z}},val(Z){return Z}},XQ=O$;import{validate as N$}from"tosijs-schema";function q0(Z,X={}){let{ast:$,returnType:K,originalSource:Q,requiredParams:H}=F1(Z,{filename:X.filename,colonShorthand:!0,vmTarget:!0}),Y=N0($,X.filename),{ast:G,signature:z,warnings:W}=K0(Y,Q,K,X,H);return{ast:G,signature:z,warnings:W}}var E$=10;class Z6{atoms;constructor(Z={}){this.atoms={...W4,...Z}}get builder(){return new e(this.atoms)}get Agent(){return new e(this.atoms)}get A99(){return this.Agent}resolve(Z){return this.atoms[Z]}getTools(Z="all"){let X=Object.values(this.atoms);if(Array.isArray(Z))X=X.filter(($)=>Z.includes($.op));else if(Z==="flow"){let $=["seq","if","while","return","try","varSet","varGet","scope"];X=X.filter((K)=>$.includes(K.op))}return X.map(($)=>({type:"function",function:{name:$.op,description:$.docs,parameters:$.inputSchema?.schema??{}}}))}async run(Z,X={},$={}){let K;if(typeof Z==="string")if(a4(Z))K=r4(Z);else try{K=q0(Z).ast}catch(U){throw Error(`AJS transpilation failed: ${U.message}`)}else K=Z;let Q=$.fuel??1000,H=$.timeoutMs??Q*E$,Y=$.capabilities??{},G=[];if(!Y.store){let U=new Map,R=!1;Y.store={get:async(M)=>{if(!R)R=!0,G.push("Using default in-memory store (not suitable for production)");return U.get(M)},set:async(M,w)=>{if(!R)R=!0,G.push("Using default in-memory store (not suitable for production)");U.set(M,w)}}}let z=new AbortController,W=setTimeout(()=>z.abort(),H);if($.signal)$.signal.addEventListener("abort",()=>z.abort());let J={fuel:{current:Q},args:X,state:{},consts:new Set,capabilities:Y,resolver:(U)=>this.resolve(U),output:void 0,signal:z.signal,costOverrides:$.costOverrides,context:$.context,warnings:G};if($.trace)J.trace=[];if(K.op!=="seq")throw Error("Root AST must be 'seq'. Ensure you're passing a transpiled agent (use ajs`...` or transpile()).");let L=K.inputSchema;if(L&&!N$(X,L)){let U=new H1("Input validation failed: args do not match expected schema","vm.run");return{result:U,error:U,fuelUsed:0,trace:J.trace,warnings:G.length>0?G:void 0}}try{await Promise.race([this.resolve("seq")?.exec(K,J),new Promise((U,R)=>{if(z.signal.addEventListener("abort",()=>{R(Error(`Execution timeout after ${H}ms (fuel: ${Q}). Consider increasing fuel or optimizing your agent.`))}),z.signal.aborted)R(Error(`Execution timeout after ${H}ms (fuel: ${Q}). Consider increasing fuel or optimizing your agent.`))})])}catch(U){if(U.message?.includes("timeout")||U.message?.includes("aborted")||z.signal.aborted)J.error=new H1(`Execution timeout after ${H}ms (fuel: ${Q}). Consider increasing fuel or optimizing your agent.`,"vm.run");else throw U}finally{clearTimeout(W)}if(J.error&&J.output===void 0)J.output=J.error;let _=[...G,...J.warnings??[]];return{result:J.output,error:J.error,fuelUsed:Q-J.fuel.current,trace:J.trace,warnings:_.length>0?_:void 0}}}var T$=null,k7=()=>T$??=new Z6;function x1(Z){if(!Z||typeof Z!=="object")return;if(Array.isArray(Z)){for(let X of Z)x1(X);return}if(Z.op==="return"&&"value"in Z)Z.value={__result:Z.value};if(Z.steps)x1(Z.steps);if(Z.then)x1(Z.then);if(Z.else)x1(Z.else);if(Z.body)x1(Z.body)}async function S$(Z){let{code:X,context:$={},fuel:K=1000,timeoutMs:Q,capabilities:H={}}=Z,Y=k7(),z=/\breturn\b/.test(X)?`function __eval() { ${X} }`:`function __eval() { return (${X}) }`;try{let{ast:W}=q0(z);x1(W);let J=await Y.run(W,$,{fuel:K,timeoutMs:Q,capabilities:H}),L=J.result;return{result:L&&typeof L==="object"&&"__result"in L?L.__result:L,fuelUsed:J.fuelUsed,error:J.error?{message:J.error.message||String(J.error)}:void 0}}catch(W){return{result:void 0,fuelUsed:K,error:{message:W.message||String(W)}}}}async function k$(Z){let{body:X,params:$=[],fuel:K=1000,timeoutMs:Q,capabilities:H={}}=Z,Y=k7(),z=`function __safeFn(${$.join(", ")}) { ${X} }`,{ast:W}=q0(z);return x1(W),async(...J)=>{let L={};for(let _=0;_<$.length;_++)L[$[_]]=J[_];try{let _=await Y.run(W,L,{fuel:K,timeoutMs:Q,capabilities:H}),U=_.result;return{result:U&&typeof U==="object"&&"__result"in U?U.__result:U,fuelUsed:_.fuelUsed,error:_.error?{message:_.error.message||String(_.error)}:void 0}}catch(_){return{result:void 0,fuelUsed:K,error:{message:_.message||String(_)}}}}}function L4(Z,X={}){let{ast:$,returnType:K,originalSource:Q,requiredParams:H}=F1(Z,{filename:X.filename,colonShorthand:!0,vmTarget:!0}),Y=N0($,X.filename),{ast:G,signature:z,warnings:W}=K0(Y,Q,K,X,H);return{ast:G,signature:z,warnings:W}}function FQ(Z,...X){if(typeof Z==="string")return L4(Z).ast;let $=Z.reduce((K,Q,H)=>K+Q+(X[H]!==void 0?String(X[H]):""),"");return L4($).ast}function wQ(Z,X,...$){if(typeof Z==="string")return J0(Z,X);let K=X!==void 0?[X,...$]:$,Q=Z.reduce((H,Y,G)=>H+Y+(K[G]!==void 0?String(K[G]):""),"");return J0(Q)}async function jQ(Z,X={},$){let K=$??await Q4(),Q=await K.getTranspile(Z);if(Q)return{ast:Q.ast,signature:Q.signature,warnings:Q.warnings};let H=L4(Z,X);return K.setTranspile(Z,{ast:H.ast,signature:H.signature,warnings:H.warnings}),H}async function PQ(Z,X={},$){let K=$??await Q4(),Q=await K.getTJS(Z);if(Q)return{code:Q.code,types:Q.types,metadata:Q.types,testRunner:Q.testRunner,testCount:Q.testCount,warnings:Q.warnings};let H=J0(Z,X);return K.setTJS(Z,{code:H.code,types:H.types,testRunner:H.testRunner,testCount:H.testCount,warnings:H.warnings}),H}function VQ(Z,X,$){let{ast:K,signature:Q}=L4(Z),H=async(Y)=>{return(await X.run(K,Y,$)).result};return H.signature=Q,H.ast=K,H}function CQ(Z){return Object.entries(Z).map(([X,$])=>{let K=$.signature,Q={},H=[];for(let[Y,G]of Object.entries(K.parameters)){if(Q[Y]=_4(G.type),G.description)Q[Y].description=G.description;if(G.required)H.push(Y)}return{type:"function",function:{name:K.name||X,description:K.description,parameters:{type:"object",properties:Q,required:H}}}})}function _4(Z){switch(Z.kind){case"string":return{type:"string"};case"number":return{type:"number"};case"boolean":return{type:"boolean"};case"null":return{type:"null"};case"array":return{type:"array",items:Z.items?_4(Z.items):{}};case"object":if(!Z.shape)return{type:"object"};return{type:"object",properties:Object.fromEntries(Object.entries(Z.shape).map(([X,$])=>[X,_4($)]))};case"union":if(!Z.members)return{};return{anyOf:Z.members.map(_4)};case"any":default:return{}}}import{s as k}from"tosijs-schema";var g7=S("storeVectorize",k.object({text:k.string,model:k.string.optional}),k.array(k.number),async({text:Z},X)=>{let $=X.capabilities.vector;if(!$)throw Error("Capability 'vector' missing. Ensure vector battery is loaded.");let K=O(Z,X);return $.embed(K)},{docs:"Generate embeddings using vector battery",cost:20}),b7=S("storeCreateCollection",k.object({collection:k.string,dimension:k.number.optional}),void 0,async({collection:Z,dimension:X},$)=>{let K=$.capabilities.store;if(!K?.createCollection)throw Error("Capability 'store' missing or does not support createCollection.");let Q=O(Z,$),H=O(X,$);return K.createCollection(Q,void 0,H)},{docs:"Create a vector store collection",cost:5}),v7=S("storeVectorAdd",k.object({collection:k.string,doc:k.any}),void 0,async({collection:Z,doc:X},$)=>{let K=$.capabilities.store;if(!K?.vectorAdd)throw Error("Capability 'store' missing or does not support vectorAdd.");let Q=O(Z,$),H=O(X,$);return K.vectorAdd(Q,H)},{docs:"Add a document to a vector store collection",cost:5}),f7=S("storeSearch",k.object({collection:k.string,queryVector:k.array(k.number),k:k.number.optional,filter:k.record(k.any).optional}),k.array(k.any),async({collection:Z,queryVector:X,k:$,filter:K},Q)=>{let H=Q.capabilities.store;if(!H?.vectorSearch)throw Error("Capability 'store' missing or does not support vectorSearch.");let Y=O(Z,Q),G=O(X,Q),z=O($,Q)??5,W=O(K,Q);return H.vectorSearch(Y,G,z,W)},{docs:"Search vector store",cost:(Z,X)=>5+(O(Z.k,X)??5)}),y7=S("llmPredictBattery",k.object({system:k.string.optional,user:k.string,tools:k.array(k.any).optional,responseFormat:k.any.optional}),k.object({role:k.string.optional,content:k.string.optional,tool_calls:k.array(k.any).optional}),async({system:Z,user:X,tools:$,responseFormat:K},Q)=>{let H=Q.capabilities.llmBattery;if(!H?.predict)throw Error("Capability 'llmBattery' missing or invalid.");let Y=O(Z,Q)??"You are a helpful agent.",G=O(X,Q),z=O($,Q),W=O(K,Q);return H.predict(Y,G,z,W)},{docs:"Generate completion using LLM battery",cost:100}),h7=S("llmVision",k.object({system:k.string.optional,prompt:k.string,images:k.array(k.string),responseFormat:k.any.optional}),k.object({role:k.string.optional,content:k.string.optional,tool_calls:k.array(k.any).optional}),async({system:Z,prompt:X,images:$,responseFormat:K},Q)=>{let H=Q.capabilities.llmBattery;if(!H?.predict)throw Error("Capability 'llmBattery' missing or invalid.");let Y=O(Z,Q)??"You analyze images accurately and concisely.",G=O(X,Q),z=O($,Q)??[],W=O(K,Q);return H.predict(Y,{text:G,images:z},void 0,W)},{docs:"Analyze images using a vision model",timeoutMs:120000,cost:150});var cQ={storeCreateCollection:b7,storeSearch:f7,storeVectorAdd:v7,storeVectorize:g7,llmPredictBattery:y7,llmVision:h7};var x7=new Map,U4=new Map;function g$(Z,X){if(Z.length!==X.length)throw Error("Vectors must have the same length for cosine similarity.");let $=0,K=0,Q=0;for(let H=0;H<Z.length;H++)$+=Z[H]*X[H],K+=Z[H]*Z[H],Q+=X[H]*X[H];if(K=Math.sqrt(K),Q=Math.sqrt(Q),K===0||Q===0)return 0;return $/(K*Q)}function $6(){return{async get(Z){return x7.get(Z)},async set(Z,X){x7.set(Z,X)},async createCollection(Z,X,$){if(U4.has(Z))console.warn(`Collection '${Z}' already exists. Overwriting.`);U4.set(Z,[])},async vectorAdd(Z,X){let $=U4.get(Z);if(!$)throw Error(`Collection '${Z}' not found. Create it first.`);if(!X.embedding||!Array.isArray(X.embedding))throw Error("Document must have an 'embedding' property that is an array of numbers.");$.push(X)},async vectorSearch(Z,X,$=5){let K=U4.get(Z);if(!K)throw Error(`Collection '${Z}' not found. Create it first.`);let Q=K.map((H)=>({doc:H,score:g$(X,H.embedding)}));return Q.sort((H,Y)=>Y.score-H.score),Q.slice(0,$).map((H)=>H.doc)}}}function b$(Z){if(typeof Z==="string")return{role:"user",content:Z};let X=[{type:"text",text:Z.text}];for(let $ of Z.images||[])X.push({type:"image_url",image_url:{url:$}});return{role:"user",content:X}}var v$="http://localhost:1234/v1";function u7(Z,X=v$){return{async predict($,K,Q,H){try{let Y=H?Z.getStructuredLLM():Z.getLLM(),G=[{role:"system",content:$},b$(K)],z=await fetch(`${X}/chat/completions`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:Y.id,messages:G,temperature:0.7,tools:Q,response_format:H})});if(!z.ok)throw Error(`LLM Error: ${z.status} ${z.statusText}`);return(await z.json()).choices[0]?.message??{content:""}}catch(Y){if(Y.cause?.code==="ECONNREFUSED")throw Error("No LLM provider configured. Please start LM Studio or provide an API key.");throw Y}},async embed($){try{let K=Z.getEmbedding(),Q=await fetch(`${X}/embeddings`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:K.id,input:$})});if(!Q.ok)throw Error(`Embedding Error: ${Q.status}`);return(await Q.json()).data[0]?.embedding??[]}catch(K){if(K.cause?.code==="ECONNREFUSED")throw Error("No LLM provider configured. Please start LM Studio or provide an API key.");throw K}}}}var D0=typeof window<"u"&&typeof window.localStorage<"u";async function h$(Z){try{if(D0){let X=window.localStorage.getItem(".models.cache.json");if(!X)return null;let $=JSON.parse(X);if($.baseUrl!==Z)return null;if(Date.now()-$.timestamp>86400000)return null;return $.models}else{let X=await import("node:fs/promises"),K=(await Promise.resolve().then(() => (Q6(),K6))).join(process.cwd(),".models.cache.json");try{let Q=await X.readFile(K,"utf-8"),H=JSON.parse(Q);if(H.baseUrl!==Z)return null;if(Date.now()-H.timestamp>86400000)return null;return H.models}catch{return null}}}catch(X){return console.warn("⚠️ Error reading model cache:",X),null}}async function x$(Z,X){let $={timestamp:Date.now(),baseUrl:Z,models:X};try{if(D0)window.localStorage.setItem(".models.cache.json",JSON.stringify($));else{let K=await import("node:fs/promises"),H=(await Promise.resolve().then(() => (Q6(),K6))).join(process.cwd(),".models.cache.json");await K.writeFile(H,JSON.stringify($,null,2))}}catch(K){console.error("❌ Error writing model cache:",K)}}var R0=async(Z,X)=>{let $=new AbortController,K=setTimeout(()=>$.abort(),60000);try{let Q=await fetch(Z,{...X,signal:$.signal});return clearTimeout(K),Q}catch(Q){throw clearTimeout(K),Q}};async function u$(Z,X){try{let $={type:"json_schema",json_schema:{name:"test",strict:!1,schema:{type:"object",properties:{status:{type:"string"}}}}},K=await R0(`${Z}/chat/completions`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:X,messages:[{role:"system",content:"You respond in JSON."},{role:"user",content:'Return JSON: {"status": "ok"}'}],response_format:$,max_tokens:20})});if(!K.ok){if(K.status===400)return d$(Z,X);return{ok:!1,msg:`HTTP ${K.status}`}}let Q=await K.json();return JSON.parse(Q.choices[0].message.content),{ok:!0,msg:"OK (Schema)"}}catch($){return{ok:!1,msg:$.message||"Error"}}}async function d$(Z,X){try{if((await R0(`${Z}/chat/completions`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:X,messages:[{role:"user",content:'JSON: {"a":1}'}],response_format:{type:"json_object"},max_tokens:10})})).ok)return{ok:!0,msg:"OK (Legacy Mode)"};return{ok:!1,msg:"Not Supported"}}catch{return{ok:!1,msg:"Legacy Fail"}}}async function m$(Z,X){try{return(await R0(`${Z}/chat/completions`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:X,messages:[{role:"user",content:"hi"}],max_tokens:1})})).ok}catch{return!1}}async function l$(Z,X){try{let $=await R0(`${Z}/embeddings`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:X,input:"test"})});if(!$.ok)return null;return(await $.json()).data[0]?.embedding?.length??null}catch{return null}}var i$="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAADUlEQVR42mP8z8DwHwAFBQIAX8jx0gAAAABJRU5ErkJggg==";async function p$(Z,X){try{return(await R0(`${Z}/chat/completions`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:X,messages:[{role:"user",content:[{type:"text",text:"What color is this?"},{type:"image_url",image_url:{url:i$}}]}],max_tokens:10})})).ok}catch{return!1}}async function Z8(Z){let X=await h$(Z),$=[];try{let Y=await fetch(`${Z}/models`);if(!Y.ok)throw Error("Could not connect");$=(await Y.json()).data.map((z)=>z.id).sort()}catch(Y){if(X)return console.log("⚠️ LM Studio unavailable, using cached model audit."),X;return console.error("❌ Failed to connect to LM Studio."),[]}if(X){let Y=X.map((G)=>G.id).sort();if(JSON.stringify($)===JSON.stringify(Y))return console.log("✅ Using cached model audit."),X;console.log("\uD83D\uDD0D Model list changed. Re-running audit...")}console.log("\uD83D\uDD0D Scanning models (this may take a moment)...");let K=[],Q=$.map((Y)=>({id:Y})),H;if(!D0)H=await import("node:readline");for(let Y of Q){if(!D0&&H)H.cursorTo(process.stdout,0),process.stdout.write(`\uD83D\uDC49 Testing: ${Y.id}...`),H.clearLine(process.stdout,1);let G="Unknown",z=!1,W=!1,J="",L=void 0,_=await m$(Z,Y.id),U=await l$(Z,Y.id);if(U)L=U;if(_){G="LLM";let R=await u$(Z,Y.id);if(z=R.ok,W=await p$(Z,Y.id),J=z?R.msg:`Fail: ${R.msg}`,W)J+=" +Vision"}else if(U)G="Embedding",J=`OK (Dim: ${U})`;else J="LLM Fail";K.push({id:Y.id,type:G,structuredOutput:z,vision:W,dimension:L,status:J})}if(!D0&&H)H.cursorTo(process.stdout,0),H.clearLine(process.stdout,0);return console.log(`
|
|
403
|
-
`),console.table(K),await x$(Z,K),console.log("\uD83D\uDCDD Audit results saved to cache."),K}var n$="http://localhost:1234/v1";class H6{baseUrl;models=[];defaultLLM=null;defaultEmbedding=null;defaultStructuredLLM=null;constructor(Z=n$){this.baseUrl=Z}async audit(){this.models=await Z8(this.baseUrl),this.selectDefaults()}selectDefaults(){if(this.defaultEmbedding=this.models.find((Z)=>Z.type==="Embedding")||null,this.defaultLLM=this.models.find((Z)=>Z.type==="LLM")||null,this.defaultStructuredLLM=this.models.find((Z)=>Z.type==="LLM"&&Z.structuredOutput)||null,!this.defaultEmbedding)console.warn("⚠️ No embedding model found.");if(!this.defaultLLM)console.warn("⚠️ No LLM found.");if(!this.defaultStructuredLLM)console.warn("⚠️ No LLM with structured output support found.")}getModels(){return this.models}_setDefaultModel(Z,X,$,K){let Q=this.models.find((H)=>H.id===Z&&$(H));if(!Q)throw Error(`Model '${Z}' not found or is not ${K}.`);this[X]=Q}setDefaultLLM(Z){this._setDefaultModel(Z,"defaultLLM",(X)=>X.type==="LLM","an LLM")}setDefaultEmbedding(Z){this._setDefaultModel(Z,"defaultEmbedding",(X)=>X.dimension!==void 0,"an embedding model")}setDefaultStructuredLLM(Z){this._setDefaultModel(Z,"defaultStructuredLLM",(X)=>X.type==="LLM"&&X.structuredOutput,"a structured-output LLM")}getLLM(){if(!this.defaultLLM)throw Error("No LLM available.");return this.defaultLLM}getEmbedding(){if(!this.defaultEmbedding)throw Error("No embedding model available.");return this.defaultEmbedding}getStructuredLLM(){if(!this.defaultStructuredLLM)throw Error("No structured-output LLM available.");return this.defaultStructuredLLM}}var c$=typeof window<"u",o$=c$&&window.location.protocol==="https:",B0=null,Y6=null,$8=!1;async function s$(){if($8)return{localModels:B0,llm:Y6};if($8=!0,o$)return console.log("\uD83D\uDCE1 HTTPS detected - local LLM endpoints disabled. Use HTTP for local LLM support."),{localModels:null,llm:null};try{B0=new H6,await B0.audit(),Y6=u7(B0)}catch(Z){console.warn("⚠️ Could not connect to local LLM:",Z)}return{localModels:B0,llm:Y6}}async function a$(){let{localModels:Z,llm:X}=await s$();return{vector:X?{embed:X.embed}:void 0,store:$6(),llmBattery:X,models:Z}}async function KH(){return a$()}var QH={store:$6(),llmBattery:null,vector:void 0,models:null};function r$(Z){if(typeof Z!=="string")return!1;let X=new Date(Z);return!isNaN(X.getTime())&&Z.includes("T")}function t$(){return new Date().toISOString()}function c1(Z,X,$,K=0,Q=0,H=0,Y=0){return new Date(Date.UTC(Z,X-1,$,K,Q,H,Y)).toISOString()}function X8(Z){let X=new Date(Z);if(isNaN(X.getTime()))throw Error(`Invalid date string: ${Z}`);return X.toISOString()}function e$(Z){try{return X8(Z)}catch{return null}}function I0(Z,X){let $=new Date(Z);return $.setTime($.getTime()+X),$.toISOString()}function ZX(Z,X){return I0(Z,X*1000)}function $X(Z,X){return I0(Z,X*60*1000)}function XX(Z,X){return I0(Z,X*60*60*1000)}function K8(Z,X){return I0(Z,X*24*60*60*1000)}function KX(Z,X){return K8(Z,X*7)}function QX(Z,X){let $=new Date(Z),K=$.getUTCMonth()+X;if($.setUTCMonth(K),$.getUTCMonth()!==(K%12+12)%12)$.setUTCDate(0);return $.toISOString()}function HX(Z,X){let $=new Date(Z),K=$.getUTCDate();if($.setUTCFullYear($.getUTCFullYear()+X),$.getUTCDate()!==K)$.setUTCDate(0);return $.toISOString()}function N1(Z,X){return new Date(Z).getTime()-new Date(X).getTime()}function YX(Z,X){return Math.floor(N1(Z,X)/1000)}function GX(Z,X){return Math.floor(N1(Z,X)/60000)}function zX(Z,X){return Math.floor(N1(Z,X)/3600000)}function WX(Z,X){return Math.floor(N1(Z,X)/86400000)}function o1(Z){return new Date(Z).getUTCFullYear()}function D4(Z){return new Date(Z).getUTCMonth()+1}function G6(Z){return new Date(Z).getUTCDate()}function JX(Z){return new Date(Z).getUTCHours()}function _X(Z){return new Date(Z).getUTCMinutes()}function LX(Z){return new Date(Z).getUTCSeconds()}function UX(Z){return new Date(Z).getUTCMilliseconds()}function qX(Z){let X=new Date(Z).getUTCDay();return X===0?7:X}function R4(Z,X,$){let K=new Date(Z),Q={timeZone:X,...$};return new Intl.DateTimeFormat(void 0,Q).format(K)}function DX(Z,X){return R4(Z,X,{year:"numeric",month:"short",day:"numeric",hour:"2-digit",minute:"2-digit",second:"2-digit"})}function RX(Z,X){return R4(Z,X,{year:"numeric",month:"short",day:"numeric"})}function BX(Z,X){return R4(Z,X,{hour:"2-digit",minute:"2-digit",second:"2-digit"})}function IX(Z){return Z.slice(0,10)}function Q8(Z,X){return N1(Z,X)<0}function H8(Z,X){return N1(Z,X)>0}function AX(Z,X){return N1(Z,X)===0}function FX(Z,X){return Q8(Z,X)?Z:X}function MX(Z,X){return H8(Z,X)?Z:X}function wX(Z){return c1(o1(Z),D4(Z),G6(Z))}function jX(Z){return c1(o1(Z),D4(Z),G6(Z),23,59,59,999)}function PX(Z){return c1(o1(Z),D4(Z),1)}function VX(Z){let X=new Date(Z);return X.setUTCMonth(X.getUTCMonth()+1,0),X.setUTCHours(23,59,59,999),X.toISOString()}function CX(Z){return c1(o1(Z),1,1)}function OX(Z){return c1(o1(Z),12,31,23,59,59,999)}var s1={isValid:r$,now:t$,from:c1,parse:X8,tryParse:e$,addMilliseconds:I0,addSeconds:ZX,addMinutes:$X,addHours:XX,addDays:K8,addWeeks:KX,addMonths:QX,addYears:HX,diff:N1,diffSeconds:YX,diffMinutes:GX,diffHours:zX,diffDays:WX,year:o1,month:D4,day:G6,hour:JX,minute:_X,second:LX,millisecond:UX,dayOfWeek:qX,toLocal:R4,format:DX,formatDate:RX,formatTime:BX,toDate:IX,isBefore:Q8,isAfter:H8,isEqual:AX,min:FX,max:MX,startOfDay:wX,endOfDay:jX,startOfMonth:PX,endOfMonth:VX,startOfYear:CX,endOfYear:OX};function z6(Z){if(typeof Z!=="string")return!1;if(!/^\d{4}-\d{2}-\d{2}$/.test(Z))return!1;let X=parseInt(Z.slice(0,4),10),$=parseInt(Z.slice(5,7),10),K=parseInt(Z.slice(8,10),10);if($<1||$>12)return!1;if(K<1)return!1;let Q=[31,28,31,30,31,30,31,31,30,31,30,31],H=$===2&&(X%4===0&&X%100!==0||X%400===0)?29:Q[$-1];return K<=H}function NX(){return s1.toDate(s1.now())}function EX(Z){let X=new Date;return new Intl.DateTimeFormat("en-CA",{timeZone:Z,year:"numeric",month:"2-digit",day:"2-digit"}).format(X)}function _1(Z,X,$){let K=String(Z).padStart(4,"0"),Q=String(X).padStart(2,"0"),H=String($).padStart(2,"0"),Y=`${K}-${Q}-${H}`;if(!z6(Y))throw Error(`Invalid date: ${Z}-${X}-${$}`);return Y}function Y8(Z){if(/^\d{4}-\d{2}-\d{2}$/.test(Z)){if(!z6(Z))throw Error(`Invalid date: ${Z}`);return Z}let X=new Date(Z);if(isNaN(X.getTime()))throw Error(`Invalid date string: ${Z}`);let $=X.getUTCFullYear(),K=X.getUTCMonth()+1,Q=X.getUTCDate();return _1($,K,Q)}function TX(Z){try{return Y8(Z)}catch{return null}}function B4(Z,X){let $=z8(Z);return s1.toDate(s1.addDays($,X))}function SX(Z,X){return B4(Z,X*7)}function kX(Z,X){let $=X1(Z),K=E1(Z),Q=W6(Z),H=$*12+(K-1)+X,Y=Math.floor(H/12),G=H%12+1,z=A0(Y,G),W=Math.min(Q,z);return _1(Y,G,W)}function gX(Z,X){let $=X1(Z),K=E1(Z),Q=W6(Z),H=$+X,Y=A0(H,K),G=Math.min(Q,Y);return _1(H,K,G)}function G8(Z,X){let K=new Date(Z+"T00:00:00Z").getTime(),Q=new Date(X+"T00:00:00Z").getTime();return Math.round((K-Q)/86400000)}function bX(Z,X){let $=X1(Z),K=E1(Z),Q=X1(X),H=E1(X);return($-Q)*12+(K-H)}function vX(Z,X){return X1(Z)-X1(X)}function X1(Z){return parseInt(Z.slice(0,4),10)}function E1(Z){return parseInt(Z.slice(5,7),10)}function W6(Z){return parseInt(Z.slice(8,10),10)}function J6(Z){let X=new Date(Z+"T00:00:00Z").getUTCDay();return X===0?7:X}function fX(Z){let X=new Date(Z+"T00:00:00Z"),$=X.getUTCDay()||7;X.setUTCDate(X.getUTCDate()+4-$);let K=new Date(Date.UTC(X.getUTCFullYear(),0,1));return Math.ceil(((X.getTime()-K.getTime())/86400000+1)/7)}function yX(Z){let X=_1(X1(Z),1,1);return G8(Z,X)+1}function _6(Z){return Math.ceil(E1(Z)/3)}function L6(Z){return Z%4===0&&Z%100!==0||Z%400===0}function A0(Z,X){let $=[31,28,31,30,31,30,31,31,30,31,30,31];if(X===2&&L6(Z))return 29;return $[X-1]}function hX(Z){return L6(Z)?366:365}function z8(Z){return Z+"T00:00:00.000Z"}function xX(Z){return Math.floor(new Date(Z+"T00:00:00Z").getTime()/1000)}function uX(Z){let X=new Date(Z*1000);return _1(X.getUTCFullYear(),X.getUTCMonth()+1,X.getUTCDate())}function U6(Z,X){let $=new Date(Z+"T00:00:00Z"),K={timeZone:"UTC",...X};return new Intl.DateTimeFormat(void 0,K).format($)}function dX(Z){return U6(Z,{year:"numeric",month:"long",day:"numeric"})}function mX(Z){return U6(Z,{year:"numeric",month:"short",day:"numeric"})}function lX(Z,X){return Z<X}function iX(Z,X){return Z>X}function pX(Z,X){return Z===X}function nX(Z,X){return Z<X?Z:X}function cX(Z,X){return Z>X?Z:X}function oX(Z,X,$){return Z>=X&&Z<=$}function sX(Z){return _1(X1(Z),E1(Z),1)}function aX(Z){let X=X1(Z),$=E1(Z);return _1(X,$,A0(X,$))}function rX(Z){let $=(_6(Z)-1)*3+1;return _1(X1(Z),$,1)}function tX(Z){let $=_6(Z)*3;return _1(X1(Z),$,A0(X1(Z),$))}function eX(Z){return _1(X1(Z),1,1)}function ZK(Z){return _1(X1(Z),12,31)}function $K(Z){let X=J6(Z);return B4(Z,-(X-1))}function XK(Z){let X=J6(Z);return B4(Z,7-X)}var KK={isValid:z6,today:NX,todayIn:EX,from:_1,parse:Y8,tryParse:TX,addDays:B4,addWeeks:SX,addMonths:kX,addYears:gX,diff:G8,diffMonths:bX,diffYears:vX,year:X1,month:E1,day:W6,dayOfWeek:J6,weekOfYear:fX,dayOfYear:yX,quarter:_6,isLeapYear:L6,daysInMonth:A0,daysInYear:hX,toTimestamp:z8,toUnix:xX,fromUnix:uX,format:U6,formatLong:dX,formatShort:mX,isBefore:lX,isAfter:iX,isEqual:pX,min:nX,max:cX,isBetween:oX,startOfMonth:sX,endOfMonth:aX,startOfQuarter:rX,endOfQuarter:tX,startOfYear:eX,endOfYear:ZK,startOfWeek:$K,endOfWeek:XK};export{_$ as xmlParse,i4 as wrap,N5 as whileLoop,Q$ as vectorSearch,f5 as varsLet,v5 as varsImport,y5 as varsExport,k5 as varSet,b5 as varGet,l4 as validateArgs,D$ as uuid,j4 as typeToString,l1 as typeOf,T5 as tryCatch,jQ as transpileWithCache,J0 as transpileToJS,G$ as transpileCode,L4 as transpile,K0 as transformFunction,PQ as tjsWithCache,wQ as tjs,r8 as testUtils,c5 as template,S0 as stripTjsPreamble,T0 as stripModuleSyntax,X$ as storeSet,K$ as storeQuery,A$ as storeProcedure,$$ as storeGet,p5 as split,J5 as setGlobalCache,J1 as seq,h5 as scope,b1 as runtime,z$ as runCode,E5 as ret,O as resolveValue,r4 as resolveProcedureToken,F$ as releaseProcedure,e6 as registerWasmBlock,o5 as regexMatch,d5 as reduce,q$ as random,l5 as push,n1 as procedureStore,O0 as preprocess,s5 as pick,u6 as parseReturnType,P1 as parseParameter,F1 as parse,a5 as omit,r5 as merge,L$ as memoize,x5 as map,F8 as lookupVariable,H$ as llmPredict,U5 as lint,i5 as len,t5 as keys,J$ as jsonStringify,W$ as jsonParse,n5 as join,b4 as isValidUrl,v4 as isValidTimestamp,f4 as isValidLegalDate,C1 as isRuntimeType,a4 as isProcedureToken,M1 as isError,B5 as isAgentError,t6 as instantiateWasm,nZ as installRuntime,G1 as inferTypeFromValue,O5 as iff,G5 as hashSourceSync,K4 as hashSource,t4 as hash,CQ as getToolDefinitions,$6 as getStoreCapabilityDefault,KH as getStandardCapabilities,d as getLocation,u7 as getLLMCapability,Q4 as getGlobalCache,a$ as getBatteries,R5 as generateDocsMarkdown,I7 as generateDocs,H5 as fromTS,m5 as find,u5 as filter,Z$ as fetch,V4 as extractTests,Z0 as extractTDoc,R1 as extractLiteralValue,n6 as expectFunction,i as evaluateExpr,S5 as errorAtom,I1 as error,cZ as emitRuntimeWrapper,S as defineAtom,O1 as createChildScope,z1 as createChildContext,VQ as createAgent,W4 as coreAtoms,g5 as constSet,B$ as consoleWarn,R$ as consoleLog,I$ as consoleError,wZ as compileWasmBlocks,b0 as compileToWasm,M$ as clearExpiredProcedures,v1 as checkType,U$ as cache,j1 as builtins,cQ as batteryAtoms,QH as batteries,p6 as assertFunction,FQ as ajs,Y$ as agentRun,c0 as Union,e as TypedBuilder,A8 as TypeError,p as Type,u as TranspileError,y4 as TimestampType,s1 as Timestamp,i0 as TUuid,l0 as TUrl,f0 as TString,a0 as TRecord,u0 as TPositiveInt,s0 as TPair,y0 as TNumber,d0 as TNonEmptyString,$1 as TJS_VERSION,x0 as TInteger,m0 as TEmail,h0 as TBoolean,o0 as TArray,K1 as SyntaxError,Y5 as Schema,k$ as SafeFunction,s4 as PROCEDURE_TOKEN_PREFIX,n0 as Optional,p0 as Nullable,n4 as MetadataCache,H6 as LocalModels,h4 as LegalDateType,KK as LegalDate,m1 as Generic,S$ as Eval,r0 as Enum,I5 as DEFAULT_PROCEDURE_TTL,A5 as DEFAULT_MAX_AST_SIZE,Z6 as AgentVM,H1 as AgentError,O$ as Agent,XQ as A99};
|
|
409
|
+
`}return Q.trim()||"*No documentation available*"}import{s as A,validate as r4,filter as N7}from"tosijs-schema";var G4=Symbol.for("tjs.equals");function _4(Z,X){if(Z!==null&&typeof Z==="object"&&typeof Z[G4]==="function")return Z[G4](X);if(X!==null&&typeof X==="object"&&typeof X[G4]==="function")return X[G4](Z);if(Z!==null&&typeof Z==="object"&&typeof Z.Equals==="function")return Z.Equals(X);if(X!==null&&typeof X==="object"&&typeof X.Equals==="function")return X.Equals(Z);if(Z===X)return!0;if((Z===null||Z===void 0)&&(X===null||X===void 0))return!0;if(Z===null||Z===void 0||X===null||X===void 0)return!1;if(typeof Z!==typeof X)return!1;if(typeof Z!=="object")return!1;if(Array.isArray(Z)&&Array.isArray(X)){if(Z.length!==X.length)return!1;return Z.every((K,H)=>_4(K,X[H]))}if(Array.isArray(Z)!==Array.isArray(X))return!1;let $=Object.keys(Z),Q=Object.keys(X);if($.length!==Q.length)return!1;return $.every((K)=>_4(Z[K],X[K]))}class H1{$error=!0;message;op;cause;constructor(Z,X,$){this.message=Z,this.op=X,this.cause=$}toString(){return`AgentError[${this.op}]: ${this.message}`}toJSON(){return{$error:!0,message:this.message,op:this.op}}}function k5(Z){return Z instanceof H1||Z&&Z.$error===!0}var o1=new Map,g5=3600000,b5=102400,t4="proc_";function e4(Z){return typeof Z==="string"&&Z.startsWith(t4)}function Z6(Z){let X=o1.get(Z);if(!X)throw Error(`Procedure not found: ${Z}`);if(Date.now()>X.expiresAt)throw o1.delete(Z),Error(`Procedure expired: ${Z}`);return X.ast}function v5(){if(typeof crypto<"u"&&crypto.randomUUID)return t4+crypto.randomUUID();return t4+Math.random().toString(36).slice(2)+Date.now().toString(36)}var E7=new Set(["__proto__","constructor","prototype"]);function F7(Z){if(E7.has(Z))throw Error(`Security Error: Access to '${Z}' is forbidden`)}var f5=new Set(["localhost","127.0.0.1","0.0.0.0","[::1]","metadata.google.internal"]);function y5(Z){try{let X=new URL(Z);if(X.protocol!=="http:"&&X.protocol!=="https:")return!0;let $=X.hostname.toLowerCase();if(f5.has($))return!0;if($.endsWith(".internal")||$.endsWith(".local"))return!0;if($==="169.254.169.254")return!0;if(/^10\./.test($)||/^192\.168\./.test($)||/^172\.(1[6-9]|2\d|3[01])\./.test($))return!0;return!1}catch{return!0}}function h5(Z){if(/\([^)]*[+*][^)]*\)[+*]/.test(Z))return!0;if(/\(([^|)]+)\|\1\)[+*]/.test(Z))return!0;if(/\(\.\*\)\+/.test(Z))return!0;if(/\(\.\+\)\+/.test(Z))return!0;if(/\(\[.*\]\+\)\+/.test(Z))return!0;return!1}function O1(Z){return{...Z,state:Object.create(Z.state)}}function x5(Z,X){let $={},Q=new Set([...Object.keys(Z),...Object.keys(X)]);for(let K of Q){let H=Z[K],Y=X[K];if(Y!==H)$[K]=Y}return $}function N(Z,X){if(Z&&typeof Z==="object"&&Z.$kind==="arg")return X.args[Z.path];if(Z&&typeof Z==="object"&&Z.$expr)return p(Z,X);if(typeof Z==="string"){if(Z.startsWith("args.")&&!("args"in X.state))return X.args[Z.replace("args.","")];if(Z.includes(".")){let $=Z.split(".");for(let K of $)if(E7.has(K))throw Error(`Security Error: Access to '${K}' is forbidden`);let Q=X.state[$[0]];if(Q!==void 0){for(let K=1;K<$.length;K++)Q=Q?.[$[K]];return Q}}if(Z in X.state)return X.state[Z];return Z}if(Z&&typeof Z==="object"&&!Array.isArray(Z)&&Z.constructor===Object){let $={};for(let Q of Object.keys(Z))$[Q]=N(Z[Q],X);return $}if(Array.isArray(Z))return Z.map(($)=>N($,X));return Z}function h1(Z,X,$){return new Proxy(X,{get(Q,K){if(K in Q)return Q[K];let H=$?.[K];if(H)throw Error(`${Z}.${K} is not available. ${H}`);throw Error(`${Z}.${K} is not supported in AsyncJS. Check docs for available ${Z} methods.`)}})}function c1(Z){if(Z===null)return{type:"null"};if(Z===void 0)return{};if(typeof Z==="object"&&Z!==null&&"type"in Z&&typeof Z.type==="string")return Z;if(typeof Z==="object"&&Z!==null&&"schema"in Z&&typeof Z.schema==="object")return Z.schema;let X=typeof Z;if(X==="string")return{type:"string"};if(X==="number")return Number.isInteger(Z)?{type:"integer"}:{type:"number"};if(X==="boolean")return{type:"boolean"};if(Array.isArray(Z)){if(Z.length===0)return{type:"array"};return{type:"array",items:c1(Z[0])}}if(X==="object"){let $={},Q=[];for(let[K,H]of Object.entries(Z))$[K]=c1(H),Q.push(K);return{type:"object",properties:$,required:Q}}return{}}var j1={Math:h1("Math",{PI:Math.PI,E:Math.E,LN2:Math.LN2,LN10:Math.LN10,LOG2E:Math.LOG2E,LOG10E:Math.LOG10E,SQRT2:Math.SQRT2,SQRT1_2:Math.SQRT1_2,abs:Math.abs,ceil:Math.ceil,floor:Math.floor,round:Math.round,trunc:Math.trunc,sign:Math.sign,sqrt:Math.sqrt,cbrt:Math.cbrt,pow:Math.pow,exp:Math.exp,expm1:Math.expm1,log:Math.log,log2:Math.log2,log10:Math.log10,log1p:Math.log1p,sin:Math.sin,cos:Math.cos,tan:Math.tan,asin:Math.asin,acos:Math.acos,atan:Math.atan,atan2:Math.atan2,sinh:Math.sinh,cosh:Math.cosh,tanh:Math.tanh,asinh:Math.asinh,acosh:Math.acosh,atanh:Math.atanh,hypot:Math.hypot,min:Math.min,max:Math.max,clz32:Math.clz32,imul:Math.imul,fround:Math.fround,random:()=>{if(typeof crypto<"u"&&crypto.getRandomValues){let Z=new Uint32Array(1);return crypto.getRandomValues(Z),Z[0]/4294967296}return Math.random()}}),JSON:h1("JSON",{parse:(Z)=>JSON.parse(Z),stringify:(Z,X,$)=>JSON.stringify(Z,X,$)}),console:h1("console",{log:(...Z)=>{return},warn:(...Z)=>{return},error:(...Z)=>{return},info:(...Z)=>{return}},{table:"Use console.log with JSON.stringify for structured data.",dir:"Use console.log instead.",trace:"Stack traces are not available in AsyncJS."}),Array:h1("Array",{isArray:(Z)=>Array.isArray(Z),from:(Z,X,$)=>Array.from(Z,X,$),of:(...Z)=>Array.of(...Z)},{prototype:"Prototype access is not allowed."}),Object:h1("Object",{keys:(Z)=>Object.keys(Z),values:(Z)=>Object.values(Z),entries:(Z)=>Object.entries(Z),fromEntries:(Z)=>Object.fromEntries(Z),assign:(Z,...X)=>Object.assign({},Z,...X),hasOwn:(Z,X)=>Object.hasOwn(Z,X)},{prototype:"Prototype access is not allowed.",create:"Use object literals instead.",defineProperty:"Property descriptors are not supported.",getPrototypeOf:"Prototype access is not allowed.",setPrototypeOf:"Prototype modification is not allowed."}),String:h1("String",{fromCharCode:(...Z)=>String.fromCharCode(...Z),fromCodePoint:(...Z)=>String.fromCodePoint(...Z)}),Number:h1("Number",{isNaN:Number.isNaN,isFinite:Number.isFinite,isInteger:Number.isInteger,isSafeInteger:Number.isSafeInteger,parseFloat,parseInt,MAX_VALUE:Number.MAX_VALUE,MIN_VALUE:Number.MIN_VALUE,MAX_SAFE_INTEGER:Number.MAX_SAFE_INTEGER,MIN_SAFE_INTEGER:Number.MIN_SAFE_INTEGER,POSITIVE_INFINITY:Number.POSITIVE_INFINITY,NEGATIVE_INFINITY:Number.NEGATIVE_INFINITY,NaN:Number.NaN,EPSILON:Number.EPSILON}),parseInt,parseFloat,isNaN,isFinite,encodeURI,decodeURI,encodeURIComponent,decodeURIComponent,undefined:void 0,null:null,NaN:NaN,Infinity:1/0,filter:(Z,X)=>{let $=c1(X),Q=N7(Z,$);if(Q instanceof Error)throw Q;return Q},Schema:{...A,response:(Z,X)=>{let $=X?.schema!=null?X.schema:c1(X);return{type:"json_schema",json_schema:{name:Z,strict:!0,schema:$}}},fromExample:(Z)=>c1(Z),isValid:(Z,X)=>{if(X?.schema!=null)return r4(Z,X);return r4(Z,c1(X))}},Set:(Z=[])=>{let X=[...new globalThis.Set(Z)];return{add($){if(!X.includes($))X.push($);return this},remove($){let Q=X.indexOf($);if(Q!==-1)X.splice(Q,1);return this},clear(){return X.length=0,this},has($){return X.includes($)},get size(){return X.length},toArray(){return[...X]},union($){let Q=$?.toArray?.()??$??[];return j1.Set([...X,...Q])},intersection($){let Q=$?.toArray?.()??$??[];return j1.Set(X.filter((K)=>Q.includes(K)))},diff($){let Q=$?.toArray?.()??$??[];return j1.Set(X.filter((K)=>!Q.includes(K)))},forEach($){X.forEach($)},map($){return j1.Set(X.map($))},filter($){return j1.Set(X.filter($))},toJSON(){return[...X]}}},Date:(()=>{let Z=($)=>({get value(){return $.toISOString()},get timestamp(){return $.getTime()},get year(){return $.getFullYear()},get month(){return $.getMonth()+1},get day(){return $.getDate()},get hours(){return $.getHours()},get minutes(){return $.getMinutes()},get seconds(){return $.getSeconds()},get dayOfWeek(){return $.getDay()},add({years:Q=0,months:K=0,days:H=0,hours:Y=0,minutes:z=0,seconds:W=0,ms:G=0}={}){let J=new globalThis.Date($.getTime());if(Q)J.setFullYear(J.getFullYear()+Q);if(K)J.setMonth(J.getMonth()+K);if(H)J.setDate(J.getDate()+H);if(Y)J.setHours(J.getHours()+Y);if(z)J.setMinutes(J.getMinutes()+z);if(W)J.setSeconds(J.getSeconds()+W);if(G)J.setMilliseconds(J.getMilliseconds()+G);return Z(J)},diff(Q,K="ms"){let H=typeof Q==="object"&&Q.timestamp?Q.timestamp:new globalThis.Date(Q).getTime(),Y=$.getTime()-H;switch(K){case"seconds":return Y/1000;case"minutes":return Y/60000;case"hours":return Y/3600000;case"days":return Y/86400000;default:return Y}},format(Q="ISO"){if(Q==="ISO")return $.toISOString();if(Q==="date")return $.toISOString().split("T")[0];if(Q==="time")return $.toISOString().split("T")[1].split(".")[0];return Q.replace("YYYY",String($.getFullYear())).replace("MM",String($.getMonth()+1).padStart(2,"0")).replace("DD",String($.getDate()).padStart(2,"0")).replace("HH",String($.getHours()).padStart(2,"0")).replace("mm",String($.getMinutes()).padStart(2,"0")).replace("ss",String($.getSeconds()).padStart(2,"0"))},isBefore(Q){let K=typeof Q==="object"&&Q.timestamp?Q.timestamp:new globalThis.Date(Q).getTime();return $.getTime()<K},isAfter(Q){let K=typeof Q==="object"&&Q.timestamp?Q.timestamp:new globalThis.Date(Q).getTime();return $.getTime()>K},toString(){return $.toISOString()},toJSON(){return $.toISOString()}}),X=($)=>{let Q=$!==void 0?new globalThis.Date($):new globalThis.Date;if(isNaN(Q.getTime()))throw Error(`Invalid date: ${$}`);return Z(Q)};return X.now=()=>globalThis.Date.now(),X.parse=($)=>Z(new globalThis.Date($)),X})()},J4={RegExp:"RegExp is not available. Use string methods or the regexMatch atom.",Promise:"Promise is not needed. All operations are implicitly async.",Map:"Map is not available. Use plain objects instead.",WeakSet:"WeakSet is not available.",WeakMap:"WeakMap is not available.",Symbol:"Symbol is not available.",Proxy:"Proxy is not available.",Reflect:"Reflect is not available.",Function:"Function constructor is not available. Define functions normally.",eval:"eval is not available. Code is compiled, not evaluated.",setTimeout:"setTimeout is not available. Use the delay atom.",setInterval:"setInterval is not available. Use while loops with delay.",fetch:"fetch is not available. Use the httpFetch atom.",require:"require is not available. Atoms must be registered with the VM.",import:"import is not available. Atoms must be registered with the VM.",process:"process is not available. AsyncJS runs in a sandboxed environment.",window:"window is not available. AsyncJS runs in a sandboxed environment.",document:"document is not available. AsyncJS runs in a sandboxed environment.",global:"global is not available. AsyncJS runs in a sandboxed environment.",globalThis:"globalThis is not available. Use builtins directly."},u5=0.01,j7=0.0001,P7=0.001,d5=new Set(["concat","slice","map","filter","flatMap","flat","toReversed","toSorted","toSpliced","repeat","padStart","padEnd","split","join","replace","replaceAll","substring","substr","trim","trimStart","trimEnd","toLowerCase","toUpperCase","match","matchAll","parse","stringify"]);function p(Z,X){if(Z===null||Z===void 0)return Z;if(typeof Z!=="object"||!("$expr"in Z))return Z;if(X.fuel){if(X.fuel.current-=u5,X.fuel.current<=0)throw Error("Out of Fuel")}switch(Z.$expr){case"literal":return Z.value;case"ident":{if(Z.name in X.state)return X.state[Z.name];if(Z.name in X.args)return X.args[Z.name];if(Z.name in j1)return j1[Z.name];if(Z.name in J4)throw Error(J4[Z.name]);return}case"member":{let $=p(Z.object,X);if(Z.optional&&($===null||$===void 0))return;let Q=Z.property;return F7(Q),$?.[Q]}case"binary":{let $=p(Z.left,X),Q=p(Z.right,X);switch(Z.op){case"+":{let K=$+Q;if(typeof K==="string"&&X.fuel){if(X.fuel.current-=K.length*j7,X.fuel.current<=0){X.error=new H1("Out of Fuel","expr.concat");return}}return K}case"-":return $-Q;case"*":return $*Q;case"/":return $/Q;case"%":return $%Q;case"**":return $**Q;case">":return $>Q;case"<":return $<Q;case">=":return $>=Q;case"<=":return $<=Q;case"==":return _4($,Q);case"!=":return!_4($,Q);case"===":return $===Q;case"!==":return $!==Q;default:throw Error(`Unknown binary operator: ${Z.op}`)}}case"unary":{let $=p(Z.argument,X);switch(Z.op){case"!":return!$;case"-":return-$;case"+":return+$;case"typeof":return typeof $;default:throw Error(`Unknown unary operator: ${Z.op}`)}}case"logical":{let $=p(Z.left,X);if(Z.op==="&&")return $?p(Z.right,X):$;else if(Z.op==="??")return $??p(Z.right,X);else return $?$:p(Z.right,X)}case"conditional":return p(Z.test,X)?p(Z.consequent,X):p(Z.alternate,X);case"array":return Z.elements.map(($)=>p($,X));case"object":{let $={};for(let Q of Z.properties)$[Q.key]=p(Q.value,X);return $}case"call":{if(Z.callee==="Error"){let Q=Z.arguments.map((H)=>p(H,X)),K=typeof Q[0]==="string"?Q[0]:"Error";X.error=new H1(K,"Error");return}if(Z.callee in j1){let Q=j1[Z.callee];if(typeof Q==="function"){let K=Z.arguments.map((H)=>p(H,X));return Q(...K)}}if(!X.resolver(Z.callee)){if(Z.callee in J4)throw Error(J4[Z.callee]);throw Error(`Unknown function: ${Z.callee}`)}throw Error(`Atom calls in expressions not yet supported: ${Z.callee}`)}case"methodCall":{let $=p(Z.object,X);if(Z.optional&&($===null||$===void 0))return;let Q=Z.method;if(F7(Q),$===null||$===void 0)throw Error(`Cannot call method '${Q}' on ${$}`);let K=$[Q];if(typeof K!=="function")throw Error(`'${Q}' is not a function`);let H=Z.arguments.map((z)=>p(z,X)),Y=K.apply($,H);if(X.fuel&&d5.has(Q)){let z=0;if(typeof Y==="string")z=Y.length*j7;else if(Array.isArray(Y))z=Y.length*P7;else if(typeof Y==="object"&&Y!==null)z=Object.keys(Y).length*P7;if(X.fuel.current-=z,X.fuel.current<=0){X.error=new H1("Out of Fuel",`expr.${Q}`);return}}return Y}default:throw Error(`Unknown expression type: ${Z.$expr}`)}}function S(Z,X,$,Q,K={}){let{docs:H="",timeoutMs:Y=1000,cost:z=1}=typeof K==="string"?{docs:K}:K;return{op:Z,inputSchema:X,outputSchema:$,exec:async(G,J)=>{let{op:L,result:_,...U}=G;if(J.error)return;let D=J.trace?{...J.state}:null,R=J.fuel.current,M,I;try{let V=J.costOverrides?.[Z],F=V!==void 0?V:z,j=typeof F==="function"?F(U,J):F;if((J.fuel.current-=j)<=0){J.error=new H1("Out of Fuel",Z);return}let B,P=async()=>Q(G,J);if(M=Y>0?await Promise.race([P(),new Promise((C,O)=>{B=setTimeout(()=>O(Error(`Atom '${Z}' timed out`)),Y)})]).finally(()=>clearTimeout(B)):await P(),G.result){if(J.consts.has(G.result))throw Error(`Cannot reassign const variable '${G.result}'`);if(M!==void 0&&$&&!r4(M,$)){J.error=new H1(`Output validation failed for '${Z}'`,Z);return}if(J.state[G.result]=M,G.resultConst)J.consts.add(G.result)}}catch(V){I=V.message||String(V),J.error=new H1(I,Z,V)}finally{if(J.trace&&D){let V=x5(D,J.state);J.trace.push({op:Z,input:U,stateDiff:V,result:M,error:I,fuelBefore:R,fuelAfter:J.fuel.current,timestamp:new Date().toISOString()})}}},docs:H,timeoutMs:Y,cost:z,create:(G)=>({op:Z,...G})}}var J1=S("seq",A.object({steps:A.array(A.any)}),void 0,async({steps:Z},X)=>{for(let $ of Z){if(X.output!==void 0)return;if(X.error)return;let Q=X.resolver($.op);if(!Q)throw Error(`Unknown Atom: ${$.op}`);await Q.exec($,X)}},{docs:"Sequence",timeoutMs:0,cost:0.1}),l5=S("if",A.object({condition:A.any,then:A.array(A.any),else:A.array(A.any).optional}),void 0,async(Z,X)=>{if(p(Z.condition,X))await J1.exec({op:"seq",steps:Z.then},X);else if(Z.else)await J1.exec({op:"seq",steps:Z.else},X)},{docs:"If/Else",timeoutMs:0,cost:0.1}),m5=S("while",A.object({condition:A.any,body:A.array(A.any)}),void 0,async(Z,X)=>{while(p(Z.condition,X)){if(X.signal?.aborted)throw Error("Execution aborted");if((X.fuel.current-=0.1)<=0)throw Error("Out of Fuel");if(await J1.exec({op:"seq",steps:Z.body},X),X.output!==void 0)return}},{docs:"While Loop",timeoutMs:0,cost:0.1}),i5=S("return",void 0,A.any,async(Z,X)=>{if(X.error)return X.output=X.error,X.error;if("value"in Z){let Q=N(Z.value,X);if(Q!==void 0&&Q!==null&&!k5(Q)&&(typeof Q!=="object"||Array.isArray(Q))){let K=new H1(`Agent must return an object, got ${Array.isArray(Q)?"array":typeof Q}`,"return");return X.error=K,X.output=K,K}return X.output=Q,Q}let $={};if(Z.schema?.properties){for(let Q of Object.keys(Z.schema.properties))$[Q]=X.state[Q];if(Z.filter!==!1){let Q=N7($,Z.schema);if(!(Q instanceof Error))$=Q}}return X.output=$,$},{docs:"Return",cost:0.1}),p5=S("try",A.object({try:A.array(A.any),catch:A.array(A.any).optional,catchParam:A.string.optional}),void 0,async(Z,X)=>{if(await J1.exec({op:"seq",steps:Z.try},X),X.error&&Z.catch){let $=Z.catchParam||"error";X.state[$]=X.error.message,X.state.errorOp=X.error.op,X.error=void 0,await J1.exec({op:"seq",steps:Z.catch},X)}},{docs:"Try/Catch",timeoutMs:0,cost:0.1}),n5=S("Error",A.object({args:A.array(A.any).optional}),void 0,async(Z,X)=>{let $=Z.args?.[0]??"Error";X.error=new H1(String($),"Error")},{docs:"Trigger error flow",cost:0.1}),c5=S("varSet",A.object({key:A.string,value:A.any}),void 0,async({key:Z,value:X},$)=>{if($.consts.has(Z))throw Error(`Cannot reassign const variable '${Z}'`);$.state[Z]=N(X,$)},{docs:"Set Variable",cost:0.1}),o5=S("constSet",A.object({key:A.string,value:A.any}),void 0,async({key:Z,value:X},$)=>{if($.consts.has(Z))throw Error(`Cannot reassign const variable '${Z}'`);if(Z in $.state)throw Error(`Cannot redeclare variable '${Z}' as const`);$.state[Z]=N(X,$),$.consts.add(Z)},{docs:"Set Const Variable (immutable)",cost:0.1}),s5=S("varGet",A.object({key:A.string}),A.any,async({key:Z},X)=>{return N(Z,X)},{docs:"Get Variable",cost:0.1}),a5=S("varsImport",A.object({keys:A.union([A.array(A.string),A.record(A.string)])}),void 0,async({keys:Z},X)=>{if(Array.isArray(Z))for(let $ of Z)X.state[$]=N({$kind:"arg",path:$},X);else for(let[$,Q]of Object.entries(Z))X.state[$]=N({$kind:"arg",path:Q},X)},{docs:"Import variables from args into the current scope, with optional renaming.",cost:0.2}),r5=S("varsLet",A.record(A.any),void 0,async(Z,X)=>{for(let $ of Object.keys(Z)){if($==="op"||$==="result")continue;X.state[$]=N(Z[$],X)}},{docs:"Initialize a set of variables in the current scope from the step object properties.",cost:0.1}),t5=S("varsExport",A.object({keys:A.union([A.array(A.string),A.record(A.string)])}),A.record(A.any),async({keys:Z},X)=>{let $={};if(Array.isArray(Z))for(let Q of Z)$[Q]=N(Q,X);else for(let[Q,K]of Object.entries(Z))$[Q]=N(K,X);return $},{docs:"Export variables from the current scope, with optional renaming.",cost:0.2}),e5=S("scope",A.object({steps:A.array(A.any)}),void 0,async({steps:Z},X)=>{let $=O1(X);if(await J1.exec({op:"seq",steps:Z},$),$.output!==void 0)X.output=$.output},{docs:"Create new scope",timeoutMs:0,cost:0.1}),Z$=S("map",A.object({items:A.array(A.any),as:A.string,steps:A.array(A.any)}),A.array(A.any),async({items:Z,as:X,steps:$},Q)=>{let K=[],H=N(Z,Q);if(!Array.isArray(H))throw Error("map: items is not an array");for(let Y of H){if(Q.signal?.aborted)throw Error("Execution aborted");let z=O1(Q);z.state[X]=Y,await J1.exec({op:"seq",steps:$},z),K.push(z.state.result??null)}return K},{docs:"Map Array",timeoutMs:0,cost:1}),$$=S("filter",A.object({items:A.array(A.any),as:A.string,condition:A.any}),A.array(A.any),async({items:Z,as:X,condition:$},Q)=>{let K=[],H=N(Z,Q);if(!Array.isArray(H))throw Error("filter: items is not an array");for(let Y of H){if(Q.signal?.aborted)throw Error("Execution aborted");let z=O1(Q);if(z.state[X]=Y,p($,z))K.push(Y)}return K},{docs:"Filter Array",timeoutMs:0,cost:1}),X$=S("reduce",A.object({items:A.array(A.any),as:A.string,accumulator:A.string,initial:A.any,steps:A.array(A.any)}),A.any,async({items:Z,as:X,accumulator:$,initial:Q,steps:K},H)=>{let Y=N(Z,H),z=N(Q,H);if(!Array.isArray(Y))throw Error("reduce: items is not an array");let W=z;for(let G of Y){if(H.signal?.aborted)throw Error("Execution aborted");let J=O1(H);J.state[X]=G,J.state[$]=W,await J1.exec({op:"seq",steps:K},J),W=J.state.result??W}return W},{docs:"Reduce Array",timeoutMs:0,cost:1}),Q$=S("find",A.object({items:A.array(A.any),as:A.string,condition:A.any}),A.any,async({items:Z,as:X,condition:$},Q)=>{let K=N(Z,Q);if(!Array.isArray(K))throw Error("find: items is not an array");for(let H of K){if(Q.signal?.aborted)throw Error("Execution aborted");let Y=O1(Q);if(Y.state[X]=H,p($,Y))return H}return null},{docs:"Find in Array",timeoutMs:0,cost:1}),K$=S("push",A.object({list:A.array(A.any),item:A.any}),A.array(A.any),async({list:Z,item:X},$)=>{let Q=N(Z,$),K=N(X,$);if(Array.isArray(Q))Q.push(K);return Q},{docs:"Push to Array",cost:1}),H$=S("len",A.object({list:A.any}),A.number,async({list:Z},X)=>{let $=N(Z,X);return Array.isArray($)||typeof $==="string"?$.length:0},{docs:"Length",cost:1}),Y$=S("split",A.object({str:A.string,sep:A.string}),A.array(A.string),async({str:Z,sep:X},$)=>N(Z,$).split(N(X,$)),{docs:"Split String",cost:1}),z$=S("join",A.object({list:A.array(A.string),sep:A.string}),A.string,async({list:Z,sep:X},$)=>N(Z,$).join(N(X,$)),{docs:"Join String",cost:1}),W$=S("template",A.object({tmpl:A.string,vars:A.record(A.any)}),A.string,async({tmpl:Z,vars:X},$)=>{return N(Z,$).replace(/\{\{(\w+)\}\}/g,(K,H)=>String(N(X[H],$)??""))},{docs:"String Template",cost:1}),G$=S("regexMatch",A.object({pattern:A.string,value:A.any}),A.boolean,async({pattern:Z,value:X},$)=>{if(h5(Z))throw Error(`Suspicious regex pattern rejected (potential ReDoS): ${Z}`);let Q=N(X,$);return new RegExp(Z).test(Q)},{docs:"Returns true if the value matches the regex pattern.",cost:2}),J$=S("pick",A.object({obj:A.record(A.any),keys:A.array(A.string)}),A.record(A.any),async({obj:Z,keys:X},$)=>{let Q=N(Z,$),K=N(X,$),H={};if(Q&&Array.isArray(K))K.forEach((Y)=>H[Y]=Q[Y]);return H},{docs:"Pick Keys",cost:1}),_$=S("omit",A.object({obj:A.record(A.any),keys:A.array(A.string)}),A.record(A.any),async({obj:Z,keys:X},$)=>{let Q=N(Z,$),K=new Set(N(X,$)),H={};if(Q)Object.keys(Q).forEach((Y)=>{if(!K.has(Y))H[Y]=Q[Y]});return H},{docs:"Omit Keys",cost:1}),L$=S("merge",A.object({a:A.record(A.any),b:A.record(A.any)}),A.record(A.any),async({a:Z,b:X},$)=>({...N(Z,$),...N(X,$)}),{docs:"Merge Objects",cost:1}),U$=S("keys",A.object({obj:A.record(A.any)}),A.array(A.string),async({obj:Z},X)=>Object.keys(N(Z,X)??{}),{docs:"Object Keys",cost:1}),V7=10,C7="X-Agent-Depth";function q$(Z,X){try{let Q=new URL(Z).hostname.toLowerCase();for(let K of X){let H=K.toLowerCase();if(H.startsWith("*.")){let Y=H.slice(1);if(Q.endsWith(Y)||Q===H.slice(2))return!0}else if(Q===H)return!0}return!1}catch{return!1}}var D$=S("httpFetch",A.object({url:A.string,method:A.string.optional,headers:A.record(A.string).optional,body:A.any.optional,responseType:A.string.optional}),A.any,async(Z,X)=>{let $=N(Z.url,X),Q=N(Z.method,X),K=N(Z.headers,X)||{},H=N(Z.body,X),Y=N(Z.responseType,X),z=X.context?.requestDepth??0;if(z>=V7)throw Error(`Agent request depth exceeded (max ${V7}). This prevents recursive agent loops.`);if(X.capabilities.fetch)return X.capabilities.fetch($,{method:Q,headers:{...K,[C7]:String(z+1)},body:H,signal:X.signal,responseType:Y});let W=X.context?.allowedFetchDomains;if(W){if(!q$($,W))throw Error(`Fetch blocked: domain not in allowlist. Allowed: ${W.join(", ")}`)}else{if(y5($))throw Error("Blocked URL: private/internal addresses not allowed in default fetch");try{let J=new URL($).hostname.toLowerCase();if(J!=="localhost"&&J!=="127.0.0.1"&&J!=="[::1]")throw Error("Fetch blocked: no allowedFetchDomains configured. Set ctx.context.allowedFetchDomains or provide a custom fetch capability.")}catch(G){if(G.message.includes("allowedFetchDomains"))throw G;throw Error(`Invalid URL: ${$}`)}}if(typeof globalThis.fetch==="function"){let G=await globalThis.fetch($,{method:Q,headers:{...K,[C7]:String(z+1)},body:H?JSON.stringify(H):void 0,signal:X.signal});if(Y==="dataUrl"){let L=await G.arrayBuffer(),_=new Uint8Array(L),U="";for(let M=0;M<_.length;M++)U+=String.fromCharCode(_[M]);let D=btoa(U);return`data:${G.headers.get("content-type")||"application/octet-stream"};base64,${D}`}let J=G.headers.get("content-type");if(Y==="json"||J&&J.includes("application/json"))return G.json();return G.text()}throw Error("Capability 'fetch' missing and no global fetch available")},{docs:"HTTP Fetch",timeoutMs:30000,cost:5}),A$=S("storeGet",A.object({key:A.string}),A.any,async({key:Z},X)=>{let $=N(Z,X);return X.capabilities.store?.get($)},{docs:"Store Get",cost:5}),I$=S("storeSet",A.object({key:A.string,value:A.any}),void 0,async({key:Z,value:X},$)=>{let Q=N(Z,$),K=N(X,$);return $.capabilities.store?.set(Q,K)},{docs:"Store Set",cost:5}),B$=S("storeQuery",A.object({query:A.any}),A.array(A.any),async({query:Z},X)=>X.capabilities.store?.query?.(N(Z,X))??[],{docs:"Store Query",cost:5}),R$=S("storeVectorSearch",A.object({collection:A.string.optional,vector:A.array(A.number),k:A.number.optional}),A.array(A.any),async({collection:Z,vector:X,k:$},Q)=>Q.capabilities.store?.vectorSearch?.(N(Z,Q),N(X,Q),N($,Q))??[],{docs:"Vector Search",cost:(Z,X)=>5+(N(Z.k,X)??5)}),M$=S("llmPredict",A.object({prompt:A.string,options:A.any.optional}),A.string,async({prompt:Z,options:X},$)=>{if(!$.capabilities.llm?.predict)throw Error("Capability 'llm.predict' missing");return $.capabilities.llm.predict(N(Z,$),N(X,$))},{docs:"LLM Predict",timeoutMs:120000,cost:100}),w$=S("agentRun",A.object({agentId:A.any,input:A.any}),A.any,async({agentId:Z,input:X},$)=>{let Q=N(Z,$),K=N(X,$),H=K;if(K&&typeof K==="object"&&!Array.isArray(K)){H={};for(let z in K)H[z]=N(K[z],$)}if(e4(Q)){let z=Z6(Q),W={...$,args:H,state:{},consts:new Set,output:void 0,error:void 0},G=$.resolver("seq");if(!G)throw Error("seq atom not found");if(await G.exec(z,W),W.error)throw Error(W.error.message||"Sub-agent failed");return W.output}if(Q&&typeof Q==="object"&&"op"in Q){let z={...$,args:H,state:{},consts:new Set,output:void 0,error:void 0},W=$.resolver("seq");if(!W)throw Error("seq atom not found");if(await W.exec(Q,z),z.error)throw Error(z.error.message||"Sub-agent failed");return z.output}if(!$.capabilities.agent?.run)throw Error("Capability 'agent.run' missing");let Y=await $.capabilities.agent.run(Q,H);if(Y&&typeof Y==="object"&&"fuelUsed"in Y&&typeof Y.fuelUsed==="number"){if(Y.error)throw Error(Y.error.message||"Sub-agent failed");return Y.result}return Y},{docs:"Run Sub-Agent (accepts procedure token, AST, or agent ID)",cost:1}),F$=S("transpileCode",A.object({code:A.string}),A.any,async({code:Z},X)=>{if(!X.capabilities.code?.transpile)throw Error("Capability 'code.transpile' missing. Enable code transpilation by providing the code capability.");let $=N(Z,X);try{return X.capabilities.code.transpile($)}catch(Q){throw Error(`Code transpilation failed: ${Q.message}`)}},{docs:"Transpile AsyncJS code to AST",cost:1}),O7=10,j$=S("runCode",A.object({code:A.string,args:A.record(A.any).optional}),A.any,async({code:Z,args:X},$)=>{let Q=$.runCodeDepth??0;if(Q>=O7)throw Error(`runCode recursion limit exceeded (max ${O7}). This prevents infinite loops from dynamically generated code calling runCode.`);if(!$.capabilities.code?.transpile)throw Error("Capability 'code.transpile' missing. Enable dynamic code execution by providing the code capability.");let K=N(Z,$),H=X?N(X,$):{},Y;try{Y=$.capabilities.code.transpile(K)}catch(W){throw Error(`Code transpilation failed: ${W.message}`)}if(Y.op!=="seq")throw Error("Transpiled code must be a seq node");let z=O1($);if(z.args=H,z.output=void 0,z.runCodeDepth=Q+1,await J1.exec(Y,z),z.error){$.error=z.error;return}return z.output},{docs:"Run dynamically generated AsyncJS code",cost:1}),P$=S("jsonParse",A.object({str:A.string}),A.any,async({str:Z},X)=>JSON.parse(N(Z,X)),{docs:"Parse JSON",cost:1}),V$=S("jsonStringify",A.object({value:A.any}),A.string,async({value:Z},X)=>JSON.stringify(N(Z,X)),{docs:"Stringify JSON",cost:1}),C$=S("xmlParse",A.object({str:A.string}),A.any,async({str:Z},X)=>{if(!X.capabilities.xml?.parse)throw Error("Capability 'xml.parse' missing");return X.capabilities.xml.parse(N(Z,X))},{docs:"Parse XML",cost:1}),O$=S("memoize",A.object({key:A.string.optional,steps:A.array(A.any)}),A.any,async({key:Z,steps:X},$)=>{if(!$.memo)$.memo=new Map;let Q=N(Z,$)??await $6.exec({value:X,algorithm:"SHA-256"},$);if($.memo.has(Q))return $.memo.get(Q);let K=O1($);await J1.exec({op:"seq",steps:X},K);let H=K.output??K.state.result;return $.memo.set(Q,H),H},{docs:"Memoize steps result in memory",cost:1}),N$=S("cache",A.object({key:A.string.optional,steps:A.array(A.any),ttlMs:A.number.optional}),A.any,async({key:Z,steps:X,ttlMs:$},Q)=>{if(!Q.capabilities.store)throw Error("Capability 'store' missing for caching");let H=`cache:${N(Z,Q)??await $6.exec({value:X,algorithm:"SHA-256"},Q)}`,Y=await Q.capabilities.store.get(H);if(Y)if(typeof Y==="object"&&Y._exp){if(Date.now()<Y._exp)return Y.val}else return Y;let z=O1(Q);await J1.exec({op:"seq",steps:X},z);let W=z.output??z.state.result,G=Date.now()+($??86400000);if((Q.fuel.current-=5)<=0)throw Error("Out of Fuel");return await Q.capabilities.store.set(H,{val:W,_exp:G}),W},{docs:"Cache steps result in store with TTL",cost:5}),E$=S("random",A.object({min:A.number.optional,max:A.number.optional,format:A.string.optional,length:A.number.optional}),A.any,async({min:Z,max:X,format:$,length:Q},K)=>{let H=N($,K)??"float",Y=N(Q,K)??10,z=N(Z,K)??0,W=N(X,K)??1;if(H==="base36"){let U="";if(typeof crypto<"u"&&crypto.getRandomValues){let D=new Uint8Array(Y);crypto.getRandomValues(D);for(let R=0;R<Y;R++)U+="0123456789abcdefghijklmnopqrstuvwxyz"[D[R]%36]}else for(let D=0;D<Y;D++)U+="0123456789abcdefghijklmnopqrstuvwxyz".charAt(Math.floor(Math.random()*36));return U}let G;if(typeof crypto<"u"&&crypto.getRandomValues){let _=new Uint32Array(1);crypto.getRandomValues(_),G=_[0]/4294967296}else G=Math.random();let J=W-z,L=G*J+z;if(H==="integer")return Math.floor(L);return L},{docs:"Generate Random",cost:1}),T$=S("uuid",void 0,A.string,async()=>{if(typeof crypto<"u"&&crypto.randomUUID)return crypto.randomUUID();if(typeof crypto<"u"&&crypto.getRandomValues){let Z=new Uint8Array(16);crypto.getRandomValues(Z),Z[6]=Z[6]&15|64,Z[8]=Z[8]&63|128;let X=Array.from(Z,($)=>$.toString(16).padStart(2,"0")).join("");return`${X.slice(0,8)}-${X.slice(8,12)}-${X.slice(12,16)}-${X.slice(16,20)}-${X.slice(20)}`}return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,(Z)=>{let X=Math.random()*16|0;return(Z==="x"?X:X&3|8).toString(16)})},{docs:"Generate UUID",cost:1}),$6=S("hash",A.object({value:A.any,algorithm:A.string.optional}),A.string,async({value:Z,algorithm:X},$)=>{let Q=typeof Z==="string"?Z:JSON.stringify(N(Z,$)),K=N(X,$)||"SHA-256";if(typeof crypto<"u"&&crypto.subtle){let z=new TextEncoder().encode(Q),W=await crypto.subtle.digest(K,z);return Array.from(new Uint8Array(W)).map((J)=>J.toString(16).padStart(2,"0")).join("")}let H=0;for(let Y=0;Y<Q.length;Y++){let z=Q.charCodeAt(Y);H=(H<<5)-H+z,H|=0}return String(H)},{docs:"Hash a value",cost:1}),S$=S("consoleLog",A.object({message:A.any}),void 0,async({message:Z},X)=>{let $=N(Z,X);if(X.trace)X.trace.push({op:"console.log",input:{message:$},stateDiff:{},result:$,fuelBefore:X.fuel.current,fuelAfter:X.fuel.current,timestamp:new Date().toISOString()})},{docs:"Log to trace",cost:0.1}),k$=S("consoleWarn",A.object({message:A.any}),void 0,async({message:Z},X)=>{let $=N(Z,X),Q=typeof $==="string"?$:JSON.stringify($);if(!X.warnings)X.warnings=[];if(X.warnings.push(Q),X.trace)X.trace.push({op:"console.warn",input:{message:$},stateDiff:{},result:$,fuelBefore:X.fuel.current,fuelAfter:X.fuel.current,timestamp:new Date().toISOString()})},{docs:"Add warning",cost:0.1}),g$=S("consoleError",A.object({message:A.any}),void 0,async({message:Z},X)=>{let $=N(Z,X),Q=typeof $==="string"?$:JSON.stringify($);X.error=new H1(Q,"console.error")},{docs:"Emit error and stop",cost:0.1}),b$=S("storeProcedure",A.object({ast:A.any,ttl:A.number.optional,maxSize:A.number.optional}),A.string,async({ast:Z,ttl:X,maxSize:$},Q)=>{let K=N(Z,Q),H=X?N(X,Q):g5,Y=$?N($,Q):b5;if(!K||typeof K!=="object"||!K.op)throw Error('Invalid AST: must be an object with an "op" property');let z=JSON.stringify(K);if(z.length>Y)throw Error(`AST too large: ${z.length} bytes exceeds limit of ${Y} bytes. Consider reducing AST size or using a shorter TTL.`);let W=v5(),G=Date.now();return o1.set(W,{ast:K,createdAt:G,expiresAt:G+H}),W},{docs:"Store an AST and return a token for later execution",cost:1}),v$=S("releaseProcedure",A.object({token:A.string}),A.boolean,async({token:Z},X)=>{let $=N(Z,X);return o1.delete($)},{docs:"Release a stored procedure by token",cost:0.1}),f$=S("clearExpiredProcedures",void 0,A.number,async()=>{let Z=Date.now(),X=0;for(let[$,Q]of o1)if(Z>Q.expiresAt)o1.delete($),X++;return X},{docs:"Clear all expired procedures and return count",cost:0.5}),L4={seq:J1,if:l5,while:m5,return:i5,try:p5,Error:n5,varSet:c5,constSet:o5,varGet:s5,varsImport:a5,varsLet:r5,varsExport:t5,scope:e5,map:Z$,filter:$$,reduce:X$,find:Q$,push:K$,len:H$,split:Y$,join:z$,template:W$,regexMatch:G$,pick:J$,omit:_$,merge:L$,keys:U$,httpFetch:D$,storeGet:A$,storeSet:I$,storeQuery:B$,storeVectorSearch:R$,llmPredict:M$,agentRun:w$,transpileCode:F$,runCode:j$,jsonParse:P$,jsonStringify:V$,xmlParse:C$,memoize:O$,cache:N$,random:E$,uuid:T$,hash:$6,consoleLog:S$,consoleWarn:k$,consoleError:g$,storeProcedure:b$,releaseProcedure:v$,clearExpiredProcedures:f$};var y$=new Set(["true","false","null","undefined","and","or","not"]);function h$(Z,X){let $=Z.replace(/"[^"]*"/g,'""').replace(/'[^']*'/g,"''"),Q=[],K=/(?<![.])\b([a-zA-Z_][a-zA-Z0-9_]*)\b/g,H;while((H=K.exec($))!==null)Q.push(H[1]);let z=[...new Set(Q)].filter((W)=>!y$.has(W)&&!(W in X)&&!new RegExp(`\\b${W}\\s*\\(`).test($));if(z.length>0)console.warn(`[Agent99 Builder] Condition "${Z}" references variables not in vars mapping: ${z.join(", ")}. Add them to vars or use AsyncJS syntax (ajs\`...\`) which handles this automatically.`)}function U4(Z,X){h$(Z,X);let $=x$(Z),Q=b7($,0,X);if(Q.pos<$.length){let K=$.slice(Q.pos).join(" ");throw Error(`Unsupported condition syntax near '${K}' in: ${Z}
|
|
410
|
+
Supported: comparisons, &&, ||, !, arithmetic, member access (a.b), literals`)}return Q.node}function x$(Z){let X=[],$=0;while($<Z.length){while($<Z.length&&/\s/.test(Z[$]))$++;if($>=Z.length)break;if(Z[$]==='"'||Z[$]==="'"){let Q=Z[$++],K="";while($<Z.length&&Z[$]!==Q)if(Z[$]==="\\"&&$+1<Z.length)$++,K+=Z[$++];else K+=Z[$++];$++,X.push(JSON.stringify(K));continue}if(Z.slice($,$+2).match(/^(&&|\|\||==|!=|>=|<=)$/)){X.push(Z.slice($,$+2)),$+=2;continue}if("+-*/%><!().?:[]".includes(Z[$])){X.push(Z[$]),$++;continue}if(/\d/.test(Z[$])){let Q="";while($<Z.length&&/[\d.]/.test(Z[$]))Q+=Z[$++];X.push(Q);continue}if(/[a-zA-Z_]/.test(Z[$])){let Q="";while($<Z.length&&/[a-zA-Z0-9_]/.test(Z[$]))Q+=Z[$++];X.push(Q);continue}$++}return X}function b7(Z,X,$){return u$(Z,X,$)}function u$(Z,X,$){let{node:Q,pos:K}=T7(Z,X,$);while(Z[K]==="||"){K++;let{node:H,pos:Y}=T7(Z,K,$);Q={$expr:"logical",op:"||",left:Q,right:H},K=Y}return{node:Q,pos:K}}function T7(Z,X,$){let{node:Q,pos:K}=S7(Z,X,$);while(Z[K]==="&&"){K++;let{node:H,pos:Y}=S7(Z,K,$);Q={$expr:"logical",op:"&&",left:Q,right:H},K=Y}return{node:Q,pos:K}}function S7(Z,X,$){let{node:Q,pos:K}=k7(Z,X,$),H=["==","!=",">","<",">=","<="];while(H.includes(Z[K])){let Y=Z[K++],{node:z,pos:W}=k7(Z,K,$);Q={$expr:"binary",op:Y,left:Q,right:z},K=W}return{node:Q,pos:K}}function k7(Z,X,$){let{node:Q,pos:K}=g7(Z,X,$);while(Z[K]==="+"||Z[K]==="-"){let H=Z[K++],{node:Y,pos:z}=g7(Z,K,$);Q={$expr:"binary",op:H,left:Q,right:Y},K=z}return{node:Q,pos:K}}function g7(Z,X,$){let{node:Q,pos:K}=X6(Z,X,$);while(Z[K]==="*"||Z[K]==="/"||Z[K]==="%"){let H=Z[K++],{node:Y,pos:z}=X6(Z,K,$);Q={$expr:"binary",op:H,left:Q,right:Y},K=z}return{node:Q,pos:K}}function X6(Z,X,$){if(Z[X]==="!"||Z[X]==="-"){let Q=Z[X++],{node:K,pos:H}=X6(Z,X,$);return{node:{$expr:"unary",op:Q,argument:K},pos:H}}return d$(Z,X,$)}function d$(Z,X,$){let Q=Z[X];if(Q==="("){let{node:K,pos:H}=b7(Z,X+1,$);return{node:K,pos:H+1}}if(Q&&Q.startsWith('"'))return{node:{$expr:"literal",value:JSON.parse(Q)},pos:X+1};if(Q&&/^\d/.test(Q))return{node:{$expr:"literal",value:parseFloat(Q)},pos:X+1};if(Q==="true")return{node:{$expr:"literal",value:!0},pos:X+1};if(Q==="false")return{node:{$expr:"literal",value:!1},pos:X+1};if(Q==="null")return{node:{$expr:"literal",value:null},pos:X+1};if(Q&&/^[a-zA-Z_]/.test(Q)){let K={$expr:"ident",name:Q},H=X+1;while(Z[H]==="."){H++;let Y=Z[H++];K={$expr:"member",object:K,property:Y}}return{node:K,pos:H}}return{node:{$expr:"literal",value:null},pos:X+1}}class e{steps=[];atoms;proxy;constructor(Z){return this.atoms=Z,this.proxy=new Proxy(this,{get:(X,$,Q)=>{if($ in X)return X[$];if(typeof $==="string"&&$ in X.atoms)return(K)=>{let H=X.atoms[$];return X.add(H.create(K)),Q};return}}),this.proxy}add(Z){return this.steps.push(Z),this.proxy}as(Z){if(this.steps.length===0)throw Error("No step to capture");let X=this.steps[this.steps.length-1];return X.result=Z,this.proxy}step(Z){return this.add(Z)}return(Z){let X=this.atoms.return;if(!X)throw Error("Atom 'return' not found");let $=Z.schema??Z;return this.add(X.create({schema:$}))}toJSON(){return{op:"seq",steps:[...this.steps]}}varsImport(Z){return this.add(this.atoms.varsImport.create({keys:Z}))}varsExport(Z){return this.add(this.atoms.varsExport.create({keys:Z}))}if(Z,X,$,Q){let K=new e(this.atoms);$(K);let H;if(Q){let W=new e(this.atoms);Q(W),H=W.steps}let Y=U4(Z,X),z=this.atoms.if;return this.add(z.create({condition:Y,then:K.steps,else:H}))}while(Z,X,$){let Q=new e(this.atoms);$(Q);let K=U4(Z,X),H=this.atoms.while;return this.add(H.create({condition:K,body:Q.steps}))}scope(Z){let X=new e(this.atoms);Z(X);let $=this.atoms.scope;return this.add($.create({steps:X.steps}))}map(Z,X,$){let Q=new e(this.atoms);$(Q);let K=this.atoms.map;return this.add(K.create({items:Z,as:X,steps:Q.steps}))}filter(Z,X,$,Q={}){let K=U4($,Q),H=this.atoms.filter;return this.add(H.create({items:Z,as:X,condition:K}))}find(Z,X,$,Q={}){let K=U4($,Q),H=this.atoms.find;return this.add(H.create({items:Z,as:X,condition:K}))}reduce(Z,X,$,Q,K){let H=new e(this.atoms);K(H);let Y=this.atoms.reduce;return this.add(Y.create({items:Z,as:X,accumulator:$,initial:Q,steps:H.steps}))}memoize(Z,X){let $=new e(this.atoms);Z($);let Q=this.atoms.memoize;return this.add(Q.create({key:X,steps:$.steps}))}cache(Z,X,$){let Q=new e(this.atoms);Z(Q);let K=this.atoms.cache;return this.add(K.create({key:X,steps:Q.steps,ttlMs:$}))}try(Z){let X=new e(this.atoms);Z.try(X);let $;if(Z.catch){let K=new e(this.atoms);Z.catch(K),$=K.steps}let Q=this.atoms.try;return this.add(Q.create({try:X.steps,catch:$}))}}var l$={take(Z){return new e(L4)},custom(Z){return new e(Z)},args(Z){return{$kind:"arg",path:Z}},val(Z){return Z}},BK=l$;import{validate as m$}from"tosijs-schema";function A0(Z,X={}){let{ast:$,returnType:Q,originalSource:K,requiredParams:H}=M1(Z,{filename:X.filename,colonShorthand:!0,vmTarget:!0}),Y=T0($,X.filename),{ast:z,signature:W,warnings:G}=H0(Y,K,Q,X,H);return{ast:z,signature:W,warnings:G}}var i$=10;class Q6{atoms;constructor(Z={}){this.atoms={...L4,...Z}}get builder(){return new e(this.atoms)}get Agent(){return new e(this.atoms)}get A99(){return this.Agent}resolve(Z){return this.atoms[Z]}getTools(Z="all"){let X=Object.values(this.atoms);if(Array.isArray(Z))X=X.filter(($)=>Z.includes($.op));else if(Z==="flow"){let $=["seq","if","while","return","try","varSet","varGet","scope"];X=X.filter((Q)=>$.includes(Q.op))}return X.map(($)=>({type:"function",function:{name:$.op,description:$.docs,parameters:$.inputSchema?.schema??{}}}))}async run(Z,X={},$={}){let Q;if(typeof Z==="string")if(e4(Z))Q=Z6(Z);else try{Q=A0(Z).ast}catch(U){throw Error(`AJS transpilation failed: ${U.message}`)}else Q=Z;let K=$.fuel??1000,H=$.timeoutMs??K*i$,Y=$.capabilities??{},z=[];if(!Y.store){let U=new Map,D=!1;Y.store={get:async(R)=>{if(!D)D=!0,z.push("Using default in-memory store (not suitable for production)");return U.get(R)},set:async(R,M)=>{if(!D)D=!0,z.push("Using default in-memory store (not suitable for production)");U.set(R,M)}}}let W=new AbortController,G=setTimeout(()=>W.abort(),H);if($.signal)$.signal.addEventListener("abort",()=>W.abort());let J={fuel:{current:K},args:X,state:{},consts:new Set,capabilities:Y,resolver:(U)=>this.resolve(U),output:void 0,signal:W.signal,costOverrides:$.costOverrides,context:$.context,warnings:z};if($.trace)J.trace=[];if(Q.op!=="seq")throw Error("Root AST must be 'seq'. Ensure you're passing a transpiled agent (use ajs`...` or transpile()).");let L=Q.inputSchema;if(L&&!m$(X,L)){let U=new H1("Input validation failed: args do not match expected schema","vm.run");return{result:U,error:U,fuelUsed:0,trace:J.trace,warnings:z.length>0?z:void 0}}try{await Promise.race([this.resolve("seq")?.exec(Q,J),new Promise((U,D)=>{if(W.signal.addEventListener("abort",()=>{D(Error(`Execution timeout after ${H}ms (fuel: ${K}). Consider increasing fuel or optimizing your agent.`))}),W.signal.aborted)D(Error(`Execution timeout after ${H}ms (fuel: ${K}). Consider increasing fuel or optimizing your agent.`))})])}catch(U){if(U.message?.includes("timeout")||U.message?.includes("aborted")||W.signal.aborted)J.error=new H1(`Execution timeout after ${H}ms (fuel: ${K}). Consider increasing fuel or optimizing your agent.`,"vm.run");else throw U}finally{clearTimeout(G)}if(J.error&&J.output===void 0)J.output=J.error;let _=[...z,...J.warnings??[]];return{result:J.output,error:J.error,fuelUsed:K-J.fuel.current,trace:J.trace,warnings:_.length>0?_:void 0}}}var p$=null,v7=()=>p$??=new Q6;function x1(Z){if(!Z||typeof Z!=="object")return;if(Array.isArray(Z)){for(let X of Z)x1(X);return}if(Z.op==="return"&&"value"in Z)Z.value={__result:Z.value};if(Z.steps)x1(Z.steps);if(Z.then)x1(Z.then);if(Z.else)x1(Z.else);if(Z.body)x1(Z.body)}async function n$(Z){let{code:X,context:$={},fuel:Q=1000,timeoutMs:K,capabilities:H={}}=Z,Y=v7(),W=/\breturn\b/.test(X)?`function __eval() { ${X} }`:`function __eval() { return (${X}) }`;try{let{ast:G}=A0(W);x1(G);let J=await Y.run(G,$,{fuel:Q,timeoutMs:K,capabilities:H}),L=J.result;return{result:L&&typeof L==="object"&&"__result"in L?L.__result:L,fuelUsed:J.fuelUsed,error:J.error?{message:J.error.message||String(J.error)}:void 0}}catch(G){return{result:void 0,fuelUsed:Q,error:{message:G.message||String(G)}}}}async function c$(Z){let{body:X,params:$=[],fuel:Q=1000,timeoutMs:K,capabilities:H={}}=Z,Y=v7(),W=`function __safeFn(${$.join(", ")}) { ${X} }`,{ast:G}=A0(W);return x1(G),async(...J)=>{let L={};for(let _=0;_<$.length;_++)L[$[_]]=J[_];try{let _=await Y.run(G,L,{fuel:Q,timeoutMs:K,capabilities:H}),U=_.result;return{result:U&&typeof U==="object"&&"__result"in U?U.__result:U,fuelUsed:_.fuelUsed,error:_.error?{message:_.error.message||String(_.error)}:void 0}}catch(_){return{result:void 0,fuelUsed:Q,error:{message:_.message||String(_)}}}}}function D4(Z,X={}){let{ast:$,returnType:Q,originalSource:K,requiredParams:H}=M1(Z,{filename:X.filename,colonShorthand:!0,vmTarget:!0}),Y=T0($,X.filename),{ast:z,signature:W,warnings:G}=H0(Y,K,Q,X,H);return{ast:z,signature:W,warnings:G}}function fK(Z,...X){if(typeof Z==="string")return D4(Z).ast;let $=Z.reduce((Q,K,H)=>Q+K+(X[H]!==void 0?String(X[H]):""),"");return D4($).ast}function hK(Z,X,...$){if(typeof Z==="string")return L0(Z,X);let Q=X!==void 0?[X,...$]:$,K=Z.reduce((H,Y,z)=>H+Y+(Q[z]!==void 0?String(Q[z]):""),"");return L0(K)}async function xK(Z,X={},$){let Q=$??await z4(),K=await Q.getTranspile(Z);if(K)return{ast:K.ast,signature:K.signature,warnings:K.warnings};let H=D4(Z,X);return Q.setTranspile(Z,{ast:H.ast,signature:H.signature,warnings:H.warnings}),H}async function uK(Z,X={},$){let Q=$??await z4(),K=await Q.getTJS(Z);if(K)return{code:K.code,types:K.types,metadata:K.types,testRunner:K.testRunner,testCount:K.testCount,warnings:K.warnings};let H=L0(Z,X);return Q.setTJS(Z,{code:H.code,types:H.types,testRunner:H.testRunner,testCount:H.testCount,warnings:H.warnings}),H}function dK(Z,X,$){let{ast:Q,signature:K}=D4(Z),H=async(Y)=>{return(await X.run(Q,Y,$)).result};return H.signature=K,H.ast=Q,H}function lK(Z){return Object.entries(Z).map(([X,$])=>{let Q=$.signature,K={},H=[];for(let[Y,z]of Object.entries(Q.parameters)){if(K[Y]=q4(z.type),z.description)K[Y].description=z.description;if(z.required)H.push(Y)}return{type:"function",function:{name:Q.name||X,description:Q.description,parameters:{type:"object",properties:K,required:H}}}})}function q4(Z){switch(Z.kind){case"string":return{type:"string"};case"number":return{type:"number"};case"boolean":return{type:"boolean"};case"null":return{type:"null"};case"array":return{type:"array",items:Z.items?q4(Z.items):{}};case"object":if(!Z.shape)return{type:"object"};return{type:"object",properties:Object.fromEntries(Object.entries(Z.shape).map(([X,$])=>[X,q4($)]))};case"union":if(!Z.members)return{};return{anyOf:Z.members.map(q4)};case"any":default:return{}}}import{s as b}from"tosijs-schema";var f7=S("storeVectorize",b.object({text:b.string,model:b.string.optional}),b.array(b.number),async({text:Z},X)=>{let $=X.capabilities.vector;if(!$)throw Error("Capability 'vector' missing. Ensure vector battery is loaded.");let Q=N(Z,X);return $.embed(Q)},{docs:"Generate embeddings using vector battery",cost:20}),y7=S("storeCreateCollection",b.object({collection:b.string,dimension:b.number.optional}),void 0,async({collection:Z,dimension:X},$)=>{let Q=$.capabilities.store;if(!Q?.createCollection)throw Error("Capability 'store' missing or does not support createCollection.");let K=N(Z,$),H=N(X,$);return Q.createCollection(K,void 0,H)},{docs:"Create a vector store collection",cost:5}),h7=S("storeVectorAdd",b.object({collection:b.string,doc:b.any}),void 0,async({collection:Z,doc:X},$)=>{let Q=$.capabilities.store;if(!Q?.vectorAdd)throw Error("Capability 'store' missing or does not support vectorAdd.");let K=N(Z,$),H=N(X,$);return Q.vectorAdd(K,H)},{docs:"Add a document to a vector store collection",cost:5}),x7=S("storeSearch",b.object({collection:b.string,queryVector:b.array(b.number),k:b.number.optional,filter:b.record(b.any).optional}),b.array(b.any),async({collection:Z,queryVector:X,k:$,filter:Q},K)=>{let H=K.capabilities.store;if(!H?.vectorSearch)throw Error("Capability 'store' missing or does not support vectorSearch.");let Y=N(Z,K),z=N(X,K),W=N($,K)??5,G=N(Q,K);return H.vectorSearch(Y,z,W,G)},{docs:"Search vector store",cost:(Z,X)=>5+(N(Z.k,X)??5)}),u7=S("llmPredictBattery",b.object({system:b.string.optional,user:b.string,tools:b.array(b.any).optional,responseFormat:b.any.optional}),b.object({role:b.string.optional,content:b.string.optional,tool_calls:b.array(b.any).optional}),async({system:Z,user:X,tools:$,responseFormat:Q},K)=>{let H=K.capabilities.llmBattery;if(!H?.predict)throw Error("Capability 'llmBattery' missing or invalid.");let Y=N(Z,K)??"You are a helpful agent.",z=N(X,K),W=N($,K),G=N(Q,K);return H.predict(Y,z,W,G)},{docs:"Generate completion using LLM battery",cost:100}),d7=S("llmVision",b.object({system:b.string.optional,prompt:b.string,images:b.array(b.string),responseFormat:b.any.optional}),b.object({role:b.string.optional,content:b.string.optional,tool_calls:b.array(b.any).optional}),async({system:Z,prompt:X,images:$,responseFormat:Q},K)=>{let H=K.capabilities.llmBattery;if(!H?.predict)throw Error("Capability 'llmBattery' missing or invalid.");let Y=N(Z,K)??"You analyze images accurately and concisely.",z=N(X,K),W=N($,K)??[],G=N(Q,K);return H.predict(Y,{text:z,images:W},void 0,G)},{docs:"Analyze images using a vision model",timeoutMs:120000,cost:150});var JH={storeCreateCollection:y7,storeSearch:x7,storeVectorAdd:h7,storeVectorize:f7,llmPredictBattery:u7,llmVision:d7};var l7=new Map,A4=new Map;function o$(Z,X){if(Z.length!==X.length)throw Error("Vectors must have the same length for cosine similarity.");let $=0,Q=0,K=0;for(let H=0;H<Z.length;H++)$+=Z[H]*X[H],Q+=Z[H]*Z[H],K+=X[H]*X[H];if(Q=Math.sqrt(Q),K=Math.sqrt(K),Q===0||K===0)return 0;return $/(Q*K)}function K6(){return{async get(Z){return l7.get(Z)},async set(Z,X){l7.set(Z,X)},async createCollection(Z,X,$){if(A4.has(Z))console.warn(`Collection '${Z}' already exists. Overwriting.`);A4.set(Z,[])},async vectorAdd(Z,X){let $=A4.get(Z);if(!$)throw Error(`Collection '${Z}' not found. Create it first.`);if(!X.embedding||!Array.isArray(X.embedding))throw Error("Document must have an 'embedding' property that is an array of numbers.");$.push(X)},async vectorSearch(Z,X,$=5){let Q=A4.get(Z);if(!Q)throw Error(`Collection '${Z}' not found. Create it first.`);let K=Q.map((H)=>({doc:H,score:o$(X,H.embedding)}));return K.sort((H,Y)=>Y.score-H.score),K.slice(0,$).map((H)=>H.doc)}}}function s$(Z){if(typeof Z==="string")return{role:"user",content:Z};let X=[{type:"text",text:Z.text}];for(let $ of Z.images||[])X.push({type:"image_url",image_url:{url:$}});return{role:"user",content:X}}var a$="http://localhost:1234/v1";function m7(Z,X=a$){return{async predict($,Q,K,H){try{let Y=H?Z.getStructuredLLM():Z.getLLM(),z=[{role:"system",content:$},s$(Q)],W=await fetch(`${X}/chat/completions`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:Y.id,messages:z,temperature:0.7,tools:K,response_format:H})});if(!W.ok)throw Error(`LLM Error: ${W.status} ${W.statusText}`);return(await W.json()).choices[0]?.message??{content:""}}catch(Y){if(Y.cause?.code==="ECONNREFUSED")throw Error("No LLM provider configured. Please start LM Studio or provide an API key.");throw Y}},async embed($){try{let Q=Z.getEmbedding(),K=await fetch(`${X}/embeddings`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:Q.id,input:$})});if(!K.ok)throw Error(`Embedding Error: ${K.status}`);return(await K.json()).data[0]?.embedding??[]}catch(Q){if(Q.cause?.code==="ECONNREFUSED")throw Error("No LLM provider configured. Please start LM Studio or provide an API key.");throw Q}}}}var I0=typeof window<"u"&&typeof window.localStorage<"u";async function e$(Z){try{if(I0){let X=window.localStorage.getItem(".models.cache.json");if(!X)return null;let $=JSON.parse(X);if($.baseUrl!==Z)return null;if(Date.now()-$.timestamp>86400000)return null;return $.models}else{let X=await import("node:fs/promises"),Q=(await Promise.resolve().then(() => (z6(),Y6))).join(process.cwd(),".models.cache.json");try{let K=await X.readFile(Q,"utf-8"),H=JSON.parse(K);if(H.baseUrl!==Z)return null;if(Date.now()-H.timestamp>86400000)return null;return H.models}catch{return null}}}catch(X){return console.warn("⚠️ Error reading model cache:",X),null}}async function ZX(Z,X){let $={timestamp:Date.now(),baseUrl:Z,models:X};try{if(I0)window.localStorage.setItem(".models.cache.json",JSON.stringify($));else{let Q=await import("node:fs/promises"),H=(await Promise.resolve().then(() => (z6(),Y6))).join(process.cwd(),".models.cache.json");await Q.writeFile(H,JSON.stringify($,null,2))}}catch(Q){console.error("❌ Error writing model cache:",Q)}}var B0=async(Z,X)=>{let $=new AbortController,Q=setTimeout(()=>$.abort(),60000);try{let K=await fetch(Z,{...X,signal:$.signal});return clearTimeout(Q),K}catch(K){throw clearTimeout(Q),K}};async function $X(Z,X){try{let $={type:"json_schema",json_schema:{name:"test",strict:!1,schema:{type:"object",properties:{status:{type:"string"}}}}},Q=await B0(`${Z}/chat/completions`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:X,messages:[{role:"system",content:"You respond in JSON."},{role:"user",content:'Return JSON: {"status": "ok"}'}],response_format:$,max_tokens:20})});if(!Q.ok){if(Q.status===400)return XX(Z,X);return{ok:!1,msg:`HTTP ${Q.status}`}}let K=await Q.json();return JSON.parse(K.choices[0].message.content),{ok:!0,msg:"OK (Schema)"}}catch($){return{ok:!1,msg:$.message||"Error"}}}async function XX(Z,X){try{if((await B0(`${Z}/chat/completions`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:X,messages:[{role:"user",content:'JSON: {"a":1}'}],response_format:{type:"json_object"},max_tokens:10})})).ok)return{ok:!0,msg:"OK (Legacy Mode)"};return{ok:!1,msg:"Not Supported"}}catch{return{ok:!1,msg:"Legacy Fail"}}}async function QX(Z,X){try{return(await B0(`${Z}/chat/completions`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:X,messages:[{role:"user",content:"hi"}],max_tokens:1})})).ok}catch{return!1}}async function KX(Z,X){try{let $=await B0(`${Z}/embeddings`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:X,input:"test"})});if(!$.ok)return null;return(await $.json()).data[0]?.embedding?.length??null}catch{return null}}var HX="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAADUlEQVR42mP8z8DwHwAFBQIAX8jx0gAAAABJRU5ErkJggg==";async function YX(Z,X){try{return(await B0(`${Z}/chat/completions`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:X,messages:[{role:"user",content:[{type:"text",text:"What color is this?"},{type:"image_url",image_url:{url:HX}}]}],max_tokens:10})})).ok}catch{return!1}}async function Q8(Z){let X=await e$(Z),$=[];try{let Y=await fetch(`${Z}/models`);if(!Y.ok)throw Error("Could not connect");$=(await Y.json()).data.map((W)=>W.id).sort()}catch(Y){if(X)return console.log("⚠️ LM Studio unavailable, using cached model audit."),X;return console.error("❌ Failed to connect to LM Studio."),[]}if(X){let Y=X.map((z)=>z.id).sort();if(JSON.stringify($)===JSON.stringify(Y))return console.log("✅ Using cached model audit."),X;console.log("\uD83D\uDD0D Model list changed. Re-running audit...")}console.log("\uD83D\uDD0D Scanning models (this may take a moment)...");let Q=[],K=$.map((Y)=>({id:Y})),H;if(!I0)H=await import("node:readline");for(let Y of K){if(!I0&&H)H.cursorTo(process.stdout,0),process.stdout.write(`\uD83D\uDC49 Testing: ${Y.id}...`),H.clearLine(process.stdout,1);let z="Unknown",W=!1,G=!1,J="",L=void 0,_=await QX(Z,Y.id),U=await KX(Z,Y.id);if(U)L=U;if(_){z="LLM";let D=await $X(Z,Y.id);if(W=D.ok,G=await YX(Z,Y.id),J=W?D.msg:`Fail: ${D.msg}`,G)J+=" +Vision"}else if(U)z="Embedding",J=`OK (Dim: ${U})`;else J="LLM Fail";Q.push({id:Y.id,type:z,structuredOutput:W,vision:G,dimension:L,status:J})}if(!I0&&H)H.cursorTo(process.stdout,0),H.clearLine(process.stdout,0);return console.log(`
|
|
411
|
+
`),console.table(Q),await ZX(Z,Q),console.log("\uD83D\uDCDD Audit results saved to cache."),Q}var zX="http://localhost:1234/v1";class W6{baseUrl;models=[];defaultLLM=null;defaultEmbedding=null;defaultStructuredLLM=null;constructor(Z=zX){this.baseUrl=Z}async audit(){this.models=await Q8(this.baseUrl),this.selectDefaults()}selectDefaults(){if(this.defaultEmbedding=this.models.find((Z)=>Z.type==="Embedding")||null,this.defaultLLM=this.models.find((Z)=>Z.type==="LLM")||null,this.defaultStructuredLLM=this.models.find((Z)=>Z.type==="LLM"&&Z.structuredOutput)||null,!this.defaultEmbedding)console.warn("⚠️ No embedding model found.");if(!this.defaultLLM)console.warn("⚠️ No LLM found.");if(!this.defaultStructuredLLM)console.warn("⚠️ No LLM with structured output support found.")}getModels(){return this.models}_setDefaultModel(Z,X,$,Q){let K=this.models.find((H)=>H.id===Z&&$(H));if(!K)throw Error(`Model '${Z}' not found or is not ${Q}.`);this[X]=K}setDefaultLLM(Z){this._setDefaultModel(Z,"defaultLLM",(X)=>X.type==="LLM","an LLM")}setDefaultEmbedding(Z){this._setDefaultModel(Z,"defaultEmbedding",(X)=>X.dimension!==void 0,"an embedding model")}setDefaultStructuredLLM(Z){this._setDefaultModel(Z,"defaultStructuredLLM",(X)=>X.type==="LLM"&&X.structuredOutput,"a structured-output LLM")}getLLM(){if(!this.defaultLLM)throw Error("No LLM available.");return this.defaultLLM}getEmbedding(){if(!this.defaultEmbedding)throw Error("No embedding model available.");return this.defaultEmbedding}getStructuredLLM(){if(!this.defaultStructuredLLM)throw Error("No structured-output LLM available.");return this.defaultStructuredLLM}}var WX=typeof window<"u",GX=WX&&window.location.protocol==="https:",R0=null,G6=null,K8=!1;async function JX(){if(K8)return{localModels:R0,llm:G6};if(K8=!0,GX)return console.log("\uD83D\uDCE1 HTTPS detected - local LLM endpoints disabled. Use HTTP for local LLM support."),{localModels:null,llm:null};try{R0=new W6,await R0.audit(),G6=m7(R0)}catch(Z){console.warn("⚠️ Could not connect to local LLM:",Z)}return{localModels:R0,llm:G6}}async function _X(){let{localModels:Z,llm:X}=await JX();return{vector:X?{embed:X.embed}:void 0,store:K6(),llmBattery:X,models:Z}}async function MH(){return _X()}var wH={store:K6(),llmBattery:null,vector:void 0,models:null};function LX(Z){if(typeof Z!=="string")return!1;let X=new Date(Z);return!isNaN(X.getTime())&&Z.includes("T")}function UX(){return new Date().toISOString()}function s1(Z,X,$,Q=0,K=0,H=0,Y=0){return new Date(Date.UTC(Z,X-1,$,Q,K,H,Y)).toISOString()}function H8(Z){let X=new Date(Z);if(isNaN(X.getTime()))throw Error(`Invalid date string: ${Z}`);return X.toISOString()}function qX(Z){try{return H8(Z)}catch{return null}}function M0(Z,X){let $=new Date(Z);return $.setTime($.getTime()+X),$.toISOString()}function DX(Z,X){return M0(Z,X*1000)}function AX(Z,X){return M0(Z,X*60*1000)}function IX(Z,X){return M0(Z,X*60*60*1000)}function Y8(Z,X){return M0(Z,X*24*60*60*1000)}function BX(Z,X){return Y8(Z,X*7)}function RX(Z,X){let $=new Date(Z),Q=$.getUTCMonth()+X;if($.setUTCMonth(Q),$.getUTCMonth()!==(Q%12+12)%12)$.setUTCDate(0);return $.toISOString()}function MX(Z,X){let $=new Date(Z),Q=$.getUTCDate();if($.setUTCFullYear($.getUTCFullYear()+X),$.getUTCDate()!==Q)$.setUTCDate(0);return $.toISOString()}function N1(Z,X){return new Date(Z).getTime()-new Date(X).getTime()}function wX(Z,X){return Math.floor(N1(Z,X)/1000)}function FX(Z,X){return Math.floor(N1(Z,X)/60000)}function jX(Z,X){return Math.floor(N1(Z,X)/3600000)}function PX(Z,X){return Math.floor(N1(Z,X)/86400000)}function a1(Z){return new Date(Z).getUTCFullYear()}function B4(Z){return new Date(Z).getUTCMonth()+1}function J6(Z){return new Date(Z).getUTCDate()}function VX(Z){return new Date(Z).getUTCHours()}function CX(Z){return new Date(Z).getUTCMinutes()}function OX(Z){return new Date(Z).getUTCSeconds()}function NX(Z){return new Date(Z).getUTCMilliseconds()}function EX(Z){let X=new Date(Z).getUTCDay();return X===0?7:X}function R4(Z,X,$){let Q=new Date(Z),K={timeZone:X,...$};return new Intl.DateTimeFormat(void 0,K).format(Q)}function TX(Z,X){return R4(Z,X,{year:"numeric",month:"short",day:"numeric",hour:"2-digit",minute:"2-digit",second:"2-digit"})}function SX(Z,X){return R4(Z,X,{year:"numeric",month:"short",day:"numeric"})}function kX(Z,X){return R4(Z,X,{hour:"2-digit",minute:"2-digit",second:"2-digit"})}function gX(Z){return Z.slice(0,10)}function z8(Z,X){return N1(Z,X)<0}function W8(Z,X){return N1(Z,X)>0}function bX(Z,X){return N1(Z,X)===0}function vX(Z,X){return z8(Z,X)?Z:X}function fX(Z,X){return W8(Z,X)?Z:X}function yX(Z){return s1(a1(Z),B4(Z),J6(Z))}function hX(Z){return s1(a1(Z),B4(Z),J6(Z),23,59,59,999)}function xX(Z){return s1(a1(Z),B4(Z),1)}function uX(Z){let X=new Date(Z);return X.setUTCMonth(X.getUTCMonth()+1,0),X.setUTCHours(23,59,59,999),X.toISOString()}function dX(Z){return s1(a1(Z),1,1)}function lX(Z){return s1(a1(Z),12,31,23,59,59,999)}var r1={isValid:LX,now:UX,from:s1,parse:H8,tryParse:qX,addMilliseconds:M0,addSeconds:DX,addMinutes:AX,addHours:IX,addDays:Y8,addWeeks:BX,addMonths:RX,addYears:MX,diff:N1,diffSeconds:wX,diffMinutes:FX,diffHours:jX,diffDays:PX,year:a1,month:B4,day:J6,hour:VX,minute:CX,second:OX,millisecond:NX,dayOfWeek:EX,toLocal:R4,format:TX,formatDate:SX,formatTime:kX,toDate:gX,isBefore:z8,isAfter:W8,isEqual:bX,min:vX,max:fX,startOfDay:yX,endOfDay:hX,startOfMonth:xX,endOfMonth:uX,startOfYear:dX,endOfYear:lX};function _6(Z){if(typeof Z!=="string")return!1;if(!/^\d{4}-\d{2}-\d{2}$/.test(Z))return!1;let X=parseInt(Z.slice(0,4),10),$=parseInt(Z.slice(5,7),10),Q=parseInt(Z.slice(8,10),10);if($<1||$>12)return!1;if(Q<1)return!1;let K=[31,28,31,30,31,30,31,31,30,31,30,31],H=$===2&&(X%4===0&&X%100!==0||X%400===0)?29:K[$-1];return Q<=H}function mX(){return r1.toDate(r1.now())}function iX(Z){let X=new Date;return new Intl.DateTimeFormat("en-CA",{timeZone:Z,year:"numeric",month:"2-digit",day:"2-digit"}).format(X)}function _1(Z,X,$){let Q=String(Z).padStart(4,"0"),K=String(X).padStart(2,"0"),H=String($).padStart(2,"0"),Y=`${Q}-${K}-${H}`;if(!_6(Y))throw Error(`Invalid date: ${Z}-${X}-${$}`);return Y}function G8(Z){if(/^\d{4}-\d{2}-\d{2}$/.test(Z)){if(!_6(Z))throw Error(`Invalid date: ${Z}`);return Z}let X=new Date(Z);if(isNaN(X.getTime()))throw Error(`Invalid date string: ${Z}`);let $=X.getUTCFullYear(),Q=X.getUTCMonth()+1,K=X.getUTCDate();return _1($,Q,K)}function pX(Z){try{return G8(Z)}catch{return null}}function M4(Z,X){let $=_8(Z);return r1.toDate(r1.addDays($,X))}function nX(Z,X){return M4(Z,X*7)}function cX(Z,X){let $=X1(Z),Q=E1(Z),K=L6(Z),H=$*12+(Q-1)+X,Y=Math.floor(H/12),z=H%12+1,W=w0(Y,z),G=Math.min(K,W);return _1(Y,z,G)}function oX(Z,X){let $=X1(Z),Q=E1(Z),K=L6(Z),H=$+X,Y=w0(H,Q),z=Math.min(K,Y);return _1(H,Q,z)}function J8(Z,X){let Q=new Date(Z+"T00:00:00Z").getTime(),K=new Date(X+"T00:00:00Z").getTime();return Math.round((Q-K)/86400000)}function sX(Z,X){let $=X1(Z),Q=E1(Z),K=X1(X),H=E1(X);return($-K)*12+(Q-H)}function aX(Z,X){return X1(Z)-X1(X)}function X1(Z){return parseInt(Z.slice(0,4),10)}function E1(Z){return parseInt(Z.slice(5,7),10)}function L6(Z){return parseInt(Z.slice(8,10),10)}function U6(Z){let X=new Date(Z+"T00:00:00Z").getUTCDay();return X===0?7:X}function rX(Z){let X=new Date(Z+"T00:00:00Z"),$=X.getUTCDay()||7;X.setUTCDate(X.getUTCDate()+4-$);let Q=new Date(Date.UTC(X.getUTCFullYear(),0,1));return Math.ceil(((X.getTime()-Q.getTime())/86400000+1)/7)}function tX(Z){let X=_1(X1(Z),1,1);return J8(Z,X)+1}function q6(Z){return Math.ceil(E1(Z)/3)}function D6(Z){return Z%4===0&&Z%100!==0||Z%400===0}function w0(Z,X){let $=[31,28,31,30,31,30,31,31,30,31,30,31];if(X===2&&D6(Z))return 29;return $[X-1]}function eX(Z){return D6(Z)?366:365}function _8(Z){return Z+"T00:00:00.000Z"}function ZQ(Z){return Math.floor(new Date(Z+"T00:00:00Z").getTime()/1000)}function $Q(Z){let X=new Date(Z*1000);return _1(X.getUTCFullYear(),X.getUTCMonth()+1,X.getUTCDate())}function A6(Z,X){let $=new Date(Z+"T00:00:00Z"),Q={timeZone:"UTC",...X};return new Intl.DateTimeFormat(void 0,Q).format($)}function XQ(Z){return A6(Z,{year:"numeric",month:"long",day:"numeric"})}function QQ(Z){return A6(Z,{year:"numeric",month:"short",day:"numeric"})}function KQ(Z,X){return Z<X}function HQ(Z,X){return Z>X}function YQ(Z,X){return Z===X}function zQ(Z,X){return Z<X?Z:X}function WQ(Z,X){return Z>X?Z:X}function GQ(Z,X,$){return Z>=X&&Z<=$}function JQ(Z){return _1(X1(Z),E1(Z),1)}function _Q(Z){let X=X1(Z),$=E1(Z);return _1(X,$,w0(X,$))}function LQ(Z){let $=(q6(Z)-1)*3+1;return _1(X1(Z),$,1)}function UQ(Z){let $=q6(Z)*3;return _1(X1(Z),$,w0(X1(Z),$))}function qQ(Z){return _1(X1(Z),1,1)}function DQ(Z){return _1(X1(Z),12,31)}function AQ(Z){let X=U6(Z);return M4(Z,-(X-1))}function IQ(Z){let X=U6(Z);return M4(Z,7-X)}var BQ={isValid:_6,today:mX,todayIn:iX,from:_1,parse:G8,tryParse:pX,addDays:M4,addWeeks:nX,addMonths:cX,addYears:oX,diff:J8,diffMonths:sX,diffYears:aX,year:X1,month:E1,day:L6,dayOfWeek:U6,weekOfYear:rX,dayOfYear:tX,quarter:q6,isLeapYear:D6,daysInMonth:w0,daysInYear:eX,toTimestamp:_8,toUnix:ZQ,fromUnix:$Q,format:A6,formatLong:XQ,formatShort:QQ,isBefore:KQ,isAfter:HQ,isEqual:YQ,min:zQ,max:WQ,isBetween:GQ,startOfMonth:JQ,endOfMonth:_Q,startOfQuarter:LQ,endOfQuarter:UQ,startOfYear:qQ,endOfYear:DQ,startOfWeek:AQ,endOfWeek:IQ};export{C$ as xmlParse,c4 as wrap,m5 as whileLoop,R$ as vectorSearch,r5 as varsLet,a5 as varsImport,t5 as varsExport,c5 as varSet,s5 as varGet,n4 as validateArgs,T$ as uuid,C4 as typeToString,i1 as typeOf,l1 as typeDescriptorToTS,p5 as tryCatch,xK as transpileWithCache,L0 as transpileToJS,F$ as transpileCode,D4 as transpile,H0 as transformFunction,uK as tjsWithCache,hK as tjs,XZ as testUtils,W$ as template,g0 as stripTjsPreamble,k0 as stripModuleSyntax,I$ as storeSet,B$ as storeQuery,b$ as storeProcedure,A$ as storeGet,Y$ as split,V5 as setGlobalCache,J1 as seq,e5 as scope,b1 as runtime,j$ as runCode,i5 as ret,N as resolveValue,Z6 as resolveProcedureToken,v$ as releaseProcedure,X7 as registerWasmBlock,G$ as regexMatch,X$ as reduce,E$ as random,K$ as push,o1 as procedureStore,E0 as preprocess,J$ as pick,m6 as parseReturnType,P1 as parseParameter,M1 as parse,_$ as omit,L$ as merge,O$ as memoize,Z$ as map,V8 as lookupVariable,M$ as llmPredict,N5 as lint,H$ as len,U$ as keys,V$ as jsonStringify,P$ as jsonParse,z$ as join,y4 as isValidUrl,h4 as isValidTimestamp,x4 as isValidLegalDate,C1 as isRuntimeType,e4 as isProcedureToken,w1 as isError,k5 as isAgentError,$7 as instantiateWasm,Y5 as installRuntime,z1 as inferTypeFromValue,l5 as iff,F5 as hashSourceSync,Y4 as hashSource,$6 as hash,lK as getToolDefinitions,K6 as getStoreCapabilityDefault,MH as getStandardCapabilities,m as getLocation,m7 as getLLMCapability,z4 as getGlobalCache,_X as getBatteries,S5 as generateDocsMarkdown,w7 as generateDocs,iZ as generateDTS,M5 as fromTS,Q$ as find,$$ as filter,D$ as fetch,N4 as extractTests,X0 as extractTDoc,A1 as extractLiteralValue,s6 as expectFunction,p as evaluateExpr,n5 as errorAtom,B1 as error,z5 as emitRuntimeWrapper,S as defineAtom,O1 as createChildScope,W1 as createChildContext,dK as createAgent,L4 as coreAtoms,o5 as constSet,k$ as consoleWarn,S$ as consoleLog,g$ as consoleError,OZ as compileWasmBlocks,f0 as compileToWasm,f$ as clearExpiredProcedures,v1 as checkType,N$ as cache,j1 as builtins,JH as batteryAtoms,wH as batteries,o6 as assertFunction,fK as ajs,w$ as agentRun,a0 as Union,e as TypedBuilder,P8 as TypeError,n as Type,u as TranspileError,u4 as TimestampType,r1 as Timestamp,c0 as TUuid,n0 as TUrl,x0 as TString,e0 as TRecord,m0 as TPositiveInt,t0 as TPair,u0 as TNumber,i0 as TNonEmptyString,$1 as TJS_VERSION,l0 as TInteger,p0 as TEmail,d0 as TBoolean,r0 as TArray,Q1 as SyntaxError,w5 as Schema,c$ as SafeFunction,t4 as PROCEDURE_TOKEN_PREFIX,s0 as Optional,o0 as Nullable,s4 as MetadataCache,W6 as LocalModels,d4 as LegalDateType,BQ as LegalDate,m1 as Generic,n$ as Eval,Z4 as Enum,g5 as DEFAULT_PROCEDURE_TTL,b5 as DEFAULT_MAX_AST_SIZE,Q6 as AgentVM,H1 as AgentError,l$ as Agent,BK as A99};
|
|
404
412
|
|
|
405
|
-
//# debugId=
|
|
413
|
+
//# debugId=165187DC4FDC9E3964756E2164756E21
|