glre 0.34.0 → 0.35.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/dist/native.d.ts CHANGED
@@ -1,38 +1,40 @@
1
1
  import * as reev from 'reev';
2
2
  import * as refr_dist_types_687121c7 from 'refr/dist/types-687121c7';
3
3
  import { GL, Vec4, WebGPUState, WebGLState, Uniform, NodeProxy, Attribute } from './index.js';
4
- export { AttribData, Attributes, BVec2, BVec3, BVec4, BaseNodeProxy, Bool, Color, Constants, ConstantsToType, Conversions, Float, Fn, FnLayout, Functions, GLClearMode, GLDrawMode, GLDrawType, IVec2, IVec3, IVec4, If, Int, Loop, Mat2, Mat3, Mat4, NodeContext, NodeProps, NodeTypes, Operators, PrecisionMode, Return, Sampler2D, Struct, Switch, Swizzles, Texture, TextureData, UInt, UVec2, UVec3, UVec4, UniformData, Uniforms, Vec2, Vec3, X, abs, acos, acosh, addDependency, all, any, asin, asinh, assign, atan, atan2, atanh, attribute, bitcast, bool, builtin, bvec2, bvec3, bvec4, cbrt, ceil, clamp, code, color, constant, conversion, conversionToConstant, cos, cosh, createAttrib, createAttribBuffer, createBindGroup, createBindings, createDepthTexture, createDescriptor, createDevice, default as createGL, createIbo, createPipeline, createProgram, createTexture, createTextureSampler, createUniformBuffer, createVbo, createVertexBuffers, cross, cubeTexture, dFdx, dFdy, degrees, difference, dig, distance, dot, each, equals, exp, exp2, ext, faceforward, fig, float, floor, flush, formatConversions, fract, fragDepth, fragment, frontFacing, function_, fwidth, getBluiltin, getEventFun, getId, getOperator, getStride, hex2rgb, iMouse, iResolution, iTime, initNodeContext, instanceIndex, int, inverseSqrt, is, isConstants, isConversion, isFunction, isGL, isNodeProxy, isOperator, isServer, isSwizzle, isWebGPUSupported, ivec2, ivec3, ivec4, length, lengthSq, log, log2, mat2, mat3, mat4, max, member, min, mix, negate, node, normalLocal, normalView, normalWorld, normalize, oneMinus, operator, pointCoord, position, positionLocal, positionView, positionWorld, pow, pow2, pow3, pow4, radians, reciprocal, reflect, refract, replace, round, safeEventCall, sampleIndex, sampleMask, sampler2D, saturate, screenCoordinate, screenUV, select, sig, sign, sin, sinh, smoothstep, sortHeadersByDependencies, sqrt, step, struct, tan, tanh, texture, texture2D, textureSize, toVar, transformDirection, trunc, uint, uniform, uv, uvec2, uvec3, uvec4, variable, vec2, vec3, vec4, vertex, vertexIndex, vertexStage, webgl, webgpu } from './index.js';
4
+ export { AttribData, Attributes, BVec2, BVec3, BVec4, BaseNodeProxy, Bool, Color, Constants, ConstantsToType, Conversions, Float, Fn, FnLayout, Functions, GLClearMode, GLDrawMode, GLDrawType, IVec2, IVec3, IVec4, If, Int, Loop, Mat2, Mat3, Mat4, NodeContext, NodeProps, NodeTypes, Operators, PrecisionMode, Return, Sampler2D, Struct, Switch, Swizzles, Texture, TextureData, UInt, UVec2, UVec3, UVec4, UniformData, Uniforms, Vec2, Vec3, X, abs, acos, acosh, addDependency, all, any, asin, asinh, assign, atan, atan2, atanh, attribute, bitcast, bool, builtin, bvec2, bvec3, bvec4, cbrt, ceil, clamp, code, color, constant, conversion, conversionToConstant, cos, cosh, createAttrib, createAttribBuffer, createBindGroup, createBindings, createDepthTexture, createDescriptor, createDevice, default as createGL, createIbo, createPipeline, createProgram, createTexture, createTextureSampler, createUniformBuffer, createVbo, createVertexBuffers, cross, cubeTexture, dFdx, dFdy, degrees, difference, dig, distance, dot, each, equals, exp, exp2, ext, faceforward, fig, float, floor, flush, formatConversions, fract, fragDepth, fragment, frontFacing, function_, fwidth, getBluiltin, getEventFun, getId, getOperator, getStride, hex2rgb, iMouse, iResolution, iTime, initNodeContext, instanceIndex, int, inverseSqrt, is, isConstants, isConversion, isFunction, isGL, isNodeProxy, isOperator, isServer, isSwizzle, isWebGPUSupported, ivec2, ivec3, ivec4, length, lengthSq, log, log2, mat2, mat3, mat4, max, member, min, mix, mod, negate, node, normalLocal, normalView, normalWorld, normalize, oneMinus, operator, pointCoord, position, positionLocal, positionView, positionWorld, pow, pow2, pow3, pow4, radians, reciprocal, reflect, refract, replace, round, safeEventCall, sampleIndex, sampleMask, sampler2D, saturate, screenCoordinate, screenUV, select, sig, sign, sin, sinh, smoothstep, sortHeadersByDependencies, sqrt, step, struct, tan, tanh, texture, texture2D, textureSize, toVar, transformDirection, trunc, uint, uniform, uv, uvec2, uvec3, uvec4, variable, vec2, vec3, vec4, vertex, vertexIndex, vertexStage, webgl, webgpu } from './index.js';
5
5
  export { Frame, Fun, Queue } from 'refr';
6
6
 
7
7
  declare const useGL: (props?: Partial<GL>) => reev.EventState<{
8
8
  isNative: boolean;
9
9
  isWebGL: boolean;
10
+ isError: boolean;
10
11
  isLoop: boolean;
11
12
  isGL: true;
12
- width: number;
13
- height: number;
13
+ width?: number;
14
+ height?: number;
14
15
  size: [number, number];
15
16
  mouse: [number, number];
16
17
  count: number;
18
+ loading: number;
17
19
  el: HTMLCanvasElement;
18
- vs: string | Vec4;
19
- fs: string | Vec4;
20
- vert: string | Vec4;
21
- frag: string | Vec4;
22
- vertex: string | Vec4;
23
- fragment: string | Vec4;
20
+ vs?: string | Vec4;
21
+ fs?: string | Vec4;
22
+ vert?: string | Vec4;
23
+ frag?: string | Vec4;
24
+ vertex?: string | Vec4;
25
+ fragment?: string | Vec4;
24
26
  webgpu: WebGPUState;
25
27
  webgl: WebGLState;
26
28
  queue: refr_dist_types_687121c7.Q;
27
29
  frame: refr_dist_types_687121c7.a;
28
30
  ref?: any;
29
- init(): void;
30
- loop(): void;
31
31
  mount(): void;
32
32
  clean(): void;
33
+ error(e?: string): void;
33
34
  render(): void;
34
35
  resize(e?: Event): void;
35
36
  mousemove(e: Event): void;
37
+ loop(): void;
36
38
  _uniform?(key: string, value: Uniform, isMatrix?: boolean): GL;
37
39
  uniform(key: string, value: Uniform, isMatrix?: boolean): GL;
38
40
  uniform(node: NodeProxy): GL;
package/dist/native.js CHANGED
@@ -1,40 +1,38 @@
1
- import{useState as It}from"react";import{durable as de,event as $t}from"reev";import{createFrame as Gt,createQueue as Lt}from"refr";import{nested as ce}from"reev";var d={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)},gt=(e,t)=>e.forEach(t),Ut=(e,...t)=>{gt(e,r=>r(...t))},At=(e="",t="_",r="/")=>e.split(t).join(r),Bt=(e=".pdf")=>e.split(".").pop()?.toLowerCase()??"",Dt=(e=0)=>`${e}`.split(".")[1]?.length??0,Mt=(e=0)=>`${e}`.split(".")[0]?.length-(e<0?1:0),Wt=(e=0,t=-2)=>(t*=-1,t=Math.pow(10,t),e*=t,e=Math.round(e),e/=t,e);var K={bool:"bool",uint:"u32",int:"i32",float:"f32",bvec2:"vec2<bool>",ivec2:"vec2i",uvec2:"vec2u",vec2:"vec2f",bvec3:"vec3<bool>",ivec3:"vec3i",uvec3:"vec3u",vec3:"vec3f",bvec4:"vec4<bool>",ivec4:"vec4i",uvec4:"vec4u",vec4:"vec4f",color:"color",mat2:"mat2x2f",mat3:"mat3x3f",mat4:"mat4x4f",texture:"texture_2d<f32>",sampler2D:"sampler",struct:"struct"},Z=Object.keys(K),Q=["toBool","toUint","toInt","toFloat","toBvec2","toIvec2","toUvec2","toVec2","toBvec3","toIvec3","toUvec3","toVec3","toBvec4","toIvec4","toUvec4","toVec4","toColor","toMat2","toMat3","toMat4"],J={add:"+",sub:"-",mul:"*",div:"/",mod:"%",equal:"==",notEqual:"!=",lessThan:"<",lessThanEqual:"<=",greaterThan:">",greaterThanEqual:">=",and:"&&",or:"||",bitAnd:"&",bitOr:"|",bitXor:"^",shiftLeft:"<<",shiftRight:">>"},xe=Object.keys(J),me=["dot","distance","length","lengthSq","determinant","luminance","all","any","abs","sign","floor","ceil","round","fract","trunc","sin","cos","tan","asin","acos","atan","sinh","cosh","tanh","asinh","acosh","atanh","exp","exp2","log","log2","sqrt","inverseSqrt","normalize","oneMinus","saturate","negate","reciprocal","dFdx","dFdy","fwidth","degrees","radians","cross","reflect","refract","min","max","mix","clamp","step","smoothstep","pow","atan2","texture","textureLod","textureSize","cubeTexture","faceforward","bitcast","cbrt","difference","equals","pow2","pow3","pow4","transformDirection"],ee={1:"float",2:"vec2",3:"vec3",4:"vec4",9:"mat3",16:"mat4"},Te={texture:"vec4",cubeTexture:"vec4",textureSize:"vec4",length:"float",lengthSq:"float",distance:"float",dot:"float",all:"bool",any:"bool",cross:"vec3"},ge={position:"vec4",vertex_index:"uint",instance_index:"uint",front_facing:"bool",frag_depth:"float",sample_index:"uint",sample_mask:"uint",point_coord:"vec2",positionLocal:"vec3",positionWorld:"vec3",positionView:"vec3",normalLocal:"vec3",normalWorld:"vec3",normalView:"vec3",screenCoordinate:"vec2",screenUV:"vec2",gl_FragCoord:"vec4",gl_VertexID:"uint",gl_InstanceID:"uint",gl_FrontFacing:"bool",gl_FragDepth:"float",gl_SampleID:"uint",gl_SampleMask:"uint",gl_PointCoord:"vec2",normal:"vec3",uv:"vec2",color:"vec4"},be=["equal","notEqual","lessThan","lessThanEqual","greaterThan","greaterThanEqual"],ve=["and","or"],he={position:"gl_FragCoord",vertex_index:"gl_VertexID",instance_index:"gl_InstanceID",front_facing:"gl_FrontFacing",frag_depth:"gl_FragDepth",sample_index:"gl_SampleID",sample_mask:"gl_SampleMask",point_coord:"gl_PointCoord",uv:"gl_FragCoord.xy"};var ye=e=>d.str(e)&&/^[xyzwrgbastpq]{1,4}$/.test(e),Ce=e=>xe.includes(e),Xe=e=>me.includes(e),_e=e=>Q.includes(e),W=e=>!e||typeof e!="object"?!1:e.isProxy,te=e=>d.str(e)?Z.includes(e):!1,Pe=e=>{let t=(e>>16&255)/255,r=(e>>8&255)/255,o=(e&255)/255;return[t,r,o]},bt=0,$=()=>`i${bt++}`,G=(e,t)=>d.str(e)?t?.isWebGL?e:K[e]||e:"",Ee=e=>J[e]||e,we=e=>he[e],Ne=e=>{let t=Q.indexOf(e);return t!==-1?Z[t]:"float"},re=(e,t,r=!1,o=!1)=>e.isWebGL?r?n=>e.gl?.attribute?.(t,n):o?n=>e.gl?.texture?.(t,n):n=>e.gl?.uniform?.(t,n):r?n=>e.gl?._attribute?.(t,n):o?n=>e.gl?._texture?.(t,n):n=>e.gl?._uniform?.(t,n),ne=(e,t)=>{if(!e)return;if(!W(e))return t(e);if(e.type!=="conversion")return;let r=e.props.children?.slice(1).filter(Boolean);r?.length&&t(r)},$e=e=>(e.code||(e.code={headers:new Map,fragInputs:new Map,vertInputs:new Map,vertOutputs:new Map,vertVaryings:new Map,dependencies:new Map},e.isWebGL||(e.code.fragInputs.set("position","@builtin(position) position: vec4f"),e.code.vertOutputs.set("position","@builtin(position) position: vec4f"))),e),V=(e,t="",r)=>{e.code?.dependencies?.has(t)||e.code.dependencies.set(t,new Set),te(r)||e.code.dependencies.get(t).add(r)},Ge=(e,t)=>{let r=[],o=new Set,n=new Set,s=i=>{if(n.has(i)||o.has(i))return;n.add(i);let p=t.get(i)||new Set;for(let a of p)e.has(a)&&s(a);n.delete(i),o.add(i),e.has(i)&&r.push([i,e.get(i)])};for(let[i]of e)s(i);return r};var vt=e=>ge[e],Le=(e,t,r)=>be.includes(r)||ve.includes(r)?"bool":e===t?e:e==="float"||e==="int"?t:t==="float"||t==="int"?e:e==="mat4"&&t==="vec4"||e==="mat3"&&t==="vec3"||e==="mat2"&&t==="vec2"?t:e,ht=e=>d.bol(e)?"bool":d.str(e)?"texture":d.num(e)?"float":d.arr(e)?ee[e.length]:"float",oe=e=>ee[e],yt=(e,t)=>{if(e.length===0)return"void";let[r]=e;if(d.str(r))return r;let o=v(r,t);for(let n of e.slice(1))if(o!==v(n,t))throw new Error("glre node system error: defined scope return mismatch");return o},Ct=e=>Te[e],Xt=(e,t)=>{let{type:r,props:o}=e,{id:n,children:s=[],inferFrom:i,layout:p}=o,[a,c,l]=s;if(r==="conversion")return a;if(r==="operator")return Le(v(c,t),v(l,t),a);if(r==="ternary")return Le(v(c,t),v(l,t),"add");if(r==="builtin")return vt(n);if(r==="function")return Ct(a)||v(c,t);if(r==="define"&&te(p?.type))return p?.type;if(r==="attribute"&&d.arr(a)&&t.gl?.count)return oe(a.length/t.gl.count);if(r==="member"){if(ye(a))return oe(a.length);if(W(c)&&d.str(a)){let E=c.props.fields?.[a];if(E)return v(E,t)}return"float"}return i?yt(i,t):v(a,t)},v=(e,t)=>{if(t||(t={}),!W(e))return ht(e);if(d.arr(e))return oe(e.length);if(t.infers||(t.infers=new WeakMap),t.infers.has(e))return t.infers.get(e);let r=Xt(e,t);return t.infers.set(e,r),r};var R=(e,t)=>e.filter(r=>!d.und(r)&&!d.nul(r)).map(r=>f(r,t)).join(", "),Se=(e,t,r,o)=>{if(e.isWebGL)return`texture(${R(o?[t,r,o]:[t,r],e)})`;let n=f(t,e),s=[n,n+"Sampler",f(r,e)];return o?(s.push(f(o,e)),`textureSampleLevel(${s})`):`textureSample(${s})`},Re=(e,t,r,o)=>{let n=`if (${f(t,e)}) {
2
- ${f(r,e)}
3
- }`;for(let s=2;s<o.length;s+=2){let i=s>=o.length-1;n+=i?` else {
4
- ${f(o[s],e)}
5
- }`:` else if (${f(o[s],e)}) {
6
- ${f(o[s+1],e)}
7
- }`}return n},Oe=(e,t,r)=>{let o=`switch (${f(t,e)}) {
1
+ import{useState as Ft}from"react";import{durable as fe,event as wt}from"reev";import{createFrame as Nt,createQueue as Gt}from"refr";import{nested as pe}from"reev";var d={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)},Tt=(e,t)=>e.forEach(t),It=(e,...t)=>{Tt(e,r=>r(...t))},Ut=(e="",t="_",r="/")=>e.split(t).join(r),At=(e=".pdf")=>e.split(".").pop()?.toLowerCase()??"",Bt=(e=0)=>`${e}`.split(".")[1]?.length??0,Dt=(e=0)=>`${e}`.split(".")[0]?.length-(e<0?1:0),Mt=(e=0,t=-2)=>(t*=-1,t=Math.pow(10,t),e*=t,e=Math.round(e),e/=t,e);var j={bool:"bool",uint:"u32",int:"i32",float:"f32",bvec2:"vec2<bool>",ivec2:"vec2i",uvec2:"vec2u",vec2:"vec2f",bvec3:"vec3<bool>",ivec3:"vec3i",uvec3:"vec3u",vec3:"vec3f",bvec4:"vec4<bool>",ivec4:"vec4i",uvec4:"vec4u",vec4:"vec4f",color:"color",mat2:"mat2x2f",mat3:"mat3x3f",mat4:"mat4x4f",texture:"texture_2d<f32>",sampler2D:"sampler",struct:"struct"},K=Object.keys(j),Z=["toBool","toUint","toInt","toFloat","toBvec2","toIvec2","toUvec2","toVec2","toBvec3","toIvec3","toUvec3","toVec3","toBvec4","toIvec4","toUvec4","toVec4","toColor","toMat2","toMat3","toMat4"],Q={add:"+",sub:"-",mul:"*",div:"/",mod:"%",equal:"==",notEqual:"!=",lessThan:"<",lessThanEqual:"<=",greaterThan:">",greaterThanEqual:">=",and:"&&",or:"||",bitAnd:"&",bitOr:"|",bitXor:"^",shiftLeft:"<<",shiftRight:">>"},le=Object.keys(Q),xe=["dot","distance","length","lengthSq","determinant","luminance","all","any","abs","sign","floor","ceil","round","fract","trunc","sin","cos","tan","asin","acos","atan","sinh","cosh","tanh","asinh","acosh","atanh","exp","exp2","log","log2","sqrt","inverseSqrt","normalize","oneMinus","saturate","negate","reciprocal","dFdx","dFdy","fwidth","degrees","radians","cross","reflect","refract","min","max","mix","clamp","step","smoothstep","pow","atan2","texture","textureLod","textureSize","cubeTexture","faceforward","bitcast","cbrt","difference","equals","pow2","pow3","pow4","transformDirection"],J={1:"float",2:"vec2",3:"vec3",4:"vec4",9:"mat3",16:"mat4"},me={texture:"vec4",cubeTexture:"vec4",textureSize:"vec4",length:"float",lengthSq:"float",distance:"float",dot:"float",all:"bool",any:"bool",cross:"vec3"},Te={position:"vec4",vertex_index:"uint",instance_index:"uint",front_facing:"bool",frag_depth:"float",sample_index:"uint",sample_mask:"uint",point_coord:"vec2",positionLocal:"vec3",positionWorld:"vec3",positionView:"vec3",normalLocal:"vec3",normalWorld:"vec3",normalView:"vec3",screenCoordinate:"vec2",screenUV:"vec2",gl_FragCoord:"vec4",gl_VertexID:"uint",gl_InstanceID:"uint",gl_FrontFacing:"bool",gl_FragDepth:"float",gl_SampleID:"uint",gl_SampleMask:"uint",gl_PointCoord:"vec2",normal:"vec3",uv:"vec2",color:"vec4"},ge=["equal","notEqual","lessThan","lessThanEqual","greaterThan","greaterThanEqual"],be=["and","or"],ve={position:"gl_FragCoord",vertex_index:"gl_VertexID",instance_index:"gl_InstanceID",front_facing:"gl_FrontFacing",frag_depth:"gl_FragDepth",sample_index:"gl_SampleID",sample_mask:"gl_SampleMask",point_coord:"gl_PointCoord",uv:"gl_FragCoord.xy"};var he=e=>d.str(e)&&/^[xyzwrgbastpq]{1,4}$/.test(e),ye=e=>le.includes(e),Ce=e=>xe.includes(e),Xe=e=>Z.includes(e),M=e=>!e||typeof e!="object"?!1:e.isProxy,ee=e=>d.str(e)?K.includes(e):!1,_e=e=>{let t=(e>>16&255)/255,r=(e>>8&255)/255,o=(e&255)/255;return[t,r,o]},gt=0,E=()=>`x${gt++}`,G=(e,t)=>d.str(e)?t?.isWebGL?e:j[e]||e:"",Pe=e=>Q[e]||e,Ee=e=>ve[e],$e=e=>{let t=Z.indexOf(e);return t!==-1?K[t]:"float"},te=(e,t,r=!1,o=!1)=>e.isWebGL?r?n=>e.gl?.attribute?.(t,n):o?n=>e.gl?.texture?.(t,n):n=>e.gl?.uniform?.(t,n):r?n=>e.gl?._attribute?.(t,n):o?n=>e.gl?._texture?.(t,n):n=>e.gl?._uniform?.(t,n),re=(e,t)=>{if(d.und(e))return;if(!M(e))return t(e);if(e.type!=="conversion")return;let r=e.props.children?.slice(1).filter(Boolean);r?.length&&t(r)},we=e=>(e.code||(e.code={headers:new Map,fragInputs:new Map,vertInputs:new Map,vertOutputs:new Map,vertVaryings:new Map,dependencies:new Map},e.isWebGL||(e.code.fragInputs.set("position","@builtin(position) position: vec4f"),e.code.vertOutputs.set("position","@builtin(position) position: vec4f"))),e),W=(e,t="",r)=>{e.code?.dependencies?.has(t)||e.code.dependencies.set(t,new Set),ee(r)||e.code.dependencies.get(t).add(r)},Ne=(e,t)=>{let r=[],o=new Set,n=new Set,s=a=>{if(n.has(a)||o.has(a))return;n.add(a);let c=t.get(a)||new Set;for(let i of c)e.has(i)&&s(i);n.delete(a),o.add(a),e.has(a)&&r.push([a,e.get(a)])};for(let[a]of e)s(a);return r};var bt=e=>Te[e],Ge=(e,t,r)=>ge.includes(r)||be.includes(r)?"bool":e===t?e:e==="float"||e==="int"?t:t==="float"||t==="int"?e:e==="mat4"&&t==="vec4"||e==="mat3"&&t==="vec3"||e==="mat2"&&t==="vec2"?t:e,vt=e=>d.bol(e)?"bool":d.str(e)?"texture":d.num(e)?"float":d.arr(e)?J[e.length]:"float",ne=e=>J[e],ht=(e,t)=>{if(e.length===0)return"void";let[r]=e;if(d.str(r))return r;let o=h(r,t);for(let n of e.slice(1))if(o!==h(n,t))throw new Error("glre node system error: defined scope return mismatch");return o},yt=e=>me[e],Ct=(e,t)=>{let{type:r,props:o}=e,{id:n,children:s=[],inferFrom:a,layout:c}=o,[i,f,l]=s;if(r==="conversion")return i;if(r==="operator")return Ge(h(f,t),h(l,t),i);if(r==="ternary")return Ge(h(f,t),h(l,t),"add");if(r==="builtin")return bt(n);if(r==="function")return yt(i)||h(f,t);if(r==="define"&&ee(c?.type))return c?.type;if(r==="attribute"&&d.arr(i)&&t.gl?.count)return ne(i.length/t.gl.count);if(r==="member"){if(he(i))return ne(i.length);if(M(f)&&d.str(i)){let _=f.props.fields?.[i];if(_)return h(_,t)}return"float"}return a?ht(a,t):h(i,t)},h=(e,t)=>{if(t||(t={}),!M(e))return vt(e);if(d.arr(e))return ne(e.length);if(t.infers||(t.infers=new WeakMap),t.infers.has(e))return t.infers.get(e);let r=Ct(e,t);return t.infers.set(e,r),r};var R=(e,t)=>e.filter(r=>!d.und(r)&&!d.nul(r)).map(r=>p(r,t)).join(", "),Le=(e,t,r,o)=>{if(e.isWebGL)return`texture(${R(o?[t,r,o]:[t,r],e)})`;let n=p(t,e),s=[n,n+"Sampler",p(r,e)];return o?(s.push(p(o,e)),`textureSampleLevel(${s})`):`textureSample(${s})`},Se=(e,t,r,o)=>{let n=`if (${p(t,e)}) {
2
+ ${p(r,e)}
3
+ }`;for(let s=2;s<o.length;s+=2){let a=s>=o.length-1;n+=a?` else {
4
+ ${p(o[s],e)}
5
+ }`:` else if (${p(o[s],e)}) {
6
+ ${p(o[s+1],e)}
7
+ }`}return n},Re=(e,t,r)=>{let o=`switch (${p(t,e)}) {
8
8
  `;for(let n=1;n<r.length;n+=2)n>=r.length-1&&r.length%2===0?o+=`default:
9
- ${f(r[n],e)}
9
+ ${p(r[n],e)}
10
10
  break;
11
- `:n+1<r.length&&(o+=`case ${f(r[n],e)}:
12
- ${f(r[n+1],e)}
11
+ `:n+1<r.length&&(o+=`case ${p(r[n],e)}:
12
+ ${p(r[n+1],e)}
13
13
  break;
14
- `);return o+="}",o},Fe=(e,t,r)=>{let o=v(t,e),n=r?.props?.id;if(e.isWebGL)return`${o} ${n} = ${f(t,e)};`;let s=G(o);return`var ${n}: ${s} = ${f(t,e)};`},Ie=(e,t,r)=>{let{id:o,children:n=[],layout:s}=t,[i,...p]=n,a=[],c=[];if(s?.inputs)for(let b of s.inputs)a.push([b.name,b.type]);else for(let b=0;b<p.length;b++)a.push([`p${b}`,v(p[b],e)]);let l=[];if(e?.isWebGL){for(let[b,m]of a)V(e,o,m),c.push(`${m} ${b}`);V(e,o,r),l.push(`${r} ${o}(${c}) {`)}else{for(let[b,m]of a)c.push(`${b}: ${G(m,e)}`);l.push(`fn ${o}(${c}) -> ${G(r,e)} {`)}let E=f(i,e);return E&&l.push(E),l.push("}"),l.join(`
15
- `)},Ue=(e,t,r={})=>{let o=[];for(let s in r){let i=r[s],p=v(i,e);e.isWebGL&&V(e,t,p),o.push(e.isWebGL?`${p} ${s};`:`${s}: ${G(p,e)},`)}let n=o.join(`
14
+ `);return o+="}",o},Oe=(e,t,r)=>{let o=h(t,e),n=r?.props?.id;if(e.isWebGL)return`${o} ${n} = ${p(t,e)};`;let s=G(o);return`var ${n}: ${s} = ${p(t,e)};`},Fe=(e,t,r={})=>{let o=[];for(let s in r){let a=r[s],c=h(a,e);e.isWebGL&&W(e,t,c),o.push(e.isWebGL?`${c} ${s};`:`${s}: ${G(c,e)},`)}let n=o.join(`
16
15
  `);return`struct ${t} {
17
16
  ${n}
18
- };`},Ae=(e,t,r="",o,n)=>{if(e.isWebGL)if(n){let s=[];for(let i in o)s.push(n[i]);return`${t} ${r} = ${t}(${R(s,e)});`}else return`${t} ${r};`;else if(n){let s=[];for(let i in o)s.push(n[i]);return`var ${r}: ${t} = ${t}(${R(s,e)});`}else return`var ${r}: ${t};`},Be=(e,t,r)=>e.isWebGL?`${r} ${t};`:`@location(${e.code?.vertVaryings?.size||0}) ${t}: ${G(r,e)}`,De=(e,t,r)=>{let o=r==="sampler2D"||r==="texture";if(e.isWebGL)return o?`uniform sampler2D ${t};`:`uniform ${r} ${t};`;if(o){let{group:p=1,binding:a=0}=e.gl?.webgpu?.textures.map.get(t)||{};return`@group(${p}) @binding(${a}) var ${t}Sampler: sampler;
19
- @group(${p}) @binding(${a+1}) var ${t}: texture_2d<f32>;`}let{group:n=0,binding:s=0}=e.gl?.webgpu?.uniforms.map.get(t)||{},i=G(r,e);return`@group(${n}) @binding(${s}) var<uniform> ${t}: ${i};`},Me=(e,t,r)=>{if(e.isWebGL)return`${r} ${t};`;let{location:o=0}=e.gl?.webgpu?.attribs.map.get(t)||{},n=G(r,e);return`@location(${o}) ${t}: ${n}`},We=(e,t,r,o)=>e.isWebGL?`const ${r} ${t} = ${o};`:`const ${t}: ${G(r,e)} = ${o};`;var f=(e,t)=>{if(t||(t={}),$e(t),d.arr(e))return R(e,t);if(d.str(e))return e;if(d.num(e)){let m=`${e}`;return m.includes(".")?m:m+".0"}if(d.bol(e))return e?"true":"false";if(!e)return"";let{type:r,props:o}=e,{id:n="",children:s=[],fields:i,initialValues:p}=o,[a,c,l,E]=s;if(r==="variable")return n;if(r==="member")return`${f(c,t)}.${f(a,t)}`;if(r==="ternary")return t.isWebGL?`(${f(l,t)} ? ${f(a,t)} : ${f(c,t)})`:`select(${f(a,t)}, ${f(c,t)}, ${f(l,t)})`;if(r==="conversion")return`${G(a,t)}(${R(s.slice(1),t)})`;if(r==="operator")return a==="not"||a==="bitNot"?`!${f(c,t)}`:`(${f(c,t)} ${Ee(a)} ${f(l,t)})`;if(r==="function")return a==="negate"?`(-${R(s.slice(1),t)})`:a==="texture"?Se(t,c,l,E):`${a}(${R(s.slice(1),t)})`;if(r==="scope")return s.map(m=>f(m,t)).join(`
20
- `);if(r==="assign")return`${f(a,t)} = ${f(c,t)};`;if(r==="return")return`return ${f(a,t)};`;if(r==="loop")return t.isWebGL?`for (int i = 0; i < ${f(a,t)}; i += 1) {
21
- ${f(c,t)}
22
- }`:`for (var i: i32 = 0; i < ${f(a,t)}; i++) {
23
- ${f(c,t)}
24
- }`;if(r==="if")return Re(t,a,c,s);if(r==="switch")return Oe(t,a,s);if(r==="declare")return Fe(t,a,c);if(r==="define")return t.code?.headers.has(n)||t.code?.headers.set(n,Ie(t,o,v(e,t))),`${n}(${R(s.slice(1),t)})`;if(r==="struct")return t.code?.headers.has(n)||t.code?.headers.set(n,Ue(t,n,i)),Ae(t,n,a.props.id,i,p);if(r==="varying"){if(t.code?.vertOutputs.has(n))return t.isWebGL?`${n}`:`out.${n}`;let m=Be(t,n,v(e,t));return t.code?.fragInputs.set(n,m),t.code?.vertOutputs.set(n,m),t.code?.vertVaryings.set(n,f(a,t)),t.isWebGL?`${n}`:`out.${n}`}if(r==="builtin"){if(t.isWebGL)return we(n);if(n==="position")return"out.position";let m=`@builtin(${n}) ${n}: ${G(v(e,t),t)}`;return t.isFrag?t.code?.fragInputs.set(n,m):t.code?.vertInputs.set(n,m),`in.${n}`}if(r==="attribute"){let m=re(t,n,!0);return ne(a,m),e.listeners.add(m),t.code?.vertInputs.set(n,Me(t,n,v(e,t))),t.isWebGL?`${n}`:`in.${n}`}if(t.code?.headers.has(n))return n;let b="";if(r==="uniform"){let m=v(e,t),A=re(t,n,!1,m==="texture");ne(a,A),e.listeners.add(A),b=De(t,n,m)}return r==="constant"&&(b=We(t,n,v(e,t),f(a,t))),b?(t.code?.headers.set(n,b),n):f(a,t)};var O=null,U=null,I=e=>{if(!O||(O.props.children||(O.props.children=[]),O.props.children.push(e),e.type!=="return"||!U))return;let{props:t}=U;t.inferFrom||(t.inferFrom=[]),t.inferFrom.push(e)},Ve=(e,t)=>{t||(t=$());let r=x("variable",{id:t,inferFrom:[e]}),o=x("declare",null,e,r);return I(o),r},ze=(e,t)=>{let r=x("assign",null,e,t);return I(r),e},_t=e=>{let t=x("return",{inferFrom:[e]},e);return I(t),t},cr=(e,t=$())=>(r={},o=$())=>{let n=x("variable",{id:o,inferFrom:[t]}),s=x("struct",{id:t,fields:e,initialValues:r},n);return I(s),n},F=(e,t,r=U)=>{let o=O,n=U;O=e,U=r,o&&(e.props.parent=o);let s=t();s&&_t(s),O=o,U=n},fr=(e,t)=>{let r=x("scope");F(r,t);let o=x("if",null,e,r);I(o);let n=()=>({ElseIf:(s,i)=>{let p=x("scope");return F(p,i),o.props.children.push(s,p),n()},Else:s=>{let i=x("scope");F(i,s),o.props.children.push(i)}});return n()},dr=(e,t)=>{let r=x("scope");F(r,()=>t({i:x("variable",{id:"i",inferFrom:[T("int",0)]})}));let o=x("loop",null,e,r);return I(o),o},lr=e=>{let t=x("switch",null,e);I(t);let r=()=>({Case:(...o)=>n=>{let s=x("scope");F(s,n);for(let i of o)t.props.children.push(i,s);return r()},Default:o=>{let n=x("scope");F(n,o),t.props.children.push(n)}});return r()},xr=(e,t=$())=>{let r,o=(...n)=>{let s=r?.name||t,i=x("scope"),p=[],a=[];if(r?.inputs)for(let l of r.inputs)a.push({id:l.name,inferFrom:[T(l.type)]});else for(let l=0;l<n.length;l++)a.push({id:`p${l}`,inferFrom:[n[l]]});for(let l of a)p.push(x("variable",l));let c=x("define",{id:s,layout:r},i,...n);return F(i,()=>e(p),c),c};return o.setLayout=n=>(r=n,o),o};var Pt=(e,t)=>{if(t==="string")return f(e)},x=(e,t,...r)=>{t||(t={}),r.length&&(t.children=r);let o=new Set,n=(p,a)=>{if(a==="type")return e;if(a==="props")return t;if(a==="toVar")return Ve.bind(null,i);if(a==="assign")return ze.bind(null,i);if(a==="isProxy")return!0;if(a==="toString")return f.bind(null,i);if(a===Symbol.toPrimitive)return Pt.bind(null,i);if(a==="listeners")return o;if(Ce(a))return(...c)=>Et(a,i,...c);if(Xe(a))return(...c)=>u(a,i,...c);if(_e(a))return()=>T(Ne(a),i);if(d.str(a))return ke(a,i)},s=(p,a,c)=>(a==="value"&&o.forEach(l=>l(c)),d.str(a)&&ke(a,i).assign(c),!0),i=new Proxy({},{get:n,set:s});return i},hr=(e,t=$())=>x("attribute",{id:t},e),yr=(e,t=$())=>x("constant",{id:t},e),z=(e,t=$())=>x("uniform",{id:t},e),Cr=(e=$())=>x("variable",{id:e}),C=(e=$())=>x("builtin",{id:e}),Xr=(e,t=$())=>x("varying",{id:t,inferFrom:[e]},e),ke=(e,t)=>x("member",null,e,t),_r=(e,t,r)=>x("ternary",null,e,t,r),Et=(e,...t)=>x("operator",null,e,...t),u=(e,...t)=>x("function",null,e,...t),T=(e,...t)=>x("conversion",null,e,...t);var wt=`
17
+ };`},Ie=(e,t,r="",o,n)=>{if(e.isWebGL)if(n){let s=[];for(let a in o)s.push(n[a]);return`${t} ${r} = ${t}(${R(s,e)});`}else return`${t} ${r};`;else if(n){let s=[];for(let a in o)s.push(n[a]);return`var ${r}: ${t} = ${t}(${R(s,e)});`}else return`var ${r}: ${t};`},Ue=(e,t,r)=>{let{id:o,children:n=[],layout:s}=t,[a,...c]=n,i=[],f=[];if(s?.inputs)for(let v of s.inputs)i.push([v.name,v.type]);else for(let v=0;v<c.length;v++)i.push([`p${v}`,h(c[v],e)]);let l=[];if(e?.isWebGL){for(let[v,g]of i)W(e,o,g),f.push(`${g} ${v}`);W(e,o,r),l.push(`${r} ${o}(${f}) {`)}else{for(let[v,g]of i)f.push(`${v}: ${G(g,e)}`);l.push(`fn ${o}(${f}) -> ${G(r,e)} {`)}let _=p(a,e);return _&&l.push(_),l.push("}"),l.join(`
18
+ `)},Ae=(e,t,r)=>e.isWebGL?`${r} ${t};`:`@location(${e.code?.vertVaryings?.size||0}) ${t}: ${G(r,e)}`,Be=(e,t,r)=>{let o=r==="sampler2D"||r==="texture";if(e.isWebGL)return o?`uniform sampler2D ${t};`:`uniform ${r} ${t};`;if(o){let{group:c=1,binding:i=0}=e.gl?.webgpu?.textures.map.get(t)||{};return`@group(${c}) @binding(${i}) var ${t}Sampler: sampler;
19
+ @group(${c}) @binding(${i+1}) var ${t}: texture_2d<f32>;`}let{group:n=0,binding:s=0}=e.gl?.webgpu?.uniforms.map.get(t)||{},a=G(r,e);return`@group(${n}) @binding(${s}) var<uniform> ${t}: ${a};`},De=(e,t,r)=>{if(e.isWebGL)return`${r} ${t};`;let{location:o=0}=e.gl?.webgpu?.attribs.map.get(t)||{},n=G(r,e);return`@location(${o}) ${t}: ${n}`},Me=(e,t,r,o)=>e.isWebGL?`const ${r} ${t} = ${o};`:`const ${t}: ${G(r,e)} = ${o};`;var p=(e,t)=>{if(t||(t={}),we(t),d.arr(e))return R(e,t);if(d.str(e))return e;if(d.num(e)){let g=`${e}`;return g.includes(".")?g:g+".0"}if(d.bol(e))return e?"true":"false";if(!e)return"";let{type:r,props:o}=e,{id:n="i",children:s=[],fields:a,initialValues:c}=o,[i,f,l,_]=s;if(r==="variable")return n;if(r==="member")return`${p(f,t)}.${p(i,t)}`;if(r==="ternary")return t.isWebGL?`(${p(l,t)} ? ${p(i,t)} : ${p(f,t)})`:`select(${p(i,t)}, ${p(f,t)}, ${p(l,t)})`;if(r==="conversion")return`${G(i,t)}(${R(s.slice(1),t)})`;if(r==="operator")return i==="not"||i==="bitNot"?`!${p(f,t)}`:`(${p(f,t)} ${Pe(i)} ${p(l,t)})`;if(r==="function")return i==="negate"?`(-${p(f,t)})`:i==="oneMinus"?`(1.0-${p(f,t)})`:i==="texture"?Le(t,f,l,_):i==="atan2"&&t.isWebGL?`atan(${p(f,t)}, ${p(l,t)})`:`${i}(${R(s.slice(1),t)})`;if(r==="scope")return s.map(g=>p(g,t)).join(`
20
+ `);if(r==="assign")return`${p(i,t)} = ${p(f,t)};`;if(r==="return")return`return ${p(i,t)};`;if(r==="loop")return t.isWebGL?`for (int ${n} = 0; ${n} < ${p(i,t)}; ${n} += 1) {
21
+ ${p(f,t)}
22
+ }`:`for (var ${n}: i32 = 0; ${n} < ${p(i,t)}; ${n}++) {
23
+ ${p(f,t)}
24
+ }`;if(r==="if")return Se(t,i,f,s);if(r==="switch")return Re(t,i,s);if(r==="declare")return Oe(t,i,f);if(r==="define")return t.code?.headers.has(n)||t.code?.headers.set(n,Ue(t,o,h(e,t))),`${n}(${R(s.slice(1),t)})`;if(r==="struct")return t.code?.headers.has(n)||t.code?.headers.set(n,Fe(t,n,a)),Ie(t,n,i.props.id,a,c);if(r==="varying"){if(t.code?.vertOutputs.has(n))return t.isWebGL?`${n}`:`out.${n}`;let g=Ae(t,n,h(e,t));return t.code?.fragInputs.set(n,g),t.code?.vertOutputs.set(n,g),t.code?.vertVaryings.set(n,p(i,t)),t.isWebGL?`${n}`:`out.${n}`}if(r==="builtin"){if(t.isWebGL)return Ee(n);if(n==="position")return"out.position";let g=`@builtin(${n}) ${n}: ${G(h(e,t),t)}`;return t.isFrag?t.code?.fragInputs.set(n,g):t.code?.vertInputs.set(n,g),`in.${n}`}if(r==="attribute"){let g=te(t,n,!0);return re(i,g),e.listeners.add(g),t.code?.vertInputs.set(n,De(t,n,h(e,t))),t.isWebGL?`${n}`:`in.${n}`}if(t.code?.headers.has(n))return n;let v="";if(r==="uniform"){let g=h(e,t),A=te(t,n,!1,g==="texture");re(i,A),e.listeners.add(A),v=Be(t,n,g)}return r==="constant"&&(v=Me(t,n,h(e,t),p(i,t))),v?(t.code?.headers.set(n,v),n):p(i,t)};var O=null,U=null,I=e=>{if(!O||(O.props.children||(O.props.children=[]),O.props.children.push(e),e.type!=="return"||!U))return;let{props:t}=U;t.inferFrom||(t.inferFrom=[]),t.inferFrom.push(e)},We=(e,t)=>{t||(t=E());let r=x("variable",{id:t,inferFrom:[e]}),o=x("declare",null,e,r);return I(o),r},Ve=(e,t)=>{let r=x("assign",null,e,t);return I(r),e},Xt=e=>{let t=x("return",{inferFrom:[e]},e);return I(t),t},pr=(e,t=E())=>(r={},o=E())=>{let n=x("variable",{id:o,inferFrom:[t]}),s=x("struct",{id:t,fields:e,initialValues:r},n);return I(s),n},F=(e,t,r=U)=>{let o=O,n=U;O=e,U=r,o&&(e.props.parent=o);let s=t();s&&Xt(s),O=o,U=n},cr=(e,t)=>{let r=x("scope");F(r,t);let o=x("if",null,e,r);I(o);let n=()=>({ElseIf:(s,a)=>{let c=x("scope");return F(c,a),o.props.children.push(s,c),n()},Else:s=>{let a=x("scope");F(a,s),o.props.children.push(a)}});return n()},fr=(e,t)=>{let r=x("scope"),o=E();F(r,()=>t({i:x("variable",{id:o,inferFrom:[T("int",0)]})}));let n=x("loop",{id:o},e,r);return I(n),n},dr=e=>{let t=x("switch",null,e);I(t);let r=()=>({Case:(...o)=>n=>{let s=x("scope");F(s,n);for(let a of o)t.props.children.push(a,s);return r()},Default:o=>{let n=x("scope");F(n,o),t.props.children.push(n)}});return r()},lr=(e,t=E())=>{let r,o=(...n)=>{let s=r?.name||t,a=x("scope"),c=[],i=[];if(r?.inputs)for(let l of r.inputs)i.push({id:l.name,inferFrom:[T(l.type)]});else for(let l=0;l<n.length;l++)i.push({id:`p${l}`,inferFrom:[n[l]]});for(let l of i)c.push(x("variable",l));let f=x("define",{id:s,layout:r},a,...n);return F(a,()=>e(c),f),f};return o.setLayout=n=>(r=n,o),o};var _t=(e,t)=>{if(t==="string")return p(e)},x=(e,t,...r)=>{t||(t={}),r.length&&(t.children=r);let o=new Set,n=(c,i)=>{if(i==="type")return e;if(i==="props")return t;if(i==="toVar")return We.bind(null,a);if(i==="assign")return Ve.bind(null,a);if(i==="isProxy")return!0;if(i==="toString")return p.bind(null,a);if(i===Symbol.toPrimitive)return _t.bind(null,a);if(i==="listeners")return o;if(ye(i))return(...f)=>Pt(i,a,...f);if(Ce(i))return(...f)=>u(i,a,...f);if(Xe(i))return()=>T($e(i),a);if(d.str(i))return ze(i,a)},s=(c,i,f)=>(i==="value"&&o.forEach(l=>l(f)),d.str(i)&&ze(i,a).assign(f),!0),a=new Proxy({},{get:n,set:s});return a},vr=(e,t=E())=>x("attribute",{id:t},e),hr=(e,t=E())=>x("constant",{id:t},e),V=(e,t=E())=>x("uniform",{id:t},e),yr=(e=E())=>x("variable",{id:e}),C=(e=E())=>x("builtin",{id:e}),Cr=(e,t=E())=>x("varying",{id:t,inferFrom:[e]},e),ze=(e,t)=>x("member",null,e,t),Xr=(e,t,r)=>x("ternary",null,e,t,r),Pt=(e,...t)=>x("operator",null,e,...t),u=(e,...t)=>x("function",null,e,...t),T=(e,...t)=>x("conversion",null,e,...t);var Et=`
25
25
  #version 300 es
26
26
  precision mediump float;
27
27
  out vec4 fragColor;
28
- `.trim(),Ye=(e,t)=>{let r=f(e,t),o="";return t.isWebGL&&t.code?.dependencies?o=Ge(t.code.headers,t.code.dependencies).map(([,s])=>s).join(`
28
+ `.trim(),qe=(e,t)=>{let r=p(e,t),o="";return t.isWebGL&&t.code?.dependencies?o=Ne(t.code.headers,t.code.dependencies).map(([,s])=>s).join(`
29
29
  `):o=Array.from(t.code?.headers?.values()||[]).join(`
30
- `),[o,r]},se=(e,t)=>`struct ${e} {
30
+ `),[o,r]},oe=(e,t)=>`struct ${e} {
31
31
  ${Array.from(t.values()).join(`,
32
32
  `)}
33
- }`,k=(e,t)=>{if(d.str(e))return e.trim();t.code?.headers?.clear(),t.isFrag=!1;let[r,o]=Ye(e,t),n=[];if(t.isWebGL){n.push("#version 300 es");for(let i of t.code?.vertInputs?.values()||[])n.push(`in ${i}`);for(let i of t.code?.vertOutputs?.values()||[])n.push(`out ${i}`);n.push(r),n.push("void main() {"),n.push(` gl_Position = ${o};`);for(let[i,p]of t.code?.vertVaryings?.entries()||[])n.push(` ${i} = ${p};`)}else{t.code?.vertInputs?.size&&n.push(se("In",t.code.vertInputs)),t.code?.vertOutputs?.size&&n.push(se("Out",t.code.vertOutputs)),n.push(r),n.push("@vertex"),n.push(`fn main(${t.code?.vertInputs?.size?"in: In":""}) -> Out {`),n.push(" var out: Out;"),n.push(` out.position = ${o};`);for(let[i,p]of t.code?.vertVaryings?.entries()||[])n.push(` out.${i} = ${p};`);n.push(" return out;")}n.push("}");let s=n.filter(Boolean).join(`
34
- `).trim();return console.log(`\u2193\u2193\u2193generated\u2193\u2193\u2193
35
- ${s}`),s},q=(e,t)=>{if(d.str(e))return e.trim();t.code?.headers?.clear(),t.isFrag=!0;let[r,o]=Ye(e,t),n=[];if(t.isWebGL){n.push(wt);for(let i of t.code?.fragInputs?.values()||[])n.push(`in ${i}`);n.push(r),n.push(`void main() {
36
- fragColor = ${o};`)}else t.code?.fragInputs?.size&&n.push(se("Out",t.code.fragInputs)),n.push(r),n.push(`@fragment
37
- fn main(out: Out) -> @location(0) vec4f {`),n.push(` return ${o};`);n.push("}");let s=n.filter(Boolean).join(`
38
- `).trim();return console.log(`\u2193\u2193\u2193generated\u2193\u2193\u2193
39
- ${s}`),s},ie=C("position"),ae=C("vertex_index"),Gr=C("instance_index"),Lr=C("front_facing"),Sr=C("frag_depth"),Rr=C("sample_index"),Or=C("sample_mask"),Fr=C("point_coord"),Ir=C("position"),Ur=C("positionWorld"),Ar=C("positionView"),Br=C("normalLocal"),Dr=C("normalWorld"),Mr=C("normalView"),Wr=C("screenCoordinate"),Vr=C("screenUV"),Y=e=>T("float",e),M=e=>T("int",e),zr=e=>T("uint",e),kr=e=>T("bool",e),He=(e,t)=>T("vec2",e,t),qe=(e,t,r)=>T("vec3",e,t,r),ue=(e,t,r,o)=>T("vec4",e,t,r,o),qr=(...e)=>T("mat2",...e),Yr=(...e)=>T("mat3",...e),Hr=(...e)=>T("mat4",...e),jr=(e,t)=>T("ivec2",e,t),Kr=(e,t,r)=>T("ivec3",e,t,r),Zr=(e,t,r,o)=>T("ivec4",e,t,r,o),Qr=(e,t)=>T("uvec2",e,t),Jr=(e,t,r)=>T("uvec3",e,t,r),en=(e,t,r,o)=>T("uvec4",e,t,r,o),tn=(e,t)=>T("bvec2",e,t),rn=(e,t,r)=>T("bvec3",e,t,r),nn=(e,t,r,o)=>T("bvec4",e,t,r,o),on=e=>T("texture",e),sn=()=>T("sampler2D"),an=(e,t,r)=>d.num(e)&&d.und(t)&&d.und(r)?qe(...Pe(e)):qe(e,t,r),pe=z(He(),"iResolution"),un=z(He(),"iMouse"),pn=z(Y(),"iTime"),cn=ie.xy.div(pe),fn=(e,t,r)=>u("texture",e,t,r),dn=(e,t,r)=>u("cubeTexture",e,t,r),ln=(e,t)=>u("textureSize",e,t),xn=e=>u("length",e),mn=e=>u("lengthSq",e),Tn=(e,t)=>u("distance",e,t),gn=(e,t)=>u("dot",e,t),bn=e=>u("all",e),vn=e=>u("any",e),hn=(e,t)=>u("cross",e,t),yn=e=>u("abs",e),Cn=e=>u("sign",e),Xn=e=>u("floor",e),_n=e=>u("ceil",e),Pn=e=>u("round",e),je=e=>u("fract",e),En=e=>u("trunc",e),wn=e=>u("sin",e),Nn=e=>u("cos",e),$n=e=>u("tan",e),Gn=e=>u("asin",e),Ln=e=>u("acos",e),Sn=e=>u("atan",e),Rn=e=>u("sinh",e),On=e=>u("cosh",e),Fn=e=>u("tanh",e),In=e=>u("asinh",e),Un=e=>u("acosh",e),An=e=>u("atanh",e),Bn=e=>u("exp",e),Dn=e=>u("exp2",e),Mn=e=>u("log",e),Wn=e=>u("log2",e),Vn=e=>u("sqrt",e),zn=e=>u("inverseSqrt",e),kn=e=>u("normalize",e),qn=e=>u("oneMinus",e),Yn=e=>u("saturate",e),Hn=e=>u("negate",e),jn=e=>u("reciprocal",e),Kn=e=>u("dFdx",e),Zn=e=>u("dFdy",e),Qn=e=>u("fwidth",e),Jn=e=>u("degrees",e),eo=e=>u("radians",e),to=(e,t)=>u("reflect",e,t),ro=(e,t,r)=>u("refract",e,t,r),no=(e,t)=>u("min",e,t),oo=(e,t)=>u("max",e,t),so=(e,t,r)=>u("mix",e,t,r),io=(e,t,r)=>u("clamp",e,t,r),ao=(e,t)=>u("step",e,t),uo=(e,t,r)=>u("smoothstep",e,t,r),po=(e,t)=>u("atan2",e,t),co=(e,t)=>u("pow",e,t),fo=e=>u("pow2",e),lo=e=>u("pow3",e),xo=e=>u("pow4",e),mo=(e,t)=>u("bitcast",e,t),To=e=>u("cbrt",e),go=(e,t)=>u("difference",e,t),bo=(e,t)=>u("equals",e,t),vo=(e,t,r)=>u("faceforward",e,t,r),ho=(e,t)=>u("transformDirection",e,t);var Ke=(e,t,r)=>{let o=e.createShader(r);if(!o)throw new Error("Failed to create shader");if(e.shaderSource(o,t.trim()),e.compileShader(o),e.getShaderParameter(o,e.COMPILE_STATUS))return o;let n=e.getShaderInfoLog(o);e.deleteShader(o),console.warn(`Could not compile shader: ${n}`)},Ze=(e,t,r,o=()=>{})=>{let n=e.createProgram(),s=Ke(e,r,e.FRAGMENT_SHADER),i=Ke(e,t,e.VERTEX_SHADER);if(!s||!i)return o();if(e.attachShader(n,i),e.attachShader(n,s),e.linkProgram(n),e.getProgramParameter(n,e.LINK_STATUS))return n;let p=e.getProgramInfoLog(n);e.deleteProgram(n),o(),console.warn(`Could not link program: ${p}`)},Qe=(e,t)=>{let r=e.createBuffer();return e.bindBuffer(e.ARRAY_BUFFER,r),e.bufferData(e.ARRAY_BUFFER,new Float32Array(t),e.STATIC_DRAW),e.bindBuffer(e.ARRAY_BUFFER,null),r},Je=(e,t)=>{let r=e.createBuffer();return e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,r),e.bufferData(e.ELEMENT_ARRAY_BUFFER,new Int16Array(t),e.STATIC_DRAW),e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,null),r},et=(e,t,r)=>{r&&(e=Math.max(...r)+1);let o=t.length/e;return Math.floor(o)},tt=(e,t,r,o,n)=>{e.bindBuffer(e.ARRAY_BUFFER,o),e.enableVertexAttribArray(r),e.vertexAttribPointer(r,t,e.FLOAT,!1,0,0),n&&e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,n)},rt=(e,t,r,o)=>{let n=e.createTexture();e.bindTexture(e.TEXTURE_2D,n),e.texImage2D(e.TEXTURE_2D,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,t),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),e.uniform1i(r,o),e.activeTexture(e.TEXTURE0+o),e.bindTexture(e.TEXTURE_2D,n)};var nt=async e=>{let t=e.el.getContext("webgl2"),r={isWebGL:!0,gl:e},o=q(e.fs,r),n=k(e.vs,r),s=Ze(t,n,o,()=>void(e.isLoop=!1));t.useProgram(s);let i=0,p=ce(w=>t.getUniformLocation(s,w)),a=ce(w=>t.getAttribLocation(s,w)),c=ce(()=>i++);return{render:()=>{t.clear(t.COLOR_BUFFER_BIT),t.viewport(0,0,...e.size),t.drawArrays(t.TRIANGLES,0,3)},clean:()=>t.deleteProgram(s),_attribute:(w="",_,N)=>{let L=a(w,!0),B=Qe(t,_),H=Je(t,N),h=et(e.count,_,N);tt(t,h,L,B,H)},_uniform:(w,_)=>{let N=p(w);if(d.num(_))return t.uniform1f(N,_);let L=_.length;if(L<=4)return t[`uniform${L}fv`](N,_);L=Math.sqrt(L)<<0,t[`uniformMatrix${L}fv`](N,!1,_)},_texture:(w,_)=>{let N=new Image;Object.assign(N,{src:_,crossOrigin:"anonymous"}),N.decode().then(()=>{let L=p(w),B=c(w);rt(t,N,L,B)})},webgl:{context:t,program:s}}};import{nested as fe}from"reev";var ot=async e=>{let t=navigator.gpu,r=t.getPreferredCanvasFormat(),n=await(await t.requestAdapter()).requestDevice();return e.configure({device:n,format:r,alphaMode:"opaque"}),{device:n,format:r}},st=()=>{let e=0,t=0,r=0;return{uniform:()=>{let o=Math.floor(e/12),n=e%12;return e++,{group:o,binding:n}},texture:()=>{let n=Math.floor(e/12)+1+Math.floor(t/6),s=t%6*2;return t++,{group:n,binding:s}},attrib:()=>{let o=r;return r++,{location:o}}}},Nt=e=>e===2?"float32x2":e===3?"float32x3":e===4?"float32x4":"float32",it=e=>{let t=[],r=[];for(let{buffer:o,location:n,stride:s}of e)t[n]=o,r[n]={arrayStride:s*4,attributes:[{shaderLocation:n,offset:0,format:Nt(s)}]};return{vertexBuffers:t,bufferLayouts:r}},at=(e,t,r)=>{let o=new Map,n={bindGroups:[],bindGroupLayouts:[]},s=(i,p,a)=>{o.has(i)||o.set(i,{layouts:[],bindings:[]});let{layouts:c,bindings:l}=o.get(i);c.push(p),l.push(a)};for(let{binding:i,buffer:p,group:a}of t)s(a,{binding:i,visibility:3,buffer:{type:"uniform"}},{binding:i,resource:{buffer:p}});for(let{binding:i,group:p,sampler:a,view:c}of r)s(p,{binding:i,visibility:2,sampler:{}},{binding:i,resource:a}),s(p,{binding:i+1,visibility:2,texture:{}},{binding:i+1,resource:c});for(let[i,{layouts:p,bindings:a}]of o)n.bindGroupLayouts[i]=e.createBindGroupLayout({entries:p}),n.bindGroups[i]=e.createBindGroup({layout:n.bindGroupLayouts[i],entries:a});return n},ut=(e,t,r,o,n,s)=>e.createRenderPipeline({vertex:{module:e.createShaderModule({label:"vert",code:n}),entryPoint:"main",buffers:r},fragment:{module:e.createShaderModule({label:"frag",code:s}),entryPoint:"main",targets:[{format:t}]},layout:e.createPipelineLayout({bindGroupLayouts:o}),primitive:{topology:"triangle-list"},depthStencil:{depthWriteEnabled:!0,depthCompare:"less",format:"depth24plus"}}),pt=(e,t)=>{let r=new Float32Array(t),o=Math.ceil(r.byteLength/256)*256,n=e.createBuffer({size:o,usage:72});return{array:r,buffer:n}},ct=(e,t)=>{let r=new Float32Array(t),o=e.createBuffer({size:r.byteLength,usage:40});return{array:r,buffer:o}},ft=(e,t)=>({colorAttachments:[{view:e.getCurrentTexture().createView(),clearValue:{r:0,g:0,b:0,a:1},loadOp:"clear",storeOp:"store"}],depthStencilAttachment:{view:t.createView(),depthClearValue:1,depthLoadOp:"clear",depthStoreOp:"store"}}),dt=(e,t=1280,r=800)=>{let o=e.createTexture({size:[t,r],format:"rgba8unorm",usage:22}),n=e.createSampler({magFilter:"linear",minFilter:"linear"});return{texture:o,sampler:n}},lt=(e,t,r)=>e.createTexture({size:[t,r],format:"depth24plus",usage:GPUTextureUsage.RENDER_ATTACHMENT});var xt=async e=>{let t=e.el.getContext("webgpu"),{device:r,format:o}=await ot(t),n=st(),s,i,p=h=>{},a=0,c=!0,l,E=fe((h,g)=>{c=!0;let{array:y,buffer:X}=pt(r,g),{binding:S,group:P}=n.uniform();return{binding:S,group:P,array:y,buffer:X}}),b=fe((h,g=0,y=0)=>{c=!0;let{texture:X,sampler:S}=dt(r,g,y),{binding:P,group:D}=n.texture();return{binding:P,group:D,texture:X,sampler:S,view:X.createView()}}),m=fe((h,g)=>{c=!0;let y=g.length/e.count,{location:X}=n.attrib(),{array:S,buffer:P}=ct(r,g);return{array:S,buffer:P,location:X,stride:y}}),A=()=>{let{vertexBuffers:h,bufferLayouts:g}=it(m.map.values()),{bindGroups:y,bindGroupLayouts:X}=at(r,E.map.values(),b.map.values()),S=ut(r,o,g,X,i,s);p=P=>{P.setPipeline(S),y.forEach((D,j)=>P.setBindGroup(j,D)),h.forEach((D,j)=>P.setVertexBuffer(j,D)),P.draw(e.count,1,0,0),P.end()}},w=()=>{if(!s||!i){let g={isWebGL:!1,gl:e};s=q(e.fs,g),i=k(e.vs,g)}if(a)return;c&&A(),c=!1;let h=r.createCommandEncoder();p(h.beginRenderPass(ft(t,l))),r.queue.submit([h.finish()])},_=()=>{let h=e.el;l?.destroy(),l=lt(r,h.width,h.height)},N=()=>{l?.destroy()},L=(h="",g)=>{let{array:y,buffer:X}=m(h,g);y.set(g),r.queue.writeBuffer(X,0,y)},B=(h,g)=>{d.num(g)&&(g=[g]);let{array:y,buffer:X}=E(h,g);y.set(g),r.queue.writeBuffer(X,0,y)},H=(h,g)=>{a++;let y=Object.assign(new Image,{src:g,crossOrigin:"anonymous"});y.decode().then(()=>{let{width:X,height:S}=y,{texture:P}=b(h,X,S);r.queue.copyExternalImageToTexture({source:y},{texture:P},{width:X,height:S}),a--})};return _(),{webgpu:{device:r,uniforms:E,textures:b,attribs:m},render:w,resize:_,clean:N,_attribute:L,_uniform:B,_texture:H}};var mt=e=>d.obj(e)?"isGL"in e:!1,St=()=>typeof window>"u",Rt=()=>St()?!1:"gpu"in navigator,le=performance.now(),Ot=()=>ue(je(ie.xy.div(pe)),0,1),Ft=()=>ue(Y(M(ae).mod(M(2))).mul(4).sub(1),Y(M(ae).div(M(2))).mul(4).sub(1),0,1),Tt=e=>{let t=$t({isNative:!1,isWebGL:!0,isLoop:!0,isGL:!0,size:[0,0],mouse:[0,0],count:6,webgl:{},webgpu:{}});return t.queue=Lt(),t.frame=Gt(),t.attribute=de((r,o,n)=>t.queue(()=>t._attribute?.(r,o,n)),t),t.uniform=de((r,o,n)=>t.queue(()=>t._uniform?.(r,o,n)),t),t.texture=de((r,o)=>t.queue(()=>t._texture?.(r,o)),t),t.uniform({iResolution:t.size,iMouse:[0,0],iTime:le}),t("mount",async()=>{t.vs=t.vs||t.vert||t.vertex||Ft(),t.fs=t.fs||t.frag||t.fragment||Ot(),Rt()||(t.isWebGL=!0),t.isWebGL?t(await nt(t)):t(await xt(t)),t.resize(),t.frame(()=>(t.loop(),t.queue.flush(),t.render(),t.isLoop)),!t.isNative&&(window.addEventListener("resize",t.resize),t.el.addEventListener("mousemove",t.mousemove))}),t("clean",()=>{t.frame.stop(),t.frame.clean(t.render),!t.isNative&&(window.removeEventListener("resize",t.resize),t.el.removeEventListener("mousemove",t.mousemove))}),t("resize",()=>{let r=t.width||window.innerWidth,o=t.height||window.innerHeight;t.size[0]=t.el.width=r,t.size[1]=t.el.height=o,t.uniform("iResolution",t.size)}),t("mousemove",(r,o=r.clientX,n=r.clientY)=>{let[s,i]=t.size,{top:p,left:a}=t.el.getBoundingClientRect();t.mouse[0]=(o-p-s/2)/(s/2),t.mouse[1]=-(n-a-i/2)/(i/2),t.uniform("iMouse",t.mouse)}),t("loop",()=>{le=performance.now()/1e3,t.uniform("iTime",le)}),t(e)};var ts=(e={})=>It(()=>{let t=mt(e)?e:Tt(e);return t.ref=r=>{t.el={},t({render(){r.flush(),r.endFrameEXP()}}),t.mount(),(()=>{t.width=r.drawingBufferWidth,t.height=r.drawingBufferHeight,t.resize()})()},t({isNative:!0})})[0];export{xr as Fn,fr as If,dr as Loop,_t as Return,lr as Switch,yn as abs,Ln as acos,Un as acosh,V as addDependency,bn as all,vn as any,Gn as asin,In as asinh,ze as assign,Sn as atan,po as atan2,An as atanh,hr as attribute,mo as bitcast,kr as bool,C as builtin,tn as bvec2,rn as bvec3,nn as bvec4,To as cbrt,_n as ceil,io as clamp,f as code,an as color,yr as constant,T as conversion,Ne as conversionToConstant,Nn as cos,On as cosh,tt as createAttrib,ct as createAttribBuffer,at as createBindGroup,st as createBindings,lt as createDepthTexture,ft as createDescriptor,ot as createDevice,Tt as createGL,Je as createIbo,ut as createPipeline,Ze as createProgram,rt as createTexture,dt as createTextureSampler,pt as createUniformBuffer,Qe as createVbo,it as createVertexBuffers,hn as cross,dn as cubeTexture,Kn as dFdx,Zn as dFdy,Jn as degrees,go as difference,Mt as dig,Tn as distance,gn as dot,gt as each,bo as equals,Bn as exp,Dn as exp2,Bt as ext,vo as faceforward,Dt as fig,Y as float,Xn as floor,Ut as flush,G as formatConversions,je as fract,Sr as fragDepth,q as fragment,Lr as frontFacing,u as function_,Qn as fwidth,we as getBluiltin,re as getEventFun,$ as getId,Ee as getOperator,et as getStride,Pe as hex2rgb,un as iMouse,pe as iResolution,pn as iTime,$e as initNodeContext,Gr as instanceIndex,M as int,zn as inverseSqrt,d as is,te as isConstants,_e as isConversion,Xe as isFunction,mt as isGL,W as isNodeProxy,Ce as isOperator,St as isServer,ye as isSwizzle,Rt as isWebGPUSupported,jr as ivec2,Kr as ivec3,Zr as ivec4,xn as length,mn as lengthSq,Mn as log,Wn as log2,qr as mat2,Yr as mat3,Hr as mat4,oo as max,ke as member,no as min,so as mix,Hn as negate,x as node,Br as normalLocal,Mr as normalView,Dr as normalWorld,kn as normalize,qn as oneMinus,Et as operator,Fr as pointCoord,ie as position,Ir as positionLocal,Ar as positionView,Ur as positionWorld,co as pow,fo as pow2,lo as pow3,xo as pow4,eo as radians,jn as reciprocal,to as reflect,ro as refract,At as replace,Pn as round,ne as safeEventCall,Rr as sampleIndex,Or as sampleMask,sn as sampler2D,Yn as saturate,Wr as screenCoordinate,Vr as screenUV,_r as select,Wt as sig,Cn as sign,wn as sin,Rn as sinh,uo as smoothstep,Ge as sortHeadersByDependencies,Vn as sqrt,ao as step,cr as struct,$n as tan,Fn as tanh,fn as texture,on as texture2D,ln as textureSize,Ve as toVar,ho as transformDirection,En as trunc,zr as uint,z as uniform,ts as useGL,cn as uv,Qr as uvec2,Jr as uvec3,en as uvec4,Cr as variable,He as vec2,qe as vec3,ue as vec4,k as vertex,ae as vertexIndex,Xr as vertexStage,nt as webgl,xt as webgpu};
33
+ }`,z=(e,t)=>{if(d.str(e))return e.trim();t.code?.headers?.clear(),t.isFrag=!1;let[r,o]=qe(e,t),n=[];if(t.isWebGL){n.push("#version 300 es");for(let a of t.code?.vertInputs?.values()||[])n.push(`in ${a}`);for(let a of t.code?.vertOutputs?.values()||[])n.push(`out ${a}`);n.push(r),n.push("void main() {"),n.push(` gl_Position = ${o};`);for(let[a,c]of t.code?.vertVaryings?.entries()||[])n.push(` ${a} = ${c};`)}else{t.code?.vertInputs?.size&&n.push(oe("In",t.code.vertInputs)),t.code?.vertOutputs?.size&&n.push(oe("Out",t.code.vertOutputs)),n.push(r),n.push("@vertex"),n.push(`fn main(${t.code?.vertInputs?.size?"in: In":""}) -> Out {`),n.push(" var out: Out;"),n.push(` out.position = ${o};`);for(let[a,c]of t.code?.vertVaryings?.entries()||[])n.push(` out.${a} = ${c};`);n.push(" return out;")}return n.push("}"),n.filter(Boolean).join(`
34
+ `).trim()},k=(e,t)=>{if(d.str(e))return e.trim();t.code?.headers?.clear(),t.isFrag=!0;let[r,o]=qe(e,t),n=[];if(t.isWebGL){n.push(Et);for(let a of t.code?.fragInputs?.values()||[])n.push(`in ${a}`);n.push(r),n.push(`void main() {
35
+ fragColor = ${o};`)}else t.code?.fragInputs?.size&&n.push(oe("Out",t.code.fragInputs)),n.push(r),n.push(`@fragment
36
+ fn main(out: Out) -> @location(0) vec4f {`),n.push(` return ${o};`);return n.push("}"),n.filter(Boolean).join(`
37
+ `).trim()},se=C("position"),ie=C("vertex_index"),Nr=C("instance_index"),Gr=C("front_facing"),Lr=C("frag_depth"),Sr=C("sample_index"),Rr=C("sample_mask"),Or=C("point_coord"),Fr=C("position"),Ir=C("positionWorld"),Ur=C("positionView"),Ar=C("normalLocal"),Br=C("normalWorld"),Dr=C("normalView"),Mr=C("screenCoordinate"),Wr=C("screenUV"),q=e=>T("float",e),D=e=>T("int",e),Vr=e=>T("uint",e),zr=e=>T("bool",e),Ye=(e,t)=>T("vec2",e,t),ke=(e,t,r)=>T("vec3",e,t,r),ae=(e,t,r,o)=>T("vec4",e,t,r,o),kr=(...e)=>T("mat2",...e),qr=(...e)=>T("mat3",...e),Yr=(...e)=>T("mat4",...e),Hr=(e,t)=>T("ivec2",e,t),jr=(e,t,r)=>T("ivec3",e,t,r),Kr=(e,t,r,o)=>T("ivec4",e,t,r,o),Zr=(e,t)=>T("uvec2",e,t),Qr=(e,t,r)=>T("uvec3",e,t,r),Jr=(e,t,r,o)=>T("uvec4",e,t,r,o),en=(e,t)=>T("bvec2",e,t),tn=(e,t,r)=>T("bvec3",e,t,r),rn=(e,t,r,o)=>T("bvec4",e,t,r,o),nn=e=>T("texture",e),on=()=>T("sampler2D"),sn=(e,t,r)=>d.num(e)&&d.und(t)&&d.und(r)?ke(..._e(e)):ke(e,t,r),ue=V(Ye(),"iResolution"),an=V(Ye(),"iMouse"),un=V(q(),"iTime"),pn=se.xy.div(ue),cn=(e,t,r)=>u("texture",e,t,r),fn=(e,t,r)=>u("cubeTexture",e,t,r),dn=(e,t)=>u("textureSize",e,t),ln=e=>u("length",e),xn=e=>u("lengthSq",e),mn=(e,t)=>u("distance",e,t),Tn=(e,t)=>u("dot",e,t),gn=e=>u("all",e),bn=e=>u("any",e),vn=(e,t)=>u("cross",e,t),hn=e=>u("abs",e),yn=e=>u("sign",e),Cn=e=>u("floor",e),Xn=e=>u("ceil",e),_n=e=>u("round",e),He=e=>u("fract",e),Pn=e=>u("trunc",e),En=e=>u("sin",e),$n=e=>u("cos",e),wn=e=>u("tan",e),Nn=e=>u("asin",e),Gn=e=>u("acos",e),Ln=e=>u("atan",e),Sn=e=>u("sinh",e),Rn=e=>u("cosh",e),On=e=>u("tanh",e),Fn=e=>u("asinh",e),In=e=>u("acosh",e),Un=e=>u("atanh",e),An=e=>u("exp",e),Bn=e=>u("exp2",e),Dn=e=>u("log",e),Mn=e=>u("log2",e),Wn=e=>u("sqrt",e),Vn=e=>u("inverseSqrt",e),zn=e=>u("normalize",e),kn=e=>u("oneMinus",e),qn=e=>u("saturate",e),Yn=e=>u("negate",e),Hn=e=>u("reciprocal",e),jn=e=>u("dFdx",e),Kn=e=>u("dFdy",e),Zn=e=>u("fwidth",e),Qn=e=>u("degrees",e),Jn=e=>u("radians",e),eo=(e,t)=>u("reflect",e,t),to=(e,t,r)=>u("refract",e,t,r),ro=(e,t)=>u("min",e,t),no=(e,t)=>u("max",e,t),oo=(e,t,r)=>u("mix",e,t,r),so=(e,t,r)=>u("clamp",e,t,r),io=(e,t)=>u("step",e,t),ao=(e,t,r)=>u("smoothstep",e,t,r),uo=(e,t)=>u("atan2",e,t),po=(e,t)=>u("pow",e,t),co=e=>u("pow2",e),fo=e=>u("pow3",e),lo=e=>u("pow4",e),xo=(e,t)=>u("bitcast",e,t),mo=e=>u("cbrt",e),To=(e,t)=>u("difference",e,t),go=(e,t)=>u("equals",e,t),bo=(e,t,r)=>u("faceforward",e,t,r),vo=(e,t)=>u("transformDirection",e,t),ho=(e,t)=>e.sub(e.div(t).floor().mul(t));var je=(e,t,r,o=console.warn)=>{let n=e.createShader(r);if(!n)return o("Failed to create shader");if(e.shaderSource(n,t.trim()),e.compileShader(n),e.getShaderParameter(n,e.COMPILE_STATUS))return n;let s=e.getShaderInfoLog(n);e.deleteShader(n),o(`Could not compile shader: ${s}`)},Ke=(e,t,r,o=console.warn)=>{let n=e.createProgram(),s=je(e,r,e.FRAGMENT_SHADER,o),a=je(e,t,e.VERTEX_SHADER,o);if(!s||!a)return;if(e.attachShader(n,a),e.attachShader(n,s),e.linkProgram(n),e.getProgramParameter(n,e.LINK_STATUS))return n;let c=e.getProgramInfoLog(n);e.deleteProgram(n),o(`Could not link program: ${c}`)},Ze=(e,t)=>{let r=e.createBuffer();return e.bindBuffer(e.ARRAY_BUFFER,r),e.bufferData(e.ARRAY_BUFFER,new Float32Array(t),e.STATIC_DRAW),e.bindBuffer(e.ARRAY_BUFFER,null),r},Qe=(e,t)=>{let r=e.createBuffer();return e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,r),e.bufferData(e.ELEMENT_ARRAY_BUFFER,new Int16Array(t),e.STATIC_DRAW),e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,null),r},Je=(e,t,r)=>{r&&(e=Math.max(...r)+1);let o=t.length/e;return Math.floor(o)},et=(e,t,r,o,n)=>{e.bindBuffer(e.ARRAY_BUFFER,o),e.enableVertexAttribArray(r),e.vertexAttribPointer(r,t,e.FLOAT,!1,0,0),n&&e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,n)},tt=(e,t,r,o)=>{let n=e.createTexture();e.bindTexture(e.TEXTURE_2D,n),e.texImage2D(e.TEXTURE_2D,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,t),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),e.uniform1i(r,o),e.activeTexture(e.TEXTURE0+o),e.bindTexture(e.TEXTURE_2D,n)};var rt=async e=>{let t=e.el.getContext("webgl2"),r={isWebGL:!0,gl:e},o=k(e.fs,r),n=z(e.vs,r),s=Ke(t,n,o,e.error);t.useProgram(s);let a=0,c=pe($=>t.getUniformLocation(s,$)),i=pe($=>t.getAttribLocation(s,$)),f=pe(()=>a++);return{webgl:{context:t,program:s},render:()=>{t.clear(t.COLOR_BUFFER_BIT),t.viewport(0,0,...e.size),t.drawArrays(t.TRIANGLES,0,3)},clean:()=>{t.deleteProgram(s),t.getExtension("WEBGL_lose_context")?.loseContext(),e.el.width=1,e.el.height=1},_attribute:($="",w,N)=>{let L=i($,!0),m=Ze(t,w),b=Qe(t,N),y=Je(e.count,w,N);et(t,y,L,m,b)},_uniform:($,w)=>{let N=c($);if(d.num(w))return t.uniform1f(N,w);let L=w.length;if(L<=4)return t[`uniform${L}fv`](N,w);L=Math.sqrt(L)<<0,t[`uniformMatrix${L}fv`](N,!1,w)},_texture:($,w)=>{e.loading++;let N=new Image;Object.assign(N,{src:w,crossOrigin:"anonymous"}),N.decode().then(()=>{let L=c($),m=f($);tt(t,N,L,m),e.loading--})}}};import{nested as ce}from"reev";var nt=async e=>{let t=navigator.gpu,r=t.getPreferredCanvasFormat(),n=await(await t.requestAdapter()).requestDevice();return e.configure({device:n,format:r,alphaMode:"opaque"}),{device:n,format:r}},ot=()=>{let e=0,t=0,r=0;return{uniform:()=>{let o=Math.floor(e/12),n=e%12;return e++,{group:o,binding:n}},texture:()=>{let n=Math.floor(e/12)+1+Math.floor(t/6),s=t%6*2;return t++,{group:n,binding:s}},attrib:()=>{let o=r;return r++,{location:o}}}},$t=e=>e===2?"float32x2":e===3?"float32x3":e===4?"float32x4":"float32",st=e=>{let t=[],r=[];for(let{buffer:o,location:n,stride:s}of e)t[n]=o,r[n]={arrayStride:s*4,attributes:[{shaderLocation:n,offset:0,format:$t(s)}]};return{vertexBuffers:t,bufferLayouts:r}},it=(e,t,r)=>{let o=new Map,n={bindGroups:[],bindGroupLayouts:[]},s=(a,c,i)=>{o.has(a)||o.set(a,{layouts:[],bindings:[]});let{layouts:f,bindings:l}=o.get(a);f.push(c),l.push(i)};for(let{binding:a,buffer:c,group:i}of t)s(i,{binding:a,visibility:3,buffer:{type:"uniform"}},{binding:a,resource:{buffer:c}});for(let{binding:a,group:c,sampler:i,view:f}of r)s(c,{binding:a,visibility:2,sampler:{}},{binding:a,resource:i}),s(c,{binding:a+1,visibility:2,texture:{}},{binding:a+1,resource:f});for(let[a,{layouts:c,bindings:i}]of o)n.bindGroupLayouts[a]=e.createBindGroupLayout({entries:c}),n.bindGroups[a]=e.createBindGroup({layout:n.bindGroupLayouts[a],entries:i});return n},at=(e,t,r,o,n,s)=>e.createRenderPipeline({vertex:{module:e.createShaderModule({label:"vert",code:n}),entryPoint:"main",buffers:r},fragment:{module:e.createShaderModule({label:"frag",code:s}),entryPoint:"main",targets:[{format:t}]},layout:e.createPipelineLayout({bindGroupLayouts:o}),primitive:{topology:"triangle-list"},depthStencil:{depthWriteEnabled:!0,depthCompare:"less",format:"depth24plus"}}),ut=(e,t)=>{let r=new Float32Array(t),o=Math.ceil(r.byteLength/256)*256,n=e.createBuffer({size:o,usage:72});return{array:r,buffer:n}},pt=(e,t)=>{let r=new Float32Array(t),o=e.createBuffer({size:r.byteLength,usage:40});return{array:r,buffer:o}},ct=(e,t)=>({colorAttachments:[{view:e.getCurrentTexture().createView(),clearValue:{r:0,g:0,b:0,a:1},loadOp:"clear",storeOp:"store"}],depthStencilAttachment:{view:t.createView(),depthClearValue:1,depthLoadOp:"clear",depthStoreOp:"store"}}),ft=(e,t=1280,r=800)=>{let o=e.createTexture({size:[t,r],format:"rgba8unorm",usage:22}),n=e.createSampler({magFilter:"linear",minFilter:"linear"});return{texture:o,sampler:n}},dt=(e,t,r)=>e.createTexture({size:[t,r],format:"depth24plus",usage:GPUTextureUsage.RENDER_ATTACHMENT});var lt=async e=>{let t=e.el.getContext("webgpu"),{device:r,format:o}=await nt(t);r.onuncapturederror=m=>e.error(m.error.message);let n=ot(),s,a,c=m=>{},i=!0,f,l=ce((m,b)=>{i=!0;let{array:y,buffer:X}=ut(r,b),{binding:S,group:P}=n.uniform();return{binding:S,group:P,array:y,buffer:X}}),_=ce((m,b=0,y=0)=>{i=!0;let{texture:X,sampler:S}=ft(r,b,y),{binding:P,group:B}=n.texture();return{binding:P,group:B,texture:X,sampler:S,view:X.createView()}}),v=ce((m,b)=>{i=!0;let y=b.length/e.count,{location:X}=n.attrib(),{array:S,buffer:P}=pt(r,b);return{array:S,buffer:P,location:X,stride:y}}),g=()=>{let{vertexBuffers:m,bufferLayouts:b}=st(v.map.values()),{bindGroups:y,bindGroupLayouts:X}=it(r,l.map.values(),_.map.values()),S=at(r,o,b,X,a,s);c=P=>{P.setPipeline(S),y.forEach((B,H)=>P.setBindGroup(H,B)),m.forEach((B,H)=>P.setVertexBuffer(H,B)),P.draw(e.count,1,0,0),P.end()}},A=()=>{if(!s||!a){let b={isWebGL:!1,gl:e};s=k(e.fs,b),a=z(e.vs,b)}if(e.loading)return;i&&g(),i=!1;let m=r.createCommandEncoder();c(m.beginRenderPass(ct(t,f))),r.queue.submit([m.finish()])},Y=()=>{let m=e.el;f?.destroy(),f=dt(r,m.width,m.height)},$=()=>{r.destroy(),f?.destroy();for(let{texture:m}of _.map.values())m.destroy();for(let{buffer:m}of l.map.values())m.destroy();for(let{buffer:m}of v.map.values())m.destroy()},w=(m="",b)=>{let{array:y,buffer:X}=v(m,b);y.set(b),r.queue.writeBuffer(X,0,y)},N=(m,b)=>{d.num(b)&&(b=[b]);let{array:y,buffer:X}=l(m,b);y.set(b),r.queue.writeBuffer(X,0,y)},L=(m,b)=>{e.loading++;let y=Object.assign(new Image,{src:b,crossOrigin:"anonymous"});y.decode().then(()=>{let{width:X,height:S}=y,{texture:P}=_(m,X,S);r.queue.copyExternalImageToTexture({source:y},{texture:P},{width:X,height:S}),e.loading--})};return Y(),{webgpu:{device:r,uniforms:l,textures:_,attribs:v},render:A,resize:Y,clean:$,_attribute:w,_uniform:N,_texture:L}};var xt=e=>d.obj(e)?"isGL"in e:!1,Lt=()=>typeof window>"u",St=()=>Lt()?!1:"gpu"in navigator,de=performance.now(),Rt=()=>ae(He(se.xy.div(ue)),0,1),Ot=()=>ae(q(D(ie).mod(D(2))).mul(4).sub(1),q(D(ie).div(D(2))).mul(4).sub(1),0,1),mt=e=>{let t=wt({isNative:!1,isWebGL:!0,isError:!1,isLoop:!0,isGL:!0,size:[0,0],mouse:[0,0],count:6,webgl:{},webgpu:{},loading:0,error(){t.isError=!0,t.isLoop=!1,t.clean()}});return t.queue=Gt(),t.frame=Nt(),t.attribute=fe((r,o,n)=>t.queue(()=>t._attribute?.(r,o,n)),t),t.uniform=fe((r,o,n)=>t.queue(()=>t._uniform?.(r,o,n)),t),t.texture=fe((r,o)=>t.queue(()=>t._texture?.(r,o)),t),t.uniform({iResolution:t.size,iMouse:[0,0],iTime:de}),t("mount",async()=>{t.vs=t.vs||t.vert||t.vertex||Ot(),t.fs=t.fs||t.frag||t.fragment||Rt(),St()||(t.isWebGL=!0),t.isWebGL?t(await rt(t)):t(await lt(t)),!t.isError&&(t.resize(),t.frame(()=>(t.loop(),t.queue.flush(),t.loading?!0:(t.render(),t.isLoop))),!t.isNative&&(window.addEventListener("resize",t.resize),t.el.addEventListener("mousemove",t.mousemove)))}),t("clean",()=>{t.frame.stop(),!t.isNative&&(window.removeEventListener("resize",t.resize),t.el.removeEventListener("mousemove",t.mousemove))}),t("resize",()=>{let r=t.width||window.innerWidth,o=t.height||window.innerHeight;t.size[0]=t.el.width=r,t.size[1]=t.el.height=o,t.uniform("iResolution",t.size)}),t("mousemove",(r,o=r.clientX,n=r.clientY)=>{let[s,a]=t.size,{top:c,left:i}=t.el.getBoundingClientRect();t.mouse[0]=(o-c-s/2)/(s/2),t.mouse[1]=-(n-i-a/2)/(a/2),t.uniform("iMouse",t.mouse)}),t("loop",()=>{de=performance.now()/1e3,t.uniform("iTime",de)}),t(e)};var ts=(e={})=>Ft(()=>{let t=xt(e)?e:mt(e);return t.ref=r=>{t.el={},t({render(){r.flush(),r.endFrameEXP()}}),t.mount(),(()=>{t.width=r.drawingBufferWidth,t.height=r.drawingBufferHeight,t.resize()})()},t({isNative:!0})})[0];export{lr as Fn,cr as If,fr as Loop,Xt as Return,dr as Switch,hn as abs,Gn as acos,In as acosh,W as addDependency,gn as all,bn as any,Nn as asin,Fn as asinh,Ve as assign,Ln as atan,uo as atan2,Un as atanh,vr as attribute,xo as bitcast,zr as bool,C as builtin,en as bvec2,tn as bvec3,rn as bvec4,mo as cbrt,Xn as ceil,so as clamp,p as code,sn as color,hr as constant,T as conversion,$e as conversionToConstant,$n as cos,Rn as cosh,et as createAttrib,pt as createAttribBuffer,it as createBindGroup,ot as createBindings,dt as createDepthTexture,ct as createDescriptor,nt as createDevice,mt as createGL,Qe as createIbo,at as createPipeline,Ke as createProgram,tt as createTexture,ft as createTextureSampler,ut as createUniformBuffer,Ze as createVbo,st as createVertexBuffers,vn as cross,fn as cubeTexture,jn as dFdx,Kn as dFdy,Qn as degrees,To as difference,Dt as dig,mn as distance,Tn as dot,Tt as each,go as equals,An as exp,Bn as exp2,At as ext,bo as faceforward,Bt as fig,q as float,Cn as floor,It as flush,G as formatConversions,He as fract,Lr as fragDepth,k as fragment,Gr as frontFacing,u as function_,Zn as fwidth,Ee as getBluiltin,te as getEventFun,E as getId,Pe as getOperator,Je as getStride,_e as hex2rgb,an as iMouse,ue as iResolution,un as iTime,we as initNodeContext,Nr as instanceIndex,D as int,Vn as inverseSqrt,d as is,ee as isConstants,Xe as isConversion,Ce as isFunction,xt as isGL,M as isNodeProxy,ye as isOperator,Lt as isServer,he as isSwizzle,St as isWebGPUSupported,Hr as ivec2,jr as ivec3,Kr as ivec4,ln as length,xn as lengthSq,Dn as log,Mn as log2,kr as mat2,qr as mat3,Yr as mat4,no as max,ze as member,ro as min,oo as mix,ho as mod,Yn as negate,x as node,Ar as normalLocal,Dr as normalView,Br as normalWorld,zn as normalize,kn as oneMinus,Pt as operator,Or as pointCoord,se as position,Fr as positionLocal,Ur as positionView,Ir as positionWorld,po as pow,co as pow2,fo as pow3,lo as pow4,Jn as radians,Hn as reciprocal,eo as reflect,to as refract,Ut as replace,_n as round,re as safeEventCall,Sr as sampleIndex,Rr as sampleMask,on as sampler2D,qn as saturate,Mr as screenCoordinate,Wr as screenUV,Xr as select,Mt as sig,yn as sign,En as sin,Sn as sinh,ao as smoothstep,Ne as sortHeadersByDependencies,Wn as sqrt,io as step,pr as struct,wn as tan,On as tanh,cn as texture,nn as texture2D,dn as textureSize,We as toVar,vo as transformDirection,Pn as trunc,Vr as uint,V as uniform,ts as useGL,pn as uv,Zr as uvec2,Qr as uvec3,Jr as uvec4,yr as variable,Ye as vec2,ke as vec3,ae as vec4,z as vertex,ie as vertexIndex,Cr as vertexStage,rt as webgl,lt as webgpu};
40
38
  //# sourceMappingURL=native.js.map