glre 0.31.0 → 0.32.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 +30 -64
- package/dist/index.cjs.map +1 -1
- package/dist/{index.d.cts → index.d.ts} +141 -185
- package/dist/index.js +30 -64
- package/dist/index.js.map +1 -1
- package/dist/native.cjs +30 -64
- package/dist/native.cjs.map +1 -1
- package/dist/native.d.ts +54 -0
- package/dist/native.js +30 -64
- package/dist/native.js.map +1 -1
- package/dist/react.cjs +30 -64
- package/dist/react.cjs.map +1 -1
- package/dist/react.d.ts +8 -0
- package/dist/react.js +30 -64
- package/dist/react.js.map +1 -1
- package/dist/solid.cjs +30 -64
- package/dist/solid.cjs.map +1 -1
- package/dist/solid.d.ts +8 -0
- package/dist/solid.js +30 -64
- package/dist/solid.js.map +1 -1
- package/package.json +7 -6
- package/src/index.ts +19 -5
- package/src/node/code.ts +66 -69
- package/src/node/const.ts +2 -0
- package/src/node/index.ts +78 -8
- package/src/node/infer.ts +19 -14
- package/src/node/node.ts +12 -14
- package/src/node/parse.ts +118 -0
- package/src/node/scope.ts +37 -18
- package/src/node/types.ts +90 -56
- package/src/node/utils.ts +9 -92
- package/src/types.ts +31 -16
- package/src/utils/pipeline.ts +135 -83
- package/src/utils/program.ts +7 -29
- package/src/webgl.ts +2 -3
- package/src/webgpu.ts +67 -58
- package/dist/native.d.cts +0 -53
- package/dist/react.d.cts +0 -8
- package/dist/solid.d.cts +0 -8
package/dist/index.js
CHANGED
|
@@ -1,70 +1,36 @@
|
|
|
1
|
-
import{durable as
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
`.trim(),ke=`
|
|
11
|
-
@fragment
|
|
12
|
-
fn main(@builtin(position) position: vec4f) -> @location(0) vec4f {
|
|
13
|
-
`.trim(),Ye=(e,t,r=!0)=>{let o="";return r&&(o+=qe),t&&(o+=`
|
|
14
|
-
`+t+`
|
|
15
|
-
`),r?o+=`void main() {
|
|
16
|
-
fragColor = ${e};`:(o+=ke+`
|
|
17
|
-
`,o+=` return ${e};`),o+=`
|
|
18
|
-
}`,o},je=(e,t,r=!0)=>"",F=(e,t={})=>{let r=c(e,t),o=xe(t),n=Ye(r,o,t.isWebGL);return console.log(`// \u2193\u2193\u2193 generated \u2193\u2193\u2193
|
|
19
|
-
|
|
20
|
-
${n}
|
|
21
|
-
|
|
22
|
-
`),n},U=(e,t)=>{let r=c(e,t),o=xe(t);return je(r,o,t.isWebGL)};var He=(e,t)=>e.reduce((r,o)=>{let n=T(o,t),s=C.indexOf(r);return C.indexOf(n)>s?n:r},"float"),Ke=e=>ne[e],Ze=(e,t,r)=>{let o=t.length>0?T(t[0],r):"float";return q.includes(e)?o:M.includes(e)?"float":V.includes(e)?"bool":z.includes(e)?o:W.includes(e)?"vec3":Y.includes(e)?"vec4":k.includes(e)?He(t,r):o},be=(e,t,r)=>{if(se.includes(r)||ie.includes(r))return"bool";if(e===t||e.includes("vec")&&!t.includes("vec"))return e;if(t.includes("vec")&&!e.includes("vec"))return t;let o=C.indexOf(e),n=C.indexOf(t);return o>=n?e:t},Qe=e=>v.bol(e)?"bool":v.num(e)?"float":v.arr(e)&&j[e.length]||"float",Je=e=>j[e],et=(e,t)=>{let{type:r,props:o}=e,{id:n,children:s=[],inferFrom:a}=o,[u,d,l]=s;return a?T(a,t):r==="conversion"?u:r==="operator"?be(T(d,t),T(l,t),u):r==="function"?Ze(u,s.slice(1),t):r==="swizzle"?Je(u.length):r==="ternary"?be(T(d,t),T(l,t),"add"):r==="builtin"?Ke(n):r==="define"?o.layout?.type&&o.layout?.type!=="auto"?o.layout.type:d?T(d,t):"void":T(u,t)},T=(e,t)=>{if(t||(t={}),!R(e))return Qe(e);if(t.infers||(t.infers=new WeakMap),t.infers.has(e))return t.infers.get(e);let r=et(e,t);return t.infers.set(e,r),r};var c=(e,t)=>{if(t||(t={}),t.headers||(t.headers=new Map),v.str(e))return e;if(v.num(e)){let p=`${e}`;return p.includes(".")?p:p+".0"}if(v.bol(e))return e?"true":"false";if(!e)return"";let{type:r,props:o}=e,{id:n="",children:s=[]}=o,[a,u,d]=s,l="";if(r==="attribute"){if(t.headers.has(n))return n;l=`${T(e,t)} ${n}`}if(r==="uniform"){if(t.headers.has(n))return n;t.binding||(t.binding=0);let p=T(e,t);l=t.isWebGL?`uniform ${p} ${n};`:`@group(0) @binding(${t.binding++}) var<uniform> ${n}: ${L(p,t)};`}if(r==="constant"){if(t.headers.has(n))return n;let p=T(e,t),f=c(a,t);l=t.isWebGL?`const ${p} ${n} = ${f};`:`const ${n}: ${L(p,t)} = ${f};`}if(r==="varying"){if(t.headers.has(n))return n;l=`${T(e,t)} ${n}`}if(l)return t.headers.set(n,l),t.onMount?.(n),n;if(r==="variable")return n;if(r==="swizzle")return`${c(u,t)}.${c(a,t)}`;if(r==="ternary")return`(${c(a,t)} ? ${c(u,t)} : ${c(d,t)})`;if(r==="builtin")return t?.isWebGL?me(n):n;if(r==="conversion")return`${L(a,t)}(${I(s.slice(1),t)})`;if(r==="operator")return a==="not"||a==="bitNot"?`!${c(u,t)}`:`(${c(u,t)} ${le(a)} ${c(d,t)})`;if(r==="function")return a==="negate"?`(-${I(s.slice(1),t)})`:`${a}(${I(s.slice(1),t)})`;if(r==="scope")return s.map(p=>c(p,t)).join(`
|
|
23
|
-
`);if(r==="assign")return`${c(a,t)} = ${c(u,t)};`;if(r==="loop")return t.isWebGL?`for (int i = 0; i < ${a}; i += 1) {
|
|
24
|
-
${c(u,t)}
|
|
25
|
-
}`:`for (var i: i32 = 0; i < ${a}; i++) {
|
|
26
|
-
${c(u,t)}
|
|
27
|
-
}`;if(r==="define"){let p=s.slice(2),f=`${n}(${p.map(N=>c(N,t))})`;return t.headers.has(n)||t.headers.set(n,ge(o,t)),f}if(r==="if"){let p=`if (${c(a,t)}) {
|
|
28
|
-
${c(u,t)}
|
|
29
|
-
}`;for(let f=2;f<s.length;f+=2){let N=f>=s.length-1;p+=N?` else {
|
|
30
|
-
${c(s[f],t)}
|
|
31
|
-
}`:` else if (${c(s[f],t)}) {
|
|
32
|
-
${c(s[f+1],t)}
|
|
33
|
-
}`}return p}if(r==="switch"){let p=`switch (${c(a,t)}) {
|
|
34
|
-
`;for(let f=1;f<s.length;f+=2)f>=s.length-1&&s.length%2===0?p+=`default:
|
|
35
|
-
${c(s[f],t)}
|
|
1
|
+
import{durable as fe,event as Pt}from"reev";import{createFrame as St,createQueue as wt}from"refr";import{nested as pe}from"reev";var l={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)},lt=(e,t)=>e.forEach(t),It=(e,...t)=>{lt(e,r=>r(...t))},Ut=(e="",t="_",r="/")=>e.split(t).join(r),Ft=(e=".pdf")=>e.split(".").pop()?.toLowerCase()??"",At=(e=0)=>`${e}`.split(".")[1]?.length??0,Dt=(e=0)=>`${e}`.split(".")[0]?.length-(e<0?1:0),Bt=(e=0,t=-2)=>(t*=-1,t=Math.pow(10,t),e*=t,e=Math.round(e),e/=t,e);var R=["bool","uint","int","float","bvec2","ivec2","uvec2","vec2","bvec3","ivec3","uvec3","vec3","bvec4","ivec4","uvec4","vec4","color","mat2","mat3","mat4","texture","sampler2D"],Y=["toBool","toUint","toInt","toFloat","toBvec2","toIvec2","toUvec2","toVec2","toBvec3","toIvec3","toUvec3","toVec3","toBvec4","toIvec4","toUvec4","toVec4","toColor","toMat2","toMat3","toMat4"],H={add:"+",sub:"-",mul:"*",div:"/",mod:"%",equal:"==",notEqual:"!=",lessThan:"<",lessThanEqual:"<=",greaterThan:">",greaterThanEqual:">=",and:"&&",or:"||",bitAnd:"&",bitOr:"|",bitXor:"^",shiftLeft:"<<",shiftRight:">>"},xe=Object.keys(H),j=["dot","distance","length","lengthSq","determinant","luminance"],K=["all","any"],Z=["abs","sign","floor","ceil","round","fract","trunc","sin","cos","tan","asin","acos","atan","exp","exp2","log","log2","sqrt","inverseSqrt","normalize","oneMinus","saturate","negate","reciprocal","dFdx","dFdy","fwidth"],Q=["cross"],J=["reflect","refract"],ee=["min","max","mix","clamp","step","smoothstep"],te=["texture","textureLod","textureSize","cubeTexture"],mt=["atan2","degrees","faceforward","bitcast","cbrt","difference","equals","pow","pow2","pow3","pow4","radians","transformDirection"],de=[...j,...K,...Z,...Q,...J,...ee,...te,...mt],ge={float:"f32",int:"i32",uint:"u32",bool:"bool",vec2:"vec2f",vec3:"vec3f",vec4:"vec4f",mat2:"mat2x2f",mat3:"mat3x3f",mat4:"mat4x4f",ivec2:"vec2i",ivec3:"vec3i",ivec4:"vec4i",uvec2:"vec2u",uvec3:"vec3u",uvec4:"vec4u",bvec2:"vec2<bool>",bvec3:"vec3<bool>",bvec4:"vec4<bool>"},re={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",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"},ve=["equal","notEqual","lessThan","lessThanEqual","greaterThan","greaterThanEqual"],he=["and","or"],Xe={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 oe=e=>l.str(e)&&/^[xyzwrgbastpq]{1,4}$/.test(e),ye=e=>xe.includes(e),Te=e=>de.includes(e),_e=e=>Y.includes(e),Ee=e=>!e||typeof e!="object"?!1:e.isProxy,Ce=e=>!(!e||e==="auto"),Ne=e=>{let t=(e>>16&255)/255,r=(e>>8&255)/255,n=(e&255)/255;return[t,r,n]},xt=0,w=()=>`i${xt++}`,O=(e,t)=>e.filter(r=>!l.und(r)&&!l.nul(r)).map(r=>c(r,t)).join(", "),S=(e,t)=>l.str(e)?t?.isWebGL?e:ge[e]:"",Pe=e=>H[e]||e,Se=e=>Xe[e],we=e=>{let t=Y.indexOf(e);return t!==-1?R[t]:"float"};var dt=(e,t)=>e.reduce((r,n)=>{let o=X(n,t),i=R.indexOf(r);return R.indexOf(o)>i?o:r},"float"),gt=e=>be[e],bt=(e,t,r)=>{let n=t.length>0?X(t[0],r):"float";return J.includes(e)?n:j.includes(e)?"float":K.includes(e)?"bool":Z.includes(e)?n:Q.includes(e)?"vec3":te.includes(e)?"vec4":ee.includes(e)?dt(t,r):n},Le=(e,t,r)=>{if(ve.includes(r)||he.includes(r))return"bool";if(e===t||e.includes("vec")&&!t.includes("vec"))return e;if(t.includes("vec")&&!e.includes("vec"))return t;let n=R.indexOf(e),o=R.indexOf(t);return n>=o?e:t},vt=e=>l.bol(e)?"bool":l.num(e)?"float":l.arr(e)&&re[e.length]||"float",ht=e=>re[e],Xt=(e,t)=>{if(e.length===0)return"void";let r=X(e[0],t);for(let n of e.slice(1))if(r!==X(n))throw new Error("glre node system error: defined scope return mismatch");return r},yt=(e,t)=>{let{type:r,props:n}=e,{id:o,children:i=[],layout:s,inferFrom:a}=n,[p,f,b]=i;return r==="conversion"?p:r==="operator"?Le(X(f,t),X(b,t),p):r==="function"?bt(p,i.slice(1),t):r==="swizzle"?ht(p.length):r==="ternary"?Le(X(f,t),X(b,t),"add"):r==="builtin"?gt(o):r==="define"&&Ce(s?.type)?s?.type:a?Xt(a,t):X(p,t)},X=(e,t)=>{if(t||(t={}),!Ee(e))return vt(e);if(t.infers||(t.infers=new WeakMap),t.infers.has(e))return t.infers.get(e);let r=yt(e,t);return t.infers.set(e,r),r};var Re=(e,t,r,n)=>{if(e.isWebGL)return`texture(${O(n?[t,r,n]:[t,r],e)})`;let o=c(t,e),i=[o,o+"Sampler",c(r,e)];return n?(i.push(c(n,e)),`textureSampleLevel(${i})`):`textureSample(${i})`},Oe=(e,t,r,n)=>{let o=`if (${c(t,e)}) {
|
|
2
|
+
${c(r,e)}
|
|
3
|
+
}`;for(let i=2;i<n.length;i+=2){let s=i>=n.length-1;o+=s?` else {
|
|
4
|
+
${c(n[i],e)}
|
|
5
|
+
}`:` else if (${c(n[i],e)}) {
|
|
6
|
+
${c(n[i+1],e)}
|
|
7
|
+
}`}return o},Ge=(e,t,r)=>{let n=`switch (${c(t,e)}) {
|
|
8
|
+
`;for(let o=1;o<r.length;o+=2)o>=r.length-1&&r.length%2===0?n+=`default:
|
|
9
|
+
${c(r[o],e)}
|
|
36
10
|
break;
|
|
37
|
-
`:
|
|
38
|
-
${c(
|
|
11
|
+
`:o+1<r.length&&(n+=`case ${c(r[o],e)}:
|
|
12
|
+
${c(r[o+1],e)}
|
|
39
13
|
break;
|
|
40
|
-
`);return
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
}
|
|
47
|
-
`,
|
|
14
|
+
`);return n+="}",n},$e=(e,t,r)=>{let n=X(t,e),o=r?.props?.id;if(e.isWebGL)return`${n} ${o} = ${c(t,e)};`;let i=S(n);return`var ${o}: ${i} = ${c(t,e)};`},Ie=(e,t,r)=>{let{id:n,children:o=[],layout:i}=t,[s,...a]=o,p=[],f=[];if(i?.inputs)for(let g of i.inputs)p.push([g.name,g.type]);else for(let g=0;g<a.length;g++)p.push([`p${g}`,X(a[g],e)]);let b=[];if(e?.isWebGL){for(let[g,_]of p)f.push(`${_} ${g}`);b.push(`${r} ${n}(${f}) {`)}else{for(let[g,_]of p)f.push(`${g}: ${S(_,e)}`);b.push(`fn ${n}(${f}) -> ${S(r,e)} {`)}let x=c(s,e);return x&&b.push(x),b.push("}"),b.join(`
|
|
15
|
+
`)},Ue=(e,t,r)=>e.isWebGL?`${r} ${t};`:`@location(${e.vertVaryings.size}) ${t}: ${S(r,e)}`,Fe=(e,t,r)=>{let n=r==="sampler2D"||r==="texture";if(e.isWebGL)return n?`uniform sampler2D ${t};`:`uniform ${r} ${t};`;if(n){let{group:a=1,binding:p=0}=e.webgpu?.textures.map.get(t)||{};return`@group(${a}) @binding(${p}) var ${t}Sampler: sampler;
|
|
16
|
+
@group(${a}) @binding(${p+1}) var ${t}: texture_2d<f32>;`}let{group:o=0,binding:i=0}=e.webgpu?.uniforms.map.get(t)||{},s=S(r,e);return`@group(${o}) @binding(${i}) var<uniform> ${t}: ${s};`},Ae=(e,t,r)=>{if(e.isWebGL)return`${r} ${t};`;let{location:n=0}=e.webgpu?.attribs.map.get(t)||{},o=S(r,e);return`@location(${n}) ${t}: ${o}`},De=(e,t,r,n)=>e.isWebGL?`const ${r} ${t} = ${n};`:`const ${t}: ${S(r,e)} = ${n};`;var c=(e,t)=>{if(t||(t={}),t.headers||(t.headers=new Map),t.vertVaryings||(t.vertVaryings=new Map),t.fragInputs||(t.fragInputs=new Map),t.vertInputs||(t.vertInputs=new Map),t.vertOutputs||(t.vertOutputs=new Map,t.isWebGL||(t.fragInputs.set("position","@builtin(position) position: vec4f"),t.vertOutputs.set("position","@builtin(position) position: vec4f"))),l.str(e))return e;if(l.num(e)){let x=`${e}`;return x.includes(".")?x:x+".0"}if(l.bol(e))return e?"true":"false";if(!e)return"";let{type:r,props:n}=e,{id:o="",children:i=[]}=n,[s,a,p,f]=i;if(r==="variable")return o;if(r==="swizzle")return`${c(a,t)}.${c(s,t)}`;if(r==="ternary")return t.isWebGL?`(${c(s,t)} ? ${c(a,t)} : ${c(p,t)})`:`select(${c(s,t)}, ${c(a,t)}, ${c(p,t)})`;if(r==="conversion")return`${S(s,t)}(${O(i.slice(1),t)})`;if(r==="operator")return s==="not"||s==="bitNot"?`!${c(a,t)}`:`(${c(a,t)} ${Pe(s)} ${c(p,t)})`;if(r==="function")return s==="negate"?`(-${O(i.slice(1),t)})`:s==="texture"?Re(t,a,p,f):`${s}(${O(i.slice(1),t)})`;if(r==="scope")return i.map(x=>c(x,t)).join(`
|
|
17
|
+
`);if(r==="assign")return`${c(s,t)} = ${c(a,t)};`;if(r==="return")return`return ${c(s,t)};`;if(r==="loop")return t.isWebGL?`for (int i = 0; i < ${s}; i += 1) {
|
|
18
|
+
${c(a,t)}
|
|
19
|
+
}`:`for (var i: i32 = 0; i < ${s}; i++) {
|
|
20
|
+
${c(a,t)}
|
|
21
|
+
}`;if(r==="if")return Oe(t,s,a,i);if(r==="switch")return Ge(t,s,i);if(r==="declare")return $e(t,s,a);if(r==="define"){let x=`${o}(${O(i.slice(1),t)})`;return t.headers.has(o)||t.headers.set(o,Ie(t,n,X(e,t))),x}if(r==="varying"){if(t.vertOutputs.has(o))return t.isWebGL?`${o}`:`out.${o}`;let x=Ue(t,o,X(e,t));return t.fragInputs.set(o,x),t.vertOutputs.set(o,x),t.vertVaryings.set(o,c(s,t)),t.isWebGL?`${o}`:`out.${o}`}if(r==="builtin"){if(t.isWebGL)return Se(o);if(o==="position")return"out.position";let x=`@builtin(${o}) ${o}: ${S(X(e,t),t)}`;return t.isFrag?t.fragInputs.set(o,x):t.vertInputs.set(o,x),`in.${o}`}if(r==="attribute")return t.vertInputs.set(o,Ae(t,o,X(e,t))),t.isWebGL?`${o}`:`in.${o}`;if(t.headers.has(o))return o;let b="";return r==="uniform"&&(b=Fe(t,o,X(e,t))),r==="constant"&&(b=De(t,o,X(e,t),c(s,t))),b?(t.headers.set(o,b),o):c(s,t)};var G=null,U=null,F=e=>{if(!G||(G.props.children||(G.props.children=[]),G.props.children.push(e),e.type!=="return"||!U))return;let{props:t}=U;t.inferFrom||(t.inferFrom=[]),t.inferFrom.push(e)},Be=(e,t)=>{t||(t=w());let r=m("variable",{id:t,inferFrom:[e]}),n=m("declare",null,e,r);return F(n),r},Me=(e,t)=>{let r=m("assign",null,e,t);return F(r),e},Tt=e=>{let t=m("return",{inferFrom:[e]},e);return F(t),t},$=(e,t,r=U)=>{let n=G,o=U;G=e,U=r,n&&(e.props.parent=n);let i=t();i&&Tt(i),G=n,U=o},pr=(e,t)=>{let r=m("scope");$(r,t);let n=m("if",null,e,r);F(n);let o=()=>({ElseIf:(i,s)=>{let a=m("scope");return $(a,s),n.props.children.push(i,a),o()},Else:i=>{let s=m("scope");$(s,i),n.props.children.push(s)}});return o()},cr=(e,t)=>{let r=m("scope");$(r,()=>t({i:m("variable",{id:"i",inferFrom:[I(0)]})}));let n=m("loop",null,e,r);return F(n),n},fr=e=>{let t=m("switch",null,e);F(t);let r=()=>({Case:(...n)=>o=>{let i=m("scope");$(i,o);for(let s of n)t.props.children.push(s,i);return r()},Default:n=>{let o=m("scope");$(o,n),t.props.children.push(o)}});return r()},lr=e=>{let t,r=(...n)=>{let o=t?.name||w(),i=m("scope"),s=[],a=[];if(t?.inputs)for(let f of t.inputs)a.push({id:f.name,inferFrom:[d(f.type)]});else for(let f=0;f<n.length;f++)a.push({id:`p${f}`,inferFrom:[n[f]]});for(let f of a)s.push(m("variable",f));let p=m("define",{id:o,layout:t},i,...n);return $(i,()=>e(s),p),p};return r.setLayout=n=>(t=n,r),r};var _t=(e,t)=>{if(t==="string")return c(e)},m=(e,t,...r)=>{t||(t={}),r.length&&(t.children=r);let n=(s,a)=>{if(a==="type")return e;if(a==="props")return t;if(a==="toVar")return Be.bind(null,i);if(a==="assign")return Me.bind(null,i);if(a==="isProxy")return!0;if(a==="toString")return c.bind(null,i);if(a===Symbol.toPrimitive)return _t.bind(null,i);if(oe(a))return Ve(a,i);if(ye(a))return(...p)=>Et(a,i,...p);if(Te(a))return(...p)=>u(a,i,...p);if(_e(a))return()=>d(we(a),i)},o=(s,a,p)=>oe(a)?(Ve(a,i).assign(p),!0):!1,i=new Proxy({},{get:n,set:o});return i},vr=(e,t=w())=>m("attribute",{id:t},e),hr=(e,t=w())=>m("constant",{id:t},e),B=(e,t=w())=>m("uniform",{id:t},e),Xr=(e=w())=>m("variable",{id:e}),T=(e=w())=>m("builtin",{id:e}),yr=(e,t=w())=>m("varying",{id:t,inferFrom:[e]},e),Ve=(e,t)=>m("swizzle",null,e,t),Et=(e,...t)=>m("operator",null,e,...t),u=(e,...t)=>m("function",null,e,...t),d=(e,...t)=>m("conversion",null,e,...t),Tr=(e,t,r)=>m("ternary",null,e,t,r);var Ct=`
|
|
48
22
|
#version 300 es
|
|
49
23
|
precision mediump float;
|
|
50
|
-
uniform vec2 iResolution;
|
|
51
24
|
out vec4 fragColor;
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
@vertex
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
`,at=`
|
|
63
|
-
@group(0) @binding(0) var<uniform> iResolution: vec2f;
|
|
64
|
-
|
|
65
|
-
@fragment
|
|
66
|
-
fn main(@builtin(position) position: vec4f) -> @location(0) vec4f {
|
|
67
|
-
return vec4f(position.xy / iResolution, 0.0, 1.0);
|
|
68
|
-
}
|
|
69
|
-
`,Oe=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}},Ge=(e,t,r,o,n=it,s=at)=>{R(n)&&(n=U(n,{isWebGL:!1})),R(s)&&(s=F(s,{isWebGL:!1}));let a=e.createPipelineLayout({bindGroupLayouts:o});return e.createRenderPipeline({vertex:{module:e.createShaderModule({code:n.trim()}),entryPoint:"main",buffers:r},fragment:{module:e.createShaderModule({code:s.trim()}),entryPoint:"main",targets:[{format:t}]},layout:a,primitive:{topology:"triangle-list"}})},Ie=(e,t)=>{let r=[],o=[];t.forEach((a,u)=>{if(!a)return;let d="buffer"in a,l=a instanceof GPUTextureView,p=a instanceof GPUSampler;if(d)r.push({binding:u,visibility:3,buffer:{type:"uniform"}});else if(l)r.push({binding:u,visibility:2,texture:{}});else if(p)r.push({binding:u,visibility:2,sampler:{}});else return;o.push({binding:u,resource:a})});let n=e.createBindGroupLayout({entries:r}),s=e.createBindGroup({layout:n,entries:o});return{layout:n,bindGroup:s}},Fe=e=>({colorAttachments:[{view:e.getCurrentTexture().createView(),clearValue:{r:0,g:0,b:0,a:1},loadOp:"clear",storeOp:"store"}]}),ut=e=>Math.ceil(e/256)*256,Ue=(e,t)=>{let r=new Float32Array(t),o=e.createBuffer({size:r.byteLength,usage:40});return{array:r,buffer:o}},Ae=(e,t)=>{let r=new Float32Array(t),o=ut(r.byteLength),n=e.createBuffer({size:o,usage:72});return{array:r,buffer:n}},$e=(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}},ct=(e,t)=>e/t,pt=e=>e===2?"float32x2":e===3?"float32x3":e===4?"float32x4":"float32",Be=(e,t,r=6)=>{let o=ct(t,r);return{arrayStride:o*4,attributes:[{shaderLocation:e,offset:0,format:pt(o)}]}};var De=async e=>{let t=e.el.getContext("webgpu"),{device:r,format:o}=await Oe(t),n={device:r,context:t,resources:[[],[]],loadingImg:0,needsUpdate:!0},s=[],a=[],u=[],d=Q((_,x)=>{let{array:g,buffer:X}=Ue(r,x);return a.push(X),u.push(Be(u.length,g.length,e.count)),n.needsUpdate=!0,{array:g,buffer:X}}),l=Q((_,x)=>{let{array:g,buffer:X}=Ae(r,x);return n.resources[0].push({buffer:X}),n.needsUpdate=!0,{array:g,buffer:X}}),p=Q((_,{width:x,height:g})=>{let{texture:X,sampler:$}=$e(r,x,g);return n.resources[1].push($,X.createView()),n.needsUpdate=!0,{texture:X,width:x,height:g}}),f=()=>{let _=[];s.length=0,n.resources.forEach(x=>{if(!x.length)return;let{layout:g,bindGroup:X}=Ie(r,x);_.push(g),s.push(X)}),n.pipeline=Ge(r,o,u,_,e.vs,e.fs)};return{webgpu:n,render:()=>{if(n.loadingImg)return;n.needsUpdate&&f(),n.needsUpdate=!1;let _=r.createCommandEncoder(),x=_.beginRenderPass(Fe(t));x.setPipeline(n.pipeline),s.forEach((g,X)=>x.setBindGroup(X,g)),a.forEach((g,X)=>x.setVertexBuffer(X,g)),x.draw(e.count,1,0,0),x.end(),r.queue.submit([_.finish()])},clean:()=>{},_attribute:(_="",x)=>{let{array:g,buffer:X}=d(_,x);r.queue.writeBuffer(X,0,g)},_uniform:(_,x)=>{v.num(x)&&(x=[x]);let{array:g,buffer:X}=l(_,x);g.set(x),r.queue.writeBuffer(X,0,g)},_texture:(_,x)=>{n.loadingImg++;let g=Object.assign(new Image,{src:x,crossOrigin:"anonymous"});g.decode().then(()=>{let{texture:X,width:$,height:Me}=p(_,g);r.queue.copyExternalImageToTexture({source:g},{texture:X},{width:$,height:Me}),n.loadingImg--})}}};var bn=e=>v.obj(e)?"isGL"in e:!1,dt=()=>typeof window>"u",xt=()=>dt()?!1:"gpu"in navigator,ee=performance.now(),gt=e=>{let t=ft({isNative:!1,isWebGL:!0,isLoop:!0,isGL:!0,size:[0,0],mouse:[0,0],count:6,webgl:{},webgpu:{}});return t.queue=mt(),t.frame=lt(),t.attribute=J((r,o,n)=>t.queue(()=>t._attribute?.(r,o,n))),t.texture=J((r,o)=>t.queue(()=>t._texture?.(r,o))),t.uniform=J((r,o,n)=>t.queue(()=>t._uniform?.(r,o,n))),t.uniform({iResolution:t.size,iMouse:[0,0],iTime:ee}),t("mount",async()=>{t.vs=t.vs||t.vert||t.vertex,t.fs=t.fs||t.frag||t.fragment,xt()||(t.isWebGL=!0),t.isWebGL?t(await we(t)):t(await De(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,a]=t.size,{top:u,left:d}=t.el.getBoundingClientRect();t.mouse[0]=(o-u-s/2)/(s/2),t.mouse[1]=-(n-d-a/2)/(a/2),t.uniform("iMouse",t.mouse)}),t("loop",()=>{ee=performance.now()/1e3,t.uniform("iTime",ee)}),t(e)},vn=gt;export{ze as ADDITIONAL_FUNCTIONS,V as BOOL_RETURN_FUNCTIONS,ne as BUILTIN_TYPES,se as COMPARISON_OPERATORS,j as COMPONENT_COUNT_TO_TYPE,C as CONSTANTS,B as CONVERSIONS,q as FIRST_ARG_TYPE_FUNCTIONS,re as FUNCTIONS,qt as Fn,k as HIGHEST_TYPE_FUNCTIONS,Vt as If,ie as LOGICAL_OPERATORS,zt as Loop,D as OPERATORS,te as OPERATOR_KEYS,z as PRESERVE_TYPE_FUNCTIONS,M as SCALAR_RETURN_FUNCTIONS,Et as SWIZZLES,Wt as Switch,oe as TYPE_MAPPING,W as VEC3_RETURN_FUNCTIONS,Y as VEC4_RETURN_FUNCTIONS,ae as WGSL_TO_GLSL_BUILTIN,zr as abs,Wr as acos,ut as alignTo256,qr as all,kr as any,Yr as asin,ye as assign,jr as atan,Hr as atan2,Kt as attribute,Kr as bitcast,Tr as bool,h as builtin,Gr as bvec2,Ir as bvec3,Fr as bvec4,Zr as cbrt,Qr as ceil,Jr as clamp,c as code,Ur as color,Qt as constant,y as conversion,de as conversionToConstant,eo as cos,Ce as createAttrib,Ie as createBindGroup,Be as createBufferLayout,Fe as createDescriptor,Oe as createDevice,gt as createGL,Se as createIbo,Ge as createPipeline,Ne as createProgram,Le as createTexture,$e as createTextureSampler,Ae as createUniformBuffer,Pe as createVbo,Ue as createVertexBuffer,to as cross,Mr as cubeTexture,ro as dFdx,oo as dFdy,vn as default,st as defaultFragmentGLSL,nt as defaultVertexGLSL,no as degrees,so as difference,_t as dig,io as distance,ao as dot,Ve as each,uo as equals,co as exp,po as exp2,yt as ext,fo as faceforward,Xt as fig,ot as float,lo as floor,bt as flush,L as formatConversions,mo as fract,cr as fragDepth,F as fragment,ur as frontFacing,i as function_,xo as fwidth,ge as generateDefine,me as getBluiltin,K as getId,le as getOperator,Re as getStride,fe as hex2rgb,$r as iMouse,Ar as iResolution,Br as iTime,T as infer,et as inferImpl,ar as instanceIndex,Xe as int,go as inverseSqrt,v as is,pe as isConversion,ce as isFunction,bn as isGL,R as isNodeProxy,ue as isOperator,dt as isServer,H as isSwizzle,xt as isWebGPUSupported,Sr as ivec2,Rr as ivec3,Cr as ivec4,I as joins,bo as length,vo as lengthSq,yo as log,Xo as log2,Er as mat2,Nr as mat3,Pr as mat4,_o as max,To as min,ho as mix,Eo as negate,m as node,mr as normalLocal,xr as normalView,dr as normalWorld,No as normalize,Po as oneMinus,rt as operator,lr as pointCoord,sr as position,gr as positionLocal,vr as positionView,br as positionWorld,So as pow,Ro as pow2,Co as pow3,Lo as pow4,wo as radians,Oo as reciprocal,Go as reflect,Io as refract,vt as replace,Fo as round,pr as sampleIndex,fr as sampleMask,Uo as saturate,yr as screenCoordinate,Xr as screenUV,er as select,Tt as sig,Ao as sign,$o as sin,Bo as smoothstep,Do as sqrt,Mo as step,_e as swizzle,Vo as tan,Dr as texture,Vr as textureSize,ve as toVar,zo as transformDirection,Wo as trunc,_r as uint,A as uniform,Lr as uvec2,wr as uvec3,Or as uvec4,Jt as variable,Zt as varying,he as vec2,Te as vec3,hr as vec4,U as vertex,ir as vertexIndex,we as webgl,De as webgpu};
|
|
25
|
+
`.trim(),We=(e,t)=>{let r=c(e,t);return[Array.from(t.headers.values()).join(`
|
|
26
|
+
`),r]},ne=(e,t)=>`struct ${e} {
|
|
27
|
+
${Array.from(t.values()).join(`,
|
|
28
|
+
`)}
|
|
29
|
+
}`,M=(e,t)=>{t.headers?.clear(),t.isFrag=!1;let[r,n]=We(e,t),o=[];if(t.isWebGL){o.push("#version 300 es");for(let s of t.vertInputs.values())o.push(`in ${s}`);for(let s of t.vertOutputs.values())o.push(`out ${s}`);o.push(r),o.push("void main() {"),o.push(` gl_Position = ${n};`);for(let[s,a]of t.vertVaryings.entries())o.push(` ${s} = ${a};`)}else{t.vertInputs?.size&&o.push(ne("In",t.vertInputs)),t.vertOutputs?.size&&o.push(ne("Out",t.vertOutputs)),o.push(r),o.push("@vertex"),o.push(`fn main(${t.vertInputs?.size?"in: In":""}) -> Out {`),o.push(" var out: Out;"),o.push(` out.position = ${n};`);for(let[s,a]of t.vertVaryings.entries())o.push(` out.${s} = ${a};`);o.push(" return out;")}o.push("}");let i=o.filter(Boolean).join(`
|
|
30
|
+
`);return console.log(`\u2193\u2193\u2193generated\u2193\u2193\u2193
|
|
31
|
+
${i}`),i},V=(e,t)=>{t.headers?.clear(),t.isFrag=!0;let[r,n]=We(e,t),o=[];if(t.isWebGL){o.push(Ct);for(let s of t.fragInputs.values())o.push(`in ${s}`);o.push(r),o.push(`void main() {
|
|
32
|
+
fragColor = ${n};`)}else t.fragInputs?.size&&o.push(ne("Out",t.fragInputs)),o.push(r),o.push(`@fragment
|
|
33
|
+
fn main(out: Out) -> @location(0) vec4f {`),o.push(` return ${n};`);o.push("}");let i=o.filter(Boolean).join(`
|
|
34
|
+
`);return console.log(`\u2193\u2193\u2193generated\u2193\u2193\u2193
|
|
35
|
+
${i}`),i},se=T("position"),ie=T("vertex_index"),Sr=T("instance_index"),wr=T("front_facing"),Lr=T("frag_depth"),Rr=T("sample_index"),Or=T("sample_mask"),Gr=T("point_coord"),$r=T("normalLocal"),Ir=T("normalWorld"),Ur=T("normalView"),Fr=T("position"),Ar=T("positionWorld"),Dr=T("positionView"),Br=T("screenCoordinate"),Mr=T("screenUV"),z=e=>d("float",e),I=e=>d("int",e),Vr=e=>d("uint",e),zr=e=>d("bool",e),qe=(e,t)=>d("vec2",e,t),ze=(e,t,r)=>d("vec3",e,t,r),ae=(e,t,r,n)=>d("vec4",e,t,r,n),Wr=(...e)=>d("mat2",...e),qr=(...e)=>d("mat3",...e),kr=(...e)=>d("mat4",...e),Yr=(e,t)=>d("ivec2",e,t),Hr=(e,t,r)=>d("ivec3",e,t,r),jr=(e,t,r,n)=>d("ivec4",e,t,r,n),Kr=(e,t)=>d("uvec2",e,t),Zr=(e,t,r)=>d("uvec3",e,t,r),Qr=(e,t,r,n)=>d("uvec4",e,t,r,n),Jr=(e,t)=>d("bvec2",e,t),eo=(e,t,r)=>d("bvec3",e,t,r),to=(e,t,r,n)=>d("bvec4",e,t,r,n),ro=()=>d("texture"),oo=()=>d("sampler2D"),no=(e,t,r)=>l.num(e)&&l.und(t)&&l.und(r)?ze(...Ne(e)):ze(e,t,r),ue=B(qe(1280,800),"iResolution"),so=B(qe(0,0),"iMouse"),io=B(z(0),"iTime"),ao=()=>se.xy.div(ue),uo=(e,t,r)=>u("texture",e,t,r),po=(e,t,r)=>u("cubeTexture",e,t,r),co=(e,t)=>u("textureSize",e,t),fo=e=>u("abs",e),lo=e=>u("acos",e),mo=e=>u("all",e),xo=e=>u("any",e),go=e=>u("asin",e),bo=(e,t)=>t!==void 0?u("atan",e,t):u("atan",e),vo=(e,t)=>u("atan",e,t),ho=(e,t)=>u("bitcast",e,t),Xo=e=>u("cbrt",e),yo=e=>u("ceil",e),To=(e,t,r)=>u("clamp",e,t,r),_o=e=>u("cos",e),Eo=(e,t)=>u("cross",e,t),Co=e=>u("dFdx",e),No=e=>u("dFdy",e),Po=e=>u("degrees",e),So=(e,t)=>u("difference",e,t),wo=(e,t)=>u("distance",e,t),Lo=(e,t)=>u("dot",e,t),Ro=(e,t)=>u("equals",e,t),Oo=e=>u("exp",e),Go=e=>u("exp2",e),$o=(e,t,r)=>u("faceforward",e,t,r),Io=e=>u("floor",e),ke=e=>u("fract",e),Uo=e=>u("fwidth",e),Fo=e=>u("inverseSqrt",e),Ao=e=>u("length",e),Do=e=>u("lengthSq",e),Bo=e=>u("log",e),Mo=e=>u("log2",e),Vo=(e,t)=>u("max",e,t),zo=(e,t)=>u("min",e,t),Wo=(e,t,r)=>u("mix",e,t,r),qo=e=>u("negate",e),ko=e=>u("normalize",e),Yo=e=>u("oneMinus",e),Ho=(e,t)=>u("pow",e,t),jo=e=>u("pow2",e),Ko=e=>u("pow3",e),Zo=e=>u("pow4",e),Qo=e=>u("radians",e),Jo=e=>u("reciprocal",e),en=(e,t)=>u("reflect",e,t),tn=(e,t,r)=>u("refract",e,t,r),rn=e=>u("round",e),on=e=>u("saturate",e),nn=e=>u("sign",e),sn=e=>u("sin",e),an=(e,t,r)=>u("smoothstep",e,t,r),un=e=>u("sqrt",e),pn=(e,t)=>u("step",e,t),cn=e=>u("tan",e),fn=(e,t)=>u("transformDirection",e,t),ln=e=>u("trunc",e);var Ye=(e,t,r)=>{let n=e.createShader(r);if(!n)throw new Error("Failed to create shader");if(e.shaderSource(n,t.trim()),e.compileShader(n),e.getShaderParameter(n,e.COMPILE_STATUS))return n;let o=e.getShaderInfoLog(n);e.deleteShader(n),console.warn(`Could not compile shader: ${o}`)},He=(e,t,r,n=()=>{},o)=>{let i={isWebGL:!0,gl:o};l.str(r)||(r=V(r,i)),l.str(t)||(t=M(t,i));let s=e.createProgram(),a=Ye(e,t,e.VERTEX_SHADER),p=Ye(e,r,e.FRAGMENT_SHADER);if(!a||!p)return n();if(e.attachShader(s,a),e.attachShader(s,p),e.linkProgram(s),e.getProgramParameter(s,e.LINK_STATUS))return s;let f=e.getProgramInfoLog(s);e.deleteProgram(s),n(),console.warn(`Could not link pg: ${f}`)},je=(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},Ke=(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},Ze=(e,t,r)=>{r&&(e=Math.max(...r)+1);let n=t.length/e;return Math.floor(n)},Qe=(e,t,r,n,o)=>{e.bindBuffer(e.ARRAY_BUFFER,n),e.enableVertexAttribArray(r),e.vertexAttribPointer(r,t,e.FLOAT,!1,0,0),o&&e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,o)},Je=(e,t,r,n)=>{let o=e.createTexture();e.bindTexture(e.TEXTURE_2D,o),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,n),e.activeTexture(e.TEXTURE0+n),e.bindTexture(e.TEXTURE_2D,o)};var et=async e=>{let t=e.el.getContext("webgl2"),r=He(t,e.vs,e.fs,()=>void(e.isLoop=!1),e);t.useProgram(r);let n=0,o=pe(g=>t.getUniformLocation(r,g)),i=pe(g=>t.getAttribLocation(r,g)),s=pe(()=>n++);return{render:()=>{t.clear(t.COLOR_BUFFER_BIT),t.viewport(0,0,...e.size),t.drawArrays(t.TRIANGLES,0,3)},clean:()=>t.deleteProgram(r),_attribute:(g="",_,E)=>{let N=i(g,!0),A=je(t,_),W=Ke(t,E),q=Ze(e.count,_,E);Qe(t,q,N,A,W)},_uniform:(g,_)=>{let E=o(g);if(l.num(_))return t.uniform1f(E,_);let N=_.length;if(N<=4)return t[`uniform${N}fv`](E,_);N=Math.sqrt(N)<<0,t[`uniformMatrix${N}fv`](E,!1,_)},_texture:(g,_)=>{let E=new Image;Object.assign(E,{src:_,crossOrigin:"anonymous"}),E.decode().then(()=>{let N=o(g),A=s(g);Je(t,E,N,A)})},webgl:{context:t,program:r}}};import{nested as ce}from"reev";var tt=async e=>{let t=navigator.gpu,r=t.getPreferredCanvasFormat(),o=await(await t.requestAdapter()).requestDevice();return e.configure({device:o,format:r,alphaMode:"opaque"}),{device:o,format:r}},rt=()=>{let e=0,t=0,r=0;return{uniform:()=>{let n=Math.floor(e/12),o=e%12;return e++,{group:n,binding:o}},texture:()=>{let o=Math.floor(e/12)+1+Math.floor(t/6),i=t%6*2;return t++,{group:o,binding:i}},attrib:()=>{let n=r;return r++,{location:n}}}},ot=(e,t,r,n,o,i,s)=>{let a={isWebGL:!1,webgpu:o};l.str(s)||(s=V(s,a)),l.str(i)||(i=M(i,a));let p=e.createPipelineLayout({bindGroupLayouts:n});return e.createRenderPipeline({vertex:{module:e.createShaderModule({code:i.trim()}),entryPoint:"main",buffers:r},fragment:{module:e.createShaderModule({code:s.trim()}),entryPoint:"main",targets:[{format:t}]},layout:p,primitive:{topology:"triangle-list"},depthStencil:{depthWriteEnabled:!0,depthCompare:"less",format:"depth24plus"}})},nt=(e,t)=>{let r=new Float32Array(t),n=Math.ceil(r.byteLength/256)*256,o=e.createBuffer({size:n,usage:72});return{array:r,buffer:o}},st=(e,t)=>{let r=new Float32Array(t),n=e.createBuffer({size:r.byteLength,usage:40});return{array:r,buffer:n}},it=(e,t,r)=>{let n=new Map,o=(s=0)=>(n.has(s)||n.set(s,{entries0:[],entries1:[]}),n.get(s));for(let{binding:s,buffer:a,group:p}of t.values()){let{entries0:f,entries1:b}=o(p);f.push({binding:s,visibility:3,buffer:{type:"uniform"}}),b.push({binding:s,resource:{buffer:a}})}for(let{binding:s,group:a,sampler:p,texture:f}of r.values()){let{entries0:b,entries1:x}=o(a);b.push({binding:s,visibility:2,sampler:{}}),b.push({binding:s+1,visibility:2,texture:{}}),x.push({binding:s,resource:p}),x.push({binding:s+1,resource:f.createView()})}let i={bindGroups:[],bindGroupLayouts:[]};for(let[s,{entries0:a,entries1:p}]of n)i.bindGroupLayouts[s]=e.createBindGroupLayout({entries:a}),i.bindGroups[s]=e.createBindGroup({layout:i.bindGroupLayouts[s],entries:p});return i},at=(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"}}),ut=(e,t=1280,r=800)=>{let n=e.createTexture({size:[t,r],format:"rgba8unorm",usage:22}),o=e.createSampler({magFilter:"linear",minFilter:"linear"});return{texture:n,sampler:o}},pt=(e,t,r)=>e.createTexture({size:[t,r],format:"depth24plus",usage:GPUTextureUsage.RENDER_ATTACHMENT}),Nt=e=>e===2?"float32x2":e===3?"float32x3":e===4?"float32x4":"float32",ct=e=>{let t=[],r=[];for(let[,{buffer:n,location:o,stride:i}]of e)t[o]=n,r[o]={arrayStride:i*4,attributes:[{shaderLocation:o,offset:0,format:Nt(i)}]};return{vertexBuffers:t,bufferLayouts:r}};var ft=async e=>{let t=e.el.getContext("webgpu"),{device:r,format:n}=await tt(t),o=rt(),i=0,s=!0,a,p=y=>{},f=ce((y,v)=>{s=!0;let{group:h,binding:C}=o.uniform(),{array:L,buffer:P}=nt(r,v);return{array:L,buffer:P,binding:C,group:h}}),b=ce((y,{width:v,height:h})=>{s=!0;let{group:C,binding:L}=o.texture(),{texture:P,sampler:D}=ut(r,v,h);return{texture:P,sampler:D,binding:L,group:C}}),x=ce((y,v)=>{s=!0;let h=v.length/e.count,{location:C}=o.attrib(),{array:L,buffer:P}=st(r,v);return{array:L,buffer:P,location:C,stride:h}}),g=()=>{let{vertexBuffers:y,bufferLayouts:v}=ct(x.map),{bindGroups:h,bindGroupLayouts:C}=it(r,f.map,b.map),L=ot(r,n,v,C,me,e.vs,e.fs);p=P=>{P.setPipeline(L),h.forEach((D,k)=>P.setBindGroup(k,D)),y.forEach((D,k)=>P.setVertexBuffer(k,D)),P.draw(e.count,1,0,0),P.end()}},_=()=>{if(i)return;s&&g(),s=!1;let y=r.createCommandEncoder();p(y.beginRenderPass(at(t,a))),r.queue.submit([y.finish()])},E=()=>{let y=e.el;a?.destroy(),a=pt(r,y.width,y.height)},N=()=>{a?.destroy()},A=(y="",v)=>{let{array:h,buffer:C}=x(y,v);h.set(v),r.queue.writeBuffer(C,0,h)},W=(y,v)=>{l.num(v)&&(v=[v]);let{array:h,buffer:C}=f(y,v);h.set(v),r.queue.writeBuffer(C,0,h)},q=(y,v)=>{i++;let h=Object.assign(new Image,{src:v,crossOrigin:"anonymous"});h.decode().then(()=>{let C=b(y,h);r.queue.copyExternalImageToTexture({source:h},{texture:C.texture},{width:h.width,height:h.height}),i--})};E();let me={device:r,uniforms:f,textures:b,attribs:x};return{webgpu:me,render:_,resize:E,clean:N,_attribute:A,_uniform:W,_texture:q}};var Bn=e=>l.obj(e)?"isGL"in e:!1,Lt=()=>typeof window>"u",Rt=()=>Lt()?!1:"gpu"in navigator,le=performance.now(),Ot=()=>ae(ke(se.xy.div(ue)),0,1),Gt=()=>ae(z(I(ie).mod(I(2))).mul(4).sub(1),z(I(ie).div(I(2))).mul(4).sub(1),0,1),$t=e=>{let t=Pt({isNative:!1,isWebGL:!0,isLoop:!0,isGL:!0,size:[0,0],mouse:[0,0],count:6,webgl:{},webgpu:{}});return t.queue=wt(),t.frame=St(),t.attribute=fe((r,n,o)=>t.queue(()=>t._attribute?.(r,n,o)),t),t.uniform=fe((r,n,o)=>t.queue(()=>t._uniform?.(r,n,o)),t),t.texture=fe((r,n)=>t.queue(()=>t._texture?.(r,n)),t),t.uniform({iResolution:t.size,iMouse:[0,0],iTime:le}),t("mount",async()=>{t.vs=t.vs||t.vert||t.vertex||Gt(),t.fs=t.fs||t.frag||t.fragment||Ot(),Rt()||(t.isWebGL=!0),t.isWebGL?t(await et(t)):t(await ft(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,n=t.height||window.innerHeight;t.size[0]=t.el.width=r,t.size[1]=t.el.height=n,t.uniform("iResolution",t.size)}),t("mousemove",(r,n=r.clientX,o=r.clientY)=>{let[i,s]=t.size,{top:a,left:p}=t.el.getBoundingClientRect();t.mouse[0]=(n-a-i/2)/(i/2),t.mouse[1]=-(o-p-s/2)/(s/2),t.uniform("iMouse",t.mouse)}),t("loop",()=>{le=performance.now()/1e3,t.uniform("iTime",le)}),t(e)},Mn=$t;export{lr as Fn,pr as If,cr as Loop,Tt as Return,fr as Switch,fo as abs,lo as acos,mo as all,xo as any,go as asin,Me as assign,bo as atan,vo as atan2,vr as attribute,ho as bitcast,zr as bool,T as builtin,Jr as bvec2,eo as bvec3,to as bvec4,Xo as cbrt,yo as ceil,To as clamp,c as code,no as color,hr as constant,d as conversion,we as conversionToConstant,_o as cos,Qe as createAttrib,st as createAttribBuffer,it as createBindGroup,rt as createBindings,pt as createDepthTexture,at as createDescriptor,tt as createDevice,$t as createGL,Ke as createIbo,ot as createPipeline,He as createProgram,Je as createTexture,ut as createTextureSampler,nt as createUniformBuffer,je as createVbo,ct as createVertexBuffers,Eo as cross,po as cubeTexture,Co as dFdx,No as dFdy,Mn as default,Po as degrees,So as difference,Dt as dig,wo as distance,Lo as dot,lt as each,Ro as equals,Oo as exp,Go as exp2,Ft as ext,$o as faceforward,At as fig,z as float,Io as floor,It as flush,S as formatConversions,ke as fract,Lr as fragDepth,V as fragment,wr as frontFacing,u as function_,Uo as fwidth,Se as getBluiltin,w as getId,Pe as getOperator,Ze as getStride,Ne as hex2rgb,so as iMouse,ue as iResolution,io as iTime,Sr as instanceIndex,I as int,Fo as inverseSqrt,l as is,Ce as isConstantsType,_e as isConversion,Te as isFunction,Bn as isGL,Ee as isNodeProxy,ye as isOperator,Lt as isServer,oe as isSwizzle,Rt as isWebGPUSupported,Yr as ivec2,Hr as ivec3,jr as ivec4,O as joins,Ao as length,Do as lengthSq,Bo as log,Mo as log2,Wr as mat2,qr as mat3,kr as mat4,Vo as max,zo as min,Wo as mix,qo as negate,m as node,$r as normalLocal,Ur as normalView,Ir as normalWorld,ko as normalize,Yo as oneMinus,Et as operator,Gr as pointCoord,se as position,Fr as positionLocal,Dr as positionView,Ar as positionWorld,Ho as pow,jo as pow2,Ko as pow3,Zo as pow4,Qo as radians,Jo as reciprocal,en as reflect,tn as refract,Ut as replace,rn as round,Rr as sampleIndex,Or as sampleMask,oo as sampler2D,on as saturate,Br as screenCoordinate,Mr as screenUV,Tr as select,Bt as sig,nn as sign,sn as sin,an as smoothstep,un as sqrt,pn as step,Ve as swizzle,cn as tan,uo as texture,ro as texture2D,co as textureSize,Be as toVar,fn as transformDirection,ln as trunc,Vr as uint,B as uniform,ao as uv,Kr as uvec2,Zr as uvec3,Qr as uvec4,Xr as variable,qe as vec2,ze as vec3,ae as vec4,M as vertex,ie as vertexIndex,yr as vertexStage,et as webgl,ft as webgpu};
|
|
70
36
|
//# sourceMappingURL=index.js.map
|