glre 0.36.0 → 0.38.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/index.cjs +35 -30
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +219 -1652
- package/dist/index.js +35 -30
- package/dist/index.js.map +1 -1
- package/dist/native.cjs +35 -30
- package/dist/native.cjs.map +1 -1
- package/dist/native.d.ts +7 -6
- package/dist/native.js +35 -30
- package/dist/native.js.map +1 -1
- package/dist/react.cjs +35 -30
- package/dist/react.cjs.map +1 -1
- package/dist/react.d.ts +1 -1
- package/dist/react.js +35 -30
- package/dist/react.js.map +1 -1
- package/dist/solid.cjs +35 -30
- package/dist/solid.cjs.map +1 -1
- package/dist/solid.d.ts +1 -1
- package/dist/solid.js +35 -30
- package/dist/solid.js.map +1 -1
- package/package.json +1 -1
- package/src/index.ts +2 -0
- package/src/node/core.ts +25 -4
- package/src/node/index.ts +61 -64
- package/src/node/node.ts +9 -5
- package/src/node/scope.ts +30 -17
- package/src/node/types.ts +168 -119
- package/src/node/utils/const.ts +113 -120
- package/src/node/utils/index.ts +21 -7
- package/src/node/utils/infer.ts +13 -18
- package/src/node/utils/parse.ts +57 -16
- package/src/node/utils/utils.ts +16 -8
- package/src/types.ts +6 -4
- package/src/utils/program.ts +62 -18
- package/src/webgl.ts +79 -67
- package/src/webgpu.ts +50 -42
package/dist/index.cjs
CHANGED
|
@@ -1,44 +1,49 @@
|
|
|
1
|
-
"use strict";var
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
${
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
${
|
|
1
|
+
"use strict";var fe=Object.defineProperty;var At=Object.getOwnPropertyDescriptor;var It=Object.getOwnPropertyNames;var Ot=Object.prototype.hasOwnProperty;var Dt=(e,t)=>{for(var r in t)fe(e,r,{get:t[r],enumerable:!0})},Mt=(e,t,r,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of It(t))!Ot.call(e,n)&&n!==r&&fe(e,n,{get:()=>t[n],enumerable:!(o=At(t,n))||o.enumerable});return e};var Bt=e=>Mt(fe({},"__esModule",{value:!0}),e);var ro={};Dt(ro,{Fn:()=>tr,If:()=>Qt,Loop:()=>Jt,Return:()=>gt,Switch:()=>er,abs:()=>en,acos:()=>tn,acosh:()=>rn,all:()=>kr,any:()=>Vr,asin:()=>nn,asinh:()=>on,assign:()=>Ce,atan:()=>sn,atan2:()=>Un,atanh:()=>an,attribute:()=>bt,bool:()=>Cr,builtin:()=>_,bvec2:()=>Fr,bvec3:()=>Ur,bvec4:()=>Ar,ceil:()=>un,clamp:()=>An,color:()=>Dr,compute:()=>Y,constant:()=>vt,conversion:()=>b,cos:()=>pn,cosh:()=>fn,createGL:()=>Ut,cross:()=>jr,cubeTexture:()=>Kr,dFdx:()=>cn,dFdy:()=>ln,default:()=>to,degrees:()=>dn,distance:()=>Yr,dot:()=>Hr,element:()=>_e,exp:()=>xn,exp2:()=>mn,float:()=>H,floor:()=>Tn,fract:()=>Le,fragDepth:()=>fr,fragment:()=>z,frontFacing:()=>pr,function_:()=>c,fwidth:()=>gn,gather:()=>Et,iMouse:()=>Mr,iResolution:()=>se,iTime:()=>Br,id:()=>xr,instanceIndex:()=>ur,int:()=>W,inverseSqrt:()=>bn,isGL:()=>Qn,isServer:()=>wt,isWebGPUSupported:()=>Ft,ivec2:()=>Gr,ivec3:()=>Lr,ivec4:()=>Nr,length:()=>zr,lengthSq:()=>qr,log:()=>vn,log2:()=>hn,mat2:()=>_r,mat3:()=>Pr,mat4:()=>$r,max:()=>In,member:()=>ee,min:()=>On,mix:()=>Dn,mod:()=>zn,negate:()=>yn,node:()=>m,normalLocal:()=>br,normalView:()=>hr,normalWorld:()=>vr,normalize:()=>En,oneMinus:()=>Xn,operator:()=>Xt,pointCoord:()=>dr,position:()=>re,positionLocal:()=>mr,positionView:()=>gr,positionWorld:()=>Tr,pow:()=>Mn,radians:()=>Cn,reciprocal:()=>_n,reflect:()=>Bn,refract:()=>Wn,round:()=>Pn,sampleIndex:()=>cr,sampleMask:()=>lr,sampler2D:()=>Or,saturate:()=>$n,scatter:()=>or,screenCoordinate:()=>yr,screenUV:()=>Er,select:()=>sr,sign:()=>Gn,sin:()=>Ln,sinh:()=>Nn,smoothstep:()=>kn,sqrt:()=>Sn,step:()=>Vn,storage:()=>nr,struct:()=>Zt,tan:()=>Rn,tanh:()=>wn,texelFetch:()=>Qr,texture:()=>Zr,texture2D:()=>Ir,textureLod:()=>Jr,toVar:()=>Xe,trunc:()=>Fn,uint:()=>Xr,uniform:()=>B,uv:()=>Wr,uvec2:()=>Sr,uvec3:()=>Rr,uvec4:()=>wr,variable:()=>ht,vec2:()=>Ge,vec3:()=>$e,vec4:()=>oe,vertex:()=>q,vertexIndex:()=>ne,vertexStage:()=>yt,webgl:()=>Ne,webgpu:()=>Se});module.exports=Bt(ro);var D=require("reev"),ae=require("refr");var O=require("reev");var x={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)};var we=e=>e instanceof Float32Array,Z=(e,t,r)=>{e.loading++;let o=new Image;Object.assign(o,{src:t,crossOrigin:"anonymous"}),o.decode().then(()=>{r(o),e.loading--})};var Fe=(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}
|
|
2
|
+
|
|
3
|
+
\u2193\u2193\u2193generated\u2193\u2193\u2193
|
|
4
|
+
${t}`)},ce=(e,t,r,o)=>{let n=e.createProgram(),s=Fe(e,t,e.FRAGMENT_SHADER,o.error),i=Fe(e,r,e.VERTEX_SHADER,o.error);if(!s||!i)return;if(e.attachShader(n,s),e.attachShader(n,i),e.linkProgram(n),e.getProgramParameter(n,e.LINK_STATUS))return n;let p=e.getProgramInfoLog(n);e.deleteProgram(n),o.error(`Could not link program: ${p}`)},Wt=(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},kt=(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},Vt=(e,t,r)=>{r&&(e=Math.max(...r)+1);let o=t.length/e;return Math.floor(o)},Ue=(e,t,r,o,n)=>{let s=Wt(e,o),i=kt(e,n),p=Vt(r,o,n);e.bindBuffer(e.ARRAY_BUFFER,s),e.enableVertexAttribArray(t),e.vertexAttribPointer(t,p,e.FLOAT,!1,0,0),i&&e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,i)},le=(e,t,r)=>{if(x.num(r))return e.uniform1f(t,r);let o=r.length;if(o<=4)return e[`uniform${o}fv`](t,r);o=Math.sqrt(o)<<0,e[`uniformMatrix${o}fv`](t,!1,r)},Ae=(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)},Ie=(e,t,r,o,n,s,i)=>{let p=r*r,a=t.length/p;for(let u=0;u<p;u++)for(let d=0;d<Math.min(a,4);d++)i[4*u+d]=t[u*a+d]||0;e.activeTexture(e.TEXTURE0+s),e.bindTexture(e.TEXTURE_2D,o.texture),e.texImage2D(e.TEXTURE_2D,0,e.RGBA32F,r,r,0,e.RGBA,e.FLOAT,i),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,e.NEAREST),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,e.NEAREST),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,n.texture),e.texImage2D(e.TEXTURE_2D,0,e.RGBA32F,r,r,0,e.RGBA,e.FLOAT,i),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,e.NEAREST),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,e.NEAREST),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)},Oe=(e,t)=>{for(let{ping:r,pong:o}of t)e.deleteTexture(r.texture),e.deleteTexture(o.texture),e.deleteFramebuffer(r.buffer),e.deleteFramebuffer(o.buffer)},De=(e,t,r,o,n,s)=>{e.activeTexture(e.TEXTURE0+n),e.bindTexture(e.TEXTURE_2D,t.texture),e.uniform1i(o,n),s===0&&e.bindFramebuffer(e.FRAMEBUFFER,r.buffer);let i=e.COLOR_ATTACHMENT0+s;return e.framebufferTexture2D(e.FRAMEBUFFER,i,e.TEXTURE_2D,r.texture,0),i};var de=["toBool","toUint","toInt","toFloat","toBvec2","toIvec2","toUvec2","toVec2","toBvec3","toIvec3","toUvec3","toVec3","toBvec4","toIvec4","toUvec4","toVec4","toColor","toMat2","toMat3","toMat4"],xe={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"},me=Object.keys(xe),Te={not:"",add:"+",sub:"-",mul:"*",div:"/",mod:"%",equal:"==",notEqual:"!=",lessThan:"<",lessThanEqual:"<=",greaterThan:">",greaterThanEqual:">=",and:"&&",or:"||",bitAnd:"&",bitOr:"|",bitXor:"^",shiftLeft:"<<",shiftRight:">>"},Me=Object.keys(Te),ge={1:"float",2:"vec2",3:"vec3",4:"vec4",9:"mat3",16:"mat4"},Be={position:"vec4",vertex_index:"uint",instance_index:"uint",front_facing:"bool",frag_depth:"float",sample_index:"uint",sample_mask:"uint",point_coord:"vec2",global_invocation_id:"uvec3",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"},We=["equal","notEqual","lessThan","lessThanEqual","greaterThan","greaterThanEqual"],ke=["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"},be={all:"bool",any:"bool",determinant:"float",distance:"float",dot:"float",length:"float",lengthSq:"float",luminance:"float",cross:"vec3",cubeTexture:"vec4",texture:"vec4",texelFetch:"vec4",textureLod:"vec4"},ze=[...Object.keys(be),"abs","acos","acosh","asin","asinh","atan","atanh","ceil","cos","cosh","dFdx","dFdy","degrees","exp","exp2","floor","fract","fwidth","inverseSqrt","log","log2","negate","normalize","oneMinus","radians","reciprocal","round","saturate","sign","sin","sinh","sqrt","tan","tanh","trunc","atan2","clamp","max","min","mix","pow","reflect","refract","smoothstep","step"];var qe=e=>x.str(e)&&/^[xyzwrgbastpq]{1,4}$/.test(e),Ye=e=>Me.includes(e),He=e=>ze.includes(e),je=e=>de.includes(e),Q=e=>!e||typeof e!="object"?!1:e.isProxy,ve=e=>x.str(e)?me.includes(e):!1,Ke=e=>{let t=(e>>16&255)/255,r=(e>>8&255)/255,o=(e&255)/255;return[t,r,o]},zt=0,C=()=>`x${zt++}`,Ze=(e,t)=>{if(t==="global_invocation_id")return`uvec3(uint(gl_FragCoord.y) * uint(${Math.floor(Math.sqrt(e.gl?.particles||1024))}) + uint(gl_FragCoord.x), 0u, 0u)`;let r=Ve[t];if(!r)throw new Error(`Error: unknown builtin variable ${t}`);return r},N=(e,t)=>x.str(e)?t?.isWebGL?e:xe[e]||e:"",Qe=e=>Te[e]||e,Je=e=>{let t=de.indexOf(e);return t!==-1?me[t]:"float"},he=(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),ye=(e,t)=>{if(x.und(e))return;if(!Q(e))return t(e);if(e.type!=="conversion")return;let r=e.props.children?.slice(1);x.und(r?.[0])||t(r.map(o=>o??r[0]))},et=e=>(e.code||(e.code={headers:new Map,fragInputs:new Map,vertInputs:new Map,vertOutputs:new Map,vertVaryings:new Map,computeInputs:new Map,dependencies:new Map,structFields:new Map},e.isWebGL)||(e.code.fragInputs.set("position","@builtin(position) position: vec4f"),e.code.vertOutputs.set("position","@builtin(position) position: vec4f")),e),tt=e=>x.num(e)||x.str(e)&&/^\d+$/.test(e),J=(e,t="",r)=>{e.code?.dependencies?.has(t)||e.code.dependencies.set(t,new Set),ve(r)||e.code.dependencies.get(t).add(r)};var qt=e=>Be[e],Yt=(e,t,r)=>We.includes(r)||ke.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=>x.bol(e)?"bool":x.str(e)?"texture":x.num(e)?"float":x.arr(e)?ge[e.length]:"float",Ee=e=>ge[e],rt=(e,t)=>{if(e.length===0)return"void";let[r]=e;return x.str(r)?r:X(r,t)},jt=e=>be[e],Kt=(e,t)=>{let{type:r,props:o}=e,{id:n,children:s=[],inferFrom:i,layout:p}=o,[a,u,d]=s;if(r==="conversion")return a;if(r==="operator")return Yt(X(u,t),X(d,t),a);if(r==="builtin")return qt(n);if(r==="function")return jt(a)||X(u,t);if(r==="define")return ve(p?.type)?p?.type:!i||i.length===0?"void":rt(i,t);if(r==="attribute"&&x.arr(a)&&t.gl?.count)return Ee(a.length/t.gl.count);if(r==="member"){if(qe(u))return Ee(u.length);if(Q(a)){let h=X(a,t),T=t.code?.structFields?.get(h);if(T&&T[u])return X(T[u],t)}return"float"}return i?rt(i,t):X(a,t)},X=(e,t)=>{if(t||(t={}),!Q(e))return Ht(e);if(x.arr(e))return Ee(e.length);if(t.infers||(t.infers=new WeakMap),t.infers.has(e))return t.infers.get(e);let r=Kt(e,t);return t.infers.set(e,r),r};var w=(e,t)=>e.filter(r=>!x.und(r)&&!x.nul(r)).map(r=>f(r,t)).join(", "),nt=(e,t,r,o)=>{let n=()=>{let u=X(o,e);if(u==="float")return".x";if(u==="vec2")return".xy";if(u==="vec3")return".xyz";if(u==="vec4")return"";throw new Error(`Unsupported storage scatter type: ${u}`)},s=f(r,e),i=Math.floor(Math.sqrt(e.gl?.particles||1024)),p=`int(${s}) % ${i}`,a=`int(${s}) / ${i}`;return`texelFetch(${f(t,e)}, ivec2(${p}, ${a}), 0)${n()}`},ot=(e,t,r)=>{let o=f(t,e),n=f(r,e),s=X(r,e);if(s==="float")return`_${o} = vec4(${n}, 0.0, 0.0, 1.0);`;if(s==="vec2")return`_${o} = vec4(${n}, 0.0, 1.0);`;if(s==="vec3")return`_${o} = vec4(${n}, 1.0);`;if(s==="vec4")return`_${o} = ${n};`;throw new Error(`Unsupported storage scatter type: ${s}`)},st=(e,t,r,o)=>{if(e.isWebGL)return`texture(${w(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})`},it=(e,t,r,o)=>{let n=`if (${f(t,e)}) {
|
|
5
|
+
${f(r,e)}
|
|
6
|
+
}`;for(let s=2;s<o.length;s+=2){let i=s>=o.length-1;n+=i?` else {
|
|
7
|
+
${f(o[s],e)}
|
|
8
|
+
}`:` else if (${f(o[s],e)}) {
|
|
9
|
+
${f(o[s+1],e)}
|
|
10
|
+
}`}return n},at=(e,t,r)=>{let o=`switch (${f(t,e)}) {
|
|
11
|
+
`;for(let n=1;n<r.length;n+=2)n>=r.length-1&&r.length%2===0?o+=`default:
|
|
12
|
+
${f(r[n],e)}
|
|
10
13
|
break;
|
|
11
|
-
`:
|
|
12
|
-
${
|
|
14
|
+
`:n+1<r.length&&(o+=`case ${f(r[n],e)}:
|
|
15
|
+
${f(r[n+1],e)}
|
|
13
16
|
break;
|
|
14
|
-
`);return
|
|
17
|
+
`);return o+="}",o},ut=(e,t,r)=>{let o=X(t,e),n=r?.props?.id;if(e.isWebGL)return`${o} ${n} = ${f(t,e)};`;let s=N(o);return`var ${n}: ${s} = ${f(t,e)};`},pt=(e,t,r={})=>{e.code?.structFields?.set(t,r);let o=[];for(let s in r){let i=r[s],p=X(i,e);e.isWebGL&&J(e,t,p),o.push(e.isWebGL?`${p} ${s};`:`${s}: ${N(p,e)},`)}let n=o.join(`
|
|
15
18
|
`);return`struct ${t} {
|
|
16
|
-
${
|
|
17
|
-
};`},
|
|
18
|
-
`)},
|
|
19
|
-
@group(${
|
|
20
|
-
|
|
21
|
-
${
|
|
22
|
-
|
|
23
|
-
${
|
|
24
|
-
|
|
19
|
+
${n}
|
|
20
|
+
};`},ft=(e,t,r="",o)=>{let n=e.code?.structFields?.get(t)||{};if(e.isWebGL)if(o){let s=[];for(let i in n)s.push(o[i]);return`${t} ${r} = ${t}(${w(s,e)});`}else return`${t} ${r};`;else if(o){let s=[];for(let i in n)s.push(o[i]);return`var ${r}: ${t} = ${t}(${w(s,e)});`}else return`var ${r}: ${t};`},ct=(e,t,r)=>{let{id:o,children:n=[],layout:s}=t,[i,...p]=n,a=[],u=[];if(s?.inputs)for(let l of s.inputs)a.push([l.name,l.type]);else for(let l=0;l<p.length;l++)a.push([`p${l}`,X(p[l],e)]);let d=f(i,e),h=X(r,e),T=[];if(e?.isWebGL){for(let[l,g]of a)J(e,o,g),u.push(`${g} ${l}`);J(e,o,h),T.push(`${h} ${o}(${u}) {`)}else{for(let[g,v]of a)u.push(`${g}: ${N(v,e)}`);h==="void"?T.push(`fn ${o}(${u}) {`):T.push(`fn ${o}(${u}) -> ${N(h,e)} {`)}return d&&T.push(d),T.push("}"),T.join(`
|
|
21
|
+
`)},lt=(e,t,r)=>e.isWebGL?`${r} ${t};`:`@location(${e.code?.vertVaryings?.size||0}) ${t}: ${N(r,e)}`,dt=(e,t,r)=>{if(e.isWebGL)return`${r} ${t};`;let{location:o=0}=e.gl?.webgpu?.attribs.map.get(t)||{},n=N(r,e);return`@location(${o}) ${t}: ${n}`},xt=(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;
|
|
22
|
+
@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=N(r,e);return`@group(${n}) @binding(${s}) var<uniform> ${t}: ${i};`},mt=(e,t,r)=>{if(e.isWebGL){let i=`uniform sampler2D ${t};`;if(e.label!=="compute")return i;let p=e.units?.(t);return`${i}
|
|
23
|
+
layout(location = ${p}) out vec4 _${t};`}let{group:o=0,binding:n=0}=e.gl?.webgpu?.storages.map.get(t)||{},s=N(r,e);return`@group(${o}) @binding(${n}) var<storage, read_write> ${t}: array<${s}>;`},Tt=(e,t,r,o)=>e.isWebGL?`const ${r} ${t} = ${o};`:`const ${t}: ${N(r,e)} = ${o};`;var f=(e,t)=>{if(t||(t={}),et(t),x.arr(e))return w(e,t);if(x.str(e))return e;if(x.num(e)){let l=`${e}`;return l.includes(".")?l:l+".0"}if(x.bol(e))return e?"true":"false";if(!e)return"";let{type:r,props:o={}}=e,{id:n="i",children:s=[],fields:i,initialValues:p}=o,[a,u,d,h]=s;if(r==="variable")return n;if(r==="member")return`${f(a,t)}.${f(u,t)}`;if(r==="element")return`${f(a,t)}[${f(u,t)}]`;if(r==="gather")return t.isWebGL?nt(t,a,u,e):`${f(a,t)}[${f(u,t)}]`;if(r==="scatter"){let[l,g]=a.props.children??[];return t.isWebGL?ot(t,l,u):`${f(l,t)}[${f(g,t)}] = ${f(u,t)};`}if(r==="ternary")return t.isWebGL?`(${f(d,t)} ? ${f(a,t)} : ${f(u,t)})`:`select(${f(a,t)}, ${f(u,t)}, ${f(d,t)})`;if(r==="conversion")return`${N(a,t)}(${w(s.slice(1),t)})`;if(r==="operator")return a==="not"||a==="bitNot"?`!${f(u,t)}`:`(${f(u,t)} ${Qe(a)} ${f(d,t)})`;if(r==="function")return a==="negate"?`(-${f(u,t)})`:a==="oneMinus"?`(1.0-${f(u,t)})`:a==="texture"?st(t,u,d,h):a==="atan2"&&t.isWebGL?`atan(${f(u,t)}, ${f(d,t)})`:`${a}(${w(s.slice(1),t)})`;if(r==="scope")return s.map(l=>f(l,t)).join(`
|
|
24
|
+
`);if(r==="assign")return`${f(a,t)} = ${f(u,t)};`;if(r==="return")return`return ${f(a,t)};`;if(r==="loop")return t.isWebGL?`for (int ${n} = 0; ${n} < ${f(a,t)}; ${n} += 1) {
|
|
25
|
+
${f(u,t)}
|
|
26
|
+
}`:`for (var ${n}: i32 = 0; ${n} < ${f(a,t)}; ${n}++) {
|
|
27
|
+
${f(u,t)}
|
|
28
|
+
}`;if(r==="if")return it(t,a,u,s);if(r==="switch")return at(t,a,s);if(r==="declare")return ut(t,a,u);if(r==="define")return t.code?.headers.has(n)||t.code?.headers.set(n,ct(t,o,e)),`${n}(${w(s.slice(1),t)})`;if(r==="struct")return t.code?.headers.has(n)||t.code?.headers.set(n,pt(t,n,i)),ft(t,n,a.props.id,p);if(r==="varying"){if(t.code?.vertOutputs.has(n))return t.isWebGL?`${n}`:`out.${n}`;let l=lt(t,n,X(e,t));return t.code?.fragInputs.set(n,l),t.code?.vertOutputs.set(n,l),t.code?.vertVaryings.set(n,f(a,t)),t.isWebGL?`${n}`:`out.${n}`}if(r==="builtin"){if(t.isWebGL)return Ze(t,n);if(n==="position")return"out.position";let l=`@builtin(${n}) ${n}: ${N(X(e,t),t)}`;return t.label==="compute"?t.code?.computeInputs.set(n,l):t.label==="frag"?t.code?.fragInputs.set(n,l):t.label==="vert"&&t.code?.vertInputs.set(n,l),`in.${n}`}if(r==="attribute"){let l=he(t,n,!0);return ye(a,l),e.listeners.add(l),t.code?.vertInputs.set(n,dt(t,n,X(e,t))),t.isWebGL?`${n}`:`in.${n}`}if(t.code?.headers.has(n))return n;let T="";if(r==="uniform"){let l=X(e,t),g=he(t,n,!1,l==="texture");ye(a,g),e.listeners.add(g),T=xt(t,n,l)}return r==="storage"&&(T=mt(t,n,X(e,t))),r==="constant"&&(T=Tt(t,n,X(e,t),f(a,t))),T?(t.code?.headers.set(n,T),n):f(a,t)};var U=null,M=null,I=e=>{if(!U||(U.props.children||(U.props.children=[]),U.props.children.push(e),e.type!=="return"||!M))return;let{props:t}=M;t.inferFrom||(t.inferFrom=[]),t.inferFrom.push(e)};function Xe(e,t){t||(t=C());let r=m("variable",{id:t,inferFrom:[e]}),o=m("declare",null,e,r);return I(o),r}var Ce=(e,t=!1,r)=>{let o=m(t?"scatter":"assign",null,e,r);return I(o),e},gt=e=>{let t=m("return",{inferFrom:[e]},e);return I(t),t},Zt=(e,t=C())=>(r={},o=C())=>{let n=m("variable",{id:o,inferFrom:[t]}),s=m("struct",{id:t,fields:e,initialValues:r},n);return I(s),n},A=(e,t,r=M)=>{let[o,n]=[U,M];[U,M]=[e,r];let s=t();s&>(s),[U,M]=[o,n]},Qt=(e,t)=>{let r=m("scope");A(r,t);let o=m("if",null,e,r);I(o);let n=()=>({ElseIf:(s,i)=>{let p=m("scope");return A(p,i),o.props.children.push(s,p),n()},Else:s=>{let i=m("scope");A(i,s),o.props.children.push(i)}});return n()},Jt=(e,t)=>{let r=m("scope"),o=C();A(r,()=>t({i:m("variable",{id:o,inferFrom:[b("int",0)]})}));let n=m("loop",{id:o},e,r);return I(n),n},er=e=>{let t=m("switch",null,e);I(t);let r=()=>({Case:(...o)=>n=>{let s=m("scope");A(s,n);for(let i of o)t.props.children.push(i,s);return r()},Default:o=>{let n=m("scope");A(n,o),t.props.children.push(n)}});return r()};function tr(e,t=C()){let r,o=(...n)=>{let s=r?.name||t,i=m("scope"),p=[],a=[];if(r?.inputs)for(let d of r.inputs)a.push({id:d.name,inferFrom:[b(d.type)]});else for(let d=0;d<n.length;d++)a.push({id:`p${d}`,inferFrom:[n[d]]});for(let d of a)p.push(m("variable",d));let u=m("define",{id:s,layout:r},i,...n);return A(i,()=>e(p),u),u};return o.setLayout=n=>(r=n,o),o}var rr=(e,t)=>{if(t==="string")return f(e,null)},m=(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!=="__nodeType"){if(a==="toVar")return Xe.bind(null,i);if(a==="isProxy")return!0;if(a==="toString")return f.bind(null,i);if(a===Symbol.toPrimitive)return rr.bind(null,i);if(a==="listeners")return o;if(a==="attribute")return(u=C())=>bt(i,u);if(a==="constant")return(u=C())=>vt(i,u);if(a==="uniform")return(u=C())=>B(i,u);if(a==="variable")return(u=C())=>ht(u);if(a==="builtin")return(u=C())=>_(u);if(a==="vertexStage")return(u=C())=>yt(i,u);if(a==="element")return u=>e==="storage"?Et(i,u):_e(i,u);if(a==="member")return u=>ee(i,u);if(a==="assign")return Ce.bind(null,i,i.type==="gather");if(Ye(a))return(...u)=>Xt(a,i,...u);if(He(a))return(...u)=>c(a,i,...u);if(je(a))return()=>b(Je(a),i);if(x.str(a))return tt(a)?_e(i,a):ee(i,a)}},s=(p,a,u)=>(a==="value"&&o.forEach(d=>d(u)),x.str(a)&&ee(i,a).assign(u),!0),i=new Proxy({},{get:n,set:s});return i},bt=(e,t=C())=>m("attribute",{id:t},e),vt=(e,t=C())=>m("constant",{id:t},e),B=(e,t=C())=>m("uniform",{id:t},e),nr=(e,t=C())=>m("storage",{id:t},e),ht=(e=C())=>m("variable",{id:e}),_=(e=C())=>m("builtin",{id:e}),yt=(e,t=C())=>m("varying",{id:t,inferFrom:[e]},e),ee=(e,t)=>m("member",null,e,t),_e=(e,t)=>m("element",null,e,t),Et=(e,t)=>m("gather",null,e,t),or=(e,t)=>m("scatter",null,e,t),sr=(e,t,r)=>m("ternary",null,e,t,r),Xt=(e,...t)=>m("operator",null,e,...t),c=(e,...t)=>m("function",null,e,...t),b=(e,...t)=>m("conversion",null,e,...t);var ir=`
|
|
25
29
|
#version 300 es
|
|
26
30
|
precision mediump float;
|
|
27
31
|
out vec4 fragColor;
|
|
28
|
-
`.trim(),
|
|
29
|
-
`):
|
|
30
|
-
`),[
|
|
32
|
+
`.trim(),ar=(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},Pe=(e,t)=>{let r=f(e,t),o="";return t.isWebGL&&t.code?.dependencies?o=ar(t.code.headers,t.code.dependencies).map(([,s])=>s).join(`
|
|
33
|
+
`):o=Array.from(t.code?.headers?.values()||[]).join(`
|
|
34
|
+
`),[o,r]},te=(e,t)=>`struct ${e} {
|
|
31
35
|
${Array.from(t.values()).join(`,
|
|
32
36
|
`)}
|
|
33
|
-
}`,
|
|
34
|
-
fragColor = ${
|
|
35
|
-
fn main(out: Out) -> @location(0) vec4f {`),
|
|
36
|
-
`).trim()},
|
|
37
|
-
`).trim()},
|
|
37
|
+
}`,z=(e,t)=>{if(x.str(e))return e.trim();t.code?.headers?.clear(),t.label="frag";let[r,o]=Pe(e,t),n=[];if(t.isWebGL){n.push(ir);for(let i of t.code?.fragInputs?.values()||[])n.push(`in ${i}`);n.push(r),n.push(`void main() {
|
|
38
|
+
fragColor = ${o};`)}else t.code?.fragInputs?.size&&n.push(te("Out",t.code.fragInputs)),n.push(r),n.push(`@fragment
|
|
39
|
+
fn main(out: Out) -> @location(0) vec4f {`),n.push(` return ${o};`);return n.push("}"),n.filter(Boolean).join(`
|
|
40
|
+
`).trim()},q=(e,t)=>{if(x.str(e))return e.trim();t.code?.headers?.clear(),t.label="vert";let[r,o]=Pe(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(te("In",t.code.vertInputs)),t.code?.vertOutputs?.size&&n.push(te("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;")}return n.push("}"),n.filter(Boolean).join(`
|
|
41
|
+
`).trim()},Y=(e,t)=>{if(x.str(e))return e.trim();t.code?.headers?.clear(),t.label="compute";let[r,o]=Pe(e,t),n=[];return t.isWebGL?(n.push("#version 300 es"),n.push("precision mediump float;"),n.push(r),n.push("void main() {"),n.push(` ${o};`),n.push("}")):(t.code?.computeInputs?.size&&n.push(te("In",t.code.computeInputs)),n.push(r),n.push("@compute @workgroup_size(32)"),n.push(`fn main(${t.code?.computeInputs?.size?"in: In":""}) {`),n.push(` ${o};`),n.push("}")),n.filter(Boolean).join(`
|
|
42
|
+
`).trim()};var re=_("position"),ne=_("vertex_index"),ur=_("instance_index"),pr=_("front_facing"),fr=_("frag_depth"),cr=_("sample_index"),lr=_("sample_mask"),dr=_("point_coord"),xr=_("global_invocation_id"),mr=_("position"),Tr=_("positionWorld"),gr=_("positionView"),br=_("normalLocal"),vr=_("normalWorld"),hr=_("normalView"),yr=_("screenCoordinate"),Er=_("screenUV"),H=e=>b("float",e),W=e=>b("int",e),Xr=e=>b("uint",e),Cr=e=>b("bool",e),Ge=(e,t)=>b("vec2",e,t),$e=(e,t,r)=>b("vec3",e,t,r),oe=(e,t,r,o)=>b("vec4",e,t,r,o),_r=(...e)=>b("mat2",...e),Pr=(...e)=>b("mat3",...e),$r=(...e)=>b("mat4",...e),Gr=(e,t)=>b("ivec2",e,t),Lr=(e,t,r)=>b("ivec3",e,t,r),Nr=(e,t,r,o)=>b("ivec4",e,t,r,o),Sr=(e,t)=>b("uvec2",e,t),Rr=(e,t,r)=>b("uvec3",e,t,r),wr=(e,t,r,o)=>b("uvec4",e,t,r,o),Fr=(e,t)=>b("bvec2",e,t),Ur=(e,t,r)=>b("bvec3",e,t,r),Ar=(e,t,r,o)=>b("bvec4",e,t,r,o),Ir=e=>b("texture",e),Or=()=>b("sampler2D"),Dr=(e,t,r)=>x.num(e)&&x.und(t)&&x.und(r)?$e(...Ke(e)):$e(e,t,r),se=B(Ge(),"iResolution"),Mr=B(Ge(),"iMouse"),Br=B(H(),"iTime"),Wr=re.xy.div(se),kr=e=>c("all",e),Vr=e=>c("any",e),zr=e=>c("length",e),qr=e=>c("lengthSq",e),Yr=(e,t)=>c("distance",e,t),Hr=(e,t)=>c("dot",e,t),jr=(e,t)=>c("cross",e,t),Kr=(e,t,r)=>c("cubeTexture",e,t,r),Zr=(e,t,r)=>c("texture",e,t,r),Qr=(e,t,r)=>c("texelFetch",e,t,r),Jr=(e,t,r)=>c("textureLod",e,t,r),en=e=>c("abs",e),tn=e=>c("acos",e),rn=e=>c("acosh",e),nn=e=>c("asin",e),on=e=>c("asinh",e),sn=e=>c("atan",e),an=e=>c("atanh",e),un=e=>c("ceil",e),pn=e=>c("cos",e),fn=e=>c("cosh",e),cn=e=>c("dFdx",e),ln=e=>c("dFdy",e),dn=e=>c("degrees",e),xn=e=>c("exp",e),mn=e=>c("exp2",e),Tn=e=>c("floor",e),Le=e=>c("fract",e),gn=e=>c("fwidth",e),bn=e=>c("inverseSqrt",e),vn=e=>c("log",e),hn=e=>c("log2",e),yn=e=>c("negate",e),En=e=>c("normalize",e),Xn=e=>c("oneMinus",e),Cn=e=>c("radians",e),_n=e=>c("reciprocal",e),Pn=e=>c("round",e),$n=e=>c("saturate",e),Gn=e=>c("sign",e),Ln=e=>c("sin",e),Nn=e=>c("sinh",e),Sn=e=>c("sqrt",e),Rn=e=>c("tan",e),wn=e=>c("tanh",e),Fn=e=>c("trunc",e),Un=(e,t)=>c("atan2",e,t),An=(e,t,r)=>c("clamp",e,t,r),In=(e,t)=>c("max",e,t),On=(e,t)=>c("min",e,t),Dn=(e,t,r)=>c("mix",e,t,r),Mn=(e,t)=>c("pow",e,t),Bn=(e,t)=>c("reflect",e,t),Wn=(e,t,r)=>c("refract",e,t,r),kn=(e,t,r)=>c("smoothstep",e,t,r),Vn=(e,t)=>c("step",e,t),zn=(e,t)=>e.sub(e.div(t).toFloat().floor().mul(t));var qn=`
|
|
38
43
|
#version 300 es
|
|
39
44
|
void main() {
|
|
40
45
|
float x = float(gl_VertexID % 2) * 4.0 - 1.0;
|
|
41
46
|
float y = float(gl_VertexID / 2) * 4.0 - 1.0;
|
|
42
47
|
gl_Position = vec4(x, y, 0.0, 1.0);
|
|
43
|
-
}`.trim(),
|
|
48
|
+
}`.trim(),Yn=(e,t)=>{if(!e.cs)return null;t.getExtension("EXT_color_buffer_float");let r=0,o=0,n=(0,O.nested)(()=>r++),s={isWebGL:!0,gl:e,units:n},i=ce(t,Y(e.cs,s),qn,e),p=Math.ceil(Math.sqrt(e.particles)),a=(0,O.nested)(g=>t.getUniformLocation(i,g)),u=(0,O.nested)(g=>{let v=new Float32Array(p*p*4),P={texture:t.createTexture(),buffer:t.createFramebuffer()},S={texture:t.createTexture(),buffer:t.createFramebuffer()};return{ping:P,pong:S,array:v,loc:a(g),unit:n(g)}});return{render:()=>{t.useProgram(i);let g=u.map.values().map(({ping:v,pong:P,loc:S,unit:F},k)=>{let[K,ue]=o%2?[v,P]:[P,v];return De(t,K,ue,S,F,k)});t.drawBuffers(g),t.drawArrays(t.TRIANGLES,0,3),t.bindFramebuffer(t.FRAMEBUFFER,null),o++},clean:()=>{t.deleteProgram(i),Oe(t,u.map.values())},_uniform:(g,v)=>{t.useProgram(i),le(t,a(g),v)},_storage:(g,v)=>{let{ping:P,pong:S,unit:F,array:k}=u(g);Ie(t,v,p,P,S,F,k)},storages:u}},Ne=async e=>{let t={isWebGL:!0,gl:e},r=e.el.getContext("webgl2"),o=Yn(e,r),n=ce(r,z(e.fs,t),q(e.vs,t),e);r.useProgram(n);let s=0,i=(0,O.nested)(()=>s++),p=(0,O.nested)(v=>r.getAttribLocation(n,v)),a=(0,O.nested)(v=>r.getUniformLocation(n,v)),u=(v="",P,S)=>{let F=p(v,!0);Ue(r,F,e.count,P,S)},d=(v,P)=>{r.useProgram(n),le(r,a(v),P),o?._uniform(v,P)},h=(v,P)=>{r.useProgram(n),Z(e,P,S=>{Ae(r,S,a(v),i(v))})},T=()=>{o?.clean(),r.deleteProgram(n),r.getExtension("WEBGL_lose_context")?.loseContext()},l=()=>{o?.render(),r.useProgram(n),r.viewport(0,0,...e.size),r.drawArrays(r.TRIANGLES,0,e.count),r.bindFramebuffer(r.FRAMEBUFFER,null)};return{webgl:{context:r,program:n,storages:o?.storages},render:l,clean:T,_attribute:u,_uniform:d,_texture:h,_storage:o?._storage}};var j=require("reev");var Ct=async(e,t=console.log)=>{let r=navigator.gpu,o=r.getPreferredCanvasFormat(),s=await(await r.requestAdapter()).requestDevice();return s.onuncapturederror=i=>t(i.error.message),e.configure({device:s,format:o,alphaMode:"opaque"}),{device:s,format:o}},_t=()=>{let e=0,t=0,r=0,o=0;return{uniform:()=>{let n=Math.floor(e/12),s=e%12;return e++,{group:n,binding:s}},texture:()=>{let s=Math.floor(e/12)+1+Math.floor(t/6),i=t%6*2;return t++,{group:s,binding:i}},storage:()=>{let s=Math.floor(e/12)+Math.floor(t/6)+2+Math.floor(r/12),i=r%12;return r++,{group:s,binding:i}},attrib:()=>{let n=o;return o++,{location:n}}}},Hn=e=>e===2?"float32x2":e===3?"float32x3":e===4?"float32x4":"float32",Pt=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:Hn(s)}]};return{vertexBuffers:t,bufferLayouts:r}},$t=(e,t,r,o=[])=>{let n=new Map,s={bindGroups:[],bindGroupLayouts:[]},i=(p,a,u)=>{n.has(p)||n.set(p,{layouts:[],bindings:[]});let{layouts:d,bindings:h}=n.get(p);d.push(a),h.push(u)};for(let{binding:p,buffer:a,group:u}of t)i(u,{binding:p,visibility:7,buffer:{type:"uniform"}},{binding:p,resource:{buffer:a}});for(let{binding:p,buffer:a,group:u}of o)i(u,{binding:p,visibility:6,buffer:{type:"storage"}},{binding:p,resource:{buffer:a}});for(let{binding:p,group:a,sampler:u,view:d}of r)i(a,{binding:p,visibility:2,sampler:{}},{binding:p,resource:u}),i(a,{binding:p+1,visibility:2,texture:{}},{binding:p+1,resource:d});for(let[p,{layouts:a,bindings:u}]of n)s.bindGroupLayouts[p]=e.createBindGroupLayout({entries:a}),s.bindGroups[p]=e.createBindGroup({layout:s.bindGroupLayouts[p],entries:u});return s},Gt=(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"}}),Lt=(e,t,r)=>e.createComputePipeline({compute:{module:e.createShaderModule({label:"compute",code:r}),entryPoint:"main"},layout:e.createPipelineLayout({bindGroupLayouts:t})}),jn=e=>e==="uniform"?72:e==="attrib"?40:140,ie=(e,t,r)=>{we(t)||(t=new Float32Array(t));let o=jn(r),n=r==="uniform"?Math.ceil(t.byteLength/256)*256:t.byteLength,s=e.createBuffer({size:n,usage:o});return{array:t,buffer:s}},Nt=(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"}}),St=(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}},Rt=(e,t,r)=>e.createTexture({size:[t,r],format:"depth24plus",usage:GPUTextureUsage.RENDER_ATTACHMENT});var Kn=32,Zn=(e,t,r)=>{let o=u=>{},n=(0,j.nested)((u,d)=>{let{array:h,buffer:T}=ie(t,d,"storage"),{binding:l,group:g}=r.storage();return{array:h,buffer:T,binding:l,group:g}});return{storages:n,_storage:(u,d)=>{let{array:h,buffer:T}=n(u,d);t.queue.writeBuffer(T,0,h)},update:(u,d,h)=>{let T=Lt(t,d,h);o=l=>{l.setPipeline(T),u.forEach((v,P)=>l.setBindGroup(P,v));let g=Math.ceil(e.particles/Kn);l.dispatchWorkgroups(g,1,1),l.end()}},render:u=>{o(u)},clean:()=>{for(let{buffer:u}of n.map.values())u.destroy()}}},Se=async e=>{let t=e.el.getContext("webgpu"),{device:r,format:o}=await Ct(t,e.error),n=_t(),s=Zn(e,r,n),i,p,a,u=y=>{},d=!0,h,T=(0,j.nested)((y,E)=>{d=!0;let $=E.length/e.count,{location:G}=n.attrib(),{array:R,buffer:L}=ie(r,E,"attrib");return{array:R,buffer:L,location:G,stride:$}}),l=(0,j.nested)((y,E)=>{d=!0;let{binding:$,group:G}=n.uniform(),{array:R,buffer:L}=ie(r,E,"uniform");return{array:R,buffer:L,binding:$,group:G}}),g=(0,j.nested)((y,E=0,$=0)=>{d=!0;let{binding:G,group:R}=n.texture(),{texture:L,sampler:V}=St(r,E,$);return{texture:L,sampler:V,binding:G,group:R,view:L.createView()}}),v=(y="",E)=>{let{array:$,buffer:G}=T(y,E);r.queue.writeBuffer(G,0,$)},P=(y,E)=>{x.num(E)&&(E=[E]);let{array:$,buffer:G}=l(y,E);$.set(E),r.queue.writeBuffer(G,0,$)},S=(y,E)=>{Z(e,E,$=>{let{width:G,height:R}=$,{texture:L}=g(y,G,R);r.queue.copyExternalImageToTexture({source:$},{texture:L},{width:G,height:R})})},F=()=>{let{vertexBuffers:y,bufferLayouts:E}=Pt(T.map.values()),{bindGroups:$,bindGroupLayouts:G}=$t(r,l.map.values(),g.map.values(),s.storages.map.values()),R=Gt(r,o,E,G,a,i);u=L=>{L.setPipeline(R),$.forEach((V,pe)=>L.setBindGroup(pe,V)),y.forEach((V,pe)=>L.setVertexBuffer(pe,V)),L.draw(e.count,1,0,0),L.end()},e.cs&&s.update($,G,p)},k=()=>{if(!i||!a){let E={isWebGL:!1,gl:e};i=z(e.fs,E),a=q(e.vs,E),p=Y(e.cs,E)}if(e.loading)return;d&&F(),d=!1;let y=r.createCommandEncoder();e.cs&&s.render(y.beginComputePass()),u(y.beginRenderPass(Nt(t,h))),r.queue.submit([y.finish()])},K=()=>{let y=e.el;h?.destroy(),h=Rt(r,y.width,y.height)},ue=()=>{r.destroy(),h?.destroy();for(let{texture:y}of g.map.values())y.destroy();for(let{buffer:y}of l.map.values())y.destroy();for(let{buffer:y}of T.map.values())y.destroy();s.clean()};return K(),{webgpu:{device:r,uniforms:l,textures:g,attribs:T,storages:s.storages},render:k,resize:K,clean:ue,_attribute:v,_uniform:P,_texture:S,_storage:s._storage}};var Qn=e=>x.obj(e)?"isGL"in e:!1,wt=()=>typeof window>"u",Ft=()=>wt()?!1:"gpu"in navigator,Re=performance.now(),Jn=()=>oe(Le(re.xy.div(se)),0,1),eo=()=>oe(H(W(ne).mod(W(2))).mul(4).sub(1),H(W(ne).div(W(2))).mul(4).sub(1),0,1),Ut=e=>{let t=(0,D.event)({isNative:!1,isWebGL:!0,isError:!1,isLoop:!0,isGL:!0,size:[0,0],mouse:[0,0],count:6,particles:1024,webgl:{},webgpu:{},loading:0,error(){t.isError=!0,t.isLoop=!1,t.clean(),console.warn("GLRE Error:",...arguments)}});return t.queue=(0,ae.createQueue)(),t.frame=(0,ae.createFrame)(),t.attribute=(0,D.durable)((r,o,n)=>t.queue(()=>t._attribute?.(r,o,n)),t),t.storage=(0,D.durable)((r,o)=>t.queue(()=>t._storage?.(r,o)),t),t.uniform=(0,D.durable)((r,o)=>t.queue(()=>t._uniform?.(r,o)),t),t.texture=(0,D.durable)((r,o)=>t.queue(()=>t._texture?.(r,o)),t),t.uniform({iResolution:t.size,iMouse:[0,0],iTime:Re}),t("mount",async()=>{t.vs=t.vs||t.vert||t.vertex||eo(),t.fs=t.fs||t.frag||t.fragment||Jn(),t.cs=t.cs||t.comp||t.compute,Ft()||(t.isWebGL=!0),t.isWebGL?t(await Ne(t)):t(await Se(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,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",()=>{Re=performance.now()/1e3,t.uniform("iTime",Re)}),t(e)},to=Ut;0&&(module.exports={Fn,If,Loop,Return,Switch,abs,acos,acosh,all,any,asin,asinh,assign,atan,atan2,atanh,attribute,bool,builtin,bvec2,bvec3,bvec4,ceil,clamp,color,compute,constant,conversion,cos,cosh,createGL,cross,cubeTexture,dFdx,dFdy,degrees,distance,dot,element,exp,exp2,float,floor,fract,fragDepth,fragment,frontFacing,function_,fwidth,gather,iMouse,iResolution,iTime,id,instanceIndex,int,inverseSqrt,isGL,isServer,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,radians,reciprocal,reflect,refract,round,sampleIndex,sampleMask,sampler2D,saturate,scatter,screenCoordinate,screenUV,select,sign,sin,sinh,smoothstep,sqrt,step,storage,struct,tan,tanh,texelFetch,texture,texture2D,textureLod,toVar,trunc,uint,uniform,uv,uvec2,uvec3,uvec4,variable,vec2,vec3,vec4,vertex,vertexIndex,vertexStage,webgl,webgpu});
|
|
44
49
|
//# sourceMappingURL=index.cjs.map
|