glre 0.24.0 → 0.26.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 CHANGED
@@ -139,8 +139,8 @@ import { useGL, vec4, fract, fragCoord, iResolution } from 'glre/native'
139
139
  const frag = vec4(fract(fragCoord.xy / iResolution), 0, 1)
140
140
 
141
141
  const App = () => {
142
- const { gl, ref } = useGL({ frag })
143
- return <GLView style={{ flex: 1 }} onContextCreate={ref} />
142
+ const gl = useGL({ frag })
143
+ return <GLView style={{ flex: 1 }} onContextCreate={gl.ref} />
144
144
  }
145
145
 
146
146
  registerRootComponent(App)
package/dist/index.d.ts CHANGED
@@ -161,6 +161,10 @@ interface WebGPUState {
161
161
  device: GPUDevice;
162
162
  context: GPUContext;
163
163
  pipeline: GPUPipeline;
164
+ groups: any[];
165
+ resources: any[];
166
+ loadingImg: number;
167
+ needsUpdate: boolean;
164
168
  }
165
169
  type GL = EventState<{
166
170
  /**
@@ -272,7 +276,15 @@ declare const fig: (x?: number) => number;
272
276
  declare const dig: (x?: number) => number;
273
277
  declare const sig: (value?: number, digit?: number) => number;
274
278
 
275
- declare const createPipeline: (device: GPUDevice, format: string, vs: string | undefined, fs: string | undefined, buffers: any[]) => GPUPipeline;
279
+ declare const createDevive: (c: GPUContext) => Promise<{
280
+ device: any;
281
+ format: any;
282
+ }>;
283
+ declare const createPipeline: (device: GPUDevice, format: string, bufferLayouts: any[], bindGroupLayouts: any[], vs?: string | X, fs?: string | X) => GPUPipeline;
284
+ declare const createBindGroup: (device: GPUDevice, resources: any[]) => {
285
+ layout: any;
286
+ bindGroup: any;
287
+ };
276
288
  declare const createDescriptor: (c: GPUContext) => {
277
289
  colorAttachments: {
278
290
  view: any;
@@ -286,20 +298,54 @@ declare const createDescriptor: (c: GPUContext) => {
286
298
  storeOp: string;
287
299
  }[];
288
300
  };
301
+ declare const alignTo256: (size: number) => number;
302
+ declare const createVertexBuffer: (device: GPUDevice, value: number[]) => {
303
+ array: Float32Array<ArrayBuffer>;
304
+ buffer: any;
305
+ };
306
+ declare const createUniformBuffer: (device: GPUDevice, value: number[]) => {
307
+ array: Float32Array<ArrayBuffer>;
308
+ buffer: Buffer;
309
+ };
310
+ declare const createTextureSampler: (device: GPUDevice, width?: number, height?: number) => {
311
+ texture: any;
312
+ sampler: any;
313
+ };
314
+ declare const createBufferLayout: (shaderLocation: number, dataLength: number, count?: number) => {
315
+ arrayStride: number;
316
+ attributes: {
317
+ shaderLocation: number;
318
+ offset: number;
319
+ format: string;
320
+ }[];
321
+ };
289
322
 
290
323
  declare const defaultVertexGLSL = "\n#version 300 es\nvoid main() {\n float x = float(gl_VertexID % 2) * 4.0 - 1.0;\n float y = float(gl_VertexID / 2) * 4.0 - 1.0;\n gl_Position = vec4(x, y, 0.0, 1.0);\n}\n";
291
324
  declare const defaultFragmentGLSL = "\n#version 300 es\nprecision mediump float;\nuniform vec2 iResolution;\nout vec4 fragColor;\nvoid main() {\n fragColor = vec4(fract(gl_FragCoord.xy / iResolution), 0, 1);\n}\n";
292
- declare const createShader: (c: WebGLRenderingContext, source: string, type: number) => WebGLShader;
293
- declare const createProgram: (c: WebGLRenderingContext, vs?: string, fs?: string) => WebGLProgram;
325
+ declare const createProgram: (c: WebGLRenderingContext, vs?: string | X, fs?: string | X) => WebGLProgram;
294
326
  declare const createVbo: (c: WebGLRenderingContext, data: number[]) => WebGLBuffer;
295
327
  declare const createIbo: (c: WebGLRenderingContext, data: number[]) => WebGLBuffer;
296
- declare const createAttrib: (c: WebGLRenderingContext, stride: number, location: any, vbo: WebGLBuffer, ibo?: WebGLBuffer) => void;
297
- declare const createTexture: (c: WebGLRenderingContext, img: HTMLImageElement) => WebGLTexture;
298
- declare const activeTexture: (c: WebGLRenderingContext, location: WebGLUniformLocation | null, unit: number, texture: WebGLTexture) => void;
328
+ declare const getStride: (count: number, value: number[], iboValue?: number[]) => number;
329
+ declare const createAttrib: (c: WebGLRenderingContext, stride: number, loc: any, vbo: WebGLBuffer, ibo?: WebGLBuffer) => void;
330
+ declare const createTexture: (c: WebGLRenderingContext, img: HTMLImageElement, loc: any, unit: number) => void;
299
331
 
300
- declare const webgl: (gl: GL) => Promise<GL>;
332
+ declare const webgl: (gl: Partial<GL>) => Promise<{
333
+ webgl: WebGLState;
334
+ render: () => void;
335
+ clean: () => void;
336
+ _attribute: (key: string | undefined, value: number[], iboValue: number[]) => void;
337
+ _uniform: (key: string, value: number | number[]) => void;
338
+ _texture: (key: string, src: string) => void;
339
+ }>;
301
340
 
302
- declare const webgpu: (gl: GL) => Promise<GL>;
341
+ declare const webgpu: (gl: Partial<GL>) => Promise<{
342
+ webgpu: WebGPUState;
343
+ render: () => void;
344
+ clean: () => void;
345
+ _attribute: (key: string | undefined, value: number[]) => void;
346
+ _uniform: (key: string, value: number | number[]) => void;
347
+ _texture: (key: string, src: string) => void;
348
+ }>;
303
349
 
304
350
  declare const isGL: (a: unknown) => a is EventState<GL>;
305
351
  declare const isServer: () => boolean;
@@ -350,4 +396,4 @@ declare const createGL: (props?: Partial<GL>) => EventState<{
350
396
  }): GL;
351
397
  }, any[] | unknown[]>;
352
398
 
353
- export { Attribute, Attributes, CACHE_BOOLS, CACHE_FLOATS, CACHE_INTS, ConditionalNode, ConversionContext, FUNCTIONS, Fn, FunctionNode, GL, GLClearMode, GLDrawMode, GLDrawType, GPUBindGroup, GPUBuffer, GPUContext, GPUDevice, GPUPipeline, If, MathFunction, MathMethods, Node, NodeCreator, NodeType, OPERATORS, Operator, OperatorMethods, PrecisionMode, ProxyCallback, SWIZZLES, Swillzes, SwizzleProperties, TYPES, Uniform, UniformNode, Uniforms, WebGLState, WebGPUState, X, abs, activeTexture, bool, ceil, color, convertToNode, cos, createAttrib, createDescriptor, createGL, createIbo, createNode, createPipeline, createProgram, createShader, createTexture, createVbo, createGL as default, defaultFragmentGLSL, defaultVertexGLSL, dig, each, ext, fig, findDuplicateNodes, float, floor, flush, fract, fragCoord, getCachedBool, getCachedFloat, getCachedInt, glsl, iDeltaTime, iMouse, iPrevTime, iResolution, iTime, int, is, isGL, isServer, isWebGPUSupported, length, node, nodeToGLSL, nodeToWGSL, normalize, position, replace, sig, sin, sqrt, tan, uniform, updateUniforms, vec2, vec3, vec4, webgl, webgpu, wgsl };
399
+ export { Attribute, Attributes, CACHE_BOOLS, CACHE_FLOATS, CACHE_INTS, ConditionalNode, ConversionContext, FUNCTIONS, Fn, FunctionNode, GL, GLClearMode, GLDrawMode, GLDrawType, GPUBindGroup, GPUBuffer, GPUContext, GPUDevice, GPUPipeline, If, MathFunction, MathMethods, Node, NodeCreator, NodeType, OPERATORS, Operator, OperatorMethods, PrecisionMode, ProxyCallback, SWIZZLES, Swillzes, SwizzleProperties, TYPES, Uniform, UniformNode, Uniforms, WebGLState, WebGPUState, X, abs, alignTo256, bool, ceil, color, convertToNode, cos, createAttrib, createBindGroup, createBufferLayout, createDescriptor, createDevive, createGL, createIbo, createNode, createPipeline, createProgram, createTexture, createTextureSampler, createUniformBuffer, createVbo, createVertexBuffer, createGL as default, defaultFragmentGLSL, defaultVertexGLSL, dig, each, ext, fig, findDuplicateNodes, float, floor, flush, fract, fragCoord, getCachedBool, getCachedFloat, getCachedInt, getStride, glsl, iDeltaTime, iMouse, iPrevTime, iResolution, iTime, int, is, isGL, isServer, isWebGPUSupported, length, node, nodeToGLSL, nodeToWGSL, normalize, position, replace, sig, sin, sqrt, tan, uniform, updateUniforms, vec2, vec3, vec4, webgl, webgpu, wgsl };
package/dist/index.js CHANGED
@@ -1,22 +1,22 @@
1
- "use strict";var F=Object.defineProperty;var be=Object.getOwnPropertyDescriptor;var xe=Object.getOwnPropertyNames;var ye=Object.prototype.hasOwnProperty;var ve=(e,r)=>{for(var t in r)F(e,t,{get:r[t],enumerable:!0})},Te=(e,r,t,n)=>{if(r&&typeof r=="object"||typeof r=="function")for(let o of xe(r))!ye.call(e,o)&&o!==t&&F(e,o,{get:()=>r[o],enumerable:!(n=be(r,o))||n.enumerable});return e};var Ee=e=>Te(F({},"__esModule",{value:!0}),e);var Lr={};ve(Lr,{CACHE_BOOLS:()=>K,CACHE_FLOATS:()=>Q,CACHE_INTS:()=>Z,FUNCTIONS:()=>H,Fn:()=>ar,If:()=>sr,OPERATORS:()=>j,SWIZZLES:()=>k,TYPES:()=>Oe,abs:()=>lr,activeTexture:()=>W,bool:()=>ke,ceil:()=>yr,color:()=>Ke,convertToNode:()=>De,cos:()=>gr,createAttrib:()=>O,createDescriptor:()=>V,createGL:()=>he,createIbo:()=>B,createNode:()=>L,createPipeline:()=>D,createProgram:()=>M,createShader:()=>P,createTexture:()=>z,createVbo:()=>I,default:()=>wr,defaultFragmentGLSL:()=>ie,defaultVertexGLSL:()=>oe,dig:()=>Ce,each:()=>te,ext:()=>Le,fig:()=>Ne,findDuplicateNodes:()=>We,float:()=>U,floor:()=>xr,flush:()=>$e,fract:()=>vr,fragCoord:()=>ur,getCachedBool:()=>R,getCachedFloat:()=>_,getCachedInt:()=>G,glsl:()=>C,iDeltaTime:()=>me,iMouse:()=>mr,iPrevTime:()=>pe,iResolution:()=>pr,iTime:()=>cr,int:()=>Ye,is:()=>i,isGL:()=>$r,isServer:()=>de,isWebGPUSupported:()=>ge,length:()=>Er,node:()=>a,nodeToGLSL:()=>ne,nodeToWGSL:()=>ae,normalize:()=>Tr,position:()=>fr,replace:()=>we,sig:()=>Se,sin:()=>dr,sqrt:()=>br,tan:()=>hr,uniform:()=>b,updateUniforms:()=>ir,vec2:()=>je,vec3:()=>fe,vec4:()=>He,webgl:()=>q,webgpu:()=>Y,wgsl:()=>S});module.exports=Ee(Lr);var v=require("reev"),X=require("refr");var $=require("reev");var i={arr:Array.isArray,bol:e=>typeof e=="boolean",str:e=>typeof e=="string",num:e=>typeof e=="number",int:e=>Number.isInteger(e),fun:e=>typeof e=="function",und:e=>typeof e>"u",nul:e=>e===null,set:e=>e instanceof Set,map:e=>e instanceof Map,obj:e=>!!e&&e.constructor.name==="Object",nan:e=>typeof e=="number"&&Number.isNaN(e)},te=(e,r)=>e.forEach(r),$e=(e,...r)=>{te(e,t=>t(...r))},we=(e="",r="_",t="/")=>e.split(r).join(t),Le=(e=".pdf")=>e.split(".").pop()?.toLowerCase()??"",Ne=(e=0)=>`${e}`.split(".")[1]?.length??0,Ce=(e=0)=>`${e}`.split(".")[0]?.length-(e<0?1:0),Se=(e=0,r=-2)=>(r*=-1,r=Math.pow(10,r),e*=r,e=Math.round(e),e/=r,e);var ne=(e,r)=>{let t={target:"webgl",precision:"mediump",version:"300 es",nodes:new Map,variables:new Map,functions:new Map,...r};return E(e,t)},E=(e,r)=>e?i.und(e.value)?e.property&&e.parent?`${E(e.parent,r)}.${e.property}`:e.operator&&e.children&&e.children.length>=2?Ge(e,r):e.mathFunction&&e.children&&e.children.length>=1?_e(e,r):"0.0":Re(e.value,e.type):"0.0",Re=(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"},Ge=(e,r)=>{if(!e.children||e.children.length<2)return"0.0";let t=E(e.children[0],r),n=E(e.children[1],r);return e.operator==="add"?`(${t} + ${n})`:e.operator==="sub"?`(${t} - ${n})`:e.operator==="mul"?`(${t} * ${n})`:e.operator==="div"?`(${t} / ${n})`:e.operator==="mod"?`mod(${t}, ${n})`:e.operator==="equal"?`(${t} == ${n})`:e.operator==="notEqual"?`(${t} != ${n})`:e.operator==="lessThan"?`(${t} < ${n})`:e.operator==="lessThanEqual"?`(${t} <= ${n})`:e.operator==="greaterThan"?`(${t} > ${n})`:e.operator==="greaterThanEqual"?`(${t} >= ${n})`:e.operator==="and"?`(${t} && ${n})`:e.operator==="or"?`(${t} || ${n})`:`(${t} + ${n})`},_e=(e,r)=>{if(!e.children||e.children.length<1)return"0.0";let t=e.mathFunction,n=e.children.map(d=>E(d,r)),[o,s,u]=n;return n.length===1?`${t}(${o})`:n.length===2?`${t}(${o}, ${s})`:n.length===3?`${t}(${o}, ${s}, ${u})`:o||"0.0"},Ue=e=>{if(i.num(e))return"float";if(i.bol(e))return"bool";if(i.arr(e)){let r=e.length;if(r===2)return"vec2";if(r===3)return"vec3";if(r===4)return"vec4"}return"float"},C=(e,r)=>{let t=r?.precision||"mediump",o=(r?.version||"300 es")==="300 es",s=ne(e),u="";return o&&(u+=`#version 300 es
2
- `),u+=`precision ${t} float;
1
+ "use strict";var I=Object.defineProperty;var Ce=Object.getOwnPropertyDescriptor;var Ge=Object.getOwnPropertyNames;var Re=Object.prototype.hasOwnProperty;var _e=(e,t)=>{for(var r in t)I(e,r,{get:t[r],enumerable:!0})},Ue=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Ge(t))!Re.call(e,o)&&o!==r&&I(e,o,{get:()=>t[o],enumerable:!(n=Ce(t,o))||n.enumerable});return e};var Xe=e=>Ue(I({},"__esModule",{value:!0}),e);var Mt={};_e(Mt,{CACHE_BOOLS:()=>ie,CACHE_FLOATS:()=>se,CACHE_INTS:()=>ae,FUNCTIONS:()=>oe,Fn:()=>xt,If:()=>yt,OPERATORS:()=>ne,SWIZZLES:()=>re,TYPES:()=>Qe,abs:()=>Lt,alignTo256:()=>xe,bool:()=>it,ceil:()=>_t,color:()=>ut,convertToNode:()=>rt,cos:()=>St,createAttrib:()=>q,createBindGroup:()=>H,createBufferLayout:()=>ee,createDescriptor:()=>K,createDevive:()=>k,createGL:()=>Ne,createIbo:()=>W,createNode:()=>S,createPipeline:()=>Y,createProgram:()=>z,createTexture:()=>V,createTextureSampler:()=>J,createUniformBuffer:()=>Q,createVbo:()=>O,createVertexBuffer:()=>Z,default:()=>Pt,defaultFragmentGLSL:()=>he,defaultVertexGLSL:()=>ge,dig:()=>Be,each:()=>me,ext:()=>Pe,fig:()=>Me,findDuplicateNodes:()=>et,float:()=>F,floor:()=>Rt,flush:()=>Ae,fract:()=>Ut,fragCoord:()=>Tt,getCachedBool:()=>U,getCachedFloat:()=>A,getCachedInt:()=>X,getStride:()=>D,glsl:()=>C,iDeltaTime:()=>$e,iMouse:()=>wt,iPrevTime:()=>Ee,iResolution:()=>$t,iTime:()=>Et,int:()=>ot,is:()=>i,isGL:()=>Ft,isServer:()=>we,isWebGPUSupported:()=>Le,length:()=>At,node:()=>s,nodeToGLSL:()=>le,nodeToWGSL:()=>be,normalize:()=>Xt,position:()=>vt,replace:()=>Fe,sig:()=>Ie,sin:()=>Nt,sqrt:()=>Gt,tan:()=>Ct,uniform:()=>v,updateUniforms:()=>bt,vec2:()=>at,vec3:()=>Te,vec4:()=>st,webgl:()=>j,webgpu:()=>te,wgsl:()=>R});module.exports=Xe(Mt);var w=require("reev"),M=require("refr");var G=require("reev");var i={arr:Array.isArray,bol:e=>typeof e=="boolean",str:e=>typeof e=="string",num:e=>typeof e=="number",int:e=>Number.isInteger(e),fun:e=>typeof e=="function",und:e=>typeof e>"u",nul:e=>e===null,set:e=>e instanceof Set,map:e=>e instanceof Map,obj:e=>!!e&&e.constructor.name==="Object",nan:e=>typeof e=="number"&&Number.isNaN(e)},me=(e,t)=>e.forEach(t),Ae=(e,...t)=>{me(e,r=>r(...t))},Fe=(e="",t="_",r="/")=>e.split(t).join(r),Pe=(e=".pdf")=>e.split(".").pop()?.toLowerCase()??"",Me=(e=0)=>`${e}`.split(".")[1]?.length??0,Be=(e=0)=>`${e}`.split(".")[0]?.length-(e<0?1:0),Ie=(e=0,t=-2)=>(t*=-1,t=Math.pow(10,t),e*=t,e=Math.round(e),e/=t,e);var le=(e,t)=>{let r={target:"webgl",precision:"mediump",version:"300 es",nodes:new Map,variables:new Map,functions:new Map,...t};return L(e,r)},L=(e,t)=>e?i.und(e.value)?e.property&&e.parent?`${L(e.parent,t)}.${e.property}`:e.operator&&e.children&&e.children.length>=2?Oe(e,t):e.mathFunction&&e.children&&e.children.length>=1?We(e,t):"0.0":ze(e.value,e.type):"0.0",ze=(e,t)=>{if(t==="float"){let r=Number(e);return r%1===0?`${r}.0`:`${r}`}if(t==="int")return`${Math.floor(Number(e))}`;if(t==="bool")return e?"true":"false";if(i.arr(e)){let r=e.map(n=>{let o=Number(n);return o%1===0?`${o}.0`:`${o}`}).join(", ");if(t==="vec2")return`vec2(${r})`;if(t==="vec3")return`vec3(${r})`;if(t==="vec4")return`vec4(${r})`;if(t==="color")return`vec3(${r})`}return"0.0"},Oe=(e,t)=>{if(!e.children||e.children.length<2)return"0.0";let r=L(e.children[0],t),n=L(e.children[1],t);return e.operator==="add"?`(${r} + ${n})`:e.operator==="sub"?`(${r} - ${n})`:e.operator==="mul"?`(${r} * ${n})`:e.operator==="div"?`(${r} / ${n})`:e.operator==="mod"?`mod(${r}, ${n})`:e.operator==="equal"?`(${r} == ${n})`:e.operator==="notEqual"?`(${r} != ${n})`:e.operator==="lessThan"?`(${r} < ${n})`:e.operator==="lessThanEqual"?`(${r} <= ${n})`:e.operator==="greaterThan"?`(${r} > ${n})`:e.operator==="greaterThanEqual"?`(${r} >= ${n})`:e.operator==="and"?`(${r} && ${n})`:e.operator==="or"?`(${r} || ${n})`:`(${r} + ${n})`},We=(e,t)=>{if(!e.children||e.children.length<1)return"0.0";let r=e.mathFunction,n=e.children.map(p=>L(p,t)),[o,a,u]=n;return n.length===1?`${r}(${o})`:n.length===2?`${r}(${o}, ${a})`:n.length===3?`${r}(${o}, ${a}, ${u})`:o||"0.0"},De=e=>{if(i.num(e))return"float";if(i.bol(e))return"bool";if(i.arr(e)){let t=e.length;if(t===2)return"vec2";if(t===3)return"vec3";if(t===4)return"vec4"}return"float"},C=(e,t)=>{let r=t?.precision||"mediump",o=(t?.version||"300 es")==="300 es",a=le(e),u="";return o&&(u+=`#version 300 es
2
+ `),u+=`precision ${r} float;
3
3
 
4
- `,r?.uniforms&&(Object.entries(r.uniforms).forEach(([d,h])=>{let x=Ue(h);u+=`uniform ${x} ${d};
4
+ `,t?.uniforms&&(Object.entries(t.uniforms).forEach(([p,y])=>{let E=De(y);u+=`uniform ${E} ${p};
5
5
  `}),u+=`
6
6
  `),o&&(u+=`out vec4 fragColor;
7
7
 
8
8
  `),u+=`void main() {
9
- `,u+=o?` fragColor = ${s};
10
- `:` gl_FragColor = ${s};
9
+ `,u+=o?` fragColor = ${a};
10
+ `:` gl_FragColor = ${a};
11
11
  `,u+=`}
12
- `,u};var oe=`
12
+ `,u};var ge=`
13
13
  #version 300 es
14
14
  void main() {
15
15
  float x = float(gl_VertexID % 2) * 4.0 - 1.0;
16
16
  float y = float(gl_VertexID / 2) * 4.0 - 1.0;
17
17
  gl_Position = vec4(x, y, 0.0, 1.0);
18
18
  }
19
- `,ie=`
19
+ `,he=`
20
20
  #version 300 es
21
21
  precision mediump float;
22
22
  uniform vec2 iResolution;
@@ -24,31 +24,25 @@ out vec4 fragColor;
24
24
  void main() {
25
25
  fragColor = vec4(fract(gl_FragCoord.xy / iResolution), 0, 1);
26
26
  }
27
- `,P=(e,r,t)=>{let n=e.createShader(t);if(!n)throw new Error("Failed to create shader");if(e.shaderSource(n,r.trim()),e.compileShader(n),e.getShaderParameter(n,e.COMPILE_STATUS))return n;let o=e.getShaderInfoLog(n);throw e.deleteShader(n),new Error(`Could not compile shader: ${o}`)},M=(e,r=oe,t=ie)=>{let n=e.createProgram();if(e.attachShader(n,P(e,r,e.VERTEX_SHADER)),e.attachShader(n,P(e,t,e.FRAGMENT_SHADER)),e.linkProgram(n),e.getProgramParameter(n,e.LINK_STATUS))return n;let o=e.getProgramInfoLog(n);throw e.deleteProgram(n),new Error(`Could not link pg: ${o}`)},I=(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},B=(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},O=(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)},z=(e,r)=>{let t=e.createTexture();return e.bindTexture(e.TEXTURE_2D,t),e.texImage2D(e.TEXTURE_2D,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,r),e.generateMipmap(e.TEXTURE_2D),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE),e.bindTexture(e.TEXTURE_2D,null),t},W=(e,r,t,n)=>{r&&(e.uniform1i(r,t),e.activeTexture(e.TEXTURE0+t),e.bindTexture(e.TEXTURE_2D,n))};var q=async e=>{let r=e.vs||e.vert||e.vertex,t=e.fs||e.frag||e.fragment;i.obj(t)&&(t=C(t)),i.obj(r)&&(r=C(r));let n=e.el.getContext("webgl2"),o=M(n,r,t),s=0,u=(0,$.nested)(()=>s++),d=(0,$.nested)((f,c=!1)=>c?n.getAttribLocation(o,f):n.getUniformLocation(o,f)),h=(0,$.nested)((f,c,m,l)=>{l&&(c=Math.max(...l)+1);let p=m.length/c;return p!==Math.floor(p)&&console.warn(`Vertex Stride Error: count ${c} is mismatch`),Math.floor(p)}),x=(0,$.nested)((f,c)=>{let m=d(f);if(i.num(c))return p=>n.uniform1f(m,p);let l=c.length;return l<=4?p=>n[`uniform${l}fv`](m,p):(l=Math.sqrt(l)<<0,p=>n[`uniformMatrix${l}fv`](m,!1,p))});e("clean",()=>n.deleteProgram(o)),e("render",()=>{n.useProgram(o),n.clear(n.COLOR_BUFFER_BIT),n.viewport(0,0,...e.size),n.drawArrays(n.TRIANGLES,0,3)}),e("_attribute",(f="",c,m)=>{let l=d(f,!0),p=I(n,c),T=B(n,m),N=h(f,e.count,c,m);O(n,N,l,p,T)}),e("_uniform",(f,c)=>{x(f,c)(c)});let g=f=>{let c=d(f.alt),m=u(f.alt),l=z(n,f);W(n,c,m,l)};return e("_texture",(f,c)=>{let m=new Image;m.addEventListener("load",g.bind(null,m),!1),Object.assign(m,{src:c,alt:f,crossOrigin:"anonymous"})}),e.webgl={context:n,program:o},e};var ae=(e,r)=>{let t={target:"webgpu",nodes:new Map,variables:new Map,functions:new Map,...r};return w(e,t)},w=(e,r)=>e?e.value!==void 0?Ae(e.value,e.type):e.property&&e.parent?`${w(e.parent,r)}.${e.property}`:e.operator&&e.children&&e.children.length>=2?Xe(e,r):e.mathFunction&&e.children&&e.children.length>=1?Fe(e,r):"0.0":"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<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"},Xe=(e,r)=>{if(!e.children||e.children.length<2)return"0.0";let t=w(e.children[0],r),n=w(e.children[1],r);return e.operator==="add"?`(${t} + ${n})`:e.operator==="sub"?`(${t} - ${n})`:e.operator==="mul"?`(${t} * ${n})`:e.operator==="div"?`(${t} / ${n})`:e.operator==="mod"?`(${t} % ${n})`:e.operator==="equal"?`(${t} == ${n})`:e.operator==="notEqual"?`(${t} != ${n})`:e.operator==="lessThan"?`(${t} < ${n})`:e.operator==="lessThanEqual"?`(${t} <= ${n})`:e.operator==="greaterThan"?`(${t} > ${n})`:e.operator==="greaterThanEqual"?`(${t} >= ${n})`:e.operator==="and"?`(${t} && ${n})`:e.operator==="or"?`(${t} || ${n})`:`(${t} + ${n})`},Fe=(e,r)=>{if(!e.children||e.children.length<1)return"0.0";let t=e.mathFunction,n=e.children.map(d=>w(d,r)),[o,s,u]=n;return n.length===1?`${t}(${o})`:n.length===2?`${t}(${o}, ${s})`:n.length===3?`${t}(${o}, ${s}, ${u})`:o||"0.0"},S=(e,r)=>{let t="";r?.uniforms&&(Object.entries(r.uniforms).forEach(([o,s])=>{let u=Pe(s);t+=`@group(0) @binding(0) var<uniform> ${o}: ${u};
28
- `}),t+=`
29
- `),t+=`@fragment
30
- `,t+=`fn main() -> @location(0) vec4<f32> {
31
- `;let n=ae(e);return t+=` return ${n};
32
- `,t+=`}
33
- `,t},Pe=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 Me=`
27
+ `,de=(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);throw e.deleteShader(n),new Error(`Could not compile shader: ${o}`)},z=(e,t=ge,r=he)=>{i.obj(r)&&(r=C(r)),i.obj(t)&&(t=C(t));let n=e.createProgram();if(e.attachShader(n,de(e,t,e.VERTEX_SHADER)),e.attachShader(n,de(e,r,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}`)},O=(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},W=(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},D=(e,t,r)=>{r&&(e=Math.max(...r)+1);let n=t.length/e;return Math.floor(n)},q=(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)},V=(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 j=async e=>{let t=e.el.getContext("webgl2"),r=z(t,e.vs,e.fs),n={context:t,program:r};t.useProgram(r);let o=0,a=(0,G.nested)(h=>t.getUniformLocation(r,h)),u=(0,G.nested)(h=>t.getAttribLocation(r,h)),p=(0,G.nested)(()=>o++);return{webgl:n,render:()=>{t.clear(t.COLOR_BUFFER_BIT),t.viewport(0,0,...e.size),t.drawArrays(t.TRIANGLES,0,3)},clean:()=>t.deleteProgram(r),_attribute:(h="",b,x)=>{let T=u(h,!0),l=O(t,b),f=W(t,x),c=D(e.count,b,x);q(t,c,T,l,f)},_uniform:(h,b)=>{let x=a(h);if(i.num(b))return t.uniform1f(x,b);let T=b.length;if(T<=4)return t[`uniform${T}fv`](x,b);T=Math.sqrt(T)<<0,t[`uniformMatrix${T}fv`](x,!1,b)},_texture:(h,b)=>{let x=new Image;Object.assign(x,{src:b,crossOrigin:"anonymous"}),x.decode().then(()=>{let T=a(h),l=p(h);V(t,x,T,l)})}}};var _=require("reev");var be=(e,t)=>{let r={target:"webgpu",nodes:new Map,variables:new Map,functions:new Map,...t};return N(e,r)},N=(e,t)=>e?e.value!==void 0?qe(e.value,e.type):e.property&&e.parent?`${N(e.parent,t)}.${e.property}`:e.operator&&e.children&&e.children.length>=2?Ve(e,t):e.mathFunction&&e.children&&e.children.length>=1?je(e,t):"0.0":"0.0",qe=(e,t)=>{if(t==="float"){let r=Number(e);return r%1===0?`${r}.0`:`${r}`}if(t==="int")return`${Math.floor(Number(e))}`;if(t==="bool")return e?"true":"false";if(i.arr(e)){let r=e.map(n=>{let o=Number(n);return o%1===0?`${o}.0`:`${o}`}).join(", ");if(t==="vec2")return`vec2<f32>(${r})`;if(t==="vec3")return`vec3<f32>(${r})`;if(t==="vec4")return`vec4<f32>(${r})`;if(t==="color")return`vec3<f32>(${r})`}return"0.0"},Ve=(e,t)=>{if(!e.children||e.children.length<2)return"0.0";let r=N(e.children[0],t),n=N(e.children[1],t);return e.operator==="add"?`(${r} + ${n})`:e.operator==="sub"?`(${r} - ${n})`:e.operator==="mul"?`(${r} * ${n})`:e.operator==="div"?`(${r} / ${n})`:e.operator==="mod"?`(${r} % ${n})`:e.operator==="equal"?`(${r} == ${n})`:e.operator==="notEqual"?`(${r} != ${n})`:e.operator==="lessThan"?`(${r} < ${n})`:e.operator==="lessThanEqual"?`(${r} <= ${n})`:e.operator==="greaterThan"?`(${r} > ${n})`:e.operator==="greaterThanEqual"?`(${r} >= ${n})`:e.operator==="and"?`(${r} && ${n})`:e.operator==="or"?`(${r} || ${n})`:`(${r} + ${n})`},je=(e,t)=>{if(!e.children||e.children.length<1)return"0.0";let r=e.mathFunction,n=e.children.map(p=>N(p,t)),[o,a,u]=n;return n.length===1?`${r}(${o})`:n.length===2?`${r}(${o}, ${a})`:n.length===3?`${r}(${o}, ${a}, ${u})`:o||"0.0"},R=(e,t)=>{let r="";t?.uniforms&&(Object.entries(t.uniforms).forEach(([o,a])=>{let u=ke(a);r+=`@group(0) @binding(0) var<uniform> ${o}: ${u};
28
+ `}),r+=`
29
+ `),r+=`@fragment
30
+ `,r+=`fn main() -> @location(0) vec4<f32> {
31
+ `;let n=be(e);return r+=` return ${n};
32
+ `,r+=`}
33
+ `,r},ke=e=>{if(i.num(e))return"f32";if(i.bol(e))return"bool";if(i.arr(e)){let t=e.length;if(t===2)return"vec2<f32>";if(t===3)return"vec3<f32>";if(t===4)return"vec4<f32>"}return"f32"};var Ye=`
34
34
  @vertex
35
35
  fn main(@builtin(vertex_index) vertex_index: u32) -> @builtin(position) vec4f {
36
36
  let x = f32(vertex_index % 2u) * 4.0 - 1.0;
37
37
  let y = f32(vertex_index / 2u) * 4.0 - 1.0;
38
38
  return vec4f(x, y, 0.0, 1.0);
39
39
  }
40
- `,Ie=`
41
- struct Uniforms {
42
- iResolution: vec2f,
43
- iMouse: vec2f,
44
- iTime: f32,
45
- }
46
-
47
- @group(0) @binding(0) var<uniform> u: Uniforms;
40
+ `,He=`
41
+ @group(0) @binding(0) var<uniform> iResolution: vec2f;
48
42
 
49
43
  @fragment
50
44
  fn main(@builtin(position) position: vec4f) -> @location(0) vec4f {
51
45
  return vec4f(position.xy / iResolution, 0.0, 1.0);
52
46
  }
53
- `,D=(e,r,t=Me,n=Ie,o)=>e.createRenderPipeline({vertex:{module:e.createShaderModule({code:t.trim()}),entryPoint:"main",buffers:o},fragment:{module:e.createShaderModule({code:n.trim()}),entryPoint:"main",targets:[{format:r}]},layout:"auto",primitive:{topology:"triangle-list"}}),V=e=>({colorAttachments:[{view:e.getCurrentTexture().createView(),clearValue:{r:0,g:0,b:0,a:1},loadOp:"clear",storeOp:"store"}]});var se=require("reev"),Be=3,Y=async e=>{let r=e.vs||e.vert||e.vertex,t=e.fs||e.frag||e.fragment;i.obj(r)&&(r=S(r)),i.obj(t)&&(t=S(t));let n=e.el.getContext("webgpu"),o=navigator.gpu,u=await(await o.requestAdapter()).requestDevice(),d=o.getPreferredCanvasFormat();n.configure({device:u,format:d,alphaMode:"opaque"});let h=u.createBuffer({size:64,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST});e("clean",()=>{});let x=(0,se.nested)((l,p)=>g+=p),g=0,f,c,m=new Float32Array(0);return e("render",()=>{f||(f=D(u,d,r,t,[]),c=u.createBindGroup({layout:f.getBindGroupLayout(0),entries:[{binding:0,resource:{buffer:h}}]}));let l=u.createCommandEncoder(),p=l.beginRenderPass(V(n));return p.setPipeline(f),p.setBindGroup(0,c),p.draw(Be,1,0,0),p.end(),u.queue.submit([l.finish()]),!0}),e("_attribute",(l="",p)=>{}),e("_uniform",(l,p)=>{i.num(p)&&(p=[p]);let T=p.length,N=x(l,T);if(N===g){let y=new Float32Array(g);m&&y.set(m),m=y}for(let y=0;y<T;y++)m[N-T+y]=p[y];u.queue.writeBuffer(h,0,m)}),e("_texture",(l,p)=>{}),e};var Oe=["float","int","uint","bool","color","vec2","vec3","vec4","mat2","mat3","mat4","ivec2","ivec3","ivec4","uvec2","uvec3","uvec4","bvec2","bvec3","bvec4"],k=["x","y","z","w","r","g","b","a","s","t","p","q"],j=["add","sub","mul","div","mod","equal","notEqual","lessThan","lessThanEqual","greaterThan","greaterThanEqual","and","or","not","assign","xor","bitAnd","bitNot","bitOr","bitXor","shiftLeft","shiftRight"],H=["abs","acos","asin","atan","atan2","ceil","clamp","cos","cross","degrees","distance","dot","exp","exp2","faceforward","floor","fract","length","all","any","bitcast","cbrt","dFdx","dFdy","difference","equals","fwidth","inverseSqrt","lengthSq","log","log2","max","min","mix","negate","normalize","oneMinus","pow","pow2","pow3","pow4","radians","reciprocal","reflect","refract","round","saturate","sign","sin","smoothstep","sqrt","step","tan","transformDirection","trunc"],K=[!0,!1],Z=[0,1,2,3,4,5],Q=[0,1,.5,2];var J=new Map,ee=new Map,re=new Map,ze=()=>{K.forEach(e=>{J.set(e,a("bool",e))}),Z.forEach(e=>{ee.set(e,a("int",e))}),Q.forEach(e=>{re.set(e,a("float",e))})},R=e=>(J.has(e)||ze(),J.get(e)||a("bool",e)),G=e=>ee.has(e)?ee.get(e):a("int",e),_=e=>re.has(e)?re.get(e):a("float",e),We=e=>{let r=new Map,t=new Map;return e.forEach(n=>{let o=qe(n);t.has(o)?(r.has(o)||r.set(o,[t.get(o)]),r.get(o).push(n)):t.set(o,n)}),r},qe=e=>[e.type,`${e.value}`,e.property||""].join("|");var De=e=>i.bol(e)?R(e):i.num(e)?i.int(e)?G(e):_(e):i.arr(e)?ue(e):i.obj(e)?Ve(e):a("float",0),ue=e=>{let r=e.length;return r===2?a("vec2",e):r===3?a("vec3",e):r===4?a("vec4",e):r===9?a("mat3",e):r===16?a("mat4",e):a("float",e[0])},Ve=e=>{if("r"in e&&"g"in e&&"b"in e){let r=[e.r,e.g,e.b];return"a"in e&&r.push(e.a),a("color",r)}if("x"in e&&"y"in e){let r=[e.x,e.y];return"z"in e&&r.push(e.z),"w"in e&&r.push(e.w),ue(r)}return a("float",0)},U=e=>i.num(e)?_(e):a("float",Number(e)),Ye=e=>i.num(e)&&Number.isInteger(e)?G(e):a("int",Math.floor(Number(e))),ke=e=>R(!!e),je=(e,r)=>i.und(e)?a("vec2",[0,0]):i.und(r)?i.arr(e)?a("vec2",e.slice(0,2)):i.obj(e)&&"x"in e&&"y"in e?a("vec2",[e.x,e.y]):a("vec2",[Number(e),Number(e)]):a("vec2",[Number(e),Number(r)]),fe=(e,r,t)=>i.und(e)?a("vec3",[0,0,0]):i.und(r)?i.arr(e)?a("vec3",e.slice(0,3)):i.obj(e)&&"x"in e&&"y"in e&&"z"in e?a("vec3",[e.x,e.y,e.z]):a("vec3",[Number(e),Number(e),Number(e)]):t===void 0?a("vec3",[Number(e),Number(r),0]):a("vec3",[Number(e),Number(r),Number(t)]),He=(e,r,t,n)=>i.und(e)?a("vec4",[0,0,0,1]):i.und(r)?i.arr(e)?a("vec4",e.slice(0,4)):i.obj(e)&&"x"in e&&"y"in e&&"z"in e&&"w"in e?a("vec4",[e.x,e.y,e.z,e.w]):a("vec4",[Number(e),Number(e),Number(e),1]):a("vec4",[Number(e),Number(r),Number(t),Number(n)]),Ke=(e,r,t)=>{if(e===void 0)return a("color",[1,1,1]);if(i.str(e)&&e.startsWith("#")){let n=e.slice(1),o=parseInt(n,16);return a("color",[(o>>16&255)/255,(o>>8&255)/255,(o&255)/255])}return i.num(e)&&r===void 0&&t===void 0?a("color",[(e>>16&255)/255,(e>>8&255)/255,(e&255)/255]):fe(e,r,t)};var Ze=0,Qe=()=>`node_${++Ze}`,L=(e,r,t)=>({id:Qe(),type:e,value:r,children:[],...t}),Je=(e="")=>k.includes(e),er=(e="")=>j.includes(e),rr=(e="")=>H.includes(e),A=(e,r)=>{let t=(o,s)=>{if(!(!i.str(s)||s==="then"))return s==="id"?e.id:s==="type"?e.type:s==="value"?e.value:s==="property"?e.property:Je(s)?A(L(tr(s),void 0,{parent:e,property:s}),r):er(s)?(...u)=>A(L(e.type,void 0,{operator:s,children:[e,...u]}),r):rr(s)?(...u)=>A(L(nr(s,e.type),void 0,{mathFunction:s,children:[e,...u]}),r):r?.({path:[s],args:[]})},n=(o,s,u)=>r?.({path:[],args:u});return new Proxy(()=>{},{get:t,apply:n})},tr=e=>e.length===1?"float":e.length===2?"vec2":e.length===3?"vec3":e.length===4?"vec4":"float",nr=(e,r)=>e==="length"?"float":r,a=(e,r,t)=>{let n=L(e,r,t);return A(n)};var or=e=>{if(i.num(e))return"float";if(i.bol(e))return"bool";if(i.arr(e)){let r=e.length;if(r===2)return"vec2";if(r===3)return"vec3";if(r===4)return"vec4";if(r===9)return"mat3";if(r===16)return"mat4"}return i.obj(e)&&"r"in e&&"g"in e&&"b"in e?"color":"float"},b=e=>{let r=or(e),t=e,n=null,o=null,s=a(r,t),u=f=>{t=f,s.value=f},d=f=>(n=f,g),h=f=>(o=f,g),x=f=>{if(n){let c=n(f);c!==void 0&&u(c)}if(o){let c=o(f);c!==void 0&&u(c)}},g=Object.create(s);return g.set=u,g.onObjectUpdate=d,g.onRenderUpdate=h,g._updateFromContext=x,g.isUniform=!0,g},ce=b(0),pe=b(0),me=b(0),rt=b([1920,1080]),tt=b([0,0]),ir=e=>{if(e.time!==void 0){let r=ce.value||0;ce.set(e.time),pe.set(r),me.set(e.time-r)}};var ar=e=>{let r=(...t)=>{let n=t.map(s=>i.obj(s)&&"type"in s&&s.type?s:U(s));return e(n)||U(0)};return r.call=t=>e(t),r},sr=(e,r)=>{r();let t={ElseIf(n,o){return o(),t},Else(n){n()}};return t},ur=a("vec4",void 0),fr=a("vec4",void 0),cr=b(0),pr=b([1920,1080]),mr=b([0,0]),lr=e=>e.abs(),dr=e=>e.sin(),gr=e=>e.cos(),hr=e=>e.tan(),br=e=>e.sqrt(),xr=e=>e.floor(),yr=e=>e.ceil(),vr=e=>e.fract(),Tr=e=>e.normalize(),Er=e=>e.length();var $r=e=>i.obj(e)?"isGL"in e:!1,de=()=>typeof window>"u",ge=()=>de()?!1:"gpu"in navigator,le=performance.now(),he=e=>{let r=(0,v.event)({isNative:!1,isWebGL:!0,isLoop:!0,isGL:!0,size:[0,0],mouse:[0,0],count:3,webgl:{},webgpu:{}});return r.queue=(0,X.createQueue)(),r.frame=(0,X.createFrame)(),r.attribute=(0,v.durable)((t,n,o)=>r.queue(()=>r._attribute?.(t,n,o))),r.texture=(0,v.durable)((t,n)=>r.queue(()=>r._texture?.(t,n))),r.uniform=(0,v.durable)((t,n,o)=>r.queue(()=>r._uniform?.(t,n,o))),r.uniform({iResolution:r.size,iMouse:[0,0],iTime:0}),r("mount",async()=>{ge()||(r.isWebGL=!0),r.isWebGL?await q(r):await Y(r),r.resize(),r.frame(()=>(r.loop(),r.queue.flush(),r.render(),r.isLoop)),!r.isNative&&(window.addEventListener("resize",r.resize),r.el.addEventListener("mousemove",r.mousemove))}),r("clean",()=>{r.frame.stop(),r.frame.clean(r.render),!r.isNative&&(window.removeEventListener("resize",r.resize),r.el.removeEventListener("mousemove",r.mousemove))}),r("resize",()=>{let t=r.width||window.innerWidth,n=r.height||window.innerHeight;r.size[0]=r.el.width=t,r.size[1]=r.el.height=n,r.uniform("iResolution",r.size)}),r("mousemove",(t,n=t.clientX,o=t.clientY)=>{let[s,u]=r.size,{top:d,left:h}=r.el.getBoundingClientRect();r.mouse[0]=(n-d-s/2)/(s/2),r.mouse[1]=-(o-h-u/2)/(u/2),r.uniform("iMouse",r.mouse)}),r("loop",()=>{le=performance.now()/1e3,r.uniform("iTime",le)}),r(e)},wr=he;0&&(module.exports={CACHE_BOOLS,CACHE_FLOATS,CACHE_INTS,FUNCTIONS,Fn,If,OPERATORS,SWIZZLES,TYPES,abs,activeTexture,bool,ceil,color,convertToNode,cos,createAttrib,createDescriptor,createGL,createIbo,createNode,createPipeline,createProgram,createShader,createTexture,createVbo,defaultFragmentGLSL,defaultVertexGLSL,dig,each,ext,fig,findDuplicateNodes,float,floor,flush,fract,fragCoord,getCachedBool,getCachedFloat,getCachedInt,glsl,iDeltaTime,iMouse,iPrevTime,iResolution,iTime,int,is,isGL,isServer,isWebGPUSupported,length,node,nodeToGLSL,nodeToWGSL,normalize,position,replace,sig,sin,sqrt,tan,uniform,updateUniforms,vec2,vec3,vec4,webgl,webgpu,wgsl});
47
+ `,k=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}},Y=(e,t,r,n,o=Ye,a=He)=>{i.obj(a)&&(a=R(a)),i.obj(o)&&(o=R(o));let u=e.createPipelineLayout({bindGroupLayouts:n});return e.createRenderPipeline({vertex:{module:e.createShaderModule({code:o.trim()}),entryPoint:"main",buffers:r},fragment:{module:e.createShaderModule({code:a.trim()}),entryPoint:"main",targets:[{format:t}]},layout:u,primitive:{topology:"triangle-list"}})},H=(e,t)=>{let r=[],n=[];t.forEach((u,p)=>{if(!u)return;let y="buffer"in u,E=u instanceof GPUTextureView,d=u instanceof GPUSampler;if(y)r.push({binding:p,visibility:3,buffer:{type:"uniform"}});else if(E)r.push({binding:p,visibility:2,texture:{}});else if(d)r.push({binding:p,visibility:2,sampler:{}});else return;n.push({binding:p,resource:u})});let o=e.createBindGroupLayout({entries:r}),a=e.createBindGroup({layout:o,entries:n});return{layout:o,bindGroup:a}},K=e=>({colorAttachments:[{view:e.getCurrentTexture().createView(),clearValue:{r:0,g:0,b:0,a:1},loadOp:"clear",storeOp:"store"}]}),xe=e=>Math.ceil(e/256)*256,Z=(e,t)=>{let r=new Float32Array(t),n=e.createBuffer({size:r.byteLength,usage:40});return{array:r,buffer:n}},Q=(e,t)=>{let r=new Float32Array(t),n=xe(r.byteLength),o=e.createBuffer({size:n,usage:72});return{array:r,buffer:o}},J=(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}},Ke=(e,t)=>e/t,Ze=e=>e===2?"float32x2":e===3?"float32x3":e===4?"float32x4":"float32",ee=(e,t,r=6)=>{let n=Ke(t,r);return{arrayStride:n*4,attributes:[{shaderLocation:e,offset:0,format:Ze(n)}]}};var te=async e=>{let t=e.el.getContext("webgpu"),{device:r,format:n}=await k(t),o={device:r,context:t,resources:[[],[]],loadingImg:0,needsUpdate:!0},a=[],u=[],p=[],y=(0,_.nested)((l,f)=>{let{array:c,buffer:m}=Z(r,f);return u.push(m),p.push(ee(p.length,c.length,e.count)),o.needsUpdate=!0,{array:c,buffer:m}}),E=(0,_.nested)((l,f)=>{let{array:c,buffer:m}=Q(r,f);return o.resources[0].push({buffer:m}),o.needsUpdate=!0,{array:c,buffer:m}}),d=(0,_.nested)((l,{width:f,height:c})=>{let{texture:m,sampler:B}=J(r,f,c);return o.resources[1].push(B,m.createView()),o.needsUpdate=!0,{texture:m,width:f,height:c}}),g=()=>{let l=[];a.length=0,o.resources.forEach(f=>{if(!f.length)return;let{layout:c,bindGroup:m}=H(r,f);l.push(c),a.push(m)}),o.pipeline=Y(r,n,p,l,e.vs,e.fs)};return{webgpu:o,render:()=>{if(o.loadingImg)return;o.needsUpdate&&g(),o.needsUpdate=!1;let l=r.createCommandEncoder(),f=l.beginRenderPass(K(t));f.setPipeline(o.pipeline),a.forEach((c,m)=>f.setBindGroup(m,c)),u.forEach((c,m)=>f.setVertexBuffer(m,c)),f.draw(e.count,1,0,0),f.end(),r.queue.submit([l.finish()])},clean:()=>{},_attribute:(l="",f)=>{let{array:c,buffer:m}=y(l,f);r.queue.writeBuffer(m,0,c)},_uniform:(l,f)=>{i.num(f)&&(f=[f]);let{array:c,buffer:m}=E(l,f);c.set(f),r.queue.writeBuffer(m,0,c)},_texture:(l,f)=>{o.loadingImg++;let c=Object.assign(new Image,{src:f,crossOrigin:"anonymous"});c.decode().then(()=>{let{texture:m,width:B,height:Se}=d(l,c);r.queue.copyExternalImageToTexture({source:c},{texture:m},{width:B,height:Se}),o.loadingImg--})}}};var Qe=["float","int","uint","bool","color","vec2","vec3","vec4","mat2","mat3","mat4","ivec2","ivec3","ivec4","uvec2","uvec3","uvec4","bvec2","bvec3","bvec4"],re=["x","y","z","w","r","g","b","a","s","t","p","q"],ne=["add","sub","mul","div","mod","equal","notEqual","lessThan","lessThanEqual","greaterThan","greaterThanEqual","and","or","not","assign","xor","bitAnd","bitNot","bitOr","bitXor","shiftLeft","shiftRight"],oe=["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"],ie=[!0,!1],ae=[0,1,2,3,4,5],se=[0,1,.5,2];var ue=new Map,fe=new Map,ce=new Map,Je=()=>{ie.forEach(e=>{ue.set(e,s("bool",e))}),ae.forEach(e=>{fe.set(e,s("int",e))}),se.forEach(e=>{ce.set(e,s("float",e))})},U=e=>(ue.has(e)||Je(),ue.get(e)||s("bool",e)),X=e=>fe.has(e)?fe.get(e):s("int",e),A=e=>ce.has(e)?ce.get(e):s("float",e),et=e=>{let t=new Map,r=new Map;return e.forEach(n=>{let o=tt(n);r.has(o)?(t.has(o)||t.set(o,[r.get(o)]),t.get(o).push(n)):r.set(o,n)}),t},tt=e=>[e.type,`${e.value}`,e.property||""].join("|");var rt=e=>i.bol(e)?U(e):i.num(e)?i.int(e)?X(e):A(e):i.arr(e)?ye(e):i.obj(e)?nt(e):s("float",0),ye=e=>{let t=e.length;return t===2?s("vec2",e):t===3?s("vec3",e):t===4?s("vec4",e):t===9?s("mat3",e):t===16?s("mat4",e):s("float",e[0])},nt=e=>{if("r"in e&&"g"in e&&"b"in e){let t=[e.r,e.g,e.b];return"a"in e&&t.push(e.a),s("color",t)}if("x"in e&&"y"in e){let t=[e.x,e.y];return"z"in e&&t.push(e.z),"w"in e&&t.push(e.w),ye(t)}return s("float",0)},F=e=>i.num(e)?A(e):s("float",Number(e)),ot=e=>i.num(e)&&Number.isInteger(e)?X(e):s("int",Math.floor(Number(e))),it=e=>U(!!e),at=(e,t)=>i.und(e)?s("vec2",[0,0]):i.und(t)?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(t)]),Te=(e,t,r)=>i.und(e)?s("vec3",[0,0,0]):i.und(t)?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)]):r===void 0?s("vec3",[Number(e),Number(t),0]):s("vec3",[Number(e),Number(t),Number(r)]),st=(e,t,r,n)=>i.und(e)?s("vec4",[0,0,0,1]):i.und(t)?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(t),Number(r),Number(n)]),ut=(e,t,r)=>{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)&&t===void 0&&r===void 0?s("color",[(e>>16&255)/255,(e>>8&255)/255,(e&255)/255]):Te(e,t,r)};var ft=0,ct=()=>`node_${++ft}`,S=(e,t,r)=>({id:ct(),type:e,value:t,children:[],...r}),pt=(e="")=>re.includes(e),mt=(e="")=>ne.includes(e),lt=(e="")=>oe.includes(e),P=(e,t)=>{let r=(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:pt(a)?P(S(dt(a),void 0,{parent:e,property:a}),t):mt(a)?(...u)=>P(S(e.type,void 0,{operator:a,children:[e,...u]}),t):lt(a)?(...u)=>P(S(gt(a,e.type),void 0,{mathFunction:a,children:[e,...u]}),t):t?.({path:[a],args:[]})},n=(o,a,u)=>t?.({path:[],args:u});return new Proxy(()=>{},{get:r,apply:n})},dt=e=>e.length===1?"float":e.length===2?"vec2":e.length===3?"vec3":e.length===4?"vec4":"float",gt=(e,t)=>e==="length"?"float":t,s=(e,t,r)=>{let n=S(e,t,r);return P(n)};var ht=e=>{if(i.num(e))return"float";if(i.bol(e))return"bool";if(i.arr(e)){let t=e.length;if(t===2)return"vec2";if(t===3)return"vec3";if(t===4)return"vec4";if(t===9)return"mat3";if(t===16)return"mat4"}return i.obj(e)&&"r"in e&&"g"in e&&"b"in e?"color":"float"},v=e=>{let t=ht(e),r=e,n=null,o=null,a=s(t,r),u=g=>{r=g,a.value=g},p=g=>(n=g,d),y=g=>(o=g,d),E=g=>{if(n){let $=n(g);$!==void 0&&u($)}if(o){let $=o(g);$!==void 0&&u($)}},d=Object.create(a);return d.set=u,d.onObjectUpdate=p,d.onRenderUpdate=y,d._updateFromContext=E,d.isUniform=!0,d},ve=v(0),Ee=v(0),$e=v(0),gr=v([1920,1080]),hr=v([0,0]),bt=e=>{if(e.time!==void 0){let t=ve.value||0;ve.set(e.time),Ee.set(t),$e.set(e.time-t)}};var xt=e=>{let t=(...r)=>{let n=r.map(a=>i.obj(a)&&"type"in a&&a.type?a:F(a));return e(n)||F(0)};return t.call=r=>e(r),t},yt=(e,t)=>{t();let r={ElseIf(n,o){return o(),r},Else(n){n()}};return r},Tt=s("vec4",void 0),vt=s("vec4",void 0),Et=v(0),$t=v([1920,1080]),wt=v([0,0]),Lt=e=>e.abs(),Nt=e=>e.sin(),St=e=>e.cos(),Ct=e=>e.tan(),Gt=e=>e.sqrt(),Rt=e=>e.floor(),_t=e=>e.ceil(),Ut=e=>e.fract(),Xt=e=>e.normalize(),At=e=>e.length();var Ft=e=>i.obj(e)?"isGL"in e:!1,we=()=>typeof window>"u",Le=()=>we()?!1:"gpu"in navigator,pe=performance.now(),Ne=e=>{let t=(0,w.event)({isNative:!1,isWebGL:!0,isLoop:!0,isGL:!0,size:[0,0],mouse:[0,0],count:6,webgl:{},webgpu:{}});return t.queue=(0,M.createQueue)(),t.frame=(0,M.createFrame)(),t.attribute=(0,w.durable)((r,n,o)=>t.queue(()=>t._attribute?.(r,n,o))),t.texture=(0,w.durable)((r,n)=>t.queue(()=>t._texture?.(r,n))),t.uniform=(0,w.durable)((r,n,o)=>t.queue(()=>t._uniform?.(r,n,o))),t.uniform({iResolution:t.size,iMouse:[0,0],iTime:pe}),t("mount",async()=>{t.vs=t.vs||t.vert||t.vertex,t.fs=t.fs||t.frag||t.fragment,Le()||(t.isWebGL=!0),t.isWebGL?t(await j(t)):t(await te(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[a,u]=t.size,{top:p,left:y}=t.el.getBoundingClientRect();t.mouse[0]=(n-p-a/2)/(a/2),t.mouse[1]=-(o-y-u/2)/(u/2),t.uniform("iMouse",t.mouse)}),t("loop",()=>{pe=performance.now()/1e3,t.uniform("iTime",pe)}),t(e)},Pt=Ne;0&&(module.exports={CACHE_BOOLS,CACHE_FLOATS,CACHE_INTS,FUNCTIONS,Fn,If,OPERATORS,SWIZZLES,TYPES,abs,alignTo256,bool,ceil,color,convertToNode,cos,createAttrib,createBindGroup,createBufferLayout,createDescriptor,createDevive,createGL,createIbo,createNode,createPipeline,createProgram,createTexture,createTextureSampler,createUniformBuffer,createVbo,createVertexBuffer,defaultFragmentGLSL,defaultVertexGLSL,dig,each,ext,fig,findDuplicateNodes,float,floor,flush,fract,fragCoord,getCachedBool,getCachedFloat,getCachedInt,getStride,glsl,iDeltaTime,iMouse,iPrevTime,iResolution,iTime,int,is,isGL,isServer,isWebGPUSupported,length,node,nodeToGLSL,nodeToWGSL,normalize,position,replace,sig,sin,sqrt,tan,uniform,updateUniforms,vec2,vec3,vec4,webgl,webgpu,wgsl});
54
48
  //# sourceMappingURL=index.js.map