glre 0.28.0 → 0.30.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.
@@ -0,0 +1,358 @@
1
+ import * as refr from 'refr';
2
+ import { Queue, Frame } from 'refr';
3
+ import { EventState } from 'reev';
4
+
5
+ declare const CONSTANTS: readonly ["bool", "uint", "int", "float", "bvec2", "ivec2", "uvec2", "vec2", "bvec3", "ivec3", "uvec3", "vec3", "bvec4", "ivec4", "uvec4", "vec4", "color", "mat2", "mat3", "mat4"];
6
+
7
+ type Constants = (typeof CONSTANTS)[number] | 'void';
8
+ interface FnLayout {
9
+ name: string;
10
+ type: Constants | 'auto';
11
+ inputs?: Array<{
12
+ name: string;
13
+ type: Constants;
14
+ }>;
15
+ }
16
+ interface NodeProps {
17
+ id?: string;
18
+ args?: X[];
19
+ type?: string;
20
+ children?: X[];
21
+ inferFrom?: X;
22
+ layout?: FnLayout;
23
+ }
24
+ interface NodeConfig {
25
+ isWebGL?: boolean;
26
+ binding?: number;
27
+ infers?: WeakMap<NodeProxy, Constants>;
28
+ headers?: Map<string, string>;
29
+ onMount?: (name: string) => void;
30
+ }
31
+ type _Swizzles<T extends string> = T | `${T}${T}` | `${T}${T}${T}` | `${T}${T}${T}${T}`;
32
+ type Swizzles = _Swizzles<'x' | 'y' | 'z' | 'w'> | _Swizzles<'r' | 'g' | 'b' | 'a'> | _Swizzles<'p' | 'q'> | _Swizzles<'s' | 't'>;
33
+ type NodeTypes = 'attribute' | 'uniform' | 'varying' | 'constant' | 'variable' | 'swizzle' | 'ternary' | 'builtin' | 'conversion' | 'operator' | 'function' | 'scope' | 'assign' | 'loop' | 'define' | 'if' | 'switch' | 'declare';
34
+ interface NodeProxy extends Record<Swizzles, NodeProxy> {
35
+ add(n: X): NodeProxy;
36
+ sub(n: X): NodeProxy;
37
+ mul(n: X): NodeProxy;
38
+ div(n: X): NodeProxy;
39
+ mod(n: X): NodeProxy;
40
+ equal(n: X): NodeProxy;
41
+ notEqual(n: X): NodeProxy;
42
+ lessThan(n: X): NodeProxy;
43
+ lessThanEqual(n: X): NodeProxy;
44
+ greaterThan(n: X): NodeProxy;
45
+ greaterThanEqual(n: X): NodeProxy;
46
+ and(n: X): NodeProxy;
47
+ or(n: X): NodeProxy;
48
+ not(): NodeProxy;
49
+ assign(n: X): NodeProxy;
50
+ toVar(name?: string): NodeProxy;
51
+ abs(): NodeProxy;
52
+ sin(): NodeProxy;
53
+ cos(): NodeProxy;
54
+ tan(): NodeProxy;
55
+ asin(): NodeProxy;
56
+ acos(): NodeProxy;
57
+ atan(): NodeProxy;
58
+ atan2(x: X): NodeProxy;
59
+ pow(y: X): NodeProxy;
60
+ pow2(): NodeProxy;
61
+ pow3(): NodeProxy;
62
+ pow4(): NodeProxy;
63
+ sqrt(): NodeProxy;
64
+ inverseSqrt(): NodeProxy;
65
+ exp(): NodeProxy;
66
+ exp2(): NodeProxy;
67
+ log(): NodeProxy;
68
+ log2(): NodeProxy;
69
+ floor(): NodeProxy;
70
+ ceil(): NodeProxy;
71
+ round(): NodeProxy;
72
+ fract(): NodeProxy;
73
+ trunc(): NodeProxy;
74
+ min(y: X): NodeProxy;
75
+ max(y: X): NodeProxy;
76
+ clamp(min: X, max: X): NodeProxy;
77
+ saturate(): NodeProxy;
78
+ mix(y: X, a: X): NodeProxy;
79
+ step(edge: X): NodeProxy;
80
+ smoothstep(edge0: X, edge1: X): NodeProxy;
81
+ length(): NodeProxy;
82
+ distance(y: X): NodeProxy;
83
+ dot(y: X): NodeProxy;
84
+ cross(y: X): NodeProxy;
85
+ normalize(): NodeProxy;
86
+ reflect(N: X): NodeProxy;
87
+ refract(N: X, eta: X): NodeProxy;
88
+ sign(): NodeProxy;
89
+ oneMinus(): NodeProxy;
90
+ reciprocal(): NodeProxy;
91
+ negate(): NodeProxy;
92
+ dFdx(): NodeProxy;
93
+ dFdy(): NodeProxy;
94
+ fwidth(): NodeProxy;
95
+ toBool(): NodeProxy;
96
+ toUint(): NodeProxy;
97
+ toInt(): NodeProxy;
98
+ toFloat(): NodeProxy;
99
+ toBvec2(): NodeProxy;
100
+ toIvec2(): NodeProxy;
101
+ toUvec2(): NodeProxy;
102
+ toVec2(): NodeProxy;
103
+ toBvec3(): NodeProxy;
104
+ toIvec3(): NodeProxy;
105
+ toUvec3(): NodeProxy;
106
+ toVec3(): NodeProxy;
107
+ toBvec4(): NodeProxy;
108
+ toIvec4(): NodeProxy;
109
+ toUvec4(): NodeProxy;
110
+ toVec4(): NodeProxy;
111
+ toColor(): NodeProxy;
112
+ toMat2(): NodeProxy;
113
+ toMat3(): NodeProxy;
114
+ toMat4(): NodeProxy;
115
+ toString(c?: NodeConfig): string;
116
+ type: NodeTypes;
117
+ props: NodeProps;
118
+ isProxy: true;
119
+ }
120
+ type X = NodeProxy | number | string | boolean | undefined;
121
+
122
+ type GPUContext = any;
123
+ type GPUDevice = any;
124
+ type GPUBuffer = any;
125
+ type GPUPipeline = any;
126
+ type GPUBindGroup = any;
127
+ type Uniform = number | number[];
128
+ type Attribute = number[];
129
+ type Attributes = Record<string, Attribute>;
130
+ type Uniforms = Record<string, Uniform>;
131
+ type PrecisionMode = 'highp' | 'mediump' | 'lowp';
132
+ type GLClearMode = 'COLOR_BUFFER_BIT' | 'DEPTH_BUFFER_BIT' | 'STENCIL_BUFFER_BIT';
133
+ type GLDrawType = 'UNSIGNED_BYTE' | 'UNSIGNED_SHORT' | 'UNSIGNED_INT';
134
+ type GLDrawMode = 'POINTS' | 'LINE_STRIP' | 'LINE_LOOP' | 'LINES' | 'TRIANGLE_STRIP' | 'TRIANGLE_FAN' | 'TRIANGLES';
135
+ interface WebGLState {
136
+ context: WebGLRenderingContext;
137
+ program: WebGLProgram;
138
+ }
139
+ interface WebGPUState {
140
+ device: GPUDevice;
141
+ context: GPUContext;
142
+ pipeline: GPUPipeline;
143
+ groups: any[];
144
+ resources: any[];
145
+ loadingImg: number;
146
+ needsUpdate: boolean;
147
+ }
148
+ type GL = EventState<{
149
+ /**
150
+ * initial value
151
+ */
152
+ isNative: boolean;
153
+ isWebGL: boolean;
154
+ isLoop: boolean;
155
+ isGL: true;
156
+ width: number;
157
+ height: number;
158
+ size: [number, number];
159
+ mouse: [number, number];
160
+ count: number;
161
+ el: HTMLCanvasElement;
162
+ vs: string | NodeProxy;
163
+ fs: string | NodeProxy;
164
+ vert: string | NodeProxy;
165
+ frag: string | NodeProxy;
166
+ vertex: string | NodeProxy;
167
+ fragment: string | NodeProxy;
168
+ /**
169
+ * core state
170
+ */
171
+ webgpu: WebGPUState;
172
+ webgl: WebGLState;
173
+ queue: Queue;
174
+ frame: Frame;
175
+ /**
176
+ * events
177
+ */
178
+ ref?: any;
179
+ init(): void;
180
+ loop(): void;
181
+ mount(): void;
182
+ clean(): void;
183
+ render(): void;
184
+ resize(e?: Event): void;
185
+ mousemove(e: Event): void;
186
+ /**
187
+ * setter
188
+ */
189
+ _uniform?(key: string, value: Uniform, isMatrix?: boolean): GL;
190
+ uniform(key: string, value: Uniform, isMatrix?: boolean): GL;
191
+ uniform(target: {
192
+ [key: string]: Uniform;
193
+ }): GL;
194
+ _texture?(key: string, value: string): GL;
195
+ texture(key: string, value: string): GL;
196
+ texture(target: {
197
+ [key: string]: string;
198
+ }): GL;
199
+ _attribute?(key: string, value: Attribute, iboValue?: Attribute): GL;
200
+ attribute(key: string, value: Attribute, iboValue?: Attribute): GL;
201
+ attribute(target: {
202
+ [key: string]: Attribute;
203
+ }): GL;
204
+ }>;
205
+
206
+ declare const is: {
207
+ arr: (arg: any) => arg is any[];
208
+ bol: (a: unknown) => a is boolean;
209
+ str: (a: unknown) => a is string;
210
+ num: (a: unknown) => a is number;
211
+ int: (a: unknown) => a is number;
212
+ fun: (a: unknown) => a is Function;
213
+ und: (a: unknown) => a is undefined;
214
+ nul: (a: unknown) => a is null;
215
+ set: (a: unknown) => a is Set<unknown>;
216
+ map: (a: unknown) => a is Map<unknown, unknown>;
217
+ obj: (a: unknown) => a is object;
218
+ nan: (a: unknown) => a is number;
219
+ };
220
+ /**
221
+ * each
222
+ */
223
+ type EachFn<Value, Key, This> = (this: This, value: Value, key: Key) => void;
224
+ type Eachable<Value = any, Key = any, This = any> = {
225
+ forEach(cb: EachFn<Value, Key, This>, ctx?: This): void;
226
+ };
227
+ declare const each: <Value, Key, This>(obj: Eachable<Value, Key, This>, fn: EachFn<Value, Key, This>) => void;
228
+ declare const flush: <Value extends Function, Key, This>(obj: Eachable<Value, Key, This>, ...args: any[]) => void;
229
+ /**
230
+ * other
231
+ */
232
+ declare const replace: (x?: string, from?: string, to?: string) => string;
233
+ declare const ext: (src?: string) => string;
234
+ declare const fig: (x?: number) => number;
235
+ declare const dig: (x?: number) => number;
236
+ declare const sig: (value?: number, digit?: number) => number;
237
+
238
+ declare const createDevice: (c: GPUContext) => Promise<{
239
+ device: any;
240
+ format: any;
241
+ }>;
242
+ declare const createPipeline: (device: GPUDevice, format: string, bufferLayouts: any[], bindGroupLayouts: any[], vs?: string | NodeProxy, fs?: string | NodeProxy) => GPUPipeline;
243
+ declare const createBindGroup: (device: GPUDevice, resources: any[]) => {
244
+ layout: any;
245
+ bindGroup: any;
246
+ };
247
+ declare const createDescriptor: (c: GPUContext) => {
248
+ colorAttachments: {
249
+ view: any;
250
+ clearValue: {
251
+ r: number;
252
+ g: number;
253
+ b: number;
254
+ a: number;
255
+ };
256
+ loadOp: string;
257
+ storeOp: string;
258
+ }[];
259
+ };
260
+ declare const alignTo256: (size: number) => number;
261
+ declare const createVertexBuffer: (device: GPUDevice, value: number[]) => {
262
+ array: Float32Array<ArrayBuffer>;
263
+ buffer: any;
264
+ };
265
+ declare const createUniformBuffer: (device: GPUDevice, value: number[]) => {
266
+ array: Float32Array<ArrayBuffer>;
267
+ buffer: Buffer;
268
+ };
269
+ declare const createTextureSampler: (device: GPUDevice, width?: number, height?: number) => {
270
+ texture: any;
271
+ sampler: any;
272
+ };
273
+ declare const createBufferLayout: (shaderLocation: number, dataLength: number, count?: number) => {
274
+ arrayStride: number;
275
+ attributes: {
276
+ shaderLocation: number;
277
+ offset: number;
278
+ format: string;
279
+ }[];
280
+ };
281
+
282
+ 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";
283
+ 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";
284
+ declare const createProgram: (c: WebGLRenderingContext, vs?: string | NodeProxy, fs?: string | NodeProxy, onError?: () => void) => void | WebGLProgram;
285
+ declare const createVbo: (c: WebGLRenderingContext, data: number[]) => WebGLBuffer;
286
+ declare const createIbo: (c: WebGLRenderingContext, data: number[]) => WebGLBuffer;
287
+ declare const getStride: (count: number, value: number[], iboValue?: number[]) => number;
288
+ declare const createAttrib: (c: WebGLRenderingContext, stride: number, loc: any, vbo: WebGLBuffer, ibo?: WebGLBuffer) => void;
289
+ declare const createTexture: (c: WebGLRenderingContext, img: HTMLImageElement, loc: any, unit: number) => void;
290
+
291
+ declare const webgl: (gl: Partial<GL>) => Promise<{
292
+ webgl: WebGLState;
293
+ render: () => void;
294
+ clean: () => void;
295
+ _attribute: (key: string | undefined, value: number[], iboValue: number[]) => void;
296
+ _uniform: (key: string, value: number | number[]) => void;
297
+ _texture: (key: string, src: string) => void;
298
+ }>;
299
+
300
+ declare const webgpu: (gl: Partial<GL>) => Promise<{
301
+ webgpu: WebGPUState;
302
+ render: () => void;
303
+ clean: () => void;
304
+ _attribute: (key: string | undefined, value: number[]) => void;
305
+ _uniform: (key: string, value: number | number[]) => void;
306
+ _texture: (key: string, src: string) => void;
307
+ }>;
308
+
309
+ declare const isGL: (a: unknown) => a is EventState<GL>;
310
+ declare const isServer: () => boolean;
311
+ declare const isWebGPUSupported: () => boolean;
312
+ declare const createGL: (props?: Partial<GL>) => EventState<{
313
+ isNative: boolean;
314
+ isWebGL: boolean;
315
+ isLoop: boolean;
316
+ isGL: true;
317
+ width: number;
318
+ height: number;
319
+ size: [number, number];
320
+ mouse: [number, number];
321
+ count: number;
322
+ el: HTMLCanvasElement;
323
+ vs: string | NodeProxy;
324
+ fs: string | NodeProxy;
325
+ vert: string | NodeProxy;
326
+ frag: string | NodeProxy;
327
+ vertex: string | NodeProxy;
328
+ fragment: string | NodeProxy;
329
+ webgpu: WebGPUState;
330
+ webgl: WebGLState;
331
+ queue: refr.Queue;
332
+ frame: refr.Frame;
333
+ ref?: any;
334
+ init(): void;
335
+ loop(): void;
336
+ mount(): void;
337
+ clean(): void;
338
+ render(): void;
339
+ resize(e?: Event): void;
340
+ mousemove(e: Event): void;
341
+ _uniform?(key: string, value: Uniform, isMatrix?: boolean): GL;
342
+ uniform(key: string, value: Uniform, isMatrix?: boolean): GL;
343
+ uniform(target: {
344
+ [key: string]: Uniform;
345
+ }): GL;
346
+ _texture?(key: string, value: string): GL;
347
+ texture(key: string, value: string): GL;
348
+ texture(target: {
349
+ [key: string]: string;
350
+ }): GL;
351
+ _attribute?(key: string, value: Attribute, iboValue?: Attribute): GL;
352
+ attribute(key: string, value: Attribute, iboValue?: Attribute): GL;
353
+ attribute(target: {
354
+ [key: string]: Attribute;
355
+ }): GL;
356
+ }, any[] | unknown[]>;
357
+
358
+ export { type Attribute as A, createDescriptor as B, alignTo256 as C, createVertexBuffer as D, createUniformBuffer as E, createTextureSampler as F, type GL as G, createBufferLayout as H, defaultVertexGLSL as I, defaultFragmentGLSL as J, createProgram as K, createVbo as L, createIbo as M, type NodeProxy as N, getStride as O, type PrecisionMode as P, createAttrib as Q, createTexture as R, webgl as S, webgpu as T, type Uniform as U, type WebGPUState as W, type WebGLState as a, isServer as b, isWebGPUSupported as c, createGL as d, type GPUContext as e, type GPUDevice as f, type GPUBuffer as g, type GPUPipeline as h, isGL as i, type GPUBindGroup as j, type Attributes as k, type Uniforms as l, type GLClearMode as m, type GLDrawType as n, type GLDrawMode as o, is as p, each as q, flush as r, replace as s, ext as t, fig as u, dig as v, sig as w, createDevice as x, createPipeline as y, createBindGroup as z };
package/dist/index.cjs CHANGED
@@ -1,46 +1,50 @@
1
- "use strict";var Q=Object.defineProperty;var Ke=Object.getOwnPropertyDescriptor;var He=Object.getOwnPropertyNames;var Ze=Object.prototype.hasOwnProperty;var Qe=(e,t)=>{for(var r in t)Q(e,r,{get:t[r],enumerable:!0})},Je=(e,t,r,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of He(t))!Ze.call(e,n)&&n!==r&&Q(e,n,{get:()=>t[n],enumerable:!(o=Ke(t,n))||o.enumerable});return e};var et=e=>Je(Q({},"__esModule",{value:!0}),e);var mo={};Qe(mo,{ADDITIONAL_FUNCTIONS:()=>Ie,BOOL_RETURN_FUNCTIONS:()=>B,BUILTIN_TYPES:()=>oe,COMPARISON_OPERATORS:()=>ne,COMPONENT_COUNT_TO_TYPE:()=>q,CONSTANTS:()=>L,CONVERSIONS:()=>J,FIRST_ARG_TYPE_FUNCTIONS:()=>M,FUNCTIONS:()=>te,Fn:()=>gt,HIGHEST_TYPE_FUNCTIONS:()=>W,If:()=>xt,LOGICAL_OPERATORS:()=>se,Loop:()=>dt,OPERATORS:()=>F,OPERATOR_KEYS:()=>ee,PRESERVE_TYPE_FUNCTIONS:()=>z,SCALAR_RETURN_FUNCTIONS:()=>$,SWIZZLES:()=>at,Switch:()=>bt,TYPE_MAPPING:()=>re,VEC3_RETURN_FUNCTIONS:()=>V,VEC4_RETURN_FUNCTIONS:()=>D,abs:()=>ir,acos:()=>ar,alignTo256:()=>De,all:()=>ur,any:()=>cr,asin:()=>fr,assign:()=>xe,atan:()=>pr,atan2:()=>lr,attribute:()=>Nt,bitcast:()=>mr,bool:()=>Vt,bvec2:()=>Jt,bvec3:()=>er,bvec4:()=>tr,cbrt:()=>xr,ceil:()=>dr,clamp:()=>br,code:()=>c,color:()=>rr,cos:()=>gr,createAttrib:()=>Te,createBindGroup:()=>Re,createBufferLayout:()=>Le,createDescriptor:()=>Se,createDevice:()=>_e,createGL:()=>ke,createIbo:()=>Xe,createPipeline:()=>Pe,createProgram:()=>ge,createTexture:()=>Ee,createTextureSampler:()=>Ce,createUniformBuffer:()=>we,createVbo:()=>ve,createVertexBuffer:()=>Ne,cross:()=>vr,cubeTexture:()=>nr,dFdx:()=>Xr,dFdy:()=>yr,default:()=>lo,defaultFragmentGLSL:()=>We,defaultVertexGLSL:()=>Me,degrees:()=>Tr,difference:()=>Er,dig:()=>st,distance:()=>hr,dot:()=>_r,each:()=>Ge,equals:()=>Pr,exp:()=>Rr,exp2:()=>Sr,ext:()=>ot,f:()=>i,faceforward:()=>Nr,fig:()=>nt,float:()=>$t,floor:()=>wr,flush:()=>tt,formatConversions:()=>O,fract:()=>Cr,fragment:()=>G,fwidth:()=>Lr,getId:()=>R,getOperator:()=>pe,getStride:()=>ye,hex2rgb:()=>fe,iMouse:()=>ht,iResolution:()=>Et,iTime:()=>_t,infer:()=>_,inferParameterTypes:()=>mt,int:()=>Bt,inverseSqrt:()=>Or,is:()=>l,isConversion:()=>ue,isFunction:()=>ae,isGL:()=>po,isNodeProxy:()=>ce,isOperator:()=>ie,isServer:()=>qe,isSwizzle:()=>Y,isWebGPUSupported:()=>Ye,ivec2:()=>kt,ivec3:()=>jt,ivec4:()=>Kt,joins:()=>k,length:()=>Ur,lengthSq:()=>Gr,log:()=>Ir,log2:()=>Ar,mat2:()=>Dt,mat3:()=>qt,mat4:()=>Yt,max:()=>Fr,min:()=>$r,mix:()=>Br,n:()=>b,negate:()=>zr,node:()=>u,normalLocal:()=>Ut,normalView:()=>It,normalWorld:()=>Gt,normalize:()=>Vr,o:()=>ze,oneMinus:()=>Mr,position:()=>Pt,positionLocal:()=>Ct,positionView:()=>Ot,positionWorld:()=>Lt,pow:()=>Wr,pow2:()=>Dr,pow3:()=>qr,pow4:()=>Yr,radians:()=>kr,reciprocal:()=>jr,reflect:()=>Kr,refract:()=>Hr,replace:()=>rt,round:()=>Zr,s:()=>de,saturate:()=>Qr,screenCoordinate:()=>At,screenUV:()=>Ft,select:()=>Tt,sig:()=>it,sign:()=>Jr,sin:()=>eo,smoothstep:()=>to,sqrt:()=>ro,step:()=>oo,tan:()=>no,texture:()=>or,textureSize:()=>sr,toConst:()=>me,toVar:()=>le,transformDirection:()=>so,trunc:()=>io,u:()=>A,uint:()=>zt,uv:()=>Rt,uvec2:()=>Ht,uvec3:()=>Zt,uvec4:()=>Qt,v:()=>yt,varying:()=>vt,vec2:()=>Mt,vec3:()=>be,vec4:()=>Wt,vertex:()=>I,vertexColor:()=>St,vertexStage:()=>wt,webgl:()=>he,webgpu:()=>Oe});module.exports=et(mo);var U=require("reev"),H=require("refr");var j=require("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)},Ge=(e,t)=>e.forEach(t),tt=(e,...t)=>{Ge(e,r=>r(...t))},rt=(e="",t="_",r="/")=>e.split(t).join(r),ot=(e=".pdf")=>e.split(".").pop()?.toLowerCase()??"",nt=(e=0)=>`${e}`.split(".")[1]?.length??0,st=(e=0)=>`${e}`.split(".")[0]?.length-(e<0?1:0),it=(e=0,t=-2)=>(t*=-1,t=Math.pow(10,t),e*=t,e=Math.round(e),e/=t,e);var at=["x","y","z","w","r","g","b","a","s","t","p","q"],L=["bool","uint","int","float","bvec2","bvec3","bvec4","ivec2","ivec3","ivec4","uvec2","uvec3","uvec4","vec2","vec3","vec4","color","mat2","mat3","mat4"],J=["toFloat","toInt","toUint","toBool","toVec2","toVec3","toVec4","toIvec2","toIvec3","toIvec4","toUvec2","toUvec3","toUvec4","toBvec2","toBvec3","toBvec4","toMat2","toMat3","toMat4","toColor"],F={add:"+",sub:"-",mul:"*",div:"/",mod:"%",equal:"==",notEqual:"!=",lessThan:"<",lessThanEqual:"<=",greaterThan:">",greaterThanEqual:">=",and:"&&",or:"||",bitAnd:"&",bitOr:"|",bitXor:"^",shiftLeft:"<<",shiftRight:">>"},ee=Object.keys(F),$=["dot","distance","length","lengthSq","determinant","luminance"],B=["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"],V=["cross"],M=["reflect","refract"],W=["min","max","mix","clamp","step","smoothstep"],D=["texture","textureLod","textureSize","cubeTexture"],Ie=["atan2","degrees","faceforward","bitcast","cbrt","difference","equals","pow","pow2","pow3","pow4","radians","transformDirection"],te=[...$,...B,...z,...V,...M,...W,...D,...Ie],re={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>"},q={1:"float",2:"vec2",3:"vec3",4:"vec4",9:"mat3",16:"mat4"},oe={gl_FragCoord:"vec4",position:"vec3",normal:"vec3",uv:"vec2",color:"vec4"},ne=["equal","notEqual","lessThan","lessThanEqual","greaterThan","greaterThanEqual"],se=["and","or"];var Y=e=>l.str(e)&&/^[xyzwrgbastpq]{1,4}$/.test(e),ie=e=>ee.includes(e),ae=e=>te.includes(e),ue=e=>J.includes(e),ce=e=>!e||!l.fun(e)?!1:e.isProxy,ut=0,fe=e=>{let t=(e>>16&255)/255,r=(e>>8&255)/255,o=(e&255)/255;return[t,r,o]},R=()=>`i${ut++}`,k=(e,t)=>e.filter(r=>!l.und(r)&&!l.nul(r)).map(r=>c(r,t)).join(", "),O=(e,t)=>l.str(e)?t?.isWebGL?e:re[e]:"",pe=e=>F[e]||e,Ae=e=>{let t=Array.from(e.uniforms).map((o,n)=>e.isWebGL?`uniform ${o};`:`@group(0) @binding(${n}) var<uniform> ${o};`).join(`
2
- `),r=Array.from(e.functions).join(`
3
- `);return`${t}
4
- ${r}`},Fe=(e,t,r=!0)=>r?`
1
+ "use strict";var D=Object.defineProperty;var Ye=Object.getOwnPropertyDescriptor;var je=Object.getOwnPropertyNames;var He=Object.prototype.hasOwnProperty;var Ke=(e,t)=>{for(var r in t)D(e,r,{get:t[r],enumerable:!0})},Ze=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of je(t))!He.call(e,o)&&o!==r&&D(e,o,{get:()=>t[o],enumerable:!(n=Ye(t,o))||n.enumerable});return e};var Qe=e=>Ze(D({},"__esModule",{value:!0}),e);var Pt={};Ke(Pt,{alignTo256:()=>Ve,createAttrib:()=>re,createBindGroup:()=>ae,createBufferLayout:()=>le,createDescriptor:()=>ue,createDevice:()=>se,createGL:()=>qe,createIbo:()=>ee,createPipeline:()=>ie,createProgram:()=>Q,createTexture:()=>oe,createTextureSampler:()=>fe,createUniformBuffer:()=>pe,createVbo:()=>J,createVertexBuffer:()=>ce,default:()=>Nt,defaultFragmentGLSL:()=>Me,defaultVertexGLSL:()=>De,dig:()=>ot,each:()=>xe,ext:()=>tt,fig:()=>rt,flush:()=>Je,getStride:()=>te,is:()=>x,isGL:()=>Et,isServer:()=>ze,isWebGPUSupported:()=>We,replace:()=>et,sig:()=>nt,webgl:()=>ne,webgpu:()=>me});module.exports=Qe(Pt);var C=require("reev"),$=require("refr");var U=require("reev");var x={arr:Array.isArray,bol:e=>typeof e=="boolean",str:e=>typeof e=="string",num:e=>typeof e=="number",int:e=>Number.isInteger(e),fun:e=>typeof e=="function",und:e=>typeof e>"u",nul:e=>e===null,set:e=>e instanceof Set,map:e=>e instanceof Map,obj:e=>!!e&&e.constructor.name==="Object",nan:e=>typeof e=="number"&&Number.isNaN(e)},xe=(e,t)=>e.forEach(t),Je=(e,...t)=>{xe(e,r=>r(...t))},et=(e="",t="_",r="/")=>e.split(t).join(r),tt=(e=".pdf")=>e.split(".").pop()?.toLowerCase()??"",rt=(e=0)=>`${e}`.split(".")[1]?.length??0,ot=(e=0)=>`${e}`.split(".")[0]?.length-(e<0?1:0),nt=(e=0,t=-2)=>(t*=-1,t=Math.pow(10,t),e*=t,e=Math.round(e),e/=t,e);var S=["bool","uint","int","float","bvec2","ivec2","uvec2","vec2","bvec3","ivec3","uvec3","vec3","bvec4","ivec4","uvec4","vec4","color","mat2","mat3","mat4"],M=["toBool","toUint","toInt","toFloat","toBvec2","toIvec2","toUvec2","toVec2","toBvec3","toIvec3","toUvec3","toVec3","toBvec4","toIvec4","toUvec4","toVec4","toColor","toMat2","toMat3","toMat4"],V={add:"+",sub:"-",mul:"*",div:"/",mod:"%",equal:"==",notEqual:"!=",lessThan:"<",lessThanEqual:"<=",greaterThan:">",greaterThanEqual:">=",and:"&&",or:"||",bitAnd:"&",bitOr:"|",bitXor:"^",shiftLeft:"<<",shiftRight:">>"},ge=Object.keys(V),z=["dot","distance","length","lengthSq","determinant","luminance"],W=["all","any"],q=["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"],k=["cross"],Y=["reflect","refract"],j=["min","max","mix","clamp","step","smoothstep"],H=["texture","textureLod","textureSize","cubeTexture"],st=["atan2","degrees","faceforward","bitcast","cbrt","difference","equals","pow","pow2","pow3","pow4","radians","transformDirection"],be=[...z,...W,...q,...k,...Y,...j,...H,...st],ve={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>"},K={1:"float",2:"vec2",3:"vec3",4:"vec4",9:"mat3",16:"mat4"},ye={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"},Xe=["equal","notEqual","lessThan","lessThanEqual","greaterThan","greaterThanEqual"],_e=["and","or"],Te={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 Z=e=>x.str(e)&&/^[xyzwrgbastpq]{1,4}$/.test(e),he=e=>ge.includes(e),Ee=e=>be.includes(e),Ne=e=>M.includes(e),P=e=>!e||typeof e!="object"?!1:e.isProxy;var it=0,Pe=()=>`i${it++}`,w=(e,t)=>e.filter(r=>!x.und(r)&&!x.nul(r)).map(r=>u(r,t)).join(", "),R=(e,t)=>x.str(e)?t?.isWebGL?e:ve[e]:"",Se=e=>V[e]||e,Re=e=>Te[e],Ce=e=>{let t=M.indexOf(e);return t!==-1?S[t]:"float"},Le=e=>Array.from(e.headers).map(([,t])=>t).join(`
2
+ `),we=(e,t)=>{let{id:r,children:n=[],layout:o}=e,[s,a,...i]=n,m=o?.type&&o?.type!=="auto"?o?.type:a?y(a,t):"void",b=[],c=[];if(o?.inputs)for(let d of o.inputs)b.push([d.name,d.type]);else for(let d=0;d<i.length;d++)b.push([`p${d}`,y(i[d],t)]);let p="";if(t?.isWebGL){for(let[d,_]of b)c.push(`${_} ${d}`);p+=`${m} ${r}(${c}) {
3
+ `}else{for(let[d,_]of b)c.push(`${d}: ${R(_,t)}`);p+=`fn ${r}(${c}) -> ${R(m,t)} {
4
+ `}let T=u(s,t);return T&&(p+=T+`
5
+ `),a&&(p+=`return ${u(a,t)};`),p+=`
6
+ }`,p},at=`
5
7
  #version 300 es
6
8
  precision mediump float;
7
9
  out vec4 fragColor;
8
- ${t}
9
- void main() {
10
- fragColor = ${e};
11
- }`.trim():`
12
- ${t}
10
+ `.trim(),ut=`
13
11
  @fragment
14
12
  fn main(@builtin(position) position: vec4f) -> @location(0) vec4f {
15
- return ${e};
16
- }`.trim(),G=(e,t)=>{let r=c(e,t),o=Ae(t);return Fe(r,o,t.isWebGL)},I=(e,t)=>{let r=c(e,t),o=Ae(t);return Fe(r,o,t.isWebGL)};var $e=e=>l.bol(e)?"bool":l.num(e)?Number.isInteger(e)?"int":"float":l.arr(e)&&q[e.length]||"float",Be=(e,t,r)=>{if(ne.includes(r)||se.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=L.indexOf(e),n=L.indexOf(t);return o>=n?e:t},ct=e=>e.reduce((t,r)=>{let o=_(r),n=L.indexOf(t);return L.indexOf(o)>n?o:t},"float"),ft=e=>q[e]||"vec4",pt=e=>e?oe[e]:"vec3",lt=(e,t)=>{let r=t.length>0?_(t[0]):"float";return M.includes(e)?r:$.includes(e)?"float":B.includes(e)?"bool":z.includes(e)?r:V.includes(e)?"vec3":D.includes(e)?"vec4":W.includes(e)?ct(t):r},_=(e,t)=>{if(!e)throw"";if(!ce(e))return $e(e);let{type:r,props:o}=e,{id:n,children:s=[],value:a,returnType:f}=o,[X,p,m]=s;return r==="uniform"||r==="variable"||r==="constant"||r==="attribute"||r==="varying"?$e(a):r==="conversions"?X:r==="operator"?Be(_(p,t),_(m,t),X):r==="math_fun"?lt(X,s.slice(1)):r==="swizzle"?ft(X.length):r==="ternary"?Be(_(p,t),_(m,t),"add"):r==="fn_run"||r==="fn_def"?f:r==="builtin"?pt(n):"float"},mt=(e,t)=>e.map(r=>_(r,t));var c=(e,t)=>{if(t||(t={}),t.uniforms||(t.uniforms=new Set),t.functions||(t.functions=new Set),l.num(e))return e.toFixed(1);if(l.str(e))return e;if(l.bol(e))return e.toString();if(!e)return"";let{type:r,props:o}=e,{id:n="",children:s=[]}=o,[a,f,X]=s;if(r==="uniform"){let p=_(e,t);return t.uniforms.add(`${p} ${n}`),t.onUniform?.(n,o.value),n}if(r==="variable"||r==="varying"||r==="constant"||r==="attribute")return n;if(r==="vertex_stage")return c(a,t);if(r==="swizzle")return`${c(f,t)}.${c(a,t)}`;if(r==="operator")return a==="not"||a==="bitNot"?`!${c(f,t)}`:`(${c(f,t)} ${pe(a)} ${c(X,t)})`;if(r==="math_fun")return`${a}(${k(s.slice(1),t)})`;if(r==="conversions")return`${O(a,t)}(${k(s.slice(1),t)})`;if(r==="scope")return s.map(p=>c(p,t)).join(`
17
- `);if(r==="assign")return`${c(a,t)} = ${c(f,t)};`;if(r==="fn_run")return t.functions.add(c(a,t)),`${n}(${s.slice(1).map(p=>c(p,t)).join(", ")})`;if(r==="fn_def"){let{paramInfo:p=[],returnType:m}=o,y=c(a,t),C=f?`return ${c(f,t)};`:"";if(t?.isWebGL){let T=p.map(({name:E,type:h})=>`${h} ${E}`).join(", ");return`${m} ${n}(${T}) {
18
- ${y}
19
- ${C}
20
- }`}else{let T=O(m,t),E=p.map(({name:h,type:P})=>{let g=O(P,t);return`${h}: ${g}`}).join(", ");return`fn ${n}(${E}) -> ${T} {
21
- ${y}
22
- ${C}
23
- }`}}if(r==="loop")return`for (int i = 0; i < ${a}; i++) {
24
- ${c(f,t)}
25
- }`;if(r==="if"){let p=`if (${c(a,t)}) {
26
- ${c(f,t)}
27
- }`;for(let m=2;m<s.length;m+=2){let y=m>=s.length-1;p+=y?` else {
28
- ${c(s[m],t)}
29
- }`:` else if (${c(s[m],t)}) {
30
- ${c(s[m+1],t)}
31
- }`}return p}if(r==="switch"){let p=`switch (${c(a,t)}) {
32
- `;for(let m of s.slice(1))p+=c(m,t)+`
33
- `;return p+="}",p}if(r==="case"){let p=s.slice(0,-1),m=s[s.length-1],y="";for(let C of p)y+=`case ${c(C,t)}:
34
- `;return y+=`${c(m,t)}
13
+ `.trim(),ct=(e,t,r=!0)=>{let n="";return r&&(n+=at),t&&(n+=`
14
+ `+t+`
15
+ `),r?n+=`void main() {
16
+ fragColor = ${e};`:(n+=ut+`
17
+ `,n+=` return ${e};`),n+=`
18
+ }`,n},pt=(e,t,r=!0)=>"",O=(e,t={})=>{let r=u(e,t),n=Le(t),o=ct(r,n,t.isWebGL);return console.log(`// \u2193\u2193\u2193 generated \u2193\u2193\u2193
19
+
20
+ ${o}
21
+
22
+ `),o},G=(e,t)=>{let r=u(e,t),n=Le(t);return pt(r,n,t.isWebGL)};var ft=(e,t)=>e.reduce((r,n)=>{let o=y(n,t),s=S.indexOf(r);return S.indexOf(o)>s?o:r},"float"),lt=e=>ye[e],mt=(e,t,r)=>{let n=t.length>0?y(t[0],r):"float";return Y.includes(e)?n:z.includes(e)?"float":W.includes(e)?"bool":q.includes(e)?n:k.includes(e)?"vec3":H.includes(e)?"vec4":j.includes(e)?ft(t,r):n},Oe=(e,t,r)=>{if(Xe.includes(r)||_e.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=S.indexOf(e),o=S.indexOf(t);return n>=o?e:t},dt=e=>x.bol(e)?"bool":x.num(e)?"float":x.arr(e)&&K[e.length]||"float",xt=e=>K[e],gt=(e,t)=>{let{type:r,props:n}=e,{id:o,children:s=[],inferFrom:a}=n,[i,m,b]=s;return a?y(a,t):r==="conversion"?i:r==="operator"?Oe(y(m,t),y(b,t),i):r==="function"?mt(i,s.slice(1),t):r==="swizzle"?xt(i.length):r==="ternary"?Oe(y(m,t),y(b,t),"add"):r==="builtin"?lt(o):r==="define"?n.layout?.type&&n.layout?.type!=="auto"?n.layout.type:m?y(m,t):"void":y(i,t)},y=(e,t)=>{if(t||(t={}),!P(e))return dt(e);if(t.infers||(t.infers=new WeakMap),t.infers.has(e))return t.infers.get(e);let r=gt(e,t);return t.infers.set(e,r),r};var u=(e,t)=>{if(t||(t={}),t.headers||(t.headers=new Map),x.str(e))return e;if(x.num(e)){let c=`${e}`;return c.includes(".")?c:c+".0"}if(x.bol(e))return e?"true":"false";if(!e)return"";let{type:r,props:n}=e,{id:o="",children:s=[]}=n,[a,i,m]=s,b="";if(r==="attribute"){if(t.headers.has(o))return o;b=`${y(e,t)} ${o}`}if(r==="uniform"){if(t.headers.has(o))return o;t.binding||(t.binding=0);let c=y(e,t);b=t.isWebGL?`uniform ${c} ${o};`:`@group(0) @binding(${t.binding++}) var<uniform> ${o}: ${R(c,t)};`}if(r==="constant"){if(t.headers.has(o))return o;let c=y(e,t),p=u(a,t);b=t.isWebGL?`const ${c} ${o} = ${p};`:`const ${o}: ${R(c,t)} = ${p};`}if(r==="varying"){if(t.headers.has(o))return o;b=`${y(e,t)} ${o}`}if(b)return t.headers.set(o,b),t.onMount?.(o),o;if(r==="variable")return o;if(r==="swizzle")return`${u(i,t)}.${u(a,t)}`;if(r==="ternary")return`(${u(a,t)} ? ${u(i,t)} : ${u(m,t)})`;if(r==="builtin")return t?.isWebGL?Re(o):o;if(r==="conversion")return`${R(a,t)}(${w(s.slice(1),t)})`;if(r==="operator")return a==="not"||a==="bitNot"?`!${u(i,t)}`:`(${u(i,t)} ${Se(a)} ${u(m,t)})`;if(r==="function")return a==="negate"?`(-${w(s.slice(1),t)})`:`${a}(${w(s.slice(1),t)})`;if(r==="scope")return s.map(c=>u(c,t)).join(`
23
+ `);if(r==="assign")return`${u(a,t)} = ${u(i,t)};`;if(r==="loop")return t.isWebGL?`for (int i = 0; i < ${a}; i += 1) {
24
+ ${u(i,t)}
25
+ }`:`for (var i: i32 = 0; i < ${a}; i++) {
26
+ ${u(i,t)}
27
+ }`;if(r==="define"){let c=s.slice(2),p=`${o}(${c.map(T=>u(T,t))})`;return t.headers.has(o)||t.headers.set(o,we(n,t)),p}if(r==="if"){let c=`if (${u(a,t)}) {
28
+ ${u(i,t)}
29
+ }`;for(let p=2;p<s.length;p+=2){let T=p>=s.length-1;c+=T?` else {
30
+ ${u(s[p],t)}
31
+ }`:` else if (${u(s[p],t)}) {
32
+ ${u(s[p+1],t)}
33
+ }`}return c}if(r==="switch"){let c=`switch (${u(a,t)}) {
34
+ `;for(let p=1;p<s.length;p+=2)p>=s.length-1&&s.length%2===0?c+=`default:
35
+ ${u(s[p],t)}
36
+ break;
37
+ `:p+1<s.length&&(c+=`case ${u(s[p],t)}:
38
+ ${u(s[p+1],t)}
35
39
  break;
36
- `,y}if(r==="default"&&`${c(a,t)}`,r==="ternary")return`(${c(a,t)} ? ${c(f,t)} : ${c(X,t)})`;if(r==="declare"){let p=_(f,t),m=a?.props?.id;if(t.isWebGL)return`${p} ${m} = ${c(f,t)};`;let y=O(p);return`var ${m}: ${y} = ${c(f,t)};`}if(r==="builtin"){if(t?.isWebGL){if(n==="position")return"gl_FragCoord";if(n==="uv")return"gl_FragCoord.xy"}return n}return c(a,t)};var S=null,N=(e,t=()=>{})=>{let r=S;S=e,t(),S=r},w=e=>{S&&(S.props.children||(S.props.children=[]),S.props.children.push(e))},xt=(e,t)=>{let r=u("scope");N(r,t);let o=u("if",null,e,r);w(o);let n=()=>({ElseIf:(s,a)=>{let f=u("scope");return N(f,a),o.props.children.push(s,f),n()},Else:s=>{let a=u("scope");N(a,s),o.props.children.push(a)}});return n()},dt=(e,t)=>{let r=u("scope");N(r,()=>t?.({i:u("variable",{id:"i"})}));let o=u("loop",null,e,r);return w(o),o},bt=e=>{let t=u("switch",null,e);w(t);let r=()=>({Case:(...o)=>n=>{let s=u("scope");N(s,n);let a=u("case",null,...o,s);return t.props.children.push(a),r()},Default:o=>{let n=u("scope");N(n,o);let s=u("default",null,n);t.props.children.push(s)}});return r()},gt=e=>{let t=R();return(...r)=>{let o=u("scope"),n,s=[];for(let p=0;p<r.length;p++){let m=`p${p}`,y=u("variable",{id:m});s.push(y)}N(o,()=>n=e(s));let a=n?_(n):"void",f=r.map((p,m)=>({name:`p${m}`,type:_(p)})),X=u("fn_def",{id:t,returnType:a,paramInfo:f,args:r},o,n);return u("fn_run",{id:t,returnType:a},X,...s)}},le=e=>t=>{t||(t=R());let r=u("variable",{id:t}),o=u("declare",null,r,e);return w(o),r},me=e=>t=>{t||(t=R());let r=u("constant",{id:t}),o=u("declare",null,r,e);return w(o),r},xe=e=>t=>{let r=u("assign",null,e,t);return w(r),e},vt=(e,t)=>{t||(t=R());let r=u("varying",{id:t}),o=u("declare",null,r,e);return w(o),r};var Xt=e=>t=>{if(t==="string")return c(e)},u=(e,t,...r)=>{t||(t={}),r.length&&(t.children=r);let o=new Proxy(()=>{},{get(n,s){if(s==="type")return e;if(s==="props")return t;if(s==="toVar")return le(o);if(s==="toConst")return me(o);if(s==="assign")return xe(o);if(s==="isProxy")return!0;if(s==="toString")return c.bind(null,o);if(s===Symbol.toPrimitive)return Xt(o);if(Y(s))return de(s,o);if(ie(s))return(...a)=>ze(s,o,...a);if(ae(s))return(...a)=>i(s,o,...a);if(ue(s))return b(s,o)},set(n,s,a){return Y(s)?(de(s,o).assign(a),!0):!1}});return o},yt=(...e)=>u("variable",{id:R()},...e),de=(e,t)=>u("swizzle",null,e,t),b=(e,...t)=>u("conversions",null,e,...t),ze=(e,...t)=>u("operator",null,e,...t),i=(e,...t)=>u("math_fun",null,e,...t),A=(e,t)=>u("uniform",{id:e,value:t}),Tt=(e,t,r)=>u("ternary",null,e,t,r);var Et=A("iResolution",[1280,800]),ht=A("iMouse",[0,0]),_t=A("iTime",0),Pt=u("variable",{id:"gl_FragCoord"}),Rt=(e=0)=>u("attribute",{id:`uv${e||""}`}),St=(e=0)=>u("attribute",{id:`color${e||""}`}),Nt=(e,t)=>u("attribute",{id:e,type:t}),wt=e=>u("vertex_stage",null,e),Ct=u("builtin",{id:"positionLocal"}),Lt=u("builtin",{id:"positionWorld"}),Ot=u("builtin",{id:"positionView"}),Ut=u("builtin",{id:"normalLocal"}),Gt=u("builtin",{id:"normalWorld"}),It=u("builtin",{id:"normalView"}),At=u("builtin",{id:"screenCoordinate"}),Ft=u("builtin",{id:"screenUV"}),$t=e=>b("float",e),Bt=e=>b("int",e),zt=e=>b("uint",e),Vt=e=>b("bool",e),Mt=(e,t)=>b("vec2",e,t),be=(e,t,r)=>b("vec3",e,t,r),Wt=(e,t,r,o)=>b("vec4",e,t,r,o),Dt=(...e)=>b("mat2",...e),qt=(...e)=>b("mat3",...e),Yt=(...e)=>b("mat4",...e),kt=(e,t)=>b("ivec2",e,t),jt=(e,t,r)=>b("ivec3",e,t,r),Kt=(e,t,r,o)=>b("ivec4",e,t,r,o),Ht=(e,t)=>b("uvec2",e,t),Zt=(e,t,r)=>b("uvec3",e,t,r),Qt=(e,t,r,o)=>b("uvec4",e,t,r,o),Jt=(e,t)=>b("bvec2",e,t),er=(e,t,r)=>b("bvec3",e,t,r),tr=(e,t,r,o)=>b("bvec4",e,t,r,o),rr=(e,t,r)=>l.num(e)&&l.und(t)&&l.und(r)?be(...fe(e)):be(e,t,r),or=(e,t,r)=>i("texture",e,t,r),nr=(e,t,r)=>i("cubeTexture",e,t,r),sr=(e,t)=>i("textureSize",e,t),ir=e=>i("abs",e),ar=e=>i("acos",e),ur=e=>i("all",e),cr=e=>i("any",e),fr=e=>i("asin",e),pr=(e,t)=>t!==void 0?i("atan",e,t):i("atan",e),lr=(e,t)=>i("atan",e,t),mr=(e,t)=>i("bitcast",e,t),xr=e=>i("cbrt",e),dr=e=>i("ceil",e),br=(e,t,r)=>i("clamp",e,t,r),gr=e=>i("cos",e),vr=(e,t)=>i("cross",e,t),Xr=e=>i("dFdx",e),yr=e=>i("dFdy",e),Tr=e=>i("degrees",e),Er=(e,t)=>i("difference",e,t),hr=(e,t)=>i("distance",e,t),_r=(e,t)=>i("dot",e,t),Pr=(e,t)=>i("equals",e,t),Rr=e=>i("exp",e),Sr=e=>i("exp2",e),Nr=(e,t,r)=>i("faceforward",e,t,r),wr=e=>i("floor",e),Cr=e=>i("fract",e),Lr=e=>i("fwidth",e),Or=e=>i("inverseSqrt",e),Ur=e=>i("length",e),Gr=e=>i("lengthSq",e),Ir=e=>i("log",e),Ar=e=>i("log2",e),Fr=(e,t)=>i("max",e,t),$r=(e,t)=>i("min",e,t),Br=(e,t,r)=>i("mix",e,t,r),zr=e=>i("negate",e),Vr=e=>i("normalize",e),Mr=e=>i("oneMinus",e),Wr=(e,t)=>i("pow",e,t),Dr=e=>i("pow2",e),qr=e=>i("pow3",e),Yr=e=>i("pow4",e),kr=e=>i("radians",e),jr=e=>i("reciprocal",e),Kr=(e,t)=>i("reflect",e,t),Hr=(e,t,r)=>i("refract",e,t,r),Zr=e=>i("round",e),Qr=e=>i("saturate",e),Jr=e=>i("sign",e),eo=e=>i("sin",e),to=(e,t,r)=>i("smoothstep",e,t,r),ro=e=>i("sqrt",e),oo=(e,t)=>i("step",e,t),no=e=>i("tan",e),so=(e,t)=>i("transformDirection",e,t),io=e=>i("trunc",e);var Me=`
40
+ `);return c+="}",c}if(r==="declare"){let c=y(a,t),p=i?.props?.id;if(t.isWebGL)return`${c} ${p} = ${u(a,t)};`;let T=R(c);return`var ${p}: ${T} = ${u(a,t)};`}return u(a,t)};var I=null;var Ge=e=>{I&&(I.props.children||(I.props.children=[]),I.props.children.push(e))},Ie=(e,t)=>{t||(t=Pe());let r=N("variable",{id:t,inferFrom:e}),n=N("declare",null,e,r);return Ge(n),r},Fe=(e,t)=>{let r=N("assign",null,e,t);return Ge(r),e};var bt=(e,t)=>{if(t==="string")return u(e)},N=(e,t,...r)=>{t||(t={}),r.length&&(t.children=r);let n=(a,i)=>{if(i==="type")return e;if(i==="props")return t;if(i==="toVar")return Ie.bind(null,s);if(i==="assign")return Fe.bind(null,s);if(i==="isProxy")return!0;if(i==="toString")return u.bind(null,s);if(i===Symbol.toPrimitive)return bt.bind(null,s);if(Z(i))return Ue(i,s);if(he(i))return(...m)=>vt(i,s,...m);if(Ee(i))return(...m)=>Ae(i,s,...m);if(Ne(i))return()=>L(Ce(i),s)},o=(a,i,m)=>Z(i)?(Ue(i,s).assign(m),!0):!1,s=new Proxy({},{get:n,set:o});return s};var F=(e,t)=>N("uniform",{id:t},e);var X=e=>N("builtin",{id:e}),Ue=(e,t)=>N("swizzle",null,e,t),vt=(e,...t)=>N("operator",null,e,...t),Ae=(e,...t)=>N("function",null,e,...t),L=(e,...t)=>N("conversion",null,e,...t);var rr=X("position"),or=X("vertex_index"),nr=X("instance_index"),sr=X("front_facing"),ir=X("frag_depth"),ar=X("sample_index"),ur=X("sample_mask"),cr=X("point_coord"),pr=X("normalLocal"),fr=X("normalWorld"),lr=X("normalView"),mr=X("position"),dr=X("positionWorld"),xr=X("positionView"),gr=X("screenCoordinate"),br=X("screenUV"),yt=e=>L("float",e);var $e=(e,t)=>L("vec2",e,t);var vr=F($e(1280,800),"iResolution"),yr=F($e(0,0),"iMouse"),Xr=F(yt(0),"iTime");var De=`
37
41
  #version 300 es
38
42
  void main() {
39
43
  float x = float(gl_VertexID % 2) * 4.0 - 1.0;
40
44
  float y = float(gl_VertexID / 2) * 4.0 - 1.0;
41
45
  gl_Position = vec4(x, y, 0.0, 1.0);
42
46
  }
43
- `,We=`
47
+ `,Me=`
44
48
  #version 300 es
45
49
  precision mediump float;
46
50
  uniform vec2 iResolution;
@@ -48,19 +52,19 @@ out vec4 fragColor;
48
52
  void main() {
49
53
  fragColor = vec4(fract(gl_FragCoord.xy / iResolution), 0, 1);
50
54
  }
51
- `,Ve=(e,t,r)=>{let o=e.createShader(r);if(!o)throw new Error("Failed to create shader");if(e.shaderSource(o,t.trim()),e.compileShader(o),e.getShaderParameter(o,e.COMPILE_STATUS))return o;let n=e.getShaderInfoLog(o);e.deleteShader(o),console.warn(`Could not compile shader: ${n}`)},ge=(e,t=Me,r=We,o=()=>{})=>{l.str(r)||(r=G(r,{isWebGL:!0})),l.str(t)||(t=I(r,{isWebGL:!0}));let n=e.createProgram(),s=Ve(e,t,e.VERTEX_SHADER),a=Ve(e,r,e.FRAGMENT_SHADER);if(!s||!a)return o();if(e.attachShader(n,s),e.attachShader(n,a),e.linkProgram(n),e.getProgramParameter(n,e.LINK_STATUS))return n;let f=e.getProgramInfoLog(n);e.deleteProgram(n),o(),console.warn(`Could not link pg: ${f}`)},ve=(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},Xe=(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},ye=(e,t,r)=>{r&&(e=Math.max(...r)+1);let o=t.length/e;return Math.floor(o)},Te=(e,t,r,o,n)=>{e.bindBuffer(e.ARRAY_BUFFER,o),e.enableVertexAttribArray(r),e.vertexAttribPointer(r,t,e.FLOAT,!1,0,0),n&&e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,n)},Ee=(e,t,r,o)=>{let n=e.createTexture();e.bindTexture(e.TEXTURE_2D,n),e.texImage2D(e.TEXTURE_2D,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,t),e.generateMipmap(e.TEXTURE_2D),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE),e.bindTexture(e.TEXTURE_2D,null),e.uniform1i(r,o),e.activeTexture(e.TEXTURE0+o),e.bindTexture(e.TEXTURE_2D,n)};var he=async e=>{let t=e.el.getContext("webgl2"),r=ge(t,e.vs,e.fs,()=>void(e.isLoop=!1)),o={context:t,program:r};t.useProgram(r);let n=0,s=(0,j.nested)(T=>t.getUniformLocation(r,T)),a=(0,j.nested)(T=>t.getAttribLocation(r,T)),f=(0,j.nested)(()=>n++);return{webgl:o,render:()=>{t.clear(t.COLOR_BUFFER_BIT),t.viewport(0,0,...e.size),t.drawArrays(t.TRIANGLES,0,3)},clean:()=>t.deleteProgram(r),_attribute:(T="",E,h)=>{let P=a(T,!0),g=ve(t,E),x=Xe(t,h),d=ye(e.count,E,h);Te(t,d,P,g,x)},_uniform:(T,E)=>{let h=s(T);if(l.num(E))return t.uniform1f(h,E);let P=E.length;if(P<=4)return t[`uniform${P}fv`](h,E);P=Math.sqrt(P)<<0,t[`uniformMatrix${P}fv`](h,!1,E)},_texture:(T,E)=>{let h=new Image;Object.assign(h,{src:E,crossOrigin:"anonymous"}),h.decode().then(()=>{let P=s(T),g=f(T);Ee(t,h,P,g)})}}};var K=require("reev");var ao=`
55
+ `,Be=(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}`)},Q=(e,t=De,r=Me,n=()=>{})=>{P(r)&&(r=O(r,{isWebGL:!0})),P(t)&&(t=G(r,{isWebGL:!0}));let o=e.createProgram(),s=Be(e,t,e.VERTEX_SHADER),a=Be(e,r,e.FRAGMENT_SHADER);if(!s||!a)return n();if(e.attachShader(o,s),e.attachShader(o,a),e.linkProgram(o),e.getProgramParameter(o,e.LINK_STATUS))return o;let i=e.getProgramInfoLog(o);e.deleteProgram(o),n(),console.warn(`Could not link pg: ${i}`)},J=(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},ee=(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},te=(e,t,r)=>{r&&(e=Math.max(...r)+1);let n=t.length/e;return Math.floor(n)},re=(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)},oe=(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 ne=async e=>{let t=e.el.getContext("webgl2"),r=Q(t,e.vs,e.fs,()=>void(e.isLoop=!1));t.useProgram(r);let n=0,o=(0,U.nested)(d=>t.getUniformLocation(r,d)),s=(0,U.nested)(d=>t.getAttribLocation(r,d)),a=(0,U.nested)(()=>n++);return{webgl:{context:t,program:r},render:()=>{t.clear(t.COLOR_BUFFER_BIT),t.viewport(0,0,...e.size),t.drawArrays(t.TRIANGLES,0,3)},clean:()=>t.deleteProgram(r),_attribute:(d="",_,h)=>{let E=s(d,!0),v=J(t,_),f=ee(t,h),l=te(e.count,_,h);re(t,l,E,v,f)},_uniform:(d,_)=>{let h=o(d);if(x.num(_))return t.uniform1f(h,_);let E=_.length;if(E<=4)return t[`uniform${E}fv`](h,_);E=Math.sqrt(E)<<0,t[`uniformMatrix${E}fv`](h,!1,_)},_texture:(d,_)=>{let h=new Image;Object.assign(h,{src:_,crossOrigin:"anonymous"}),h.decode().then(()=>{let E=o(d),v=a(d);oe(t,h,E,v)})}}};var A=require("reev");var Xt=`
52
56
  @vertex
53
57
  fn main(@builtin(vertex_index) vertex_index: u32) -> @builtin(position) vec4f {
54
58
  let x = f32(vertex_index % 2u) * 4.0 - 1.0;
55
59
  let y = f32(vertex_index / 2u) * 4.0 - 1.0;
56
60
  return vec4f(x, y, 0.0, 1.0);
57
61
  }
58
- `,uo=`
62
+ `,_t=`
59
63
  @group(0) @binding(0) var<uniform> iResolution: vec2f;
60
64
 
61
65
  @fragment
62
66
  fn main(@builtin(position) position: vec4f) -> @location(0) vec4f {
63
67
  return vec4f(position.xy / iResolution, 0.0, 1.0);
64
68
  }
65
- `,_e=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}},Pe=(e,t,r,o,n=ao,s=uo)=>{l.str(s)||(s=G(s,{isWebGL:!1})),l.str(n)||(n=I(n,{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"}})},Re=(e,t)=>{let r=[],o=[];t.forEach((a,f)=>{if(!a)return;let X="buffer"in a,p=a instanceof GPUTextureView,m=a instanceof GPUSampler;if(X)r.push({binding:f,visibility:3,buffer:{type:"uniform"}});else if(p)r.push({binding:f,visibility:2,texture:{}});else if(m)r.push({binding:f,visibility:2,sampler:{}});else return;o.push({binding:f,resource:a})});let n=e.createBindGroupLayout({entries:r}),s=e.createBindGroup({layout:n,entries:o});return{layout:n,bindGroup:s}},Se=e=>({colorAttachments:[{view:e.getCurrentTexture().createView(),clearValue:{r:0,g:0,b:0,a:1},loadOp:"clear",storeOp:"store"}]}),De=e=>Math.ceil(e/256)*256,Ne=(e,t)=>{let r=new Float32Array(t),o=e.createBuffer({size:r.byteLength,usage:40});return{array:r,buffer:o}},we=(e,t)=>{let r=new Float32Array(t),o=De(r.byteLength),n=e.createBuffer({size:o,usage:72});return{array:r,buffer:n}},Ce=(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}},co=(e,t)=>e/t,fo=e=>e===2?"float32x2":e===3?"float32x3":e===4?"float32x4":"float32",Le=(e,t,r=6)=>{let o=co(t,r);return{arrayStride:o*4,attributes:[{shaderLocation:e,offset:0,format:fo(o)}]}};var Oe=async e=>{let t=e.el.getContext("webgpu"),{device:r,format:o}=await _e(t),n={device:r,context:t,resources:[[],[]],loadingImg:0,needsUpdate:!0},s=[],a=[],f=[],X=(0,K.nested)((g,x)=>{let{array:d,buffer:v}=Ne(r,x);return a.push(v),f.push(Le(f.length,d.length,e.count)),n.needsUpdate=!0,{array:d,buffer:v}}),p=(0,K.nested)((g,x)=>{let{array:d,buffer:v}=we(r,x);return n.resources[0].push({buffer:v}),n.needsUpdate=!0,{array:d,buffer:v}}),m=(0,K.nested)((g,{width:x,height:d})=>{let{texture:v,sampler:Z}=Ce(r,x,d);return n.resources[1].push(Z,v.createView()),n.needsUpdate=!0,{texture:v,width:x,height:d}}),y=()=>{let g=[];s.length=0,n.resources.forEach(x=>{if(!x.length)return;let{layout:d,bindGroup:v}=Re(r,x);g.push(d),s.push(v)}),n.pipeline=Pe(r,o,f,g,e.vs,e.fs)};return{webgpu:n,render:()=>{if(n.loadingImg)return;n.needsUpdate&&y(),n.needsUpdate=!1;let g=r.createCommandEncoder(),x=g.beginRenderPass(Se(t));x.setPipeline(n.pipeline),s.forEach((d,v)=>x.setBindGroup(v,d)),a.forEach((d,v)=>x.setVertexBuffer(v,d)),x.draw(e.count,1,0,0),x.end(),r.queue.submit([g.finish()])},clean:()=>{},_attribute:(g="",x)=>{let{array:d,buffer:v}=X(g,x);r.queue.writeBuffer(v,0,d)},_uniform:(g,x)=>{l.num(x)&&(x=[x]);let{array:d,buffer:v}=p(g,x);d.set(x),r.queue.writeBuffer(v,0,d)},_texture:(g,x)=>{n.loadingImg++;let d=Object.assign(new Image,{src:x,crossOrigin:"anonymous"});d.decode().then(()=>{let{texture:v,width:Z,height:je}=m(g,d);r.queue.copyExternalImageToTexture({source:d},{texture:v},{width:Z,height:je}),n.loadingImg--})}}};var po=e=>l.obj(e)?"isGL"in e:!1,qe=()=>typeof window>"u",Ye=()=>qe()?!1:"gpu"in navigator,Ue=performance.now(),ke=e=>{let t=(0,U.event)({isNative:!1,isWebGL:!0,isLoop:!0,isGL:!0,size:[0,0],mouse:[0,0],count:6,webgl:{},webgpu:{}});return t.queue=(0,H.createQueue)(),t.frame=(0,H.createFrame)(),t.attribute=(0,U.durable)((r,o,n)=>t.queue(()=>t._attribute?.(r,o,n))),t.texture=(0,U.durable)((r,o)=>t.queue(()=>t._texture?.(r,o))),t.uniform=(0,U.durable)((r,o,n)=>t.queue(()=>t._uniform?.(r,o,n))),t.uniform({iResolution:t.size,iMouse:[0,0],iTime:Ue}),t("mount",async()=>{t.vs=t.vs||t.vert||t.vertex,t.fs=t.fs||t.frag||t.fragment,Ye()||(t.isWebGL=!0),t.isWebGL?t(await he(t)):t(await Oe(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:f,left:X}=t.el.getBoundingClientRect();t.mouse[0]=(o-f-s/2)/(s/2),t.mouse[1]=-(n-X-a/2)/(a/2),t.uniform("iMouse",t.mouse)}),t("loop",()=>{Ue=performance.now()/1e3,t.uniform("iTime",Ue)}),t(e)},lo=ke;0&&(module.exports={ADDITIONAL_FUNCTIONS,BOOL_RETURN_FUNCTIONS,BUILTIN_TYPES,COMPARISON_OPERATORS,COMPONENT_COUNT_TO_TYPE,CONSTANTS,CONVERSIONS,FIRST_ARG_TYPE_FUNCTIONS,FUNCTIONS,Fn,HIGHEST_TYPE_FUNCTIONS,If,LOGICAL_OPERATORS,Loop,OPERATORS,OPERATOR_KEYS,PRESERVE_TYPE_FUNCTIONS,SCALAR_RETURN_FUNCTIONS,SWIZZLES,Switch,TYPE_MAPPING,VEC3_RETURN_FUNCTIONS,VEC4_RETURN_FUNCTIONS,abs,acos,alignTo256,all,any,asin,assign,atan,atan2,attribute,bitcast,bool,bvec2,bvec3,bvec4,cbrt,ceil,clamp,code,color,cos,createAttrib,createBindGroup,createBufferLayout,createDescriptor,createDevice,createGL,createIbo,createPipeline,createProgram,createTexture,createTextureSampler,createUniformBuffer,createVbo,createVertexBuffer,cross,cubeTexture,dFdx,dFdy,defaultFragmentGLSL,defaultVertexGLSL,degrees,difference,dig,distance,dot,each,equals,exp,exp2,ext,f,faceforward,fig,float,floor,flush,formatConversions,fract,fragment,fwidth,getId,getOperator,getStride,hex2rgb,iMouse,iResolution,iTime,infer,inferParameterTypes,int,inverseSqrt,is,isConversion,isFunction,isGL,isNodeProxy,isOperator,isServer,isSwizzle,isWebGPUSupported,ivec2,ivec3,ivec4,joins,length,lengthSq,log,log2,mat2,mat3,mat4,max,min,mix,n,negate,node,normalLocal,normalView,normalWorld,normalize,o,oneMinus,position,positionLocal,positionView,positionWorld,pow,pow2,pow3,pow4,radians,reciprocal,reflect,refract,replace,round,s,saturate,screenCoordinate,screenUV,select,sig,sign,sin,smoothstep,sqrt,step,tan,texture,textureSize,toConst,toVar,transformDirection,trunc,u,uint,uv,uvec2,uvec3,uvec4,v,varying,vec2,vec3,vec4,vertex,vertexColor,vertexStage,webgl,webgpu});
69
+ `,se=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}},ie=(e,t,r,n,o=Xt,s=_t)=>{P(o)&&(o=G(o,{isWebGL:!1})),P(s)&&(s=O(s,{isWebGL:!1}));let a=e.createPipelineLayout({bindGroupLayouts:n});return e.createRenderPipeline({vertex:{module:e.createShaderModule({code:o.trim()}),entryPoint:"main",buffers:r},fragment:{module:e.createShaderModule({code:s.trim()}),entryPoint:"main",targets:[{format:t}]},layout:a,primitive:{topology:"triangle-list"}})},ae=(e,t)=>{let r=[],n=[];t.forEach((a,i)=>{if(!a)return;let m="buffer"in a,b=a instanceof GPUTextureView,c=a instanceof GPUSampler;if(m)r.push({binding:i,visibility:3,buffer:{type:"uniform"}});else if(b)r.push({binding:i,visibility:2,texture:{}});else if(c)r.push({binding:i,visibility:2,sampler:{}});else return;n.push({binding:i,resource:a})});let o=e.createBindGroupLayout({entries:r}),s=e.createBindGroup({layout:o,entries:n});return{layout:o,bindGroup:s}},ue=e=>({colorAttachments:[{view:e.getCurrentTexture().createView(),clearValue:{r:0,g:0,b:0,a:1},loadOp:"clear",storeOp:"store"}]}),Ve=e=>Math.ceil(e/256)*256,ce=(e,t)=>{let r=new Float32Array(t),n=e.createBuffer({size:r.byteLength,usage:40});return{array:r,buffer:n}},pe=(e,t)=>{let r=new Float32Array(t),n=Ve(r.byteLength),o=e.createBuffer({size:n,usage:72});return{array:r,buffer:o}},fe=(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}},Tt=(e,t)=>e/t,ht=e=>e===2?"float32x2":e===3?"float32x3":e===4?"float32x4":"float32",le=(e,t,r=6)=>{let n=Tt(t,r);return{arrayStride:n*4,attributes:[{shaderLocation:e,offset:0,format:ht(n)}]}};var me=async e=>{let t=e.el.getContext("webgpu"),{device:r,format:n}=await se(t),o={device:r,context:t,resources:[[],[]],loadingImg:0,needsUpdate:!0},s=[],a=[],i=[],m=(0,A.nested)((v,f)=>{let{array:l,buffer:g}=ce(r,f);return a.push(g),i.push(le(i.length,l.length,e.count)),o.needsUpdate=!0,{array:l,buffer:g}}),b=(0,A.nested)((v,f)=>{let{array:l,buffer:g}=pe(r,f);return o.resources[0].push({buffer:g}),o.needsUpdate=!0,{array:l,buffer:g}}),c=(0,A.nested)((v,{width:f,height:l})=>{let{texture:g,sampler:B}=fe(r,f,l);return o.resources[1].push(B,g.createView()),o.needsUpdate=!0,{texture:g,width:f,height:l}}),p=()=>{let v=[];s.length=0,o.resources.forEach(f=>{if(!f.length)return;let{layout:l,bindGroup:g}=ae(r,f);v.push(l),s.push(g)}),o.pipeline=ie(r,n,i,v,e.vs,e.fs)};return{webgpu:o,render:()=>{if(o.loadingImg)return;o.needsUpdate&&p(),o.needsUpdate=!1;let v=r.createCommandEncoder(),f=v.beginRenderPass(ue(t));f.setPipeline(o.pipeline),s.forEach((l,g)=>f.setBindGroup(g,l)),a.forEach((l,g)=>f.setVertexBuffer(g,l)),f.draw(e.count,1,0,0),f.end(),r.queue.submit([v.finish()])},clean:()=>{},_attribute:(v="",f)=>{let{array:l,buffer:g}=m(v,f);r.queue.writeBuffer(g,0,l)},_uniform:(v,f)=>{x.num(f)&&(f=[f]);let{array:l,buffer:g}=b(v,f);l.set(f),r.queue.writeBuffer(g,0,l)},_texture:(v,f)=>{o.loadingImg++;let l=Object.assign(new Image,{src:f,crossOrigin:"anonymous"});l.decode().then(()=>{let{texture:g,width:B,height:ke}=c(v,l);r.queue.copyExternalImageToTexture({source:l},{texture:g},{width:B,height:ke}),o.loadingImg--})}}};var Et=e=>x.obj(e)?"isGL"in e:!1,ze=()=>typeof window>"u",We=()=>ze()?!1:"gpu"in navigator,de=performance.now(),qe=e=>{let t=(0,C.event)({isNative:!1,isWebGL:!0,isLoop:!0,isGL:!0,size:[0,0],mouse:[0,0],count:6,webgl:{},webgpu:{}});return t.queue=(0,$.createQueue)(),t.frame=(0,$.createFrame)(),t.attribute=(0,C.durable)((r,n,o)=>t.queue(()=>t._attribute?.(r,n,o))),t.texture=(0,C.durable)((r,n)=>t.queue(()=>t._texture?.(r,n))),t.uniform=(0,C.durable)((r,n,o)=>t.queue(()=>t._uniform?.(r,n,o))),t.uniform({iResolution:t.size,iMouse:[0,0],iTime:de}),t("mount",async()=>{t.vs=t.vs||t.vert||t.vertex,t.fs=t.fs||t.frag||t.fragment,We()||(t.isWebGL=!0),t.isWebGL?t(await ne(t)):t(await me(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[s,a]=t.size,{top:i,left:m}=t.el.getBoundingClientRect();t.mouse[0]=(n-i-s/2)/(s/2),t.mouse[1]=-(o-m-a/2)/(a/2),t.uniform("iMouse",t.mouse)}),t("loop",()=>{de=performance.now()/1e3,t.uniform("iTime",de)}),t(e)},Nt=qe;0&&(module.exports={alignTo256,createAttrib,createBindGroup,createBufferLayout,createDescriptor,createDevice,createGL,createIbo,createPipeline,createProgram,createTexture,createTextureSampler,createUniformBuffer,createVbo,createVertexBuffer,defaultFragmentGLSL,defaultVertexGLSL,dig,each,ext,fig,flush,getStride,is,isGL,isServer,isWebGPUSupported,replace,sig,webgl,webgpu});
66
70
  //# sourceMappingURL=index.cjs.map