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