glre 0.22.0 → 0.24.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.
Files changed (50) hide show
  1. package/README.md +19 -28
  2. package/dist/index.d.ts +49 -222
  3. package/dist/index.js +43 -37
  4. package/dist/index.js.map +1 -1
  5. package/dist/index.mjs +43 -37
  6. package/dist/index.mjs.map +1 -1
  7. package/dist/native.d.ts +49 -5
  8. package/dist/native.js +43 -37
  9. package/dist/native.js.map +1 -1
  10. package/dist/native.mjs +43 -37
  11. package/dist/native.mjs.map +1 -1
  12. package/dist/react.d.ts +1 -2
  13. package/dist/react.js +43 -37
  14. package/dist/react.js.map +1 -1
  15. package/dist/react.mjs +43 -37
  16. package/dist/react.mjs.map +1 -1
  17. package/dist/solid.d.ts +1 -2
  18. package/dist/solid.js +43 -37
  19. package/dist/solid.js.map +1 -1
  20. package/dist/solid.mjs +43 -37
  21. package/dist/solid.mjs.map +1 -1
  22. package/package.json +5 -1
  23. package/src/code/glsl.ts +7 -45
  24. package/src/code/wgsl.ts +10 -46
  25. package/src/index.ts +34 -35
  26. package/src/native.ts +9 -4
  27. package/src/node/cache.ts +3 -10
  28. package/src/node/const.ts +2 -19
  29. package/src/node/conv.ts +6 -17
  30. package/src/node/index.ts +5 -8
  31. package/src/node/node.ts +8 -22
  32. package/src/node/uniform.ts +6 -13
  33. package/src/react.ts +0 -1
  34. package/src/solid.ts +0 -1
  35. package/src/types.ts +21 -21
  36. package/src/{utils.ts → utils/helpers.ts} +0 -9
  37. package/src/utils/pipeline.ts +124 -0
  38. package/src/utils/program.ts +94 -0
  39. package/src/webgl.ts +77 -0
  40. package/src/webgpu.ts +102 -0
  41. package/src/webgl/buffer.ts +0 -78
  42. package/src/webgl/index.ts +0 -79
  43. package/src/webgl/program.ts +0 -61
  44. package/src/webgl/shader.ts +0 -60
  45. package/src/webgl/texture.ts +0 -93
  46. package/src/webgpu/buffer.ts +0 -96
  47. package/src/webgpu/device.ts +0 -91
  48. package/src/webgpu/index.ts +0 -40
  49. package/src/webgpu/pipeline.ts +0 -94
  50. package/src/webgpu/texture.ts +0 -139
package/dist/native.js CHANGED
@@ -1,48 +1,54 @@
1
- "use strict";var U=Object.defineProperty;var Se=Object.getOwnPropertyDescriptor;var $e=Object.getOwnPropertyNames;var Le=Object.prototype.hasOwnProperty;var _e=(e,r)=>{for(var t in r)U(e,t,{get:r[t],enumerable:!0})},Ae=(e,r,t,n)=>{if(r&&typeof r=="object"||typeof r=="function")for(let o of $e(r))!Le.call(e,o)&&o!==t&&U(e,o,{get:()=>r[o],enumerable:!(n=Se(r,o))||n.enumerable});return e};var Ce=e=>Ae(U({},"__esModule",{value:!0}),e);var dt={};_e(dt,{BufferUsage:()=>yr,CACHE_BOOLS:()=>J,CACHE_FLOATS:()=>re,CACHE_INTS:()=>ee,FUNCTIONS:()=>Q,Fn:()=>Kr,If:()=>Zr,OPERATORS:()=>Z,SWIZZLES:()=>K,TYPES:()=>vr,TextureFormat:()=>Ur,TextureUsage:()=>wr,abs:()=>nt,activeTexture:()=>D,alignBufferSize:()=>hr,bool:()=>Yr,calculateBufferSize:()=>Er,ceil:()=>ft,checkWebGPUSupport:()=>Qe,color:()=>jr,configureCanvasContext:()=>rr,convertToNode:()=>zr,cos:()=>it,createAttribute:()=>N,createBindGroup:()=>sr,createBindGroupLayout:()=>ar,createBuffer:()=>R,createBuffers:()=>br,createCommandEncoder:()=>H,createComputePipeline:()=>or,createCubeTexture:()=>We,createDepthTexture:()=>$r,createEmptyTexture:()=>Ie,createFragmentShader:()=>I,createGL:()=>se,createIbo:()=>P,createIndexBuffer:()=>lr,createNode:()=>h,createProgram:()=>B,createRenderPass:()=>k,createRenderPipeline:()=>Y,createSampler:()=>Lr,createShaderModule:()=>ir,createStorageBuffer:()=>xr,createTexture:()=>W,createTextureFromImage:()=>Sr,createTextureView:()=>_r,createUniformBuffer:()=>dr,createVbo:()=>v,createVertexBuffer:()=>cr,createVertexShader:()=>X,deleteBuffer:()=>we,deleteProgram:()=>F,deleteShader:()=>ue,deleteTexture:()=>Xe,destroyBuffer:()=>Tr,destroyTexture:()=>Cr,dig:()=>qe,each:()=>pe,ext:()=>ze,fig:()=>Ve,findDuplicateNodes:()=>Dr,float:()=>A,floor:()=>ut,flush:()=>De,fract:()=>mt,getAttribLocation:()=>Ge,getCachedBool:()=>$,getCachedFloat:()=>_,getCachedInt:()=>L,getDeviceLimits:()=>Je,getProgramInfo:()=>Pe,getShaderInfo:()=>Me,getUniformLocation:()=>Ne,getUniformType:()=>M,gl_FragCoord:()=>Qr,gl_Position:()=>Jr,glsl:()=>b,iDeltaTime:()=>ge,iMouse:()=>tt,iPrevTime:()=>xe,iResolution:()=>rt,iTime:()=>et,int:()=>qr,is:()=>a,isGL:()=>ae,isServer:()=>me,isWebGPUSupported:()=>O,length:()=>ct,node:()=>u,nodeToGLSL:()=>ce,nodeToWGSL:()=>le,normalize:()=>pt,replace:()=>Oe,requestWebGPUDevice:()=>q,setupDeviceErrorHandling:()=>er,sig:()=>Ye,sin:()=>ot,sqrt:()=>st,tan:()=>at,uniform:()=>l,updateBuffer:()=>gr,updateIbo:()=>ve,updateTexture:()=>Ar,updateUniforms:()=>Wr,updateVbo:()=>Ue,useGL:()=>lt,vec2:()=>kr,vec3:()=>he,vec4:()=>Hr,vertexStride:()=>G,webgl:()=>V,webgpu:()=>j,wgsl:()=>y});module.exports=Ce(dt);var ye=require("react"),Re=require("react-native");var d=require("reev"),w=require("refr");var z=require("reev");var v=(e,r)=>{let t=e.createBuffer();if(!t)throw new Error("Failed to create VBO");return e.bindBuffer(e.ARRAY_BUFFER,t),e.bufferData(e.ARRAY_BUFFER,new Float32Array(r),e.STATIC_DRAW),e.bindBuffer(e.ARRAY_BUFFER,null),t},P=(e,r)=>{let t=e.createBuffer();if(!t)throw new Error("Failed to create IBO");return e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,t),e.bufferData(e.ELEMENT_ARRAY_BUFFER,new Int16Array(r),e.STATIC_DRAW),e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,null),t},N=(e,r,t,n,o)=>{e.bindBuffer(e.ARRAY_BUFFER,n),e.enableVertexAttribArray(t),e.vertexAttribPointer(t,r,e.FLOAT,!1,0,0),o&&e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,o)},we=(e,r)=>{e.deleteBuffer(r)},G=(e,r,t)=>{t&&(e=Math.max(...t)+1);let n=r.length/e;return n!==Math.floor(n)&&console.warn(`Vertex Stride Error: count ${e} is mismatch`),Math.floor(n)},Ue=(e,r,t,n=e.STATIC_DRAW)=>{e.bindBuffer(e.ARRAY_BUFFER,r),e.bufferData(e.ARRAY_BUFFER,new Float32Array(t),n),e.bindBuffer(e.ARRAY_BUFFER,null)},ve=(e,r,t,n=e.STATIC_DRAW)=>{e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,r),e.bufferData(e.ELEMENT_ARRAY_BUFFER,new Int16Array(t),n),e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,null)};var B=(e,r,t)=>{let n=e.createProgram();if(!n)throw new Error("Failed to create pg");if(e.attachShader(n,r),e.attachShader(n,t),e.linkProgram(n),e.getProgramParameter(n,e.LINK_STATUS))return n;let o=e.getProgramInfoLog(n);throw e.deleteProgram(n),new Error(`Could not link pg: ${o}`)},F=(e,r)=>{e.deleteProgram(r)},Pe=(e,r)=>({linked:e.getProgramParameter(r,e.LINK_STATUS),log:e.getProgramInfoLog(r),activeAttributes:e.getProgramParameter(r,e.ACTIVE_ATTRIBUTES),activeUniforms:e.getProgramParameter(r,e.ACTIVE_UNIFORMS)}),M=(e,r=!1)=>{let t=typeof e=="number"?0:e?.length;return t?r?(t=Math.sqrt(t)<<0,`uniformMatrix${t}fv`):`uniform${t}fv`:"uniform1f"},Ne=(e,r,t)=>e.getUniformLocation(r,t),Ge=(e,r,t)=>e.getAttribLocation(r,t);var Be=`
2
- attribute vec4 a_position;
1
+ "use strict";var F=Object.defineProperty;var ve=Object.getOwnPropertyDescriptor;var Te=Object.getOwnPropertyNames;var Ee=Object.prototype.hasOwnProperty;var $e=(e,r)=>{for(var t in r)F(e,t,{get:r[t],enumerable:!0})},we=(e,r,t,n)=>{if(r&&typeof r=="object"||typeof r=="function")for(let o of Te(r))!Ee.call(e,o)&&o!==t&&F(e,o,{get:()=>r[o],enumerable:!(n=ve(r,o))||n.enumerable});return e};var Le=e=>we(F({},"__esModule",{value:!0}),e);var Cr={};$e(Cr,{CACHE_BOOLS:()=>K,CACHE_FLOATS:()=>Q,CACHE_INTS:()=>Z,FUNCTIONS:()=>j,Fn:()=>fr,If:()=>cr,OPERATORS:()=>H,SWIZZLES:()=>k,TYPES:()=>qe,abs:()=>hr,activeTexture:()=>W,bool:()=>Ke,ceil:()=>Er,color:()=>Je,convertToNode:()=>ke,cos:()=>yr,createAttrib:()=>z,createDescriptor:()=>V,createGL:()=>ne,createIbo:()=>I,createNode:()=>L,createPipeline:()=>D,createProgram:()=>M,createShader:()=>P,createTexture:()=>O,createVbo:()=>B,defaultFragmentGLSL:()=>se,defaultVertexGLSL:()=>ae,dig:()=>Re,each:()=>oe,ext:()=>Se,fig:()=>Ge,findDuplicateNodes:()=>Ve,float:()=>U,floor:()=>Tr,flush:()=>Ne,fract:()=>$r,fragCoord:()=>pr,getCachedBool:()=>G,getCachedFloat:()=>_,getCachedInt:()=>R,glsl:()=>C,iDeltaTime:()=>de,iMouse:()=>gr,iPrevTime:()=>le,iResolution:()=>dr,iTime:()=>lr,int:()=>je,is:()=>i,isGL:()=>te,isServer:()=>he,isWebGPUSupported:()=>be,length:()=>Lr,node:()=>a,nodeToGLSL:()=>ie,nodeToWGSL:()=>ue,normalize:()=>wr,position:()=>mr,replace:()=>Ce,sig:()=>_e,sin:()=>br,sqrt:()=>vr,tan:()=>xr,uniform:()=>b,updateUniforms:()=>ur,useGL:()=>Nr,vec2:()=>Ze,vec3:()=>pe,vec4:()=>Qe,webgl:()=>q,webgpu:()=>Y,wgsl:()=>S});module.exports=Le(Cr);var ye=require("react"),xe=require("react-native");var v=require("reev"),A=require("refr");var $=require("reev");var i={arr:Array.isArray,bol:e=>typeof e=="boolean",str:e=>typeof e=="string",num:e=>typeof e=="number",int:e=>Number.isInteger(e),fun:e=>typeof e=="function",und:e=>typeof e>"u",nul:e=>e===null,set:e=>e instanceof Set,map:e=>e instanceof Map,obj:e=>!!e&&e.constructor.name==="Object",nan:e=>typeof e=="number"&&Number.isNaN(e)},oe=(e,r)=>e.forEach(r),Ne=(e,...r)=>{oe(e,t=>t(...r))},Ce=(e="",r="_",t="/")=>e.split(r).join(t),Se=(e=".pdf")=>e.split(".").pop()?.toLowerCase()??"",Ge=(e=0)=>`${e}`.split(".")[1]?.length??0,Re=(e=0)=>`${e}`.split(".")[0]?.length-(e<0?1:0),_e=(e=0,r=-2)=>(r*=-1,r=Math.pow(10,r),e*=r,e=Math.round(e),e/=r,e);var ie=(e,r)=>{let t={target:"webgl",precision:"mediump",version:"300 es",nodes:new Map,variables:new Map,functions:new Map,...r};return E(e,t)},E=(e,r)=>e?i.und(e.value)?e.property&&e.parent?`${E(e.parent,r)}.${e.property}`:e.operator&&e.children&&e.children.length>=2?Xe(e,r):e.mathFunction&&e.children&&e.children.length>=1?Ae(e,r):"0.0":Ue(e.value,e.type):"0.0",Ue=(e,r)=>{if(r==="float"){let t=Number(e);return t%1===0?`${t}.0`:`${t}`}if(r==="int")return`${Math.floor(Number(e))}`;if(r==="bool")return e?"true":"false";if(i.arr(e)){let t=e.map(n=>{let o=Number(n);return o%1===0?`${o}.0`:`${o}`}).join(", ");if(r==="vec2")return`vec2(${t})`;if(r==="vec3")return`vec3(${t})`;if(r==="vec4")return`vec4(${t})`;if(r==="color")return`vec3(${t})`}return"0.0"},Xe=(e,r)=>{if(!e.children||e.children.length<2)return"0.0";let t=E(e.children[0],r),n=E(e.children[1],r);return e.operator==="add"?`(${t} + ${n})`:e.operator==="sub"?`(${t} - ${n})`:e.operator==="mul"?`(${t} * ${n})`:e.operator==="div"?`(${t} / ${n})`:e.operator==="mod"?`mod(${t}, ${n})`:e.operator==="equal"?`(${t} == ${n})`:e.operator==="notEqual"?`(${t} != ${n})`:e.operator==="lessThan"?`(${t} < ${n})`:e.operator==="lessThanEqual"?`(${t} <= ${n})`:e.operator==="greaterThan"?`(${t} > ${n})`:e.operator==="greaterThanEqual"?`(${t} >= ${n})`:e.operator==="and"?`(${t} && ${n})`:e.operator==="or"?`(${t} || ${n})`:`(${t} + ${n})`},Ae=(e,r)=>{if(!e.children||e.children.length<1)return"0.0";let t=e.mathFunction,n=e.children.map(d=>E(d,r)),[o,s,u]=n;return n.length===1?`${t}(${o})`:n.length===2?`${t}(${o}, ${s})`:n.length===3?`${t}(${o}, ${s}, ${u})`:o||"0.0"},Fe=e=>{if(i.num(e))return"float";if(i.bol(e))return"bool";if(i.arr(e)){let r=e.length;if(r===2)return"vec2";if(r===3)return"vec3";if(r===4)return"vec4"}return"float"},C=(e,r)=>{let t=r?.precision||"mediump",o=(r?.version||"300 es")==="300 es",s=ie(e),u="";return o&&(u+=`#version 300 es
2
+ `),u+=`precision ${t} float;
3
+
4
+ `,r?.uniforms&&(Object.entries(r.uniforms).forEach(([d,h])=>{let y=Fe(h);u+=`uniform ${y} ${d};
5
+ `}),u+=`
6
+ `),o&&(u+=`out vec4 fragColor;
7
+
8
+ `),u+=`void main() {
9
+ `,u+=o?` fragColor = ${s};
10
+ `:` gl_FragColor = ${s};
11
+ `,u+=`}
12
+ `,u};var ae=`
13
+ #version 300 es
3
14
  void main() {
4
- gl_Position = a_position;
15
+ float x = float(gl_VertexID % 2) * 4.0 - 1.0;
16
+ float y = float(gl_VertexID / 2) * 4.0 - 1.0;
17
+ gl_Position = vec4(x, y, 0.0, 1.0);
5
18
  }
6
- `,Fe=`
19
+ `,se=`
20
+ #version 300 es
7
21
  precision mediump float;
8
22
  uniform vec2 iResolution;
23
+ out vec4 fragColor;
9
24
  void main() {
10
- gl_FragColor = vec4(fract(gl_FragCoord.xy / iResolution), 0, 1);
11
- }
12
- `,ue=(e,r)=>{e.deleteShader(r)},fe=(e,r,t)=>{let n=e.createShader(t);if(!n)throw new Error("Failed to create shader");if(e.shaderSource(n,r),e.compileShader(n),e.getShaderParameter(n,e.COMPILE_STATUS))return n;let o=e.getShaderInfoLog(n);throw ue(e,n),new Error(`Could not compile shader: ${o}`)},X=(e,r=Be)=>fe(e,r,e.VERTEX_SHADER),I=(e,r=Fe)=>fe(e,r,e.FRAGMENT_SHADER),Me=(e,r)=>({compiled:e.getShaderParameter(r,e.COMPILE_STATUS),log:e.getShaderInfoLog(r),source:e.getShaderSource(r)});var W=(e,r)=>{let t=e.createTexture();if(!t)throw new Error("Failed to create texture");return e.bindTexture(e.TEXTURE_2D,t),e.texImage2D(e.TEXTURE_2D,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,r),e.generateMipmap(e.TEXTURE_2D),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE),e.bindTexture(e.TEXTURE_2D,null),t},D=(e,r,t,n)=>{r&&(e.uniform1i(r,t),e.activeTexture(e.TEXTURE0+t),e.bindTexture(e.TEXTURE_2D,n))},Xe=(e,r)=>{e.deleteTexture(r)},Ie=(e,r=1280,t=800,n=e.RGBA,o=e.UNSIGNED_BYTE)=>{let i=e.createTexture();if(!i)throw new Error("Failed to create empty texture");return e.bindTexture(e.TEXTURE_2D,i),e.texImage2D(e.TEXTURE_2D,0,n,r,t,0,n,o,null),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE),e.bindTexture(e.TEXTURE_2D,null),i},We=(e,r)=>{if(r.length!==6)throw new Error("Cube texture requires exactly 6 imgs");let t=e.createTexture();if(!t)throw new Error("Failed to create cube texture");return e.bindTexture(e.TEXTURE_CUBE_MAP,t),[e.TEXTURE_CUBE_MAP_POSITIVE_X,e.TEXTURE_CUBE_MAP_NEGATIVE_X,e.TEXTURE_CUBE_MAP_POSITIVE_Y,e.TEXTURE_CUBE_MAP_NEGATIVE_Y,e.TEXTURE_CUBE_MAP_POSITIVE_Z,e.TEXTURE_CUBE_MAP_NEGATIVE_Z].forEach((o,i)=>{e.texImage2D(o,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,r[i])}),e.generateMipmap(e.TEXTURE_CUBE_MAP),e.texParameteri(e.TEXTURE_CUBE_MAP,e.TEXTURE_MIN_FILTER,e.LINEAR_MIPMAP_LINEAR),e.texParameteri(e.TEXTURE_CUBE_MAP,e.TEXTURE_MAG_FILTER,e.LINEAR),e.texParameteri(e.TEXTURE_CUBE_MAP,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE),e.texParameteri(e.TEXTURE_CUBE_MAP,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE),e.bindTexture(e.TEXTURE_CUBE_MAP,null),t};var a={arr:Array.isArray,bol:e=>typeof e=="boolean",str:e=>typeof e=="string",num:e=>typeof e=="number",int:e=>Number.isInteger(e),fun:e=>typeof e=="function",und:e=>typeof e>"u",nul:e=>e===null,set:e=>e instanceof Set,map:e=>e instanceof Map,obj:e=>!!e&&e.constructor.name==="Object",nan:e=>typeof e=="number"&&Number.isNaN(e)},me=()=>typeof window>"u",O=()=>me()?!1:"gpu"in navigator,pe=(e,r)=>e.forEach(r),De=(e,...r)=>{pe(e,t=>t(...r))},Oe=(e="",r="_",t="/")=>e.split(r).join(t),ze=(e=".pdf")=>e.split(".").pop()?.toLowerCase()??"",Ve=(e=0)=>`${e}`.split(".")[1]?.length??0,qe=(e=0)=>`${e}`.split(".")[0]?.length-(e<0?1:0),Ye=(e=0,r=-2)=>(r*=-1,r=Math.pow(10,r),e*=r,e=Math.round(e),e/=r,e);var ce=(e,r)=>{let t={target:"webgl",precision:"mediump",version:"300 es",nodes:new Map,variables:new Map,functions:new Map,...r};return T(e,t)},T=(e,r)=>e?a.und(e.value)?e.property&&e.parent?`${T(e.parent,r)}.${e.property}`:e.operator&&e.children&&e.children.length>=2?He(e,r):e.mathFunction&&e.children&&e.children.length>=1?je(e,r):"0.0":ke(e.value,e.type):"0.0",ke=(e,r)=>{if(r==="float"){let t=Number(e);return t%1===0?`${t}.0`:`${t}`}if(r==="int")return`${Math.floor(Number(e))}`;if(r==="bool")return e?"true":"false";if(a.arr(e)){let t=e.map(n=>{let o=Number(n);return o%1===0?`${o}.0`:`${o}`}).join(", ");if(r==="vec2")return`vec2(${t})`;if(r==="vec3")return`vec3(${t})`;if(r==="vec4")return`vec4(${t})`;if(r==="color")return`vec3(${t})`}return"0.0"},He=(e,r)=>{if(!e.children||e.children.length<2)return"0.0";let t=T(e.children[0],r),n=T(e.children[1],r);return e.operator==="add"?`(${t} + ${n})`:e.operator==="sub"?`(${t} - ${n})`:e.operator==="mul"?`(${t} * ${n})`:e.operator==="div"?`(${t} / ${n})`:e.operator==="mod"?`mod(${t}, ${n})`:e.operator==="equal"?`(${t} == ${n})`:e.operator==="notEqual"?`(${t} != ${n})`:e.operator==="lessThan"?`(${t} < ${n})`:e.operator==="lessThanEqual"?`(${t} <= ${n})`:e.operator==="greaterThan"?`(${t} > ${n})`:e.operator==="greaterThanEqual"?`(${t} >= ${n})`:e.operator==="and"?`(${t} && ${n})`:e.operator==="or"?`(${t} || ${n})`:`(${t} + ${n})`},je=(e,r)=>{if(!e.children||e.children.length<1)return"0.0";let t=e.mathFunction,n=e.children.map(f=>T(f,r)),[o,i,s]=n;if(n.length===1){if(t==="abs")return`abs(${o})`;if(t==="acos")return`acos(${o})`;if(t==="asin")return`asin(${o})`;if(t==="atan")return`atan(${o})`;if(t==="ceil")return`ceil(${o})`;if(t==="cos")return`cos(${o})`;if(t==="floor")return`floor(${o})`;if(t==="fract")return`fract(${o})`;if(t==="length")return`length(${o})`;if(t==="normalize")return`normalize(${o})`;if(t==="sin")return`sin(${o})`;if(t==="sqrt")return`sqrt(${o})`;if(t==="tan")return`tan(${o})`}if(n.length===2){if(t==="atan2")return`atan(${o}, ${i})`;if(t==="pow")return`pow(${o}, ${i})`;if(t==="min")return`min(${o}, ${i})`;if(t==="max")return`max(${o}, ${i})`;if(t==="dot")return`dot(${o}, ${i})`;if(t==="cross")return`cross(${o}, ${i})`;if(t==="distance")return`distance(${o}, ${i})`;if(t==="reflect")return`reflect(${o}, ${i})`}if(n.length===3){if(t==="mix")return`mix(${o}, ${i}, ${s})`;if(t==="clamp")return`clamp(${o}, ${i}, ${s})`;if(t==="smoothstep")return`smoothstep(${o}, ${i}, ${s})`;if(t==="refract")return`refract(${o}, ${i}, ${s})`}return o||"0.0"},Ke=e=>{if(a.num(e))return"float";if(a.bol(e))return"bool";if(a.arr(e)){let r=e.length;if(r===2)return"vec2";if(r===3)return"vec3";if(r===4)return"vec4"}return"float"},b=(e,r)=>{let t=r?.precision||"mediump",o=(r?.version||"300 es")==="300 es",i=ce(e),s="";return o&&(s+=`#version 300 es
13
- `),s+=`precision ${t} float;
14
-
15
- `,r?.uniforms&&(Object.entries(r.uniforms).forEach(([f,p])=>{let x=Ke(p);s+=`uniform ${x} ${f};
16
- `}),s+=`
17
- `),o&&(s+=`out vec4 fragColor;
18
-
19
- `),s+=`void main() {
20
- `,s+=o?` fragColor = ${i};
21
- `:` gl_FragColor = ${i};
22
- `,s+=`}
23
- `,s};var Ze=[-1,-1,1,-1,-1,1,-1,1,1,-1,1,1],V=e=>{e("init",()=>{let n=e.gl,o=e.vs||e.vert||e.vertex,i=e.fs||e.frag||e.fragment;a.obj(i)&&(i=b(i)),a.obj(o)&&(o=b(o)),e.count===6&&e.attribute({a_position:Ze}),e.pg=B(n,X(n,o),I(n,i)),e.location=(0,z.nested)((s,f=!1)=>f?n.getAttribLocation(e.pg,s):n.getUniformLocation(e.pg,s))}),e("clean",()=>{let n=e.gl;F(n,e.pg)}),e("render",()=>{let n=e.gl;n.useProgram(e.pg),e.queue.flush(),n.clear(n.COLOR_BUFFER_BIT),n.viewport(0,0,...e.size),n.drawArrays(n.TRIANGLES,0,e.count)}),e("_attribute",(n="",o,i)=>{let s=e.gl,f=e.count,p=e.location(n,!0),x=v(s,o),c=P(s,i),m=G(f,o,i);N(s,m,p,x,c)}),e("_uniform",(n,o=0,i=!1)=>{let s=M(o,i),f=e.gl,p=e.location(n);i?f[s](p,!1,o):f[s](p,o)});let r=n=>{let o=e.location(n.alt),i=e.activeUnit(n.alt),s=W(e.gl,n);D(e.gl,o,i,s)};e("_texture",(n,o)=>{let i=new Image;i.addEventListener("load",r.bind(null,i),!1),Object.assign(i,{src:o,alt:n,crossOrigin:"anonymous"})});let t=0;return e.activeUnit=(0,z.nested)(()=>t++),e};var q=async()=>{if(!navigator.gpu)throw new Error("WebGPU is not supported in this browser");let e=await navigator.gpu.requestAdapter();if(!e)throw new Error("Failed to get WebGPU adapter");let r=await e.requestDevice();if(!r)throw new Error("Failed to get WebGPU device");return{adapter:e,device:r}},Qe=()=>"gpu"in navigator,Je=e=>({maxTextureDimension1D:e.limits.maxTextureDimension1D,maxTextureDimension2D:e.limits.maxTextureDimension2D,maxTextureDimension3D:e.limits.maxTextureDimension3D,maxTextureArrayLayers:e.limits.maxTextureArrayLayers,maxBindGroups:e.limits.maxBindGroups,maxDynamicUniformBuffersPerPipelineLayout:e.limits.maxDynamicUniformBuffersPerPipelineLayout,maxDynamicStorageBuffersPerPipelineLayout:e.limits.maxDynamicStorageBuffersPerPipelineLayout,maxSampledTexturesPerShaderStage:e.limits.maxSampledTexturesPerShaderStage,maxSamplersPerShaderStage:e.limits.maxSamplersPerShaderStage,maxStorageBuffersPerShaderStage:e.limits.maxStorageBuffersPerShaderStage,maxStorageTexturesPerShaderStage:e.limits.maxStorageTexturesPerShaderStage,maxUniformBuffersPerShaderStage:e.limits.maxUniformBuffersPerShaderStage,maxUniformBufferBindingSize:e.limits.maxUniformBufferBindingSize,maxStorageBufferBindingSize:e.limits.maxStorageBufferBindingSize,maxVertexBuffers:e.limits.maxVertexBuffers,maxVertexAttributes:e.limits.maxVertexAttributes,maxVertexBufferArrayStride:e.limits.maxVertexBufferArrayStride,maxComputeWorkgroupStorageSize:e.limits.maxComputeWorkgroupStorageSize,maxComputeInvocationsPerWorkgroup:e.limits.maxComputeInvocationsPerWorkgroup,maxComputeWorkgroupSizeX:e.limits.maxComputeWorkgroupSizeX,maxComputeWorkgroupSizeY:e.limits.maxComputeWorkgroupSizeY,maxComputeWorkgroupSizeZ:e.limits.maxComputeWorkgroupSizeZ,maxComputeWorkgroupsPerDimension:e.limits.maxComputeWorkgroupsPerDimension}),er=e=>{e.addEventListener("uncapturederror",r=>{console.error("WebGPU uncaptured error:",r.error)})},rr=(e,r,t="bgra8unorm")=>{let n=e.getContext("webgpu");if(!n)throw new Error("Failed to get WebGPU canvas context");return n.configure({device:r,format:t,alphaMode:"premultiplied"}),n};var tr=`
24
- @vertex
25
- fn main(@builtin(vertex_index) vertexIndex: u32) -> @builtin(position) vec4<f32> {
26
- var pos = array<vec2<f32>, 6>(
27
- vec2<f32>(-1.0, -1.0),
28
- vec2<f32>( 1.0, -1.0),
29
- vec2<f32>(-1.0, 1.0),
30
- vec2<f32>(-1.0, 1.0),
31
- vec2<f32>( 1.0, -1.0),
32
- vec2<f32>( 1.0, 1.0)
33
- );
34
- return vec4<f32>(pos[vertexIndex], 0.0, 1.0);
35
- }
36
- `,nr=`
37
- @fragment
38
- fn main() -> @location(0) vec4<f32> {
39
- return vec4<f32>(1.0, 0.0, 0.0, 1.0);
25
+ fragColor = vec4(fract(gl_FragCoord.xy / iResolution), 0, 1);
40
26
  }
41
- `,Y=(e,r=tr,t=nr,n="bgra8unorm")=>{let o=e.createShaderModule({code:r}),i=e.createShaderModule({code:t});return e.createRenderPipeline({layout:"auto",vertex:{module:o,entryPoint:"main"},fragment:{module:i,entryPoint:"main",targets:[{format:n}]},primitive:{topology:"triangle-list"}})},or=(e,r)=>{let t=e.createShaderModule({code:r});return e.createComputePipeline({layout:"auto",compute:{module:t,entryPoint:"main"}})},ir=(e,r)=>e.createShaderModule({code:r}),ar=(e,r)=>e.createBindGroupLayout({entries:r}),sr=(e,r,t)=>e.createBindGroup({layout:r,entries:t}),k=(e,r,t)=>{let n={colorAttachments:[r]};return t&&(n.depthStencilAttachment=t),e.beginRenderPass(n)},H=e=>e.createCommandEncoder();var le=(e,r)=>{let t={target:"webgpu",nodes:new Map,variables:new Map,functions:new Map,...r};return E(e,t)},E=(e,r)=>e?e.value!==void 0?ur(e.value,e.type):e.property&&e.parent?`${E(e.parent,r)}.${e.property}`:e.operator&&e.children&&e.children.length>=2?fr(e,r):e.mathFunction&&e.children&&e.children.length>=1?mr(e,r):"0.0":"0.0",ur=(e,r)=>{if(r==="float"){let t=Number(e);return t%1===0?`${t}.0`:`${t}`}if(r==="int")return`${Math.floor(Number(e))}`;if(r==="bool")return e?"true":"false";if(a.arr(e)){let t=e.map(n=>{let o=Number(n);return o%1===0?`${o}.0`:`${o}`}).join(", ");if(r==="vec2")return`vec2<f32>(${t})`;if(r==="vec3")return`vec3<f32>(${t})`;if(r==="vec4")return`vec4<f32>(${t})`;if(r==="color")return`vec3<f32>(${t})`}return"0.0"},fr=(e,r)=>{if(!e.children||e.children.length<2)return"0.0";let t=E(e.children[0],r),n=E(e.children[1],r);return e.operator==="add"?`(${t} + ${n})`:e.operator==="sub"?`(${t} - ${n})`:e.operator==="mul"?`(${t} * ${n})`:e.operator==="div"?`(${t} / ${n})`:e.operator==="mod"?`(${t} % ${n})`:e.operator==="equal"?`(${t} == ${n})`:e.operator==="notEqual"?`(${t} != ${n})`:e.operator==="lessThan"?`(${t} < ${n})`:e.operator==="lessThanEqual"?`(${t} <= ${n})`:e.operator==="greaterThan"?`(${t} > ${n})`:e.operator==="greaterThanEqual"?`(${t} >= ${n})`:e.operator==="and"?`(${t} && ${n})`:e.operator==="or"?`(${t} || ${n})`:`(${t} + ${n})`},mr=(e,r)=>{if(!e.children||e.children.length<1)return"0.0";let t=e.mathFunction,n=e.children.map(f=>E(f,r)),[o,i,s]=n;if(n.length===1){if(t==="abs")return`abs(${o})`;if(t==="acos")return`acos(${o})`;if(t==="asin")return`asin(${o})`;if(t==="atan")return`atan(${o})`;if(t==="ceil")return`ceil(${o})`;if(t==="cos")return`cos(${o})`;if(t==="floor")return`floor(${o})`;if(t==="fract")return`fract(${o})`;if(t==="length")return`length(${o})`;if(t==="normalize")return`normalize(${o})`;if(t==="sin")return`sin(${o})`;if(t==="sqrt")return`sqrt(${o})`;if(t==="tan")return`tan(${o})`}if(n.length===2){if(t==="atan2")return`atan2(${o}, ${i})`;if(t==="pow")return`pow(${o}, ${i})`;if(t==="min")return`min(${o}, ${i})`;if(t==="max")return`max(${o}, ${i})`;if(t==="dot")return`dot(${o}, ${i})`;if(t==="cross")return`cross(${o}, ${i})`;if(t==="distance")return`distance(${o}, ${i})`;if(t==="reflect")return`reflect(${o}, ${i})`}return n.length===3?t==="mix"?`mix(${o}, ${i}, ${s})`:t==="clamp"?`clamp(${o}, ${i}, ${s})`:t==="smoothstep"?`smoothstep(${o}, ${i}, ${s})`:o:o||"0.0"},y=(e,r)=>{let t="";r?.uniforms&&(Object.entries(r.uniforms).forEach(([o,i])=>{let s=pr(i);t+=`@group(0) @binding(0) var<uniform> ${o}: ${s};
27
+ `,P=(e,r,t)=>{let n=e.createShader(t);if(!n)throw new Error("Failed to create shader");if(e.shaderSource(n,r.trim()),e.compileShader(n),e.getShaderParameter(n,e.COMPILE_STATUS))return n;let o=e.getShaderInfoLog(n);throw e.deleteShader(n),new Error(`Could not compile shader: ${o}`)},M=(e,r=ae,t=se)=>{let n=e.createProgram();if(e.attachShader(n,P(e,r,e.VERTEX_SHADER)),e.attachShader(n,P(e,t,e.FRAGMENT_SHADER)),e.linkProgram(n),e.getProgramParameter(n,e.LINK_STATUS))return n;let o=e.getProgramInfoLog(n);throw e.deleteProgram(n),new Error(`Could not link pg: ${o}`)},B=(e,r)=>{let t=e.createBuffer();return e.bindBuffer(e.ARRAY_BUFFER,t),e.bufferData(e.ARRAY_BUFFER,new Float32Array(r),e.STATIC_DRAW),e.bindBuffer(e.ARRAY_BUFFER,null),t},I=(e,r)=>{let t=e.createBuffer();return e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,t),e.bufferData(e.ELEMENT_ARRAY_BUFFER,new Int16Array(r),e.STATIC_DRAW),e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,null),t},z=(e,r,t,n,o)=>{e.bindBuffer(e.ARRAY_BUFFER,n),e.enableVertexAttribArray(t),e.vertexAttribPointer(t,r,e.FLOAT,!1,0,0),o&&e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,o)},O=(e,r)=>{let t=e.createTexture();return e.bindTexture(e.TEXTURE_2D,t),e.texImage2D(e.TEXTURE_2D,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,r),e.generateMipmap(e.TEXTURE_2D),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE),e.bindTexture(e.TEXTURE_2D,null),t},W=(e,r,t,n)=>{r&&(e.uniform1i(r,t),e.activeTexture(e.TEXTURE0+t),e.bindTexture(e.TEXTURE_2D,n))};var q=async e=>{let r=e.vs||e.vert||e.vertex,t=e.fs||e.frag||e.fragment;i.obj(t)&&(t=C(t)),i.obj(r)&&(r=C(r));let n=e.el.getContext("webgl2"),o=M(n,r,t),s=0,u=(0,$.nested)(()=>s++),d=(0,$.nested)((f,c=!1)=>c?n.getAttribLocation(o,f):n.getUniformLocation(o,f)),h=(0,$.nested)((f,c,m,l)=>{l&&(c=Math.max(...l)+1);let p=m.length/c;return p!==Math.floor(p)&&console.warn(`Vertex Stride Error: count ${c} is mismatch`),Math.floor(p)}),y=(0,$.nested)((f,c)=>{let m=d(f);if(i.num(c))return p=>n.uniform1f(m,p);let l=c.length;return l<=4?p=>n[`uniform${l}fv`](m,p):(l=Math.sqrt(l)<<0,p=>n[`uniformMatrix${l}fv`](m,!1,p))});e("clean",()=>n.deleteProgram(o)),e("render",()=>{n.useProgram(o),n.clear(n.COLOR_BUFFER_BIT),n.viewport(0,0,...e.size),n.drawArrays(n.TRIANGLES,0,3)}),e("_attribute",(f="",c,m)=>{let l=d(f,!0),p=B(n,c),T=I(n,m),N=h(f,e.count,c,m);z(n,N,l,p,T)}),e("_uniform",(f,c)=>{y(f,c)(c)});let g=f=>{let c=d(f.alt),m=u(f.alt),l=O(n,f);W(n,c,m,l)};return e("_texture",(f,c)=>{let m=new Image;m.addEventListener("load",g.bind(null,m),!1),Object.assign(m,{src:c,alt:f,crossOrigin:"anonymous"})}),e.webgl={context:n,program:o},e};var ue=(e,r)=>{let t={target:"webgpu",nodes:new Map,variables:new Map,functions:new Map,...r};return w(e,t)},w=(e,r)=>e?e.value!==void 0?Pe(e.value,e.type):e.property&&e.parent?`${w(e.parent,r)}.${e.property}`:e.operator&&e.children&&e.children.length>=2?Me(e,r):e.mathFunction&&e.children&&e.children.length>=1?Be(e,r):"0.0":"0.0",Pe=(e,r)=>{if(r==="float"){let t=Number(e);return t%1===0?`${t}.0`:`${t}`}if(r==="int")return`${Math.floor(Number(e))}`;if(r==="bool")return e?"true":"false";if(i.arr(e)){let t=e.map(n=>{let o=Number(n);return o%1===0?`${o}.0`:`${o}`}).join(", ");if(r==="vec2")return`vec2<f32>(${t})`;if(r==="vec3")return`vec3<f32>(${t})`;if(r==="vec4")return`vec4<f32>(${t})`;if(r==="color")return`vec3<f32>(${t})`}return"0.0"},Me=(e,r)=>{if(!e.children||e.children.length<2)return"0.0";let t=w(e.children[0],r),n=w(e.children[1],r);return e.operator==="add"?`(${t} + ${n})`:e.operator==="sub"?`(${t} - ${n})`:e.operator==="mul"?`(${t} * ${n})`:e.operator==="div"?`(${t} / ${n})`:e.operator==="mod"?`(${t} % ${n})`:e.operator==="equal"?`(${t} == ${n})`:e.operator==="notEqual"?`(${t} != ${n})`:e.operator==="lessThan"?`(${t} < ${n})`:e.operator==="lessThanEqual"?`(${t} <= ${n})`:e.operator==="greaterThan"?`(${t} > ${n})`:e.operator==="greaterThanEqual"?`(${t} >= ${n})`:e.operator==="and"?`(${t} && ${n})`:e.operator==="or"?`(${t} || ${n})`:`(${t} + ${n})`},Be=(e,r)=>{if(!e.children||e.children.length<1)return"0.0";let t=e.mathFunction,n=e.children.map(d=>w(d,r)),[o,s,u]=n;return n.length===1?`${t}(${o})`:n.length===2?`${t}(${o}, ${s})`:n.length===3?`${t}(${o}, ${s}, ${u})`:o||"0.0"},S=(e,r)=>{let t="";r?.uniforms&&(Object.entries(r.uniforms).forEach(([o,s])=>{let u=Ie(s);t+=`@group(0) @binding(0) var<uniform> ${o}: ${u};
42
28
  `}),t+=`
43
29
  `),t+=`@fragment
44
30
  `,t+=`fn main() -> @location(0) vec4<f32> {
45
- `;let n=le(e);return t+=` return ${n};
31
+ `;let n=ue(e);return t+=` return ${n};
46
32
  `,t+=`}
47
- `,t},pr=e=>{if(a.num(e))return"f32";if(a.bol(e))return"bool";if(a.arr(e)){let r=e.length;if(r===2)return"vec2<f32>";if(r===3)return"vec3<f32>";if(r===4)return"vec4<f32>"}return"f32"};var R=(e,r,t)=>{let n=a.arr(r)?new Float32Array(r):r,o=e.createBuffer({size:n.byteLength,usage:t,mappedAtCreation:!0});return n instanceof Float32Array?new Float32Array(o.getMappedRange()).set(n):n instanceof Uint32Array&&new Uint32Array(o.getMappedRange()).set(n),o.unmap(),o},cr=(e,r)=>R(e,r,32),lr=(e,r)=>R(e,new Uint32Array(r),64),dr=(e,r)=>e.createBuffer({size:r,usage:68,mappedAtCreation:!1}),xr=(e,r)=>e.createBuffer({size:r,usage:132,mappedAtCreation:!1}),gr=(e,r,t,n=0)=>{let o=a.arr(t)?new Float32Array(t):t;e.queue.writeBuffer(r,n,o)},Tr=e=>e.destroy(),Er=e=>e.length*4,hr=(e,r=256)=>Math.ceil(e/r)*r,br=(e,r)=>r.map(t=>R(e,t.data,t.usage)),yr={VERTEX:32,INDEX:64,UNIFORM:64,STORAGE:128,COPY_SRC:4,COPY_DST:8,MAP_READ:1,MAP_WRITE:2};var Rr=(e,r=1280,t=800,n="rgba8unorm",o=20)=>e.createTexture({size:{width:r,height:t,depthOrArrayLayers:1},format:n,usage:o}),Sr=(e,r,t="rgba8unorm")=>{let n=Rr(e,r.width,r.height,t,20);return e.queue.copyExternalImageToTexture({source:r},{texture:n},{width:r.width,height:r.height}),n};var $r=(e,r=1280,t=800,n="depth24plus")=>e.createTexture({size:{width:r,height:t,depthOrArrayLayers:1},format:n,usage:16}),Lr=(e,r={})=>e.createSampler({magFilter:r.magFilter||"linear",minFilter:r.minFilter||"linear",addressModeU:r.addressModeU||"repeat",addressModeV:r.addressModeV||"repeat",addressModeW:r.addressModeW||"repeat"}),_r=(e,r={})=>e.createView(r),Ar=(e,r,t,n=1280,o=800)=>{e.queue.writeTexture({texture:r},t,{bytesPerRow:n*4},{width:n,height:o})},Cr=e=>e.destroy(),wr={COPY_SRC:1,COPY_DST:2,TEXTURE_BINDING:4,STORAGE_BINDING:8,RENDER_ATTACHMENT:16},Ur={RGBA8_UNORM:"rgba8unorm",RGBA8_SRGB:"rgba8unorm-srgb",BGRA8_UNORM:"bgra8unorm",BGRA8_SRGB:"bgra8unorm-srgb",DEPTH24_PLUS:"depth24plus",DEPTH32_FLOAT:"depth32float"};var j=e=>e({init:async()=>{let{device:n}=await q();e.gl={device:n};let o=e.vs||e.vert||e.vertex,i=e.fs||e.frag||e.fragment;a.obj(o)&&(o=y(i)),a.obj(i)&&(i=y(i)),e.gl.pipeline=Y(n,o,i)},loop:()=>{let{device:n,context:o,pipeline:i}=e.gl,s=H(n),f=k(s,{view:o.getCurrentTexture().createView(),clearValue:{r:0,g:0,b:0,a:1},loadOp:"clear",storeOp:"store"});f.setPipeline(i),f.draw(e.count),f.end(),n.queue.submit([s.finish()])}});var vr=["float","int","uint","bool","color","vec2","vec3","vec4","mat2","mat3","mat4","ivec2","ivec3","ivec4","uvec2","uvec3","uvec4","bvec2","bvec3","bvec4"],K=["x","y","z","w","r","g","b","a","s","t","p","q"],Z=["add","sub","mul","div","mod","equal","notEqual","lessThan","lessThanEqual","greaterThan","greaterThanEqual","and","or","not","assign","xor","bitAnd","bitNot","bitOr","bitXor","shiftLeft","shiftRight"],Q=["abs","acos","asin","atan","atan2","ceil","clamp","cos","cross","degrees","distance","dot","exp","exp2","faceforward","floor","fract","length","all","any","bitcast","cbrt","dFdx","dFdy","difference","equals","fwidth","inverseSqrt","lengthSq","log","log2","max","min","mix","negate","normalize","oneMinus","pow","pow2","pow3","pow4","radians","reciprocal","reflect","refract","round","saturate","sign","sin","smoothstep","sqrt","step","tan","transformDirection","trunc"],J=[!0,!1],ee=[0,1,2,3,4,5],re=[0,1,.5,2];var Pr=0,Nr=()=>`node_${++Pr}`,h=(e,r,t)=>({id:Nr(),type:e,value:r,children:[],...t}),Gr=(e="")=>K.includes(e),Br=(e="")=>Z.includes(e),Fr=(e="")=>Q.includes(e),S=(e,r)=>{let t=(o,i)=>{if(!(!a.str(i)||i==="then"))return i==="id"?e.id:i==="type"?e.type:i==="value"?e.value:i==="property"?e.property:Gr(i)?S(h(Mr(i),void 0,{parent:e,property:i}),r):Br(i)?(...s)=>S(h(e.type,void 0,{operator:i,children:[e,...s]}),r):Fr(i)?(...s)=>S(h(Xr(i,e.type),void 0,{mathFunction:i,children:[e,...s]}),r):r?.({path:[i],args:[]})},n=(o,i,s)=>r?.({path:[],args:s});return new Proxy(()=>{},{get:t,apply:n})},Mr=e=>e.length===1?"float":e.length===2?"vec2":e.length===3?"vec3":e.length===4?"vec4":"float",Xr=(e,r)=>e==="length"?"float":r,u=(e,r,t)=>{let n=h(e,r,t);return S(n)};var Ir=e=>{if(a.num(e))return"float";if(a.bol(e))return"bool";if(a.arr(e)){let r=e.length;if(r===2)return"vec2";if(r===3)return"vec3";if(r===4)return"vec4";if(r===9)return"mat3";if(r===16)return"mat4"}return a.obj(e)&&"r"in e&&"g"in e&&"b"in e?"color":"float"},l=e=>{let r=Ir(e),t=e,n=null,o=null,i=u(r,t),s=m=>{t=m,i.value=m},f=m=>(n=m,c),p=m=>(o=m,c),x=m=>{if(n){let g=n(m);g!==void 0&&s(g)}if(o){let g=o(m);g!==void 0&&s(g)}},c=Object.create(i);return c.set=s,c.onObjectUpdate=f,c.onRenderUpdate=p,c._updateFromContext=x,c.isUniform=!0,c},de=l(0),xe=l(0),ge=l(0),nn=l([1920,1080]),on=l([0,0]),Wr=e=>{if(e.time!==void 0){let r=de.value||0;de.set(e.time),xe.set(r),ge.set(e.time-r)}};var te=new Map,ne=new Map,oe=new Map,Te=()=>{J.forEach(e=>{te.set(e,u("bool",e))}),ee.forEach(e=>{ne.set(e,u("int",e))}),re.forEach(e=>{oe.set(e,u("float",e))})},$=e=>(te.has(e)||Te(),te.get(e)||u("bool",e)),L=e=>ne.has(e)?ne.get(e):u("int",e),_=e=>oe.has(e)?oe.get(e):u("float",e),Dr=e=>{let r=new Map,t=new Map;return e.forEach(n=>{let o=Or(n);t.has(o)?(r.has(o)||r.set(o,[t.get(o)]),r.get(o).push(n)):t.set(o,n)}),r},Or=e=>[e.type,`${e.value}`,e.property||""].join("|");Te();var zr=e=>a.bol(e)?$(e):a.num(e)?a.int(e)?L(e):_(e):a.arr(e)?Ee(e):a.obj(e)?Vr(e):u("float",0),Ee=e=>{let r=e.length;return r===2?u("vec2",e):r===3?u("vec3",e):r===4?u("vec4",e):r===9?u("mat3",e):r===16?u("mat4",e):u("float",e[0])},Vr=e=>{if("r"in e&&"g"in e&&"b"in e){let r=[e.r,e.g,e.b];return"a"in e&&r.push(e.a),u("color",r)}if("x"in e&&"y"in e){let r=[e.x,e.y];return"z"in e&&r.push(e.z),"w"in e&&r.push(e.w),Ee(r)}return u("float",0)},A=e=>a.num(e)?_(e):u("float",Number(e)),qr=e=>a.num(e)&&Number.isInteger(e)?L(e):u("int",Math.floor(Number(e))),Yr=e=>$(!!e),kr=(e,r)=>a.und(e)?u("vec2",[0,0]):a.und(r)?a.arr(e)?u("vec2",e.slice(0,2)):a.obj(e)&&"x"in e&&"y"in e?u("vec2",[e.x,e.y]):u("vec2",[Number(e),Number(e)]):u("vec2",[Number(e),Number(r)]),he=(e,r,t)=>a.und(e)?u("vec3",[0,0,0]):a.und(r)?a.arr(e)?u("vec3",e.slice(0,3)):a.obj(e)&&"x"in e&&"y"in e&&"z"in e?u("vec3",[e.x,e.y,e.z]):u("vec3",[Number(e),Number(e),Number(e)]):t===void 0?u("vec3",[Number(e),Number(r),0]):u("vec3",[Number(e),Number(r),Number(t)]),Hr=(e,r,t,n)=>a.und(e)?u("vec4",[0,0,0,1]):a.und(r)?a.arr(e)?u("vec4",e.slice(0,4)):a.obj(e)&&"x"in e&&"y"in e&&"z"in e&&"w"in e?u("vec4",[e.x,e.y,e.z,e.w]):u("vec4",[Number(e),Number(e),Number(e),1]):u("vec4",[Number(e),Number(r),Number(t),Number(n)]),jr=(e,r,t)=>{if(e===void 0)return u("color",[1,1,1]);if(a.str(e)&&e.startsWith("#")){let n=e.slice(1),o=parseInt(n,16);return u("color",[(o>>16&255)/255,(o>>8&255)/255,(o&255)/255])}return a.num(e)&&r===void 0&&t===void 0?u("color",[(e>>16&255)/255,(e>>8&255)/255,(e&255)/255]):he(e,r,t)};var Kr=e=>{let r=(...t)=>{let n=t.map(i=>a.obj(i)&&"type"in i&&i.type?i:A(i));return e(n)||A(0)};return r.call=t=>e(t),r},Zr=(e,r)=>{r();let t={ElseIf(n,o){return o(),t},Else(n){n()}};return t},Qr=u("vec4",void 0),Jr=u("vec4",void 0),et=l(0),rt=l([1920,1080]),tt=l([0,0]),nt=e=>e.abs(),ot=e=>e.sin(),it=e=>e.cos(),at=e=>e.tan(),st=e=>e.sqrt(),ut=e=>e.floor(),ft=e=>e.ceil(),mt=e=>e.fract(),pt=e=>e.normalize(),ct=e=>e.length();var C=performance.now(),ie=0,be=0,ae=e=>a.obj(e)?"isGL"in e:!1,se=e=>{let r=(0,d.event)({isNative:!1,isWebGL:!0,isLoop:!0,isGL:!0,size:[0,0],mouse:[0,0],count:6,counter:0});return r("mount",()=>{O()||(r.isWebGL=!0),r.isWebGL?V(r):j(r),r.init(),r.resize(),r.frame(()=>(r.loop(),r.render(),r.isLoop)),!r.isNative&&(window.addEventListener("resize",r.resize),r.el.addEventListener("mousemove",r.mousemove))}),r("clean",()=>{r.frame.stop(),r.frame.clean(r.render),!r.isNative&&(window.removeEventListener("resize",r.resize),r.el.removeEventListener("mousemove",r.mousemove))}),r("loop",()=>{ie=C,C=performance.now()/1e3,be=C-ie,r.uniform({iPrevTime:ie,iTime:C,iDeltaTime:be})}),r("resize",()=>{let t=r.width||window.innerWidth,n=r.height||window.innerHeight;r.size[0]=r.el.width=t,r.size[1]=r.el.height=n,r.uniform("iResolution",r.size)}),r("mousemove",(t,n=t.clientX,o=t.clientY)=>{let[i,s]=r.size,{top:f,left:p}=r.el.getBoundingClientRect();r.mouse[0]=(n-f-i/2)/(i/2),r.mouse[1]=-(o-p-s/2)/(s/2),r.uniform("iMouse",r.mouse)}),r.queue=(0,w.createQueue)(),r.frame=(0,w.createFrame)(),r.attribute=(0,d.durable)((t,n,o)=>{r.queue(()=>void r._attribute?.(t,n,o))}),r.uniform=(0,d.durable)((t,n,o)=>{r.queue(()=>void r._uniform?.(t,n,o))}),r.texture=(0,d.durable)((t,n)=>{r.queue(()=>void r._texture?.(t,n))}),r(e)};var lt=(e={})=>(0,ye.useState)(()=>{let r=ae(e)?e:se(e);return r.ref=t=>{r.el={},r.gl=t,r.mount();let n=()=>{r.width=t.drawingBufferWidth,r.height=t.drawingBufferHeight,r.resize()};n(),Re.Dimensions.addEventListener("change",n)},r})[0];0&&(module.exports={BufferUsage,CACHE_BOOLS,CACHE_FLOATS,CACHE_INTS,FUNCTIONS,Fn,If,OPERATORS,SWIZZLES,TYPES,TextureFormat,TextureUsage,abs,activeTexture,alignBufferSize,bool,calculateBufferSize,ceil,checkWebGPUSupport,color,configureCanvasContext,convertToNode,cos,createAttribute,createBindGroup,createBindGroupLayout,createBuffer,createBuffers,createCommandEncoder,createComputePipeline,createCubeTexture,createDepthTexture,createEmptyTexture,createFragmentShader,createGL,createIbo,createIndexBuffer,createNode,createProgram,createRenderPass,createRenderPipeline,createSampler,createShaderModule,createStorageBuffer,createTexture,createTextureFromImage,createTextureView,createUniformBuffer,createVbo,createVertexBuffer,createVertexShader,deleteBuffer,deleteProgram,deleteShader,deleteTexture,destroyBuffer,destroyTexture,dig,each,ext,fig,findDuplicateNodes,float,floor,flush,fract,getAttribLocation,getCachedBool,getCachedFloat,getCachedInt,getDeviceLimits,getProgramInfo,getShaderInfo,getUniformLocation,getUniformType,gl_FragCoord,gl_Position,glsl,iDeltaTime,iMouse,iPrevTime,iResolution,iTime,int,is,isGL,isServer,isWebGPUSupported,length,node,nodeToGLSL,nodeToWGSL,normalize,replace,requestWebGPUDevice,setupDeviceErrorHandling,sig,sin,sqrt,tan,uniform,updateBuffer,updateIbo,updateTexture,updateUniforms,updateVbo,useGL,vec2,vec3,vec4,vertexStride,webgl,webgpu,wgsl});
33
+ `,t},Ie=e=>{if(i.num(e))return"f32";if(i.bol(e))return"bool";if(i.arr(e)){let r=e.length;if(r===2)return"vec2<f32>";if(r===3)return"vec3<f32>";if(r===4)return"vec4<f32>"}return"f32"};var ze=`
34
+ @vertex
35
+ fn main(@builtin(vertex_index) vertex_index: u32) -> @builtin(position) vec4f {
36
+ let x = f32(vertex_index % 2u) * 4.0 - 1.0;
37
+ let y = f32(vertex_index / 2u) * 4.0 - 1.0;
38
+ return vec4f(x, y, 0.0, 1.0);
39
+ }
40
+ `,Oe=`
41
+ struct Uniforms {
42
+ iResolution: vec2f,
43
+ iMouse: vec2f,
44
+ iTime: f32,
45
+ }
46
+
47
+ @group(0) @binding(0) var<uniform> u: Uniforms;
48
+
49
+ @fragment
50
+ fn main(@builtin(position) position: vec4f) -> @location(0) vec4f {
51
+ return vec4f(position.xy / iResolution, 0.0, 1.0);
52
+ }
53
+ `,D=(e,r,t=ze,n=Oe,o)=>e.createRenderPipeline({vertex:{module:e.createShaderModule({code:t.trim()}),entryPoint:"main",buffers:o},fragment:{module:e.createShaderModule({code:n.trim()}),entryPoint:"main",targets:[{format:r}]},layout:"auto",primitive:{topology:"triangle-list"}}),V=e=>({colorAttachments:[{view:e.getCurrentTexture().createView(),clearValue:{r:0,g:0,b:0,a:1},loadOp:"clear",storeOp:"store"}]});var fe=require("reev"),We=3,Y=async e=>{let r=e.vs||e.vert||e.vertex,t=e.fs||e.frag||e.fragment;i.obj(r)&&(r=S(r)),i.obj(t)&&(t=S(t));let n=e.el.getContext("webgpu"),o=navigator.gpu,u=await(await o.requestAdapter()).requestDevice(),d=o.getPreferredCanvasFormat();n.configure({device:u,format:d,alphaMode:"opaque"});let h=u.createBuffer({size:64,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST});e("clean",()=>{});let y=(0,fe.nested)((l,p)=>g+=p),g=0,f,c,m=new Float32Array(0);return e("render",()=>{f||(f=D(u,d,r,t,[]),c=u.createBindGroup({layout:f.getBindGroupLayout(0),entries:[{binding:0,resource:{buffer:h}}]}));let l=u.createCommandEncoder(),p=l.beginRenderPass(V(n));return p.setPipeline(f),p.setBindGroup(0,c),p.draw(We,1,0,0),p.end(),u.queue.submit([l.finish()]),!0}),e("_attribute",(l="",p)=>{}),e("_uniform",(l,p)=>{i.num(p)&&(p=[p]);let T=p.length,N=y(l,T);if(N===g){let x=new Float32Array(g);m&&x.set(m),m=x}for(let x=0;x<T;x++)m[N-T+x]=p[x];u.queue.writeBuffer(h,0,m)}),e("_texture",(l,p)=>{}),e};var qe=["float","int","uint","bool","color","vec2","vec3","vec4","mat2","mat3","mat4","ivec2","ivec3","ivec4","uvec2","uvec3","uvec4","bvec2","bvec3","bvec4"],k=["x","y","z","w","r","g","b","a","s","t","p","q"],H=["add","sub","mul","div","mod","equal","notEqual","lessThan","lessThanEqual","greaterThan","greaterThanEqual","and","or","not","assign","xor","bitAnd","bitNot","bitOr","bitXor","shiftLeft","shiftRight"],j=["abs","acos","asin","atan","atan2","ceil","clamp","cos","cross","degrees","distance","dot","exp","exp2","faceforward","floor","fract","length","all","any","bitcast","cbrt","dFdx","dFdy","difference","equals","fwidth","inverseSqrt","lengthSq","log","log2","max","min","mix","negate","normalize","oneMinus","pow","pow2","pow3","pow4","radians","reciprocal","reflect","refract","round","saturate","sign","sin","smoothstep","sqrt","step","tan","transformDirection","trunc"],K=[!0,!1],Z=[0,1,2,3,4,5],Q=[0,1,.5,2];var J=new Map,ee=new Map,re=new Map,De=()=>{K.forEach(e=>{J.set(e,a("bool",e))}),Z.forEach(e=>{ee.set(e,a("int",e))}),Q.forEach(e=>{re.set(e,a("float",e))})},G=e=>(J.has(e)||De(),J.get(e)||a("bool",e)),R=e=>ee.has(e)?ee.get(e):a("int",e),_=e=>re.has(e)?re.get(e):a("float",e),Ve=e=>{let r=new Map,t=new Map;return e.forEach(n=>{let o=Ye(n);t.has(o)?(r.has(o)||r.set(o,[t.get(o)]),r.get(o).push(n)):t.set(o,n)}),r},Ye=e=>[e.type,`${e.value}`,e.property||""].join("|");var ke=e=>i.bol(e)?G(e):i.num(e)?i.int(e)?R(e):_(e):i.arr(e)?ce(e):i.obj(e)?He(e):a("float",0),ce=e=>{let r=e.length;return r===2?a("vec2",e):r===3?a("vec3",e):r===4?a("vec4",e):r===9?a("mat3",e):r===16?a("mat4",e):a("float",e[0])},He=e=>{if("r"in e&&"g"in e&&"b"in e){let r=[e.r,e.g,e.b];return"a"in e&&r.push(e.a),a("color",r)}if("x"in e&&"y"in e){let r=[e.x,e.y];return"z"in e&&r.push(e.z),"w"in e&&r.push(e.w),ce(r)}return a("float",0)},U=e=>i.num(e)?_(e):a("float",Number(e)),je=e=>i.num(e)&&Number.isInteger(e)?R(e):a("int",Math.floor(Number(e))),Ke=e=>G(!!e),Ze=(e,r)=>i.und(e)?a("vec2",[0,0]):i.und(r)?i.arr(e)?a("vec2",e.slice(0,2)):i.obj(e)&&"x"in e&&"y"in e?a("vec2",[e.x,e.y]):a("vec2",[Number(e),Number(e)]):a("vec2",[Number(e),Number(r)]),pe=(e,r,t)=>i.und(e)?a("vec3",[0,0,0]):i.und(r)?i.arr(e)?a("vec3",e.slice(0,3)):i.obj(e)&&"x"in e&&"y"in e&&"z"in e?a("vec3",[e.x,e.y,e.z]):a("vec3",[Number(e),Number(e),Number(e)]):t===void 0?a("vec3",[Number(e),Number(r),0]):a("vec3",[Number(e),Number(r),Number(t)]),Qe=(e,r,t,n)=>i.und(e)?a("vec4",[0,0,0,1]):i.und(r)?i.arr(e)?a("vec4",e.slice(0,4)):i.obj(e)&&"x"in e&&"y"in e&&"z"in e&&"w"in e?a("vec4",[e.x,e.y,e.z,e.w]):a("vec4",[Number(e),Number(e),Number(e),1]):a("vec4",[Number(e),Number(r),Number(t),Number(n)]),Je=(e,r,t)=>{if(e===void 0)return a("color",[1,1,1]);if(i.str(e)&&e.startsWith("#")){let n=e.slice(1),o=parseInt(n,16);return a("color",[(o>>16&255)/255,(o>>8&255)/255,(o&255)/255])}return i.num(e)&&r===void 0&&t===void 0?a("color",[(e>>16&255)/255,(e>>8&255)/255,(e&255)/255]):pe(e,r,t)};var er=0,rr=()=>`node_${++er}`,L=(e,r,t)=>({id:rr(),type:e,value:r,children:[],...t}),tr=(e="")=>k.includes(e),nr=(e="")=>H.includes(e),or=(e="")=>j.includes(e),X=(e,r)=>{let t=(o,s)=>{if(!(!i.str(s)||s==="then"))return s==="id"?e.id:s==="type"?e.type:s==="value"?e.value:s==="property"?e.property:tr(s)?X(L(ir(s),void 0,{parent:e,property:s}),r):nr(s)?(...u)=>X(L(e.type,void 0,{operator:s,children:[e,...u]}),r):or(s)?(...u)=>X(L(ar(s,e.type),void 0,{mathFunction:s,children:[e,...u]}),r):r?.({path:[s],args:[]})},n=(o,s,u)=>r?.({path:[],args:u});return new Proxy(()=>{},{get:t,apply:n})},ir=e=>e.length===1?"float":e.length===2?"vec2":e.length===3?"vec3":e.length===4?"vec4":"float",ar=(e,r)=>e==="length"?"float":r,a=(e,r,t)=>{let n=L(e,r,t);return X(n)};var sr=e=>{if(i.num(e))return"float";if(i.bol(e))return"bool";if(i.arr(e)){let r=e.length;if(r===2)return"vec2";if(r===3)return"vec3";if(r===4)return"vec4";if(r===9)return"mat3";if(r===16)return"mat4"}return i.obj(e)&&"r"in e&&"g"in e&&"b"in e?"color":"float"},b=e=>{let r=sr(e),t=e,n=null,o=null,s=a(r,t),u=f=>{t=f,s.value=f},d=f=>(n=f,g),h=f=>(o=f,g),y=f=>{if(n){let c=n(f);c!==void 0&&u(c)}if(o){let c=o(f);c!==void 0&&u(c)}},g=Object.create(s);return g.set=u,g.onObjectUpdate=d,g.onRenderUpdate=h,g._updateFromContext=y,g.isUniform=!0,g},me=b(0),le=b(0),de=b(0),nt=b([1920,1080]),ot=b([0,0]),ur=e=>{if(e.time!==void 0){let r=me.value||0;me.set(e.time),le.set(r),de.set(e.time-r)}};var fr=e=>{let r=(...t)=>{let n=t.map(s=>i.obj(s)&&"type"in s&&s.type?s:U(s));return e(n)||U(0)};return r.call=t=>e(t),r},cr=(e,r)=>{r();let t={ElseIf(n,o){return o(),t},Else(n){n()}};return t},pr=a("vec4",void 0),mr=a("vec4",void 0),lr=b(0),dr=b([1920,1080]),gr=b([0,0]),hr=e=>e.abs(),br=e=>e.sin(),yr=e=>e.cos(),xr=e=>e.tan(),vr=e=>e.sqrt(),Tr=e=>e.floor(),Er=e=>e.ceil(),$r=e=>e.fract(),wr=e=>e.normalize(),Lr=e=>e.length();var te=e=>i.obj(e)?"isGL"in e:!1,he=()=>typeof window>"u",be=()=>he()?!1:"gpu"in navigator,ge=performance.now(),ne=e=>{let r=(0,v.event)({isNative:!1,isWebGL:!0,isLoop:!0,isGL:!0,size:[0,0],mouse:[0,0],count:3,webgl:{},webgpu:{}});return r.queue=(0,A.createQueue)(),r.frame=(0,A.createFrame)(),r.attribute=(0,v.durable)((t,n,o)=>r.queue(()=>r._attribute?.(t,n,o))),r.texture=(0,v.durable)((t,n)=>r.queue(()=>r._texture?.(t,n))),r.uniform=(0,v.durable)((t,n,o)=>r.queue(()=>r._uniform?.(t,n,o))),r.uniform({iResolution:r.size,iMouse:[0,0],iTime:0}),r("mount",async()=>{be()||(r.isWebGL=!0),r.isWebGL?await q(r):await Y(r),r.resize(),r.frame(()=>(r.loop(),r.queue.flush(),r.render(),r.isLoop)),!r.isNative&&(window.addEventListener("resize",r.resize),r.el.addEventListener("mousemove",r.mousemove))}),r("clean",()=>{r.frame.stop(),r.frame.clean(r.render),!r.isNative&&(window.removeEventListener("resize",r.resize),r.el.removeEventListener("mousemove",r.mousemove))}),r("resize",()=>{let t=r.width||window.innerWidth,n=r.height||window.innerHeight;r.size[0]=r.el.width=t,r.size[1]=r.el.height=n,r.uniform("iResolution",r.size)}),r("mousemove",(t,n=t.clientX,o=t.clientY)=>{let[s,u]=r.size,{top:d,left:h}=r.el.getBoundingClientRect();r.mouse[0]=(n-d-s/2)/(s/2),r.mouse[1]=-(o-h-u/2)/(u/2),r.uniform("iMouse",r.mouse)}),r("loop",()=>{ge=performance.now()/1e3,r.uniform("iTime",ge)}),r(e)};var Nr=(e={})=>(0,ye.useState)(()=>{let r=te(e)?e:ne(e);return r.ref=t=>{r.el={},r({render(){t.flush(),t.endFrameEXP()}}),r.mount();let n=()=>{r.width=t.drawingBufferWidth,r.height=t.drawingBufferHeight,r.resize()};n(),xe.Dimensions.addEventListener("change",n)},r({isNative:!0})})[0];0&&(module.exports={CACHE_BOOLS,CACHE_FLOATS,CACHE_INTS,FUNCTIONS,Fn,If,OPERATORS,SWIZZLES,TYPES,abs,activeTexture,bool,ceil,color,convertToNode,cos,createAttrib,createDescriptor,createGL,createIbo,createNode,createPipeline,createProgram,createShader,createTexture,createVbo,defaultFragmentGLSL,defaultVertexGLSL,dig,each,ext,fig,findDuplicateNodes,float,floor,flush,fract,fragCoord,getCachedBool,getCachedFloat,getCachedInt,glsl,iDeltaTime,iMouse,iPrevTime,iResolution,iTime,int,is,isGL,isServer,isWebGPUSupported,length,node,nodeToGLSL,nodeToWGSL,normalize,position,replace,sig,sin,sqrt,tan,uniform,updateUniforms,useGL,vec2,vec3,vec4,webgl,webgpu,wgsl});
48
54
  //# sourceMappingURL=native.js.map