typegpu 0.5.5 → 0.5.7

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/index.js CHANGED
@@ -1,26 +1,30 @@
1
- import{Z as F,_ as W,a as _r,aa as V,b as Lr,ba as c,c as ce,d as Qe,da as Vr,e as Y,f as Cr,g as Q,ga as Er,h as _,i as Ce,ia as Xe,ja as xe,ka as Ct,la as kr}from"./chunk-HZAXWB4J.js";import{$ as b,A as Pt,B as x,C as _e,D as R,E as P,F as _t,G as qe,H as He,I as Je,K as Te,L as Lt,M as O,N as v,O as B,P as l,Q as Le,T as Ar,U as Ur,V as Ir,W as Br,X as Rr,Y as Ye,Z as C,_ as G,a as Ue,b as me,ba as Pr,c as vt,d as Dt,e as Ft,f as ae,g as Ie,h as Be,ha as ye,i as Dr,j,k as At,l as Ut,m as oe,n as y,o as Fr,p as It,q as Bt,r as L,s as Re,t as H,u as J,v as Rt,w as se,x as Pe,y as ge,z as fe}from"./chunk-T5Y2EQPZ.js";function E(e){return e?.resourceType==="slot"}function k(e){return e?.resourceType==="derived"}function Ve(e){return e?.["~providing"]!==void 0}function ie(e){return e?.resourceType==="accessor"}var A={type:"unknown"};function Vt(e){return typeof e?.["~resolve"]=="function"}function z(e){return typeof e=="number"||typeof e=="boolean"||typeof e=="string"||Vt(e)||C(e)||E(e)||k(e)||Ve(e)}function $r(e){return!!e&&typeof e=="object"&&"getMappedRange"in e&&"mapAsync"in e}function Ze(e){return e?.resourceType==="buffer-usage"}function Or(e){return!!e&&typeof e=="object"&&!!e?.[y]?.dataType}function Gr(e){return!!e?.[y]}var Mn=["vec2f","vec2h","vec2i","vec2u","vec2<bool>","vec3f","vec3h","vec3i","vec3u","vec3<bool>","vec4f","vec4h","vec4i","vec4u","vec4<bool>","struct"],Nn={f:{1:l,2:L,3:se,4:x},h:{1:Le,2:Re,3:Pe,4:_e},i:{1:B,2:H,3:ge,4:R},u:{1:v,2:J,3:fe,4:P},b:{1:O,2:Rt,3:Pt,4:_t}},Wr={vec2f:L,vec2h:Re,vec2i:H,vec2u:J,"vec2<bool>":Rt,vec3f:se,vec3h:Pe,vec3i:ge,vec3u:fe,"vec3<bool>":Pt,vec4f:x,vec4h:_e,vec4i:R,vec4u:P,"vec4<bool>":_t,mat2x2f:qe,mat3x3f:He,mat4x4f:Je},Mr={vec2f:l,vec2h:Le,vec2i:B,vec2u:v,"vec2<bool>":O,vec3f:l,vec3h:Le,vec3i:B,vec3u:v,"vec3<bool>":O,vec4f:l,vec4h:Le,vec4i:B,vec4u:v,"vec4<bool>":O,mat2x2f:L,mat3x3f:se,mat4x4f:x};function be(e,t){if(typeof e=="string"||typeof e=="number"||typeof e=="boolean")return A;if(k(e)||E(e)){let o=j();if(!o)throw new Error("Resolution context not found when unwrapping slot or derived");let s=o.unwrap(e);return he(s)}let r=e;for(Or(r)&&(r=r[y].dataType);ye(r);)r=r.inner;let n="kind"in r?r.kind:r.type;if(n==="struct")return r.propTypes[t]??A;let a=t.length;if(Mn.includes(n)&&a>=1&&a<=4){let o=n.includes("bool")?"b":n[4],s=Nn[o][a];if(s)return s}return C(r)?r:A}function Nr(e){if(C(e)){if(G(e))return e.elementType;if(e.type in Mr)return Mr[e.type]}return A}function he(e){if(k(e)||E(e))return he(e.value);if(typeof e=="string")return A;if(typeof e=="number")return Et(String(e))?.dataType??A;if(typeof e=="boolean")return O;if("kind"in e){let t=e.kind;if(t in Wr)return Wr[t]}return C(e)?e:A}function Et(e){if(/^0x[0-9a-f]+$/i.test(e))return{value:e,dataType:Te};if(/^0b[01]+$/i.test(e))return{value:`${Number.parseInt(e.slice(2),2)}`,dataType:Te};if(/^-?(?:\d+\.\d*|\d*\.\d+)$/i.test(e))return{value:e,dataType:Lt};if(/^-?\d+(?:\.\d+)?e-?\d+$/i.test(e))return{value:e,dataType:Lt};if(/^-?\d+$/i.test(e))return{value:e,dataType:Te}}var M={get(e,t){if(t in e)return Reflect.get(e,t);if(t!=="~providing")return t==="toString"||t===Symbol.toStringTag||t===Symbol.toPrimitive?()=>e.toString():new Proxy({"~resolve":r=>`${r.resolve(e)}.${String(t)}`,toString:()=>`.value(...).${String(t)}:${e.label??"<unnamed>"}`,[y]:{dataType:be(e[y].dataType,String(t))}},M)}};function Ee(e){let t=e;for(;E(t)||k(t)||ie(t)||Ze(t);)t=t.value;return t}function jr(e,t){return new kt(e,t)}var kt=class{constructor(t,r){this.dataType=t;this._value=r;this[y]={dataType:t}}_label;[y];get label(){return this._label}$name(t){return this._label=t,this}"~resolve"(t){let r=t.names.makeUnique(this._label),n=t.resolveValue(this._value,this.dataType);return t.addDeclaration(`const ${r} = ${n};`),r}toString(){return`const:${this.label??"<unnamed>"}`}get value(){return oe()?new Proxy({"~resolve":t=>t.resolve(this),toString:()=>`.value:${this.label??"<unnamed>"}`,[y]:{dataType:this.dataType}},M):this._value}};function N(e){return!!e&&(typeof e=="object"||typeof e=="function")&&"$name"in e}function K(e,t){for(let[r,n]of Object.entries(t))e[r]=n,N(n)&&(!("label"in n)||n.label===void 0)&&n.$name(r)}function zr(e,t,r){let n=[...e.matchAll(/:\s*(?<arg>.*?)\s*[,)]/g)].map(a=>a?a[1]:void 0);r(Object.fromEntries(t.flatMap((a,o)=>{let s=n?n[o]:void 0;return b(a)&&s!==void 0?[[s,a]]:[]})))}function we(e,t,r){let n=e.match(/->\s(?<output>[\w\d_]+)\s{/),a=n?n[1]?.trim():void 0;b(t)&&a&&!/\s/g.test(a)&&r({[a]:t})}function jn(e){return new RegExp(`(?<![\\w\\$_.])${e.replaceAll(".","\\.").replaceAll("$","\\$")}(?![\\w\\$_])`,"g")}function ue(e,t,r){return Object.entries(t).reduce((n,[a,o])=>z(o)||ce(o)?n.replaceAll(jn(a),e.resolve(o)):o!==null&&typeof o=="object"?([...r.matchAll(new RegExp(`${a.replaceAll(".","\\.").replaceAll("$","\\$")}\\.(?<prop>.*?)(?![\\w\\$_])`,"g"))].map(i=>i[1])??[]).reduce((i,p)=>p&&p in o?ue(e,{[`${a}.${p}`]:o[p]},i):i,n):n,r)}function Kr(e){return new $t(e)}var $t=class{constructor(t){this.declaration=t}externalsToApply=[];$uses(t){return this.externalsToApply.push(t),this}"~resolve"(t){let r={};for(let a of this.externalsToApply)K(r,a);let n=ue(t,r,this.declaration);return t.addDeclaration(n),""}toString(){return`declare: ${this.declaration}`}};var qr=new WeakMap;function Hr(e){return qr.get(e)}function Jr(e,t,r){return qr.set(e,{ast:t,externals:r}),e}function Yr(e){return()=>{throw new Error(`The function "${e??"<unnamed>"}" is invokable only on the GPU. If you want to use it on the CPU, mark it with the "kernel & js" directive.`)}}function Qr(e,t){throw new Error(`Failed to handle ${e} at ${t}`)}function ke(e){return typeof e?.format=="string"}function Xr(e,t){let r=[];if(_(e)){if(!ke(t))throw new Error("Shader expected a single attribute, not a record of attributes to be passed in.");return r.push(t._layout),{usedVertexLayouts:r,bufferDefinitions:[{arrayStride:t._layout.stride,stepMode:t._layout.stepMode,attributes:[{format:t.format,offset:t.offset,shaderLocation:Q(e)??0}]}]}}let n=[],a=new WeakMap,o=0;for(let[s,i]of Object.entries(e)){if(Xe(i))continue;let p=t[s];if(!p)throw new Error(`An attribute by the name of '${s}' was not provided to the shader.`);let u=p._layout,d=a.get(u);d||(r.push(u),d=[],n.push({arrayStride:u.stride,stepMode:u.stepMode,attributes:d}),a.set(u,d)),o=Q(i)??o,d.push({format:p.format,offset:p.offset,shaderLocation:o++})}return{usedVertexLayouts:r,bufferDefinitions:n}}var zn=["bool","f32","f16","i32","u32","vec2f","vec3f","vec4f","vec2h","vec3h","vec4h","vec2i","vec3i","vec4i","vec2u","vec3u","vec4u","vec2<bool>","vec3<bool>","vec4<bool>","mat2x2f","mat3x3f","mat4x4f"];function Kn(e){return zn.includes(e.type)}function Ot(e,[t,r]){return` ${xe(r)}${t}: ${e.resolve(r)},
2
- `}function qn(e,t){let r=e.names.makeUnique(t.label);return e.addDeclaration(`
1
+ import{$ as K,_ as P,a as _,b as Hr,ba as S,c as qr,d as ve,da as at,e as nt,f as Z,g as en,ga as Yt,h as ee,i as $,ia as ut,j as Me,ja as Ie,ka as Qt}from"./chunk-SMTSXYNG.js";import{$ as Ge,A as j,B as z,C as I,D as jt,E as Zr,K as Se,L as rt,M as tn,N as zt,O as De,P as Kt,Q as L,R,S as C,T as f,U as _e,V as O,W as Oe,X as te,Y as re,Z as Ht,_ as fe,a as m,aa as Fe,b,ba as Ae,c as p,ca as qt,d as w,da as F,e as N,ea as We,f as pe,fa as k,g as we,ga as E,h as _t,ha as Jt,i as Ot,ia as rn,j as Gt,ja as ot,k as le,ka as st,l as Ee,la as it,m as Le,n as Kr,o as G,p as Wt,q as Mt,r as de,s as Nt,u as Jr,v as Yr,w as be,x as Qr,y as Xr,z as me}from"./chunk-5RYM4COI.js";function H(e){return e?.resourceType==="slot"}function q(e){return e?.resourceType==="derived"}function Ne(e){return e?.["~providing"]!==void 0}function ge(e){return e?.resourceType==="accessor"}function pt(e,t){throw new Error(`Failed to handle ${e} at ${t}`)}var U={type:"unknown"};function je(e){return typeof e?.["~resolve"]=="function"}function J(e){return typeof e=="number"||typeof e=="boolean"||typeof e=="string"||je(e)||j(e)||H(e)||q(e)||Ne(e)}function nn(e){return!!e&&typeof e=="object"&&"getMappedRange"in e&&"mapAsync"in e}function lt(e){return e?.resourceType==="buffer-usage"}function Xt(e){return!!e&&typeof e=="object"&&!!e?.[m]?.dataType}function Zt(e){return!!e?.[m]}var sa=["vec2f","vec2h","vec2i","vec2u","vec2<bool>","vec3f","vec3h","vec3i","vec3u","vec3<bool>","vec4f","vec4h","vec4i","vec4u","vec4<bool>","struct"],ia={f:{1:f,2:O,3:fe,4:F},h:{1:_e,2:Oe,3:Ge,4:We},i:{1:C,2:te,3:Fe,4:k},u:{1:R,2:re,3:Ae,4:E},b:{1:L,2:Ht,3:qt,4:Jt}},an={vec2f:O,vec2h:Oe,vec2i:te,vec2u:re,"vec2<bool>":Ht,vec3f:fe,vec3h:Ge,vec3i:Fe,vec3u:Ae,"vec3<bool>":qt,vec4f:F,vec4h:We,vec4i:k,vec4u:E,"vec4<bool>":Jt,mat2x2f:ot,mat3x3f:st,mat4x4f:it},on={vec2f:f,vec2h:_e,vec2i:C,vec2u:R,"vec2<bool>":L,vec3f:f,vec3h:_e,vec3i:C,vec3u:R,"vec3<bool>":L,vec4f:f,vec4h:_e,vec4i:C,vec4u:R,"vec4<bool>":L,mat2x2f:O,mat3x3f:fe,mat4x4f:F};function ce(e,t){if(typeof e=="string"||typeof e=="number"||typeof e=="boolean")return U;if(q(e)||H(e)){let o=G();if(!o)throw new Error("Resolution context not found when unwrapping slot or derived");let s=o.unwrap(e);return mt(s)}let r=e;for(Xt(r)&&(r=r[m].dataType);Se(r);)r=r.inner;let n="kind"in r?r.kind:r.type;if(n==="struct")return r.propTypes[t]??U;let a=t.length;if(sa.includes(n)&&a>=1&&a<=4){let o=n.includes("bool")?"b":n[4],s=ia[o][a];if(s)return s}return j(r)?r:U}function er(e){if(j(e)){if(z(e))return e.elementType;if(e.type in on)return on[e.type]}return U}function mt(e){if(Xt(e))return e[m].dataType;if(typeof e=="string")return U;if(typeof e=="number")return ft(String(e))?.dataType??U;if(typeof e=="boolean")return L;if("kind"in e){let t=e.kind;if(t in an)return an[t]}return j(e)||je(e)?e:U}function ft(e){if(/^0x[0-9a-f]+$/i.test(e))return{value:e,dataType:De};if(/^0b[01]+$/i.test(e))return{value:`${Number.parseInt(e.slice(2),2)}`,dataType:De};if(/^-?(?:\d+\.\d*|\d*\.\d+)$/i.test(e))return{value:e,dataType:Kt};if(/^-?\d+(?:\.\d+)?e-?\d+$/i.test(e))return{value:e,dataType:Kt};if(/^-?\d+$/i.test(e))return{value:e,dataType:De}}var tr={rank:Number.POSITIVE_INFINITY,action:"none"};function Ue(e){return e.type==="decorated"?e.inner:e}function sn(e){return be(e)?rn[e.type]:void 0}function dt(e,t){let r=Ue(e),n=Ue(t);if(r.type===n.type)return{rank:0,action:"none"};if(r.type==="abstractFloat"){if(n.type==="f32")return{rank:1,action:"none"};if(n.type==="f16")return{rank:2,action:"none"}}if(r.type==="abstractInt"){if(n.type==="i32")return{rank:3,action:"none"};if(n.type==="u32")return{rank:4,action:"none"};if(n.type==="abstractFloat")return{rank:5,action:"none"};if(n.type==="f32")return{rank:6,action:"none"};if(n.type==="f16")return{rank:7,action:"none"}}if(be(r)&&be(n)){let a=sn(r),o=sn(n);if(a&&o)return dt(a,o)}return me(r)&&me(n)?{rank:0,action:"none"}:tr}function ua(e,t){let r=Ue(e),n=Ue(t);if(r.type==="ptr"&&dt(r.inner,n).rank<Number.POSITIVE_INFINITY)return{rank:0,action:"deref"};if(n.type==="ptr"&&dt(r,n.inner).rank<Number.POSITIVE_INFINITY)return{rank:1,action:"ref"};let a={f32:0,f16:1,i32:2,u32:3,bool:4};if(r.type in a&&n.type in a){let o=r.type,s=n.type;if(o!==s){let i=a[o];return{rank:a[s]<i?10:20,action:"cast",targetType:n}}}return tr}function pa(e,t,r){let n=dt(e,t);return n.rank<Number.POSITIVE_INFINITY?n:r?ua(e,t):tr}function un(e,t,r){let n,a=Number.POSITIVE_INFINITY,o=new Map;for(let u of t){let d=0,g=[],c=!0;for(let y of e){let x=pa(y,u,r);if(x.rank===Number.POSITIVE_INFINITY){c=!1;break}d+=x.rank,g.push(x)}c&&d<a&&(a=d,n=u,o.set(n,g))}if(!n)return;let i=o.get(n).map((u,d)=>({sourceIndex:d,action:u.action,...u.action==="cast"&&{targetType:u.targetType}})),l=i.some(u=>u.action==="cast");return{targetType:n,actions:i,hasImplicitConversions:l}}function rr(e){return e.type==="abstractFloat"?f:e.type==="abstractInt"?C:e}function pn(e,t){if(e.length===0)return;let r=[...new Set(e.map(Ue))],n=t?[...new Set(t.map(Ue))]:r,a=un(e,n,!1);if(a)return a;let o=un(e,n,!0);if(o)return o.hasImplicitConversions=o.actions.some(s=>s.action==="cast"),o}function A(e,t){return J(t.value)?e.resolve(t.value):String(t.value)}function la(e,t,r,n){if(r.action==="none")return{value:t.value,dataType:n};let a=A(e,t);switch(r.action){case"ref":return{value:`&${a}`,dataType:n};case"deref":return{value:`*${a}`,dataType:n};case"cast":return{value:`${e.resolve(n)}(${a})`,dataType:n};default:pt(r.action,"applyActionToSnippet")}}function W(e,t,r){let n=t.map(o=>o.dataType);if(n.some(o=>o===U))return;let a=pn(n,r);if(a)return a.hasImplicitConversions&&console.warn(`Implicit conversions from [
2
+ ${t.map(o=>` ${o.value}: ${o.dataType.type}`).join(`,
3
+ `)}
4
+ ] to ${a.targetType.type} are supported, but not recommended.
5
+ Consider using explicit conversions instead.`),t.map((o,s)=>{let i=a.actions[s];return pe(i,"Action should not be undefined"),la(e,o,i,a.targetType)})}function nr(e,t,r){return Object.keys(t.propTypes).map(a=>{let o=r[a];if(!o)throw new Error(`Missing property ${a}`);let s=t.propTypes[a];return W(e,[o],[s])?.[0]??o})}function ar(e){if(J(e))return{value:e,dataType:mt(e)};if(Array.isArray(e)){let t=e.map(ar).filter(Boolean),r=G();if(!r)throw new Error("Tried to coerce array without a context");let n=W(r,t),a=pn(t.map(o=>o.dataType))?.targetType;return!n||!a?{value:e,dataType:U}:{value:n.map(o=>o.value).join(", "),dataType:at(rr(a),e.length)}}if(typeof e!="object"){let t=ft(String(e));if(t)return t}return{value:e,dataType:U}}var Y={get(e,t){if(t in e)return Reflect.get(e,t);if(t!=="~providing")return t==="toString"||t===Symbol.toStringTag||t===Symbol.toPrimitive?()=>e.toString():new Proxy({"~resolve":r=>`${r.resolve(e)}.${String(t)}`,toString:()=>`.value(...).${String(t)}:${p(e)??"<unnamed>"}`,[m]:{dataType:ce(e[m].dataType,String(t))}},Y)}};function ze(e){let t=e;for(;H(t)||q(t)||ge(t)||lt(t);)t=t.value;return t}function ln(e,t){return new or(e,t)}var or=class{constructor(t,r){this.dataType=t;this._value=r;this[m]={dataType:t}}[m];$name(t){return w(this,t),this}"~resolve"(t){let r=t.names.makeUnique(p(this)),n=t.resolveValue(this._value,this.dataType);return t.addDeclaration(`const ${r} = ${n};`),r}toString(){return`const:${p(this)??"<unnamed>"}`}get value(){return de()?new Proxy({"~resolve":t=>t.resolve(this),toString:()=>`.value:${p(this)??"<unnamed>"}`,[m]:{dataType:this.dataType}},Y):this._value}};function Q(e,t){for(let[r,n]of Object.entries(t))e[r]=n,N(n)&&p(n)===void 0&&n.$name(r)}function dn(e,t,r){let n=[...e.matchAll(/:\s*(?<arg>.*?)\s*[,)]/g)].map(a=>a?a[1]:void 0);r(Object.fromEntries(t.flatMap((a,o)=>{let s=n?n[o]:void 0;return I(a)&&s!==void 0?[[s,a]]:[]})))}function Be(e,t,r){let n=e.match(/->\s(?<output>[\w\d_]+)\s{/),a=n?n[1]?.trim():void 0;I(t)&&a&&!/\s/g.test(a)&&r({[a]:t})}function da(e){return new RegExp(`(?<![\\w\\$_.])${e.replaceAll(".","\\.").replaceAll("$","\\$")}(?![\\w\\$_])`,"g")}function ye(e,t,r){return Object.entries(t).reduce((n,[a,o])=>J(o)||ve(o)?n.replaceAll(da(a),e.resolve(o)):o!==null&&typeof o=="object"?([...r.matchAll(new RegExp(`${a.replaceAll(".","\\.").replaceAll("$","\\$")}\\.(?<prop>.*?)(?![\\w\\$_])`,"g"))].map(i=>i[1])??[]).reduce((i,l)=>l&&l in o?ye(e,{[`${a}.${l}`]:o[l]},i):i,n):n,r)}function mn(e){return new sr(e)}var sr=class{constructor(t){this.declaration=t}externalsToApply=[];$uses(t){return this.externalsToApply.push(t),this}"~resolve"(t){let r={};for(let a of this.externalsToApply)Q(r,a);let n=ye(t,r,this.declaration);return t.addDeclaration(n),""}toString(){return`declare: ${this.declaration}`}};var fn=new WeakMap;function gn(e){return fn.get(e)}function cn(e,t,r){return fn.set(e,{ast:t,externals:r}),e}function yn(e){return()=>{throw new Error(`The function "${e??"<unnamed>"}" is invokable only on the GPU. If you want to use it on the CPU, mark it with the "kernel & js" directive.`)}}function Ke(e){return typeof e?.format=="string"}function Tn(e,t){let r=[];if($(e)){if(!Ke(t))throw new Error("Shader expected a single attribute, not a record of attributes to be passed in.");return r.push(t._layout),{usedVertexLayouts:r,bufferDefinitions:[{arrayStride:t._layout.stride,stepMode:t._layout.stepMode,attributes:[{format:t.format,offset:t.offset,shaderLocation:ee(e)??0}]}]}}let n=[],a=new WeakMap,o=0;for(let[s,i]of Object.entries(e)){if(ut(i))continue;let l=t[s];if(!l)throw new Error(`An attribute by the name of '${s}' was not provided to the shader.`);let u=l._layout,d=a.get(u);d||(r.push(u),d=[],n.push({arrayStride:u.stride,stepMode:u.stepMode,attributes:d}),a.set(u,d)),o=ee(i)??o,d.push({format:l.format,offset:l.offset,shaderLocation:o++})}return{usedVertexLayouts:r,bufferDefinitions:n}}var ma=["bool","f32","f16","i32","u32","vec2f","vec3f","vec4f","vec2h","vec3h","vec4h","vec2i","vec3i","vec4i","vec2u","vec3u","vec4u","vec2<bool>","vec3<bool>","vec4<bool>","mat2x2f","mat3x3f","mat4x4f"];function fa(e){return ma.includes(e.type)}function ir(e,[t,r]){return` ${Ie(r)}${t}: ${e.resolve(r)},
6
+ `}function ga(e,t){let r=e.names.makeUnique(p(t));return e.addDeclaration(`
3
7
  struct ${r} {
4
- ${Object.entries(t.propTypes).map(n=>Ot(e,n)).join("")}}
5
- `),r}function Hn(e,t){let r=e.names.makeUnique(t.label);return e.addDeclaration(`
8
+ ${Object.entries(t.propTypes).map(n=>ir(e,n)).join("")}}
9
+ `),r}function ca(e,t){let r=e.names.makeUnique(p(t));return e.addDeclaration(`
6
10
  struct ${r} {
7
- ${Object.entries(t.propTypes).map(n=>ke(n[1])?Ot(e,[n[0],Ce[n[1].format]]):Ot(e,n)).join("")}
11
+ ${Object.entries(t.propTypes).map(n=>Ke(n[1])?ir(e,[n[0],Me[n[1].format]]):ir(e,n)).join("")}
8
12
  }
9
- `),r}function Jn(e,t){let r=e.resolve(t.elementType);return t.elementCount===0?`array<${r}>`:`array<${r}, ${t.elementCount}>`}function Yn(e,t){let r=e.resolve(ke(t.elementType)?Ce[t.elementType.format]:t.elementType);return t.elementCount===0?`array<${r}>`:`array<${r}, ${t.elementCount}>`}function Gt(e,t){if(ce(t))return t.type==="unstruct"?Hn(e,t):t.type==="disarray"?Yn(e,t):t.type==="loose-decorated"?e.resolve(ke(t.inner)?Ce[t.inner.format]:t.inner):e.resolve(Ce[t.type]);if(Kn(t))return t.type;if(t.type==="struct")return qn(e,t);if(t.type==="array")return Jn(e,t);if(t.type==="atomic")return`atomic<${Gt(e,t.inner)}>`;if(t.type==="decorated")return e.resolve(t.inner);if(t.type==="ptr")return t.addressSpace==="storage"?`ptr<storage, ${e.resolve(t.inner)}, ${t.access==="read-write"?"read_write":t.access}>`:`ptr<${t.addressSpace}, ${e.resolve(t.inner)}>`;if(t.type==="abstractInt"||t.type==="abstractFloat")throw new Error("Abstract types have no concrete representation in WGSL");if(t.type==="void")throw new Error("Void has no representation in WGSL");Qr(t,"resolveData")}var Xn=["==","!=","<","<=",">",">=","<<",">>","+","-","*","/","%","|","^","&","&&","||"],Zn=["&&","||","==","!=","<","<=",">",">="];function Zr(e,t,r){return r?Zn.includes(t)?O:t==="="?r:e:t==="!"||t==="~"?O:e}function h(e,t){return z(t.value)?e.resolve(t.value):String(t.value)}function ea(e){throw new Error(`'${JSON.stringify(e)}' was not handled by the WGSL generator.`)}function en(e,t){return{value:t?"true":"false",dataType:O}}function tn(e,t){e.pushBlockScope();try{return`${e.indent()}{
10
- ${t.b.map(r=>pe(e,r)).join(`
13
+ `),r}function ya(e,t){let r=e.resolve(t.elementType);return t.elementCount===0?`array<${r}>`:`array<${r}, ${t.elementCount}>`}function Ta(e,t){let r=e.resolve(Ke(t.elementType)?Me[t.elementType.format]:t.elementType);return t.elementCount===0?`array<${r}>`:`array<${r}, ${t.elementCount}>`}function ur(e,t){if(ve(t))return t.type==="unstruct"?ca(e,t):t.type==="disarray"?Ta(e,t):t.type==="loose-decorated"?e.resolve(Ke(t.inner)?Me[t.inner.format]:t.inner):e.resolve(Me[t.type]);if(fa(t))return t.type;if(t.type==="struct")return ga(e,t);if(t.type==="array")return ya(e,t);if(t.type==="atomic")return`atomic<${ur(e,t.inner)}>`;if(t.type==="decorated")return e.resolve(t.inner);if(t.type==="ptr")return t.addressSpace==="storage"?`ptr<storage, ${e.resolve(t.inner)}, ${t.access==="read-write"?"read_write":t.access}>`:`ptr<${t.addressSpace}, ${e.resolve(t.inner)}>`;if(t.type==="abstractInt"||t.type==="abstractFloat")throw new Error("Abstract types have no concrete representation in WGSL");if(t.type==="void")throw new Error("Void has no representation in WGSL");pt(t,"resolveData")}import{BufferReader as cr,BufferWriter as yr,getSystemEndianness as Sa}from"typed-binary";import{Measurer as ha}from"typed-binary";function xa(e,t){let r="size"in e?e.size:e.currentByteOffset,n=t-1,a=r&n;"skipBytes"in e?e.skipBytes(t-a&n):e.add(t-a&n)}var B=xa;var xn=new WeakMap;function gt(e){let t=xn.get(e);if(t)return t;let r=new ha,n={},a;for(let o in e.propTypes){let s=e.propTypes[o];if(s===void 0)throw new Error(`Property ${o} is undefined in struct`);let i=r.size;B(r,Z(e)?K(s):P(s)),a&&(a.padding=r.size-i);let l=S(s);n[o]={offset:r.size,size:l},a=n[o],r.add(l)}return a&&(a.padding=_(S(e),P(e))-r.size),xn.set(e,n),n}var yt=(()=>{try{return new Function("return true"),!0}catch{return!1}})(),pr=new WeakMap,lr={u32:"u32",vec2u:"u32",vec3u:"u32",vec4u:"u32",i32:"i32",vec2i:"i32",vec3i:"i32",vec4i:"i32",f32:"f32",vec2f:"f32",vec3f:"f32",vec4f:"f32",vec2h:"f32",vec3h:"f32",vec4h:"f32",mat2x2f:"f32",mat3x3f:"f32",mat4x4f:"f32"},dr={u32:"setUint32",i32:"setInt32",f32:"setFloat32"};function ct(e,t,r){if(Zr(e)||Se(e))return ct(e.inner,t,r);if(I(e)||Z(e)){let a=gt(e),o=Object.entries(a).sort((i,l)=>i[1].offset-l[1].offset),s="";for(let[i,l]of o){let u=e.propTypes[i];u&&(s+=ct(u,`(${t} + ${l.offset})`,`${r}.${i}`))}return s}if(z(e)||nt(e)){let a=e,o=_(S(a.elementType),P(a.elementType)),s="";return s+=`for (let i = 0; i < ${a.elementCount}; i++) {
14
+ `,s+=ct(a.elementType,`(${t} + i * ${o})`,`${r}[i]`),s+=`}
15
+ `,s}if(be(e)){let a=lr[e.type],o="",s=dr[a],i=["x","y","z","w"],l=Jr(e)?2:Yr(e)?3:4;for(let u=0;u<l;u++)o+=`output.${s}((${t} + ${u*4}), ${r}.${i[u]}, littleEndian);
16
+ `;return o}if(me(e)){let a=lr[e.type],o=dr[a],s=Qr(e)?2:Xr(e)?3:4,i=s*s,l=_(s*4,8),u="";for(let d=0;d<i;d++){let g=Math.floor(d/s),c=d%s,y=g*l+c*4;u+=`output.${o}((${t} + ${y}), ${r}.columns[${g}].${["x","y","z","w"][c]}, littleEndian);
17
+ `}return u}let n=lr[e.type];return`output.${dr[n]}(${t}, ${r}, littleEndian);
18
+ `}function Tt(e){if(pr.has(e))return pr.get(e);let t=ct(e,"offset","value"),r=new Function("output","offset","value","littleEndian=true",t);return pr.set(e,r),r}var Re={bool(){throw new Error("Booleans are not host-shareable")},f32(e,t,r){e.writeFloat32(r)},f16(e,t,r){e.writeFloat16(r)},i32(e,t,r){e.writeInt32(r)},u32(e,t,r){e.writeUint32(r)},vec2f(e,t,r){e.writeFloat32(r.x),e.writeFloat32(r.y)},vec2h(e,t,r){e.writeFloat16(r.x),e.writeFloat16(r.y)},vec2i(e,t,r){e.writeInt32(r.x),e.writeInt32(r.y)},vec2u(e,t,r){e.writeUint32(r.x),e.writeUint32(r.y)},"vec2<bool>"(){throw new Error("Booleans are not host-shareable")},vec3f(e,t,r){e.writeFloat32(r.x),e.writeFloat32(r.y),e.writeFloat32(r.z)},vec3h(e,t,r){e.writeFloat16(r.x),e.writeFloat16(r.y),e.writeFloat16(r.z)},vec3i(e,t,r){e.writeInt32(r.x),e.writeInt32(r.y),e.writeInt32(r.z)},vec3u(e,t,r){e.writeUint32(r.x),e.writeUint32(r.y),e.writeUint32(r.z)},"vec3<bool>"(){throw new Error("Booleans are not host-shareable")},vec4f(e,t,r){e.writeFloat32(r.x),e.writeFloat32(r.y),e.writeFloat32(r.z),e.writeFloat32(r.w)},vec4h(e,t,r){e.writeFloat16(r.x),e.writeFloat16(r.y),e.writeFloat16(r.z),e.writeFloat16(r.w)},vec4i(e,t,r){e.writeInt32(r.x),e.writeInt32(r.y),e.writeInt32(r.z),e.writeInt32(r.w)},vec4u(e,t,r){e.writeUint32(r.x),e.writeUint32(r.y),e.writeUint32(r.z),e.writeUint32(r.w)},"vec4<bool>"(){throw new Error("Booleans are not host-shareable")},mat2x2f(e,t,r){for(let n=0;n<r.length;++n)e.writeFloat32(r[n])},mat3x3f(e,t,r){for(let n=0;n<r.length;++n)e.writeFloat32(r[n])},mat4x4f(e,t,r){for(let n=0;n<r.length;++n)e.writeFloat32(r[n])},struct(e,t,r){let n=P(t);B(e,n);for(let[a,o]of Object.entries(t.propTypes))B(e,P(o)),ne(e,o,r[a]);B(e,n)},array(e,t,r){if(t.elementCount===0)throw new Error("Cannot write using a runtime-sized schema.");let n=P(t);B(e,n);let a=e.currentByteOffset;for(let o=0;o<Math.min(t.elementCount,r.length);o++)B(e,n),ne(e,t.elementType,r[o]);e.seekTo(a+S(t))},ptr(){throw new Error("Pointers are not host-shareable")},atomic(e,t,r){Re[t.inner.type]?.(e,t,r)},decorated(e,t,r){let n=K(t);B(e,n);let a=e.currentByteOffset;Re[t.inner?.type]?.(e,t.inner,r),e.seekTo(a+S(t))},uint8(e,t,r){e.writeUint8(r)},uint8x2(e,t,r){e.writeUint8(r.x),e.writeUint8(r.y)},uint8x4(e,t,r){e.writeUint8(r.x),e.writeUint8(r.y),e.writeUint8(r.z),e.writeUint8(r.w)},sint8(e,t,r){e.writeInt8(r)},sint8x2(e,t,r){e.writeInt8(r.x),e.writeInt8(r.y)},sint8x4(e,t,r){e.writeInt8(r.x),e.writeInt8(r.y),e.writeInt8(r.z),e.writeInt8(r.w)},unorm8(e,t,r){e.writeUint8(r*255)},unorm8x2(e,t,r){e.writeUint8(r.x*255),e.writeUint8(r.y*255)},unorm8x4(e,t,r){e.writeUint8(r.x*255),e.writeUint8(r.y*255),e.writeUint8(r.z*255),e.writeUint8(r.w*255)},snorm8(e,t,r){e.writeUint8(r*127+128)},snorm8x2(e,t,r){e.writeUint8(r.x*127+128),e.writeUint8(r.y*127+128)},snorm8x4(e,t,r){e.writeUint8(r.x*127+128),e.writeUint8(r.y*127+128),e.writeUint8(r.z*127+128),e.writeUint8(r.w*127+128)},uint16(e,t,r){e.writeUint16(r)},uint16x2(e,t,r){e.writeUint16(r.x),e.writeUint16(r.y)},uint16x4(e,t,r){e.writeUint16(r.x),e.writeUint16(r.y),e.writeUint16(r.z),e.writeUint16(r.w)},sint16(e,t,r){e.writeInt16(r)},sint16x2(e,t,r){e.writeInt16(r.x),e.writeInt16(r.y)},sint16x4(e,t,r){e.writeInt16(r.x),e.writeInt16(r.y),e.writeInt16(r.z),e.writeInt16(r.w)},unorm16(e,t,r){e.writeUint16(r*65535)},unorm16x2(e,t,r){e.writeUint16(r.x*65535),e.writeUint16(r.y*65535)},unorm16x4(e,t,r){e.writeUint16(r.x*65535),e.writeUint16(r.y*65535),e.writeUint16(r.z*65535),e.writeUint16(r.w*65535)},snorm16(e,t,r){e.writeUint16(r*32767+32768)},snorm16x2(e,t,r){e.writeUint16(r.x*32767+32768),e.writeUint16(r.y*32767+32768)},snorm16x4(e,t,r){e.writeUint16(r.x*32767+32768),e.writeUint16(r.y*32767+32768),e.writeUint16(r.z*32767+32768),e.writeUint16(r.w*32767+32768)},float16(e,t,r){e.writeFloat16(r)},float16x2(e,t,r){e.writeFloat16(r.x),e.writeFloat16(r.y)},float16x4(e,t,r){e.writeFloat16(r.x),e.writeFloat16(r.y),e.writeFloat16(r.z),e.writeFloat16(r.w)},float32(e,t,r){e.writeFloat32(r)},float32x2(e,t,r){e.writeFloat32(r.x),e.writeFloat32(r.y)},float32x3(e,t,r){e.writeFloat32(r.x),e.writeFloat32(r.y),e.writeFloat32(r.z)},float32x4(e,t,r){e.writeFloat32(r.x),e.writeFloat32(r.y),e.writeFloat32(r.z),e.writeFloat32(r.w)},uint32(e,t,r){e.writeUint32(r)},uint32x2(e,t,r){e.writeUint32(r.x),e.writeUint32(r.y)},uint32x3(e,t,r){e.writeUint32(r.x),e.writeUint32(r.y),e.writeUint32(r.z)},uint32x4(e,t,r){e.writeUint32(r.x),e.writeUint32(r.y),e.writeUint32(r.z),e.writeUint32(r.w)},sint32(e,t,r){e.writeInt32(r)},sint32x2(e,t,r){e.writeInt32(r.x),e.writeInt32(r.y)},sint32x3(e,t,r){e.writeInt32(r.x),e.writeInt32(r.y),e.writeInt32(r.z)},sint32x4(e,t,r){e.writeInt32(r.x),e.writeInt32(r.y),e.writeInt32(r.z),e.writeInt32(r.w)},"unorm10-10-10-2"(e,t,r){let n=0;n|=(r.x*1023&1023)<<22,n|=(r.x*1023&1023)<<12,n|=(r.y*1023&1023)<<2,n|=r.z*3&3,e.writeUint32(n)},"unorm8x4-bgra"(e,t,r){e.writeUint8(r.z*255),e.writeUint8(r.y*255),e.writeUint8(r.x*255),e.writeUint8(r.w*255)},disarray(e,t,r){let n=P(t);B(e,n);let a=e.currentByteOffset;for(let o=0;o<Math.min(t.elementCount,r.length);o++)B(e,n),Re[t.elementType?.type]?.(e,t.elementType,r[o]);e.seekTo(a+S(t))},unstruct(e,t,r){for(let[n,a]of Object.entries(t.propTypes))Re[a.type]?.(e,a,r[n])},"loose-decorated"(e,t,r){let n=K(t);B(e,n);let a=e.currentByteOffset,o=Re[t.inner?.type];return o?.(e,t.inner,r),e.seekTo(a+S(t)),r}};function ne(e,t,r){let n=Re[t.type];if(!n)throw new Error(`Cannot write data of type '${t.type}'.`);n(e,t,r)}var Te={bool(){throw new Error("Booleans are not host-shareable")},f32(e){return e.readFloat32()},f16(e){return e.readFloat16()},i32(e){return e.readInt32()},u32(e){return e.readUint32()},vec2f(e){return O(e.readFloat32(),e.readFloat32())},vec3f(e){return fe(e.readFloat32(),e.readFloat32(),e.readFloat32())},vec4f(e){return F(e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32())},vec2h(e){return Oe(e.readFloat16(),e.readFloat16())},vec3h(e){return Ge(e.readFloat16(),e.readFloat16(),e.readFloat16())},vec4h(e){return We(e.readFloat16(),e.readFloat16(),e.readFloat16(),e.readFloat16())},vec2i(e){return te(e.readInt32(),e.readInt32())},vec3i(e){return Fe(e.readInt32(),e.readInt32(),e.readInt32())},vec4i(e){return k(e.readInt32(),e.readInt32(),e.readInt32(),e.readInt32())},vec2u(e){return re(e.readUint32(),e.readUint32())},vec3u(e){return Ae(e.readUint32(),e.readUint32(),e.readUint32())},vec4u(e){return E(e.readUint32(),e.readUint32(),e.readUint32(),e.readUint32())},"vec2<bool>"(){throw new Error("Booleans are not host-shareable")},"vec3<bool>"(){throw new Error("Booleans are not host-shareable")},"vec4<bool>"(){throw new Error("Booleans are not host-shareable")},mat2x2f(e){return ot(e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32())},mat3x3f(e){let t=()=>{let r=e.readFloat32();return e.readFloat32(),r};return st(e.readFloat32(),e.readFloat32(),t(),e.readFloat32(),e.readFloat32(),t(),e.readFloat32(),e.readFloat32(),t())},mat4x4f(e){return it(e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32())},struct(e,t){let r=P(t);B(e,r);let n={};for(let[a,o]of Object.entries(t.propTypes))B(e,P(o)),n[a]=M(e,o);return B(e,r),n},array(e,t){if(t.elementCount===0)throw new Error("Cannot read using a runtime-sized schema.");let r=P(t),n=[];for(let a=0;a<t.elementCount;a++){B(e,r);let o=t.elementType,s=M(e,o);n.push(s)}return B(e,r),n},ptr(){throw new Error("Pointers are not host-shareable")},atomic(e,t){return M(e,t.inner)},decorated(e,t){let r=K(t);B(e,r);let n=e.currentByteOffset,a=M(e,t.inner);return e.seekTo(n+S(t)),a},uint8:e=>e.readUint8(),uint8x2:e=>re(e.readUint8(),e.readUint8()),uint8x4:e=>E(e.readUint8(),e.readUint8(),e.readUint8(),e.readUint8()),sint8:e=>e.readInt8(),sint8x2:e=>te(e.readInt8(),e.readInt8()),sint8x4:e=>k(e.readInt8(),e.readInt8(),e.readInt8(),e.readInt8()),unorm8:e=>e.readUint8()/255,unorm8x2:e=>O(e.readUint8()/255,e.readUint8()/255),unorm8x4:e=>F(e.readUint8()/255,e.readUint8()/255,e.readUint8()/255,e.readUint8()/255),snorm8:e=>(e.readUint8()-128)/127,snorm8x2:e=>O((e.readUint8()-128)/127,(e.readUint8()-128)/127),snorm8x4:e=>F((e.readUint8()-128)/127,(e.readUint8()-128)/127,(e.readUint8()-128)/127,(e.readUint8()-128)/127),uint16:e=>e.readUint16(),uint16x2:e=>re(e.readUint16(),e.readUint16()),uint16x4:e=>E(e.readUint16(),e.readUint16(),e.readUint16(),e.readUint16()),sint16:e=>e.readInt16(),sint16x2:e=>te(e.readInt16(),e.readInt16()),sint16x4:e=>k(e.readInt16(),e.readInt16(),e.readInt16(),e.readInt16()),unorm16:e=>e.readUint16()/65535,unorm16x2:e=>O(e.readUint16()/65535,e.readUint16()/65535),unorm16x4:e=>F(e.readUint16()/65535,e.readUint16()/65535,e.readUint16()/65535,e.readUint16()/65535),snorm16:e=>(e.readUint16()-32768)/32767,snorm16x2:e=>O(Te.snorm16(e),Te.snorm16(e)),snorm16x4:e=>F(Te.snorm16(e),Te.snorm16(e),Te.snorm16(e),Te.snorm16(e)),float16(e){return e.readFloat16()},float16x2:e=>O(e.readFloat16(),e.readFloat16()),float16x4:e=>F(e.readFloat16(),e.readFloat16(),e.readFloat16(),e.readFloat16()),float32:e=>e.readFloat32(),float32x2:e=>O(e.readFloat32(),e.readFloat32()),float32x3:e=>fe(e.readFloat32(),e.readFloat32(),e.readFloat32()),float32x4:e=>F(e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32()),uint32:e=>e.readUint32(),uint32x2:e=>re(e.readUint32(),e.readUint32()),uint32x3:e=>Ae(e.readUint32(),e.readUint32(),e.readUint32()),uint32x4:e=>E(e.readUint32(),e.readUint32(),e.readUint32(),e.readUint32()),sint32:e=>e.readInt32(),sint32x2:e=>te(e.readInt32(),e.readInt32()),sint32x3:e=>Fe(e.readInt32(),e.readInt32(),e.readInt32()),sint32x4:e=>k(e.readInt32(),e.readInt32(),e.readInt32(),e.readInt32()),"unorm10-10-10-2"(e){let t=e.readUint32(),r=(t>>22)/1023,n=(t>>12&1023)/1023,a=(t>>2&1023)/1023,o=(t&3)/3;return F(r,n,a,o)},"unorm8x4-bgra"(e){let t=e.readByte()/255,r=e.readByte()/255,n=e.readByte()/255,a=e.readByte()/255;return F(n,r,t,a)},unstruct(e,t){let r={};for(let[n,a]of Object.entries(t.propTypes))r[n]=M(e,a);return r},disarray(e,t){let r=P(t),n=[];for(let a=0;a<t.elementCount;a++)B(e,r),n.push(M(e,t.elementType));return B(e,r),n},"loose-decorated"(e,t){B(e,K(t));let r=e.currentByteOffset,n=M(e,t.inner);return e.seekTo(r+S(t)),n}};function M(e,t){let r=Te[t.type];if(!r)throw new Error(`Cannot read data of type '${t.type}'.`);return r(e,t)}import{BufferWriter as ba}from"typed-binary";function hn(e,t){let r=S(e);if(r===0||t===void 0||t===null)return[];let n=new ArrayBuffer(r),a=new ba(n),o=[];function s(u,d,g,c){if(d!=null){if(I(u)||Z(u)){let y=gt(u);for(let[x,h]of Object.entries(y)){let T=u.propTypes[x];if(!T)continue;let D=d[x];D!==void 0&&s(T,D,g+h.offset,h.padding??c)}return}if(z(u)||nt(u)){let y=u,x=_(S(y.elementType),P(y.elementType));if(!Array.isArray(d))throw new Error("Partial value for array must be an array");let h=d??[];h.sort((T,D)=>T.idx-D.idx);for(let{idx:T,value:D}of h)s(y.elementType,D,g+T*x,x-S(y.elementType))}else{let y=S(u);a.seekTo(g),ne(a,u,d),o.push({start:g,end:g+y,padding:c})}}}if(s(e,t,0),o.length===0)return[];let i=[],l=o[0];for(let u=1;u<o.length;u++){let d=o[u];if(!d||!l)throw new Error("Internal error: missing segment");d.start===l.end+(l.padding??0)?(l.end=d.end,l.padding=d.padding):(i.push({data:new Uint8Array(n,l.start,l.end-l.start)}),l=d)}if(!l)throw new Error("Internal error: missing segment");return i.push({data:new Uint8Array(n,l.start,l.end-l.start)}),i}function xe(e){return!!e?.usableAsStorage}var He=class e extends Error{constructor(t){super(`Resource '${p(t)??"<unnamed>"}' cannot be bound as 'storage'. Use .$usage('storage') to allow it.`),Object.setPrototypeOf(this,e.prototype)}};function xt(e){return!!e.usableAsUniform}var vn={uniform:"uniform",mutable:"storage, read_write",readonly:"storage, read"},qe=class{constructor(t,r){this.usage=t;this.buffer=r;this[m]={dataType:r.dataType},this[b]=r}resourceType="buffer-usage";[m];[b];$name(t){return this.buffer.$name(t),this}"~resolve"(t){let r=t.names.makeUnique(p(this)),{group:n,binding:a}=t.allocateFixedEntry(this.usage==="uniform"?{uniform:this.buffer.dataType}:{storage:this.buffer.dataType,access:this.usage},this.buffer),o=vn[this.usage];return t.addDeclaration(`@group(${n}) @binding(${a}) var<${o}> ${r}: ${t.resolve(this.buffer.dataType)};`),r}write(t){this.buffer.write(t)}toString(){return`${this.usage}:${p(this)??"<unnamed>"}`}get value(){if(!de())throw new Error("Cannot access buffer's value directly in JS.");return new Proxy({"~resolve":t=>t.resolve(this),toString:()=>`.value:${p(this)??"<unnamed>"}`,[m]:{dataType:this.buffer.dataType}},Y)}},Je=class{constructor(t,r,n){this.usage=t;this.dataType=r;this._membership=n;this[m]={dataType:r},w(this,n.key)}resourceType="buffer-usage";[m];"~resolve"(t){let r=t.names.makeUnique(p(this)),n=t.allocateLayoutEntry(this._membership.layout),a=vn[this.usage];return t.addDeclaration(`@group(${n}) @binding(${this._membership.idx}) var<${a}> ${r}: ${t.resolve(this.dataType)};`),r}toString(){return`${this.usage}:${p(this)??"<unnamed>"}`}get value(){if(!de())throw new Error("Cannot access buffer's value directly in JS.");return new Proxy({"~resolve":t=>t.resolve(this),toString:()=>`.value:${p(this)??"<unnamed>"}`,[m]:{dataType:this.dataType}},Y)}},wn=new WeakMap;function mr(e){if(!xe(e))throw new Error(`Cannot pass ${e} to asMutable, as it is not allowed to be used as storage. To allow it, call .$usage('storage') when creating the buffer.`);let t=wn.get(e);return t||(t=new qe("mutable",e),wn.set(e,t)),t}var bn=new WeakMap;function fr(e){if(!xe(e))throw new Error(`Cannot pass ${e} to asReadonly, as it is not allowed to be used as storage. To allow it, call .$usage('storage') when creating the buffer.`);let t=bn.get(e);return t||(t=new qe("readonly",e),bn.set(e,t)),t}var Sn=new WeakMap;function gr(e){if(!xt(e))throw new Error(`Cannot pass ${e} to asUniform, as it is not allowed to be used as a uniform. To allow it, call .$usage('uniform') when creating the buffer.`);let t=Sn.get(e);return t||(t=new qe("uniform",e),Sn.set(e,t)),t}var va={uniform:gr,mutable:mr,readonly:fr};function Fn(e,t,r){return j(t)?new ht(e,t,r):new ht(e,t,r,["storage","uniform"])}function ae(e){return e.resourceType==="buffer"}function Da(e){return!!e.usableAsVertex}var Dn=Sa(),ht=class{constructor(t,r,n,a){this._group=t;this.dataType=r;this.initialOrBuffer=n;this._disallowedUsages=a;nn(n)?(this._ownBuffer=!1,this._buffer=n):(this._ownBuffer=!0,this.initial=n)}resourceType="buffer";flags=GPUBufferUsage.COPY_DST|GPUBufferUsage.COPY_SRC;_buffer=null;_ownBuffer;_destroyed=!1;_hostBuffer;initial;usableAsUniform=!1;usableAsStorage=!1;usableAsVertex=!1;get buffer(){let t=this._group.device;if(this._destroyed)throw new Error("This buffer has been destroyed");if(!this._buffer&&(this._buffer=t.createBuffer({size:S(this.dataType),usage:this.flags,mappedAtCreation:!!this.initial,label:p(this)??"<unnamed>"}),this.initial)){let r=new yr(this._buffer.getMappedRange());ne(r,this.dataType,this.initial),this._buffer.unmap()}return this._buffer}get destroyed(){return this._destroyed}$name(t){return w(this,t),this._buffer&&(this._buffer.label=t),this}$usage(...t){for(let r of t){if(this._disallowedUsages?.includes(r))throw new Error(`Buffer of type ${this.dataType.type} cannot be used as ${r}`);this.flags|=r==="uniform"?GPUBufferUsage.UNIFORM:0,this.flags|=r==="storage"?GPUBufferUsage.STORAGE:0,this.flags|=r==="vertex"?GPUBufferUsage.VERTEX:0,this.usableAsUniform=this.usableAsUniform||r==="uniform",this.usableAsStorage=this.usableAsStorage||r==="storage",this.usableAsVertex=this.usableAsVertex||r==="vertex"}return this}$addFlags(t){if(!this._ownBuffer)throw new Error("Cannot add flags to a buffer that is not managed by TypeGPU.");return t&GPUBufferUsage.MAP_READ?(this.flags=GPUBufferUsage.COPY_DST|GPUBufferUsage.MAP_READ,this):t&GPUBufferUsage.MAP_WRITE?(this.flags=GPUBufferUsage.COPY_SRC|GPUBufferUsage.MAP_WRITE,this):(this.flags|=t,this)}compileWriter(){if(yt)Tt(this.dataType);else throw new Error("This environment does not allow eval")}write(t){let r=this.buffer,n=this._group.device;if(r.mapState==="mapped"){let o=r.getMappedRange();if(yt){Tt(this.dataType)(new DataView(o),0,t,Dn==="little");return}ne(new yr(o),this.dataType,t);return}let a=S(this.dataType);this._hostBuffer||(this._hostBuffer=new ArrayBuffer(a)),this._group.flush(),yt?Tt(this.dataType)(new DataView(this._hostBuffer),0,t,Dn==="little"):ne(new yr(this._hostBuffer),this.dataType,t),n.queue.writeBuffer(r,0,this._hostBuffer,0,a)}writePartial(t){let r=this.buffer,n=this._group.device,a=hn(this.dataType,t);if(r.mapState==="mapped"){let o=r.getMappedRange(),s=new Uint8Array(o);for(let i of a)s.set(i.data,i.data.byteOffset)}else for(let o of a)n.queue.writeBuffer(r,o.data.byteOffset,o.data,0,o.data.byteLength)}copyFrom(t){if(this.buffer.mapState==="mapped")throw new Error("Cannot copy to a mapped buffer.");let r=S(this.dataType);this._group.commandEncoder.copyBufferToBuffer(t.buffer,0,this.buffer,0,r)}async read(){this._group.flush();let t=this.buffer,r=this._group.device;if(t.mapState==="mapped"){let s=t.getMappedRange();return M(new cr(s),this.dataType)}if(t.usage&GPUBufferUsage.MAP_READ){await t.mapAsync(GPUMapMode.READ);let s=t.getMappedRange(),i=M(new cr(s),this.dataType);return t.unmap(),i}let n=r.createBuffer({size:S(this.dataType),usage:GPUBufferUsage.COPY_DST|GPUBufferUsage.MAP_READ}),a=r.createCommandEncoder();a.copyBufferToBuffer(t,0,n,0,S(this.dataType)),r.queue.submit([a.finish()]),await r.queue.onSubmittedWorkDone(),await n.mapAsync(GPUMapMode.READ,0,S(this.dataType));let o=M(new cr(n.getMappedRange()),this.dataType);return n.unmap(),n.destroy(),o}as(t){return va[t]?.(this)}destroy(){this._destroyed||(this._destroyed=!0,this._ownBuffer&&this._buffer?.destroy())}toString(){return`buffer:${p(this)??"<unnamed>"}`}};function An(e){return new Tr(e)}function In(e){return new xr(e)}function Ye(e){let t=e;return t?.resourceType==="sampler"&&!!t[m]}function Qe(e){let t=e;return t?.resourceType==="sampler-comparison"&&!!t[m]}var wt=class{constructor(t){this._membership=t;this[m]={},w(this,t.key)}[m];resourceType="sampler";"~resolve"(t){let r=t.names.makeUnique(p(this)),n=t.allocateLayoutEntry(this._membership.layout);return t.addDeclaration(`@group(${n}) @binding(${this._membership.idx}) var ${r}: sampler;`),r}toString(){return`${this.resourceType}:${p(this)??"<unnamed>"}`}},bt=class{constructor(t){this._membership=t;this[m]={},w(this,t.key)}[m];resourceType="sampler-comparison";"~resolve"(t){let r=t.names.makeUnique(p(this)),n=t.allocateLayoutEntry(this._membership.layout);return t.addDeclaration(`@group(${n}) @binding(${this._membership.idx}) var ${r}: sampler_comparison;`),r}toString(){return`${this.resourceType}:${p(this)??"<unnamed>"}`}},Tr=class{constructor(t){this._props=t;this[m]={unwrap:r=>(this._sampler||(this._sampler=r.device.createSampler({...this._props,label:p(this)??"<unnamed>"})),this._sampler)},this._filtering=t.minFilter==="linear"||t.magFilter==="linear"||t.mipmapFilter==="linear"}[m];resourceType="sampler";_filtering;_sampler=null;$name(t){return w(this,t),this}"~resolve"(t){let r=t.names.makeUnique(p(this)),{group:n,binding:a}=t.allocateFixedEntry({sampler:this._filtering?"filtering":"non-filtering"},this);return t.addDeclaration(`@group(${n}) @binding(${a}) var ${r}: sampler;`),r}toString(){return`${this.resourceType}:${p(this)??"<unnamed>"}`}},xr=class{constructor(t){this._props=t;this[m]={unwrap:r=>(this._sampler||(this._sampler=r.device.createSampler({...this._props,label:p(this)??"<unnamed>"})),this._sampler)}}[m];resourceType="sampler-comparison";_sampler=null;$name(t){return w(this,t),this}"~resolve"(t){let r=t.names.makeUnique(p(this)),{group:n,binding:a}=t.allocateFixedEntry({sampler:"comparison"},this);return t.addDeclaration(`@group(${n}) @binding(${a}) var ${r}: sampler_comparison;`),r}toString(){return`${this.resourceType}:${p(this)??"<unnamed>"}`}};var St=class{constructor(t){this._membership=t;w(this,t.key)}resourceType="external-texture";"~resolve"(t){let r=t.names.makeUnique(p(this)),n=t.allocateLayoutEntry(this._membership.layout);return t.addDeclaration(`@group(${n}) @binding(${this._membership.idx}) var ${r}: texture_external;`),r}toString(){return`${this.resourceType}:${p(this)??"<unnamed>"}`}};var Un={r8unorm:f,r8snorm:f,r8uint:R,r8sint:C,r16uint:R,r16sint:C,r16float:f,rg8unorm:f,rg8snorm:f,rg8uint:R,rg8sint:C,r32uint:R,r32sint:C,r32float:f,rg16uint:R,rg16sint:C,rg16float:f,rgba8unorm:f,"rgba8unorm-srgb":f,rgba8snorm:f,rgba8uint:R,rgba8sint:C,bgra8unorm:f,"bgra8unorm-srgb":f,rgb9e5ufloat:f,rgb10a2uint:R,rgb10a2unorm:f,rg11b10ufloat:f,rg32uint:R,rg32sint:C,rg32float:f,rgba16uint:R,rgba16sint:C,rgba16float:f,rgba32uint:R,rgba32sint:C,rgba32float:f,stencil8:f,depth16unorm:f,depth24plus:f,"depth24plus-stencil8":f,depth32float:f,"depth32float-stencil8":f,"bc1-rgba-unorm":f,"bc1-rgba-unorm-srgb":f,"bc2-rgba-unorm":f,"bc2-rgba-unorm-srgb":f,"bc3-rgba-unorm":f,"bc3-rgba-unorm-srgb":f,"bc4-r-unorm":f,"bc4-r-snorm":f,"bc5-rg-unorm":f,"bc5-rg-snorm":f,"bc6h-rgb-ufloat":f,"bc6h-rgb-float":f,"bc7-rgba-unorm":f,"bc7-rgba-unorm-srgb":f,"etc2-rgb8unorm":f,"etc2-rgb8unorm-srgb":f,"etc2-rgb8a1unorm":f,"etc2-rgb8a1unorm-srgb":f,"etc2-rgba8unorm":f,"etc2-rgba8unorm-srgb":f,"eac-r11unorm":f,"eac-r11snorm":f,"eac-rg11unorm":f,"eac-rg11snorm":f,"astc-4x4-unorm":f,"astc-4x4-unorm-srgb":f,"astc-5x4-unorm":f,"astc-5x4-unorm-srgb":f,"astc-5x5-unorm":f,"astc-5x5-unorm-srgb":f,"astc-6x5-unorm":f,"astc-6x5-unorm-srgb":f,"astc-6x6-unorm":f,"astc-6x6-unorm-srgb":f,"astc-8x5-unorm":f,"astc-8x5-unorm-srgb":f,"astc-8x6-unorm":f,"astc-8x6-unorm-srgb":f,"astc-8x8-unorm":f,"astc-8x8-unorm-srgb":f,"astc-10x5-unorm":f,"astc-10x5-unorm-srgb":f,"astc-10x6-unorm":f,"astc-10x6-unorm-srgb":f,"astc-10x8-unorm":f,"astc-10x8-unorm-srgb":f,"astc-10x10-unorm":f,"astc-10x10-unorm-srgb":f,"astc-12x10-unorm":f,"astc-12x10-unorm-srgb":f,"astc-12x12-unorm":f,"astc-12x12-unorm-srgb":f},Xe={rgba8unorm:F,rgba8snorm:F,rgba8uint:E,rgba8sint:k,rgba16uint:E,rgba16sint:k,rgba16float:F,r32uint:E,r32sint:k,r32float:F,rg32uint:E,rg32sint:k,rg32float:F,rgba32uint:E,rgba32sint:k,rgba32float:F,bgra8unorm:F},Bn={f32:"float",u32:"uint",i32:"sint"},Rn={float:f,"unfilterable-float":f,uint:R,sint:C,depth:f};function Cn(e,t){return new hr(e,t)}function X(e){return e?.resourceType==="texture"&&!!e[m]}function Ze(e){return e?.resourceType==="texture-storage-view"&&!!e[m]}function et(e){return e?.resourceType==="texture-sampled-view"&&!!e[m]}var Pn={mutable:"read_write",readonly:"read",writeonly:"write"},hr=class{constructor(t,r){this.props=t;this._branch=r;this[m]={unwrap:()=>{if(this._destroyed)throw new Error("This texture has been destroyed");return this._texture||(this._texture=this._branch.device.createTexture({label:p(this)??"<unnamed>",format:this.props.format,size:this.props.size,usage:this._flags,dimension:this.props.dimension??"2d",viewFormats:this.props.viewFormats??[],mipLevelCount:this.props.mipLevelCount??1,sampleCount:this.props.sampleCount??1})),this._texture}}}[m];resourceType="texture";usableAsSampled=!1;usableAsStorage=!1;usableAsRender=!1;_destroyed=!1;_flags=GPUTextureUsage.COPY_DST|GPUTextureUsage.COPY_SRC;_texture=null;$name(t){return w(this,t),this}$usage(...t){let r=t.includes("storage"),n=t.includes("sampled"),a=t.includes("render");return this._flags|=n?GPUTextureUsage.TEXTURE_BINDING:0,this._flags|=r?GPUTextureUsage.STORAGE_BINDING:0,this._flags|=a?GPUTextureUsage.RENDER_ATTACHMENT:0,this.usableAsStorage||=r,this.usableAsSampled||=n,this.usableAsRender||=a,this}createView(t,r){if(t==="sampled")return this._asSampled(r);let n=r;switch(t){case"mutable":return this._asMutable(n);case"readonly":return this._asReadonly(n);case"writeonly":return this._asWriteonly(n)}}_asStorage(t,r){if(!this.usableAsStorage)throw new Error("Unusable as storage");let n=t?.format??this.props.format,a=Xe[n];return pe(!!a,`Unsupported storage texture format: ${n}`),new wr(t??{},r,this)}_asReadonly(t){return this._asStorage(t,"readonly")}_asWriteonly(t){return this._asStorage(t,"writeonly")}_asMutable(t){return this._asStorage(t,"mutable")}_asSampled(t){if(!this.usableAsSampled)throw new Error("Unusable as sampled");let r=t?.format??this.props.format;if(!Xe[r])throw new Error(`Unsupported storage texture format: ${r}`);return new br(t,this)}destroy(){this._destroyed||(this._destroyed=!0,this._texture?.destroy())}},Ft={"1d":"1d","2d":"2d","2d-array":"2d_array",cube:"cube","cube-array":"cube_array","3d":"3d"},wr=class{constructor(t,r,n){this.access=r;this._texture=n;this[m]={unwrap:()=>(this._view||(this._view=this._texture[m].unwrap().createView({label:`${p(this)??"<unnamed>"} - View`,format:this._format,dimension:this.dimension})),this._view)},this[b]=n,this.dimension=t?.dimension??n.props.dimension??"2d",this._format=t?.format??n.props.format,this.texelDataType=Xe[this._format]}[m];[b];resourceType="texture-storage-view";texelDataType;dimension;_view;_format;$name(t){return this._texture.$name(t),this}"~resolve"(t){let r=t.names.makeUnique(p(this)),{group:n,binding:a}=t.allocateFixedEntry({storageTexture:this._format,access:this.access,viewDimension:this.dimension},this),o=`texture_storage_${Ft[this.dimension]}`;return t.addDeclaration(`@group(${n}) @binding(${a}) var ${r}: ${o}<${this._format}, ${Pn[this.access]}>;`),r}toString(){return`${this.resourceType}:${p(this)??"<unnamed>"}`}},vt=class{constructor(t,r,n,a){this._format=t;this.dimension=r;this.access=n;this._membership=a;this[m]={},this.texelDataType=Xe[this._format],w(this,a.key)}[m];resourceType="texture-storage-view";texelDataType;"~resolve"(t){let r=t.names.makeUnique(p(this)),n=t.allocateLayoutEntry(this._membership.layout),a=`texture_storage_${Ft[this.dimension]}`;return t.addDeclaration(`@group(${n}) @binding(${this._membership.idx}) var ${r}: ${a}<${this._format}, ${Pn[this.access]}>;`),r}toString(){return`${this.resourceType}:${p(this)??"<unnamed>"}`}},br=class{constructor(t,r){this._props=t;this._texture=r;this[m]={unwrap:()=>(this._view||(this._view=this._texture[m].unwrap().createView({label:`${p(this)??"<unnamed>"} - View`,...this._props})),this._view)},this[b]=r,this.dimension=t?.dimension??r.props.dimension??"2d",this._format=t?.format??r.props.format,this.channelDataType=Un[this._format]}[m];[b];resourceType="texture-sampled-view";channelDataType;dimension;_format;_view;$name(t){return this._texture.$name(t),this}"~resolve"(t){let r=t.names.makeUnique(p(this)),n=(this._texture.props.sampleCount??1)>1,{group:a,binding:o}=t.allocateFixedEntry({texture:Bn[this.channelDataType.type],viewDimension:this.dimension,multisampled:n},this),s=n?"texture_multisampled_2d":`texture_${Ft[this.dimension]}`;return t.addDeclaration(`@group(${a}) @binding(${o}) var ${r}: ${s}<${t.resolve(this.channelDataType)}>;`),r}toString(){return`${this.resourceType}:${p(this)??"<unnamed>"}`}},Dt=class{constructor(t,r,n,a){this.dimension=r;this._multisampled=n;this._membership=a;this[m]={},w(this,a.key),this.channelDataType=Rn[t]}[m];resourceType="texture-sampled-view";channelDataType;"~resolve"(t){let r=t.names.makeUnique(p(this)),n=t.allocateLayoutEntry(this._membership.layout),a=this._multisampled?"texture_multisampled_2d":`texture_${Ft[this.dimension]}`;return t.addDeclaration(`@group(${n}) @binding(${this._membership.idx}) var ${r}: ${a}<${t.resolve(this.channelDataType)}>;`),r}toString(){return`${this.resourceType}:${p(this)??"<unnamed>"}`}};function Sr(e){return!!e?.usableAsSampled}function Fa(e){return!!e?.usableAsRender}var At=class e extends Error{constructor(t){super(`Resource '${p(t)??"<unnamed>"}' cannot be bound as 'sampled'. Use .$usage('sampled') to allow it.`),Object.setPrototypeOf(this,e.prototype)}};function It(e){return new Dr(e)}function Ut(e){return!!e&&e.resourceType==="bind-group-layout"}function Fr(e){return!!e&&e.resourceType==="bind-group"}var vr=class e extends Error{constructor(t,r){super(`Bind group '${t??"<unnamed>"}' is missing a required binding '${r}'`),Object.setPrototypeOf(this,e.prototype)}},Vn=["compute"],Ce=["compute","vertex","fragment"],Dr=class{constructor(t){this.entries=t;let r=0;for(let[n,a]of Object.entries(t)){if(a===null){r++;continue}let o={layout:this,key:n,idx:r};if("uniform"in a&&(this.bound[n]=new Je("uniform",a.uniform,o)),"storage"in a){let s="type"in a.storage?a.storage:a.storage(0);this.bound[n]=new Je(a.access??"readonly",s,o)}"texture"in a&&(this.bound[n]=new Dt(a.texture,a.viewDimension??"2d",a.multisampled??!1,o)),"storageTexture"in a&&(this.bound[n]=new vt(a.storageTexture,a.viewDimension??"2d",a.access??"writeonly",o)),"externalTexture"in a&&(this.bound[n]=new St(o)),"sampler"in a&&(a.sampler==="comparison"?this.bound[n]=new bt(o):this.bound[n]=new wt(o)),"texture"in a||"storageTexture"in a||"externalTexture"in a||"sampler"in a?this.value[n]=this.bound[n]:Object.defineProperty(this.value,n,{get:()=>this.bound[n].value}),r++}}_index;resourceType="bind-group-layout";bound={};value={};$=this.value;toString(){return`bindGroupLayout:${p(this)??"<unnamed>"}`}get index(){return this._index}$name(t){return w(this,t),this}$idx(t){return this._index=t,this}unwrap(t){return t.device.createBindGroupLayout({label:p(this)??"<unnamed>",entries:Object.values(this.entries).map((n,a)=>{if(n===null)return null;let o=n.visibility,s={binding:a,visibility:0};if("uniform"in n)o=o??Ce,s.buffer={type:"uniform"};else if("storage"in n)o=o??(n.access==="mutable"?Vn:Ce),s.buffer={type:n.access==="mutable"?"storage":"read-only-storage"};else if("sampler"in n)o=o??Ce,s.sampler={type:n.sampler};else if("texture"in n)o=o??Ce,s.texture={sampleType:n.texture,viewDimension:n.viewDimension??"2d",multisampled:n.multisampled??!1};else if("storageTexture"in n){let i=n.access??"writeonly";o=o??(i==="readonly"?Ce:Vn),s.storageTexture={format:n.storageTexture,access:{mutable:"read-write",readonly:"read-only",writeonly:"write-only"}[i],viewDimension:n.viewDimension??"2d"}}else"externalTexture"in n&&(o=o??Ce,s.externalTexture={});return o?.includes("compute")&&(s.visibility|=GPUShaderStage.COMPUTE),o?.includes("vertex")&&(s.visibility|=GPUShaderStage.VERTEX),o?.includes("fragment")&&(s.visibility|=GPUShaderStage.FRAGMENT),s}).filter(n=>n!==null)})}},Pe=class{constructor(t,r){this.layout=t;this.entries=r;for(let n of Object.keys(t.entries))if(t.entries[n]!==null&&!(n in r))throw new vr(p(t),n)}resourceType="bind-group";unwrap(t){return t.device.createBindGroup({label:p(this.layout)??"<unnamed>",layout:t.unwrap(this.layout),entries:Object.entries(this.layout.entries).map(([n,a],o)=>{if(a===null)return null;let s=this.entries[n];if(s===void 0)throw new Error(`'${n}' is a resource required to populate bind group layout '${p(this.layout)??"<unnamed>"}'.`);if("uniform"in a){let i;if(ae(s)){if(!xt(s))throw new Ot(s);i={buffer:t.unwrap(s)}}else i={buffer:s};return{binding:o,resource:i}}if("storage"in a){let i;if(ae(s)){if(!xe(s))throw new He(s);i={buffer:t.unwrap(s)}}else i={buffer:s};return{binding:o,resource:i}}if("texture"in a){let i;if(X(s)){if(!Sr(s))throw new At(s);i=t.unwrap(s.createView("sampled"))}else et(s)?i=t.unwrap(s):i=s;return{binding:o,resource:i}}if("storageTexture"in a){let i;if(X(s)){if(!xe(s))throw new He(s);a.access==="readonly"?i=t.unwrap(s.createView("readonly")):a.access==="mutable"?i=t.unwrap(s.createView("mutable")):i=t.unwrap(s.createView("writeonly"))}else Ze(s)?i=t.unwrap(s):i=s;return{binding:o,resource:i}}if("sampler"in a)return Ye(s)||Qe(s)?{binding:o,resource:t.unwrap(s)}:{binding:o,resource:s};if("externalTexture"in a)return{binding:o,resource:s};throw new Error(`Malformed bind group entry: ${s} (${JSON.stringify(s)})`)}).filter(n=>n!==null)})}};import*as Aa from"tinyest";var{NodeTypeCatalog:v}=Aa,Ia=["==","!=","<","<=",">",">=","<<",">>","+","-","*","/","%","|","^","&","&&","||"],Ua=["&&","||","==","!=","<","<=",">",">="];function $n(e,t,r){return r?Ua.includes(t)?L:t==="="?r:e:t==="!"||t==="~"?L:e}function Ba(e){throw new Error(`'${JSON.stringify(e)}' was not handled by the WGSL generator.`)}function kn(e,t){return{value:t?"true":"false",dataType:L}}function En(e,[t,r]){e.pushBlockScope();try{return`${e.indent()}{
19
+ ${r.map(n=>he(e,n)).join(`
11
20
  `)}
12
- ${e.dedent()}}`}finally{e.popBlockScope()}}function ta(e,t,r){return e.defineVariable(t,r)}function Wt(e,t){let r=e.getById(t);if(!r)throw new Error(`Identifier ${t} not found`);return r}function U(e,t){if(typeof t=="string")return Wt(e,t);if(typeof t=="boolean")return en(e,t);if("x"in t){let[r,n,a]=t.x,o=U(e,r),s=U(e,a),i=h(e,o),p=h(e,s),u=Zr(o.dataType,n,s.dataType);return{value:Xn.includes(n)?`(${i} ${n} ${p})`:`${i} ${n} ${p}`,dataType:u}}if("p"in t){let[r,n]=t.p,a=U(e,n);return{value:`${h(e,a)}${r}`,dataType:a.dataType}}if("u"in t){let[r,n]=t.u,a=U(e,n),o=h(e,a),s=Zr(a.dataType,r);return{value:`${r}${o}`,dataType:s}}if("a"in t){let[r,n]=t.a,a=U(e,r);if(typeof a.value=="string")return{value:`${a.value}.${n}`,dataType:_(a.dataType)?be(a.dataType,n):A};if(G(a.dataType)&&n==="length")return a.dataType.elementCount===0?{value:`arrayLength(&${e.resolve(a.value)})`,dataType:v}:{value:String(a.dataType.elementCount),dataType:Te};let o=a.value[n];if(a.dataType.type!=="unknown")return Ye(a.dataType)&&n==="columns"?{value:a.value,dataType:a.dataType}:{value:o,dataType:be(a.dataType,n)};if(z(a.value))return{value:o,dataType:be(a.value,n)};if(typeof a.value=="object"){let s=z(o)?he(o):A;return{value:o,dataType:s}}throw new Error(`Cannot access member ${n} of ${a.value}`)}if("i"in t){let[r,n]=t.i,a=U(e,r),o=U(e,n),s=h(e,a),i=h(e,o);return{value:`${s}[${i}]`,dataType:_(a.dataType)?Nr(a.dataType):A}}if("n"in t){let r=Et(t.n);if(!r)throw new Error(`Invalid numeric literal ${t.n}`);return r}if("f"in t){let[r,n]=t.f,a=U(e,r),o=a.value;e.callStack.push(o);let i=n.map(d=>U(e,d)).map(d=>({value:h(e,d),dataType:d.dataType})),p=i.map(d=>d.value);if(e.callStack.pop(),typeof o=="string")return{value:`${o}(${p.join(", ")})`,dataType:a.dataType};if(b(o))return{value:`${e.resolve(o)}(${p.join(", ")})`,dataType:a.dataType};if(!Gr(o))throw new Error(`Function ${String(o)} has not been created using TypeGPU APIs. Did you mean to wrap the function with tgpu.fn(args, return)(...) ?`);let u=o(...i);return{value:h(e,u),dataType:u.dataType}}if("o"in t){let r=t.o,n=e.callStack[e.callStack.length-1],a=o=>o.map(s=>{let i=U(e,s);return h(e,i)}).join(", ");if(b(n)){let s=Object.keys(n.propTypes).map(i=>{let p=r[i];if(p===void 0)throw new Error(`Missing property ${i} in object literal for struct ${n}`);return p});return{value:a(s),dataType:n}}return{value:a(Object.values(r)),dataType:A}}if("y"in t){let r=t.y.map(p=>U(e,p));if(r.length===0)throw new Error("Cannot create empty array literal.");let n=r[0]?.dataType,a=r.find(p=>p.dataType!==n);if(a)throw new Error(`Cannot mix types in array literal. Type ${a.dataType.type} does not match expected type ${n?.type}.`);if(!C(n))throw new Error("Cannot use non-WGSL data types in array literals.");n=n.type==="abstractInt"?v:n.type==="abstractFloat"?l:n;let s=`array<${e.resolve(n)}, ${r.length}>`,i=r.map(p=>h(e,p));return{value:`${s}( ${i.join(", ")} )`,dataType:kr(n,r.length)}}if("s"in t)throw new Error("Cannot use string literals in TGSL.");ea(t)}function pe(e,t){if(typeof t=="string")return`${e.pre}${h(e,Wt(e,t))};`;if(typeof t=="boolean")return`${e.pre}${h(e,en(e,t))};`;if("r"in t){if(b(e.callStack[e.callStack.length-1])&&t.r!==null&&typeof t.r=="object"&&"o"in t.r){let r=h(e,U(e,t.r)),n=e.resolve(e.callStack[e.callStack.length-1]);return`${e.pre}return ${n}(${r});`}return t.r===null?`${e.pre}return;`:`${e.pre}return ${h(e,U(e,t.r))};`}if("q"in t){let[r,n,a]=t.q,o=h(e,U(e,r));e.indent();let s=pe(e,n);e.dedent(),e.indent();let i=a?pe(e,a):void 0;return e.dedent(),i?`${e.pre}if (${o})
13
- ${s}
21
+ ${e.dedent()}}`}finally{e.popBlockScope()}}function Ra(e,t,r){return e.defineVariable(t,r)}function Ar(e,t){let r=e.getById(t);if(!r)throw new Error(`Identifier ${t} not found`);return r}function V(e,t){if(typeof t=="string")return Ar(e,t);if(typeof t=="boolean")return kn(e,t);if(t[0]===v.logicalExpr||t[0]===v.binaryExpr||t[0]===v.assignmentExpr){let[r,n,a,o]=t,s=V(e,n),i=V(e,o),l=W(e,[s,i]),[u,d]=l||[s,i],g=A(e,u),c=A(e,d),y=$n(u.dataType,a,d.dataType);return{value:Ia.includes(a)?`(${g} ${a} ${c})`:`${g} ${a} ${c}`,dataType:y}}if(t[0]===v.postUpdate){let[r,n,a]=t,o=V(e,a);return{value:`${A(e,o)}${n}`,dataType:o.dataType}}if(t[0]===v.unaryExpr){let[r,n,a]=t,o=V(e,a),s=A(e,o),i=$n(o.dataType,n);return{value:`${n}${s}`,dataType:i}}if(t[0]===v.memberAccess){let[r,n,a]=t,o=V(e,n);if(jt(o.dataType))return{value:`(*${o.value}).${a}`,dataType:$(o.dataType.inner)?ce(o.dataType.inner,a):U};if(typeof o.value=="string")return{value:`${o.value}.${a}`,dataType:$(o.dataType)?ce(o.dataType,a):U};if(z(o.dataType)&&a==="length")return o.dataType.elementCount===0?{value:`arrayLength(&${e.resolve(o.value)})`,dataType:R}:{value:String(o.dataType.elementCount),dataType:De};let s=o.value[a];if(o.dataType.type!=="unknown")return me(o.dataType)&&a==="columns"?{value:o.value,dataType:o.dataType}:{value:s,dataType:ce(o.dataType,a)};if(J(o.value))return{value:s,dataType:ce(o.value,a)};if(typeof o.value=="object"){let i=J(s)?mt(s):U;return{value:s,dataType:i}}throw new Error(`Cannot access member ${a} of ${o.value}`)}if(t[0]===v.indexAccess){let[r,n,a]=t,o=V(e,n),s=V(e,a),i=A(e,o),l=A(e,s);return jt(o.dataType)?{value:`(*${i})[${l}]`,dataType:$(o.dataType.inner)?er(o.dataType.inner):U}:{value:`${i}[${l}]`,dataType:$(o.dataType)?er(o.dataType):U}}if(t[0]===v.numericLiteral){let r=ft(t[1]);if(!r)throw new Error(`Invalid numeric literal ${t[1]}`);return r}if(t[0]===v.call){let[r,n,a]=t,o=V(e,n),s=o.value;e.callStack.push(s);let i=a.map(y=>V(e,y)),l=i.map(y=>({value:A(e,y),dataType:y.dataType})),u=l.map(y=>y.value);if(e.callStack.pop(),typeof s=="string")return{value:`${s}(${u.join(", ")})`,dataType:o.dataType};if(I(s))return{value:`${e.resolve(s)}(${u.join(", ")})`,dataType:o.dataType};if(!Zt(s))throw new Error(`Function ${String(s)} has not been created using TypeGPU APIs. Did you mean to wrap the function with tgpu.fn(args, return)(...) ?`);let d=s[m]?.argTypes,g;!d||d==="keep"?g=l:d==="coerce"?g=W(e,l)??l:g=(Array.isArray(d)?d.map((x,h)=>[x,l[h]]).filter(([,x])=>!!x):typeof d=="function"?d(...l).map((x,h)=>[x,l[h]]).filter(([,x])=>!!x):Object.entries(d).map(([x,h])=>{let T=(i[0]?.value)[x];if(!T)throw new Error(`Missing argument ${x} in function call`);return[h,T]})).map(([x,h])=>{let T=W(e,[h],[x])?.[0];if(!T)throw new Error(`Cannot convert ${e.resolve(h.dataType)} to ${e.resolve(x)}`);return T});let c=s(...g);return{value:A(e,c),dataType:c.dataType}}if(t[0]===v.objectExpr){let r=t[1],n=e.callStack[e.callStack.length-1];if(I(n)){let a=Object.keys(n.propTypes),o=Object.fromEntries(a.map(i=>{let l=r[i];if(l===void 0)throw new Error(`Missing property ${i} in object literal for struct ${n}`);return[i,V(e,l)]}));return{value:nr(e,n,o).map(i=>A(e,i)).join(", "),dataType:n}}if(Zt(n)){let a=n[m]?.argTypes;if(typeof a=="object"&&a!==null){let o=Object.keys(a),s={};for(let i of o){let l=r[i];if(l===void 0)throw new Error(`Missing property ${i} in object literal for function ${n}`);let u=V(e,l),d=a[i],g=W(e,[u],[d]);s[i]=g?.[0]??u}return{value:s,dataType:U}}}throw new Error("Object expressions are only allowed as return values of functions or as arguments to structs.")}if(t[0]===v.arrayExpr){let[r,n]=t,a=n.map(g=>V(e,g));if(a.length===0)throw new Error("Cannot create empty array literal.");let o=W(e,a);if(!o)throw new Error("The given values cannot be automatically converted to a common type. Consider explicitly casting them.");let s=o[0]?.dataType,i=s.type==="abstractFloat"?f:s.type==="abstractInt"?C:s,u=`array<${e.resolve(i)}, ${a.length}>`,d=o.map(g=>A(e,g));return{value:`${u}( ${d.join(", ")} )`,dataType:at(i,a.length)}}if(t[0]===v.stringLiteral)throw new Error("Cannot use string literals in TGSL.");if(t[0]===v.preUpdate)throw new Error("Cannot use pre-updates in TGSL.");Ba(t)}function Bt(e){return typeof e!="object"||e[0]!==v.block?[v.block,[e]]:e}function he(e,t){if(typeof t=="string")return`${e.pre}${A(e,Ar(e,t))};`;if(typeof t=="boolean")return`${e.pre}${A(e,kn(e,t))};`;if(t[0]===v.return){let r=t[1],n=r!==void 0?A(e,V(e,r)):void 0;if(I(e.callStack[e.callStack.length-1])&&typeof r=="object"&&r[0]===v.objectExpr){let a=e.resolve(e.callStack[e.callStack.length-1]);return`${e.pre}return ${a}(${n});`}return n?`${e.pre}return ${n};`:`${e.pre}return;`}if(t[0]===v.if){let[r,n,a,o]=t,s=V(e,n),i=s,l=W(e,[s],[L]);l?.[0]&&([i]=l);let u=A(e,i);e.indent();let d=he(e,Bt(a));e.dedent(),e.indent();let g=o?he(e,Bt(o)):void 0;return e.dedent(),g?`${e.pre}if (${u})
22
+ ${d}
14
23
  ${e.pre}else
15
- ${i}`:`${e.pre}if (${o})
16
- ${s}`}if("l"in t||"c"in t){let[r,n]="l"in t?t.l:t.c,a=n?U(e,n):void 0;if(!a||!n)throw new Error("Cannot create variable without an initial value.");if(ce(a.dataType))throw new Error("Cannot create variable with loose data type.");ta(e,r,a.dataType);let o=h(e,Wt(e,r));if(typeof n=="object"&&"o"in n&&b(e.callStack[e.callStack.length-1])){let s=e.resolve(e.callStack[e.callStack.length-1]);return`${e.pre}var ${o} = ${s}(${h(e,a)});`}return`${e.pre}var ${o} = ${h(e,a)};`}if("b"in t){e.pushBlockScope();try{return tn(e,t)}finally{e.popBlockScope()}}if("j"in t){let[r,n,a,o]=t.j,s=r?pe(e,r):void 0,i=s?s.slice(0,-1):"",p=n?U(e,n):void 0,u=p?h(e,p):"",d=a?pe(e,a):void 0,m=d?d.slice(0,-1):"";e.indent();let T=pe(e,o);return e.dedent(),`${e.pre}for (${i}; ${u}; ${m})
17
- ${T}`}if("w"in t){let[r,n]=t.w,a=h(e,U(e,r));e.indent();let o=pe(e,n);return e.dedent(),`${e.pre}while (${a})
18
- ${o}`}return"k"in t?`${e.pre}continue;`:"d"in t?`${e.pre}break;`:`${e.pre}${h(e,U(e,t))};`}function rn(e,t){return tn(e,t)}import{BufferReader as Ht,BufferWriter as Jt}from"typed-binary";import{getSystemEndianness as oa}from"typed-binary";import{Measurer as na}from"typed-binary";function ra(e,t){let r="size"in e?e.size:e.currentByteOffset,n=t-1,a=r&n;"skipBytes"in e?e.skipBytes(t-a&n):e.add(t-a&n)}var w=ra;var nn=new WeakMap;function et(e){let t=nn.get(e);if(t)return t;let r=new na,n={},a;for(let o in e.propTypes){let s=e.propTypes[o];if(s===void 0)throw new Error(`Property ${o} is undefined in struct`);let i=r.size;w(r,Y(e)?W(s):F(s)),a&&(a.padding=r.size-i);let p=c(s);n[o]={offset:r.size,size:p},a=n[o],r.add(p)}return a&&(a.padding=V(c(e),F(e))-r.size),nn.set(e,n),n}var rt=(()=>{try{return new Function("return true"),!0}catch{return!1}})(),Mt=new WeakMap,Nt={u32:"u32",vec2u:"u32",vec3u:"u32",vec4u:"u32",i32:"i32",vec2i:"i32",vec3i:"i32",vec4i:"i32",f32:"f32",vec2f:"f32",vec3f:"f32",vec4f:"f32",vec2h:"f32",vec3h:"f32",vec4h:"f32",mat2x2f:"f32",mat3x3f:"f32",mat4x4f:"f32"},jt={u32:"setUint32",i32:"setInt32",f32:"setFloat32"};function tt(e,t,r){if(Pr(e)||ye(e))return tt(e.inner,t,r);if(b(e)||Y(e)){let a=et(e),o=Object.entries(a).sort((i,p)=>i[1].offset-p[1].offset),s="";for(let[i,p]of o){let u=e.propTypes[i];u&&(s+=tt(u,`(${t} + ${p.offset})`,`${r}.${i}`))}return s}if(G(e)||Qe(e)){let a=e,o=V(c(a.elementType),F(a.elementType)),s="";return s+=`for (let i = 0; i < ${a.elementCount}; i++) {
19
- `,s+=tt(a.elementType,`(${t} + i * ${o})`,`${r}[i]`),s+=`}
20
- `,s}if(Ir(e)){let a=Nt[e.type],o="",s=jt[a],i=["x","y","z","w"],p=Ar(e)?2:Ur(e)?3:4;for(let u=0;u<p;u++)o+=`output.${s}((${t} + ${u*4}), ${r}.${i[u]}, littleEndian);
21
- `;return o}if(Ye(e)){let a=Nt[e.type],o=jt[a],s=Br(e)?2:Rr(e)?3:4,i=s*s,p=V(s*4,8),u="";for(let d=0;d<i;d++){let m=Math.floor(d/s),T=d%s,f=m*p+T*4;u+=`output.${o}((${t} + ${f}), ${r}.columns[${m}].${["x","y","z","w"][T]}, littleEndian);
22
- `}return u}let n=Nt[e.type];return`output.${jt[n]}(${t}, ${r}, littleEndian);
23
- `}function nt(e){if(Mt.has(e))return Mt.get(e);let t=tt(e,"offset","value"),r=new Function("output","offset","value","littleEndian=true",t);return Mt.set(e,r),r}var Se={bool(){throw new Error("Booleans are not host-shareable")},f32(e,t,r){e.writeFloat32(r)},f16(e,t,r){e.writeFloat16(r)},i32(e,t,r){e.writeInt32(r)},u32(e,t,r){e.writeUint32(r)},vec2f(e,t,r){e.writeFloat32(r.x),e.writeFloat32(r.y)},vec2h(e,t,r){e.writeFloat16(r.x),e.writeFloat16(r.y)},vec2i(e,t,r){e.writeInt32(r.x),e.writeInt32(r.y)},vec2u(e,t,r){e.writeUint32(r.x),e.writeUint32(r.y)},"vec2<bool>"(){throw new Error("Booleans are not host-shareable")},vec3f(e,t,r){e.writeFloat32(r.x),e.writeFloat32(r.y),e.writeFloat32(r.z)},vec3h(e,t,r){e.writeFloat16(r.x),e.writeFloat16(r.y),e.writeFloat16(r.z)},vec3i(e,t,r){e.writeInt32(r.x),e.writeInt32(r.y),e.writeInt32(r.z)},vec3u(e,t,r){e.writeUint32(r.x),e.writeUint32(r.y),e.writeUint32(r.z)},"vec3<bool>"(){throw new Error("Booleans are not host-shareable")},vec4f(e,t,r){e.writeFloat32(r.x),e.writeFloat32(r.y),e.writeFloat32(r.z),e.writeFloat32(r.w)},vec4h(e,t,r){e.writeFloat16(r.x),e.writeFloat16(r.y),e.writeFloat16(r.z),e.writeFloat16(r.w)},vec4i(e,t,r){e.writeInt32(r.x),e.writeInt32(r.y),e.writeInt32(r.z),e.writeInt32(r.w)},vec4u(e,t,r){e.writeUint32(r.x),e.writeUint32(r.y),e.writeUint32(r.z),e.writeUint32(r.w)},"vec4<bool>"(){throw new Error("Booleans are not host-shareable")},mat2x2f(e,t,r){for(let n=0;n<r.length;++n)e.writeFloat32(r[n])},mat3x3f(e,t,r){for(let n=0;n<r.length;++n)e.writeFloat32(r[n])},mat4x4f(e,t,r){for(let n=0;n<r.length;++n)e.writeFloat32(r[n])},struct(e,t,r){let n=F(t);w(e,n);for(let[a,o]of Object.entries(t.propTypes))w(e,F(o)),X(e,o,r[a]);w(e,n)},array(e,t,r){if(t.elementCount===0)throw new Error("Cannot write using a runtime-sized schema.");let n=F(t);w(e,n);let a=e.currentByteOffset;for(let o=0;o<Math.min(t.elementCount,r.length);o++)w(e,n),X(e,t.elementType,r[o]);e.seekTo(a+c(t))},ptr(){throw new Error("Pointers are not host-shareable")},atomic(e,t,r){Se[t.inner.type]?.(e,t,r)},decorated(e,t,r){let n=W(t);w(e,n);let a=e.currentByteOffset;Se[t.inner?.type]?.(e,t.inner,r),e.seekTo(a+c(t))},uint8(e,t,r){e.writeUint8(r)},uint8x2(e,t,r){e.writeUint8(r.x),e.writeUint8(r.y)},uint8x4(e,t,r){e.writeUint8(r.x),e.writeUint8(r.y),e.writeUint8(r.z),e.writeUint8(r.w)},sint8(e,t,r){e.writeInt8(r)},sint8x2(e,t,r){e.writeInt8(r.x),e.writeInt8(r.y)},sint8x4(e,t,r){e.writeInt8(r.x),e.writeInt8(r.y),e.writeInt8(r.z),e.writeInt8(r.w)},unorm8(e,t,r){e.writeUint8(r*255)},unorm8x2(e,t,r){e.writeUint8(r.x*255),e.writeUint8(r.y*255)},unorm8x4(e,t,r){e.writeUint8(r.x*255),e.writeUint8(r.y*255),e.writeUint8(r.z*255),e.writeUint8(r.w*255)},snorm8(e,t,r){e.writeUint8(r*127+128)},snorm8x2(e,t,r){e.writeUint8(r.x*127+128),e.writeUint8(r.y*127+128)},snorm8x4(e,t,r){e.writeUint8(r.x*127+128),e.writeUint8(r.y*127+128),e.writeUint8(r.z*127+128),e.writeUint8(r.w*127+128)},uint16(e,t,r){e.writeUint16(r)},uint16x2(e,t,r){e.writeUint16(r.x),e.writeUint16(r.y)},uint16x4(e,t,r){e.writeUint16(r.x),e.writeUint16(r.y),e.writeUint16(r.z),e.writeUint16(r.w)},sint16(e,t,r){e.writeInt16(r)},sint16x2(e,t,r){e.writeInt16(r.x),e.writeInt16(r.y)},sint16x4(e,t,r){e.writeInt16(r.x),e.writeInt16(r.y),e.writeInt16(r.z),e.writeInt16(r.w)},unorm16(e,t,r){e.writeUint16(r*65535)},unorm16x2(e,t,r){e.writeUint16(r.x*65535),e.writeUint16(r.y*65535)},unorm16x4(e,t,r){e.writeUint16(r.x*65535),e.writeUint16(r.y*65535),e.writeUint16(r.z*65535),e.writeUint16(r.w*65535)},snorm16(e,t,r){e.writeUint16(r*32767+32768)},snorm16x2(e,t,r){e.writeUint16(r.x*32767+32768),e.writeUint16(r.y*32767+32768)},snorm16x4(e,t,r){e.writeUint16(r.x*32767+32768),e.writeUint16(r.y*32767+32768),e.writeUint16(r.z*32767+32768),e.writeUint16(r.w*32767+32768)},float16(e,t,r){e.writeFloat16(r)},float16x2(e,t,r){e.writeFloat16(r.x),e.writeFloat16(r.y)},float16x4(e,t,r){e.writeFloat16(r.x),e.writeFloat16(r.y),e.writeFloat16(r.z),e.writeFloat16(r.w)},float32(e,t,r){e.writeFloat32(r)},float32x2(e,t,r){e.writeFloat32(r.x),e.writeFloat32(r.y)},float32x3(e,t,r){e.writeFloat32(r.x),e.writeFloat32(r.y),e.writeFloat32(r.z)},float32x4(e,t,r){e.writeFloat32(r.x),e.writeFloat32(r.y),e.writeFloat32(r.z),e.writeFloat32(r.w)},uint32(e,t,r){e.writeUint32(r)},uint32x2(e,t,r){e.writeUint32(r.x),e.writeUint32(r.y)},uint32x3(e,t,r){e.writeUint32(r.x),e.writeUint32(r.y),e.writeUint32(r.z)},uint32x4(e,t,r){e.writeUint32(r.x),e.writeUint32(r.y),e.writeUint32(r.z),e.writeUint32(r.w)},sint32(e,t,r){e.writeInt32(r)},sint32x2(e,t,r){e.writeInt32(r.x),e.writeInt32(r.y)},sint32x3(e,t,r){e.writeInt32(r.x),e.writeInt32(r.y),e.writeInt32(r.z)},sint32x4(e,t,r){e.writeInt32(r.x),e.writeInt32(r.y),e.writeInt32(r.z),e.writeInt32(r.w)},"unorm10-10-10-2"(e,t,r){let n=0;n|=(r.x*1023&1023)<<22,n|=(r.x*1023&1023)<<12,n|=(r.y*1023&1023)<<2,n|=r.z*3&3,e.writeUint32(n)},"unorm8x4-bgra"(e,t,r){e.writeUint8(r.z*255),e.writeUint8(r.y*255),e.writeUint8(r.x*255),e.writeUint8(r.w*255)},disarray(e,t,r){let n=F(t);w(e,n);let a=e.currentByteOffset;for(let o=0;o<Math.min(t.elementCount,r.length);o++)w(e,n),Se[t.elementType?.type]?.(e,t.elementType,r[o]);e.seekTo(a+c(t))},unstruct(e,t,r){for(let[n,a]of Object.entries(t.propTypes))Se[a.type]?.(e,a,r[n])},"loose-decorated"(e,t,r){let n=W(t);w(e,n);let a=e.currentByteOffset,o=Se[t.inner?.type];return o?.(e,t.inner,r),e.seekTo(a+c(t)),r}};function X(e,t,r){let n=Se[t.type];if(!n)throw new Error(`Cannot write data of type '${t.type}'.`);n(e,t,r)}var le={bool(){throw new Error("Booleans are not host-shareable")},f32(e){return e.readFloat32()},f16(e){return e.readFloat16()},i32(e){return e.readInt32()},u32(e){return e.readUint32()},vec2f(e){return L(e.readFloat32(),e.readFloat32())},vec3f(e){return se(e.readFloat32(),e.readFloat32(),e.readFloat32())},vec4f(e){return x(e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32())},vec2h(e){return Re(e.readFloat16(),e.readFloat16())},vec3h(e){return Pe(e.readFloat16(),e.readFloat16(),e.readFloat16())},vec4h(e){return _e(e.readFloat16(),e.readFloat16(),e.readFloat16(),e.readFloat16())},vec2i(e){return H(e.readInt32(),e.readInt32())},vec3i(e){return ge(e.readInt32(),e.readInt32(),e.readInt32())},vec4i(e){return R(e.readInt32(),e.readInt32(),e.readInt32(),e.readInt32())},vec2u(e){return J(e.readUint32(),e.readUint32())},vec3u(e){return fe(e.readUint32(),e.readUint32(),e.readUint32())},vec4u(e){return P(e.readUint32(),e.readUint32(),e.readUint32(),e.readUint32())},"vec2<bool>"(){throw new Error("Booleans are not host-shareable")},"vec3<bool>"(){throw new Error("Booleans are not host-shareable")},"vec4<bool>"(){throw new Error("Booleans are not host-shareable")},mat2x2f(e){return qe(e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32())},mat3x3f(e){let t=()=>{let r=e.readFloat32();return e.readFloat32(),r};return He(e.readFloat32(),e.readFloat32(),t(),e.readFloat32(),e.readFloat32(),t(),e.readFloat32(),e.readFloat32(),t())},mat4x4f(e){return Je(e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32())},struct(e,t){let r=F(t);w(e,r);let n={};for(let[a,o]of Object.entries(t.propTypes))w(e,F(o)),n[a]=$(e,o);return w(e,r),n},array(e,t){if(t.elementCount===0)throw new Error("Cannot read using a runtime-sized schema.");let r=F(t),n=[];for(let a=0;a<t.elementCount;a++){w(e,r);let o=t.elementType,s=$(e,o);n.push(s)}return w(e,r),n},ptr(){throw new Error("Pointers are not host-shareable")},atomic(e,t){return $(e,t.inner)},decorated(e,t){let r=W(t);w(e,r);let n=e.currentByteOffset,a=$(e,t.inner);return e.seekTo(n+c(t)),a},uint8:e=>e.readUint8(),uint8x2:e=>J(e.readUint8(),e.readUint8()),uint8x4:e=>P(e.readUint8(),e.readUint8(),e.readUint8(),e.readUint8()),sint8:e=>e.readInt8(),sint8x2:e=>H(e.readInt8(),e.readInt8()),sint8x4:e=>R(e.readInt8(),e.readInt8(),e.readInt8(),e.readInt8()),unorm8:e=>e.readUint8()/255,unorm8x2:e=>L(e.readUint8()/255,e.readUint8()/255),unorm8x4:e=>x(e.readUint8()/255,e.readUint8()/255,e.readUint8()/255,e.readUint8()/255),snorm8:e=>(e.readUint8()-128)/127,snorm8x2:e=>L((e.readUint8()-128)/127,(e.readUint8()-128)/127),snorm8x4:e=>x((e.readUint8()-128)/127,(e.readUint8()-128)/127,(e.readUint8()-128)/127,(e.readUint8()-128)/127),uint16:e=>e.readUint16(),uint16x2:e=>J(e.readUint16(),e.readUint16()),uint16x4:e=>P(e.readUint16(),e.readUint16(),e.readUint16(),e.readUint16()),sint16:e=>e.readInt16(),sint16x2:e=>H(e.readInt16(),e.readInt16()),sint16x4:e=>R(e.readInt16(),e.readInt16(),e.readInt16(),e.readInt16()),unorm16:e=>e.readUint16()/65535,unorm16x2:e=>L(e.readUint16()/65535,e.readUint16()/65535),unorm16x4:e=>x(e.readUint16()/65535,e.readUint16()/65535,e.readUint16()/65535,e.readUint16()/65535),snorm16:e=>(e.readUint16()-32768)/32767,snorm16x2:e=>L(le.snorm16(e),le.snorm16(e)),snorm16x4:e=>x(le.snorm16(e),le.snorm16(e),le.snorm16(e),le.snorm16(e)),float16(e){return e.readFloat16()},float16x2:e=>L(e.readFloat16(),e.readFloat16()),float16x4:e=>x(e.readFloat16(),e.readFloat16(),e.readFloat16(),e.readFloat16()),float32:e=>e.readFloat32(),float32x2:e=>L(e.readFloat32(),e.readFloat32()),float32x3:e=>se(e.readFloat32(),e.readFloat32(),e.readFloat32()),float32x4:e=>x(e.readFloat32(),e.readFloat32(),e.readFloat32(),e.readFloat32()),uint32:e=>e.readUint32(),uint32x2:e=>J(e.readUint32(),e.readUint32()),uint32x3:e=>fe(e.readUint32(),e.readUint32(),e.readUint32()),uint32x4:e=>P(e.readUint32(),e.readUint32(),e.readUint32(),e.readUint32()),sint32:e=>e.readInt32(),sint32x2:e=>H(e.readInt32(),e.readInt32()),sint32x3:e=>ge(e.readInt32(),e.readInt32(),e.readInt32()),sint32x4:e=>R(e.readInt32(),e.readInt32(),e.readInt32(),e.readInt32()),"unorm10-10-10-2"(e){let t=e.readUint32(),r=(t>>22)/1023,n=(t>>12&1023)/1023,a=(t>>2&1023)/1023,o=(t&3)/3;return x(r,n,a,o)},"unorm8x4-bgra"(e){let t=e.readByte()/255,r=e.readByte()/255,n=e.readByte()/255,a=e.readByte()/255;return x(n,r,t,a)},unstruct(e,t){let r={};for(let[n,a]of Object.entries(t.propTypes))r[n]=$(e,a);return r},disarray(e,t){let r=F(t),n=[];for(let a=0;a<t.elementCount;a++)w(e,r),n.push($(e,t.elementType));return w(e,r),n},"loose-decorated"(e,t){w(e,W(t));let r=e.currentByteOffset,n=$(e,t.inner);return e.seekTo(r+c(t)),n}};function $(e,t){let r=le[t.type];if(!r)throw new Error(`Cannot read data of type '${t.type}'.`);return r(e,t)}import{BufferWriter as aa}from"typed-binary";function an(e,t){let r=c(e);if(r===0||t===void 0||t===null)return[];let n=new ArrayBuffer(r),a=new aa(n),o=[];function s(u,d,m,T){if(d!=null){if(b(u)||Y(u)){let f=et(u);for(let[g,D]of Object.entries(f)){let S=u.propTypes[g];if(!S)continue;let I=d[g];I!==void 0&&s(S,I,m+D.offset,D.padding??T)}return}if(G(u)||Qe(u)){let f=u,g=V(c(f.elementType),F(f.elementType));if(!Array.isArray(d))throw new Error("Partial value for array must be an array");let D=d;D.sort((S,I)=>S.idx-I.idx);for(let{idx:S,value:I}of D)s(f.elementType,I,m+S*g,g-c(f.elementType))}else{let f=c(u);a.seekTo(m),X(a,u,d),o.push({start:m,end:m+f,padding:T})}}}if(s(e,t,0),o.length===0)return[];let i=[],p=o[0];for(let u=1;u<o.length;u++){let d=o[u];if(!d||!p)throw new Error("Internal error: missing segment");d.start===p.end+(p.padding??0)?(p.end=d.end,p.padding=d.padding):(i.push({data:new Uint8Array(n,p.start,p.end-p.start)}),p=d)}if(!p)throw new Error("Internal error: missing segment");return i.push({data:new Uint8Array(n,p.start,p.end-p.start)}),i}function de(e){return!!e?.usableAsStorage}var $e=class e extends Error{constructor(t){super(`Resource '${t.label??"<unnamed>"}' cannot be bound as 'storage'. Use .$usage('storage') to allow it.`),Object.setPrototypeOf(this,e.prototype)}};function at(e){return!!e.usableAsUniform}var pn={uniform:"uniform",mutable:"storage, read_write",readonly:"storage, read"},Oe=class{constructor(t,r){this.usage=t;this.buffer=r;this[y]={dataType:r.dataType}}resourceType="buffer-usage";[y];get label(){return this.buffer.label}$name(t){return this.buffer.$name(t),this}"~resolve"(t){let r=t.names.makeUnique(this.label),{group:n,binding:a}=t.allocateFixedEntry(this.usage==="uniform"?{uniform:this.buffer.dataType}:{storage:this.buffer.dataType,access:this.usage},this.buffer),o=pn[this.usage];return t.addDeclaration(`@group(${n}) @binding(${a}) var<${o}> ${r}: ${t.resolve(this.buffer.dataType)};`),r}write(t){this.buffer.write(t)}toString(){return`${this.usage}:${this.label??"<unnamed>"}`}get value(){if(!oe())throw new Error("Cannot access buffer's value directly in JS.");return new Proxy({"~resolve":t=>t.resolve(this),toString:()=>`.value:${this.label??"<unnamed>"}`,[y]:{dataType:this.buffer.dataType}},M)}},Ge=class{constructor(t,r,n){this.usage=t;this.dataType=r;this._membership=n;this[y]={dataType:r}}resourceType="buffer-usage";[y];get label(){return this._membership.key}"~resolve"(t){let r=t.names.makeUnique(this.label),n=t.allocateLayoutEntry(this._membership.layout),a=pn[this.usage];return t.addDeclaration(`@group(${n}) @binding(${this._membership.idx}) var<${a}> ${r}: ${t.resolve(this.dataType)};`),r}toString(){return`${this.usage}:${this.label??"<unnamed>"}`}get value(){if(!oe())throw new Error("Cannot access buffer's value directly in JS.");return new Proxy({"~resolve":t=>t.resolve(this),toString:()=>`.value:${this.label??"<unnamed>"}`,[y]:{dataType:this.dataType}},M)}},on=new WeakMap;function zt(e){if(!de(e))throw new Error(`Cannot pass ${e} to asMutable, as it is not allowed to be used as storage. To allow it, call .$usage('storage') when creating the buffer.`);let t=on.get(e);return t||(t=new Oe("mutable",e),on.set(e,t)),t}var sn=new WeakMap;function Kt(e){if(!de(e))throw new Error(`Cannot pass ${e} to asReadonly, as it is not allowed to be used as storage. To allow it, call .$usage('storage') when creating the buffer.`);let t=sn.get(e);return t||(t=new Oe("readonly",e),sn.set(e,t)),t}var un=new WeakMap;function qt(e){if(!at(e))throw new Error(`Cannot pass ${e} to asUniform, as it is not allowed to be used as a uniform. To allow it, call .$usage('uniform') when creating the buffer.`);let t=un.get(e);return t||(t=new Oe("uniform",e),un.set(e,t)),t}var sa={uniform:qt,mutable:zt,readonly:Kt};function dn(e,t,r){return C(t)?new ot(e,t,r):new ot(e,t,r,["storage","uniform"])}function Z(e){return e.resourceType==="buffer"}function ia(e){return!!e.usableAsVertex}var ln=oa(),ot=class{constructor(t,r,n,a){this._group=t;this.dataType=r;this.initialOrBuffer=n;this._disallowedUsages=a;$r(n)?(this._ownBuffer=!1,this._buffer=n):(this._ownBuffer=!0,this.initial=n)}resourceType="buffer";flags=GPUBufferUsage.COPY_DST|GPUBufferUsage.COPY_SRC;_buffer=null;_ownBuffer;_destroyed=!1;_hostBuffer;_label;initial;usableAsUniform=!1;usableAsStorage=!1;usableAsVertex=!1;get label(){return this._label}get buffer(){let t=this._group.device;if(this._destroyed)throw new Error("This buffer has been destroyed");if(!this._buffer&&(this._buffer=t.createBuffer({size:c(this.dataType),usage:this.flags,mappedAtCreation:!!this.initial,label:this.label??"<unnamed>"}),this.initial)){let r=new Jt(this._buffer.getMappedRange());X(r,this.dataType,this.initial),this._buffer.unmap()}return this._buffer}get destroyed(){return this._destroyed}$name(t){return this._label=t,this._buffer&&(this._buffer.label=t),this}$usage(...t){for(let r of t){if(this._disallowedUsages?.includes(r))throw new Error(`Buffer of type ${this.dataType.type} cannot be used as ${r}`);this.flags|=r==="uniform"?GPUBufferUsage.UNIFORM:0,this.flags|=r==="storage"?GPUBufferUsage.STORAGE:0,this.flags|=r==="vertex"?GPUBufferUsage.VERTEX:0,this.usableAsUniform=this.usableAsUniform||r==="uniform",this.usableAsStorage=this.usableAsStorage||r==="storage",this.usableAsVertex=this.usableAsVertex||r==="vertex"}return this}$addFlags(t){if(!this._ownBuffer)throw new Error("Cannot add flags to a buffer that is not managed by TypeGPU.");return t&GPUBufferUsage.MAP_READ?(this.flags=GPUBufferUsage.COPY_DST|GPUBufferUsage.MAP_READ,this):t&GPUBufferUsage.MAP_WRITE?(this.flags=GPUBufferUsage.COPY_SRC|GPUBufferUsage.MAP_WRITE,this):(this.flags|=t,this)}compileWriter(){if(rt)nt(this.dataType);else throw new Error("This environment does not allow eval")}write(t){let r=this.buffer,n=this._group.device;if(r.mapState==="mapped"){let o=r.getMappedRange();if(rt){nt(this.dataType)(new DataView(o),0,t,ln==="little");return}X(new Jt(o),this.dataType,t);return}let a=c(this.dataType);this._hostBuffer||(this._hostBuffer=new ArrayBuffer(a)),this._group.flush(),rt?nt(this.dataType)(new DataView(this._hostBuffer),0,t,ln==="little"):X(new Jt(this._hostBuffer),this.dataType,t),n.queue.writeBuffer(r,0,this._hostBuffer,0,a)}writePartial(t){let r=this.buffer,n=this._group.device,a=an(this.dataType,t);if(r.mapState==="mapped"){let o=r.getMappedRange(),s=new Uint8Array(o);for(let i of a)s.set(i.data,i.data.byteOffset)}else for(let o of a)n.queue.writeBuffer(r,o.data.byteOffset,o.data,0,o.data.byteLength)}copyFrom(t){if(this.buffer.mapState==="mapped")throw new Error("Cannot copy to a mapped buffer.");let r=c(this.dataType);this._group.commandEncoder.copyBufferToBuffer(t.buffer,0,this.buffer,0,r)}async read(){this._group.flush();let t=this.buffer,r=this._group.device;if(t.mapState==="mapped"){let s=t.getMappedRange();return $(new Ht(s),this.dataType)}if(t.usage&GPUBufferUsage.MAP_READ){await t.mapAsync(GPUMapMode.READ);let s=t.getMappedRange(),i=$(new Ht(s),this.dataType);return t.unmap(),i}let n=r.createBuffer({size:c(this.dataType),usage:GPUBufferUsage.COPY_DST|GPUBufferUsage.MAP_READ}),a=r.createCommandEncoder();a.copyBufferToBuffer(t,0,n,0,c(this.dataType)),r.queue.submit([a.finish()]),await r.queue.onSubmittedWorkDone(),await n.mapAsync(GPUMapMode.READ,0,c(this.dataType));let o=$(new Ht(n.getMappedRange()),this.dataType);return n.unmap(),n.destroy(),o}as(t){return sa[t]?.(this)}destroy(){this._destroyed||(this._destroyed=!0,this._ownBuffer&&this._buffer?.destroy())}toString(){return`buffer:${this._label??"<unnamed>"}`}};function mn(e){return new Yt(e)}function gn(e){return new Qt(e)}function We(e){return e?.resourceType==="sampler"}function Me(e){return e?.resourceType==="sampler-comparison"}var st=class{constructor(t){this._membership=t}resourceType="sampler";get label(){return this._membership.key}"~resolve"(t){let r=t.names.makeUnique(this.label),n=t.allocateLayoutEntry(this._membership.layout);return t.addDeclaration(`@group(${n}) @binding(${this._membership.idx}) var ${r}: sampler;`),r}toString(){return`${this.resourceType}:${this.label??"<unnamed>"}`}},it=class{constructor(t){this._membership=t}resourceType="sampler-comparison";get label(){return this._membership.key}"~resolve"(t){let r=t.names.makeUnique(this.label),n=t.allocateLayoutEntry(this._membership.layout);return t.addDeclaration(`@group(${n}) @binding(${this._membership.idx}) var ${r}: sampler_comparison;`),r}toString(){return`${this.resourceType}:${this.label??"<unnamed>"}`}},Yt=class{constructor(t){this._props=t;this._filtering=t.minFilter==="linear"||t.magFilter==="linear"||t.mipmapFilter==="linear"}resourceType="sampler";_label;_filtering;_sampler=null;unwrap(t){return this._sampler||(this._sampler=t.device.createSampler({...this._props,label:this._label??"<unnamed>"})),this._sampler}get label(){return this._label}$name(t){return this._label=t,this}"~resolve"(t){let r=t.names.makeUnique(this._label),{group:n,binding:a}=t.allocateFixedEntry({sampler:this._filtering?"filtering":"non-filtering"},this);return t.addDeclaration(`@group(${n}) @binding(${a}) var ${r}: sampler;`),r}toString(){return`${this.resourceType}:${this.label??"<unnamed>"}`}},Qt=class{constructor(t){this._props=t}resourceType="sampler-comparison";_label;_sampler=null;unwrap(t){return this._sampler||(this._sampler=t.device.createSampler({...this._props,label:this._label??"<unnamed>"})),this._sampler}get label(){return this._label}$name(t){return this._label=t,this}"~resolve"(t){let r=t.names.makeUnique(this.label),{group:n,binding:a}=t.allocateFixedEntry({sampler:"comparison"},this);return t.addDeclaration(`@group(${n}) @binding(${a}) var ${r}: sampler_comparison;`),r}toString(){return`${this.resourceType}:${this.label??"<unnamed>"}`}};var ut=class{constructor(t){this._membership=t}resourceType="external-texture";get label(){return this._membership.key}"~resolve"(t){let r=t.names.makeUnique(this.label),n=t.allocateLayoutEntry(this._membership.layout);return t.addDeclaration(`@group(${n}) @binding(${this._membership.idx}) var ${r}: texture_external;`),r}toString(){return`${this.resourceType}:${this.label??"<unnamed>"}`}};var fn={r8unorm:l,r8snorm:l,r8uint:v,r8sint:B,r16uint:v,r16sint:B,r16float:l,rg8unorm:l,rg8snorm:l,rg8uint:v,rg8sint:B,r32uint:v,r32sint:B,r32float:l,rg16uint:v,rg16sint:B,rg16float:l,rgba8unorm:l,"rgba8unorm-srgb":l,rgba8snorm:l,rgba8uint:v,rgba8sint:B,bgra8unorm:l,"bgra8unorm-srgb":l,rgb9e5ufloat:l,rgb10a2uint:v,rgb10a2unorm:l,rg11b10ufloat:l,rg32uint:v,rg32sint:B,rg32float:l,rgba16uint:v,rgba16sint:B,rgba16float:l,rgba32uint:v,rgba32sint:B,rgba32float:l,stencil8:l,depth16unorm:l,depth24plus:l,"depth24plus-stencil8":l,depth32float:l,"depth32float-stencil8":l,"bc1-rgba-unorm":l,"bc1-rgba-unorm-srgb":l,"bc2-rgba-unorm":l,"bc2-rgba-unorm-srgb":l,"bc3-rgba-unorm":l,"bc3-rgba-unorm-srgb":l,"bc4-r-unorm":l,"bc4-r-snorm":l,"bc5-rg-unorm":l,"bc5-rg-snorm":l,"bc6h-rgb-ufloat":l,"bc6h-rgb-float":l,"bc7-rgba-unorm":l,"bc7-rgba-unorm-srgb":l,"etc2-rgb8unorm":l,"etc2-rgb8unorm-srgb":l,"etc2-rgb8a1unorm":l,"etc2-rgb8a1unorm-srgb":l,"etc2-rgba8unorm":l,"etc2-rgba8unorm-srgb":l,"eac-r11unorm":l,"eac-r11snorm":l,"eac-rg11unorm":l,"eac-rg11snorm":l,"astc-4x4-unorm":l,"astc-4x4-unorm-srgb":l,"astc-5x4-unorm":l,"astc-5x4-unorm-srgb":l,"astc-5x5-unorm":l,"astc-5x5-unorm-srgb":l,"astc-6x5-unorm":l,"astc-6x5-unorm-srgb":l,"astc-6x6-unorm":l,"astc-6x6-unorm-srgb":l,"astc-8x5-unorm":l,"astc-8x5-unorm-srgb":l,"astc-8x6-unorm":l,"astc-8x6-unorm-srgb":l,"astc-8x8-unorm":l,"astc-8x8-unorm-srgb":l,"astc-10x5-unorm":l,"astc-10x5-unorm-srgb":l,"astc-10x6-unorm":l,"astc-10x6-unorm-srgb":l,"astc-10x8-unorm":l,"astc-10x8-unorm-srgb":l,"astc-10x10-unorm":l,"astc-10x10-unorm-srgb":l,"astc-12x10-unorm":l,"astc-12x10-unorm-srgb":l,"astc-12x12-unorm":l,"astc-12x12-unorm-srgb":l},Ne={rgba8unorm:x,rgba8snorm:x,rgba8uint:P,rgba8sint:R,rgba16uint:P,rgba16sint:R,rgba16float:x,r32uint:P,r32sint:R,r32float:x,rg32uint:P,rg32sint:R,rg32float:x,rgba32uint:P,rgba32sint:R,rgba32float:x,bgra8unorm:x},Tn={f32:"float",u32:"uint",i32:"sint"},yn={float:l,"unfilterable-float":l,uint:v,sint:B,depth:l};function cn(e,t){return new Xt(e,t)}function q(e){return e?.resourceType==="texture"}function je(e){return e?.resourceType==="texture-storage-view"}function ze(e){return e?.resourceType==="texture-sampled-view"}var xn={mutable:"read_write",readonly:"read",writeonly:"write"},Xt=class{constructor(t,r){this.props=t;this._branch=r}resourceType="texture";usableAsSampled=!1;usableAsStorage=!1;usableAsRender=!1;_destroyed=!1;_label;_flags=GPUTextureUsage.COPY_DST|GPUTextureUsage.COPY_SRC;_texture=null;get label(){return this._label}$name(t){return this._label=t,this}unwrap(){if(this._destroyed)throw new Error("This texture has been destroyed");return this._texture||(this._texture=this._branch.device.createTexture({label:this._label??"<unnamed>",format:this.props.format,size:this.props.size,usage:this._flags,dimension:this.props.dimension??"2d",viewFormats:this.props.viewFormats??[],mipLevelCount:this.props.mipLevelCount??1,sampleCount:this.props.sampleCount??1})),this._texture}$usage(...t){let r=t.includes("storage"),n=t.includes("sampled"),a=t.includes("render");return this._flags|=n?GPUTextureUsage.TEXTURE_BINDING:0,this._flags|=r?GPUTextureUsage.STORAGE_BINDING:0,this._flags|=a?GPUTextureUsage.RENDER_ATTACHMENT:0,this.usableAsStorage||=r,this.usableAsSampled||=n,this.usableAsRender||=a,this}createView(t,r){if(t==="sampled")return this._asSampled(r);let n=r;switch(t){case"mutable":return this._asMutable(n);case"readonly":return this._asReadonly(n);case"writeonly":return this._asWriteonly(n)}}_asStorage(t,r){if(!this.usableAsStorage)throw new Error("Unusable as storage");let n=t?.format??this.props.format,a=Ne[n];return Ue(!!a,`Unsupported storage texture format: ${n}`),new Zt(t??{},r,this)}_asReadonly(t){return this._asStorage(t,"readonly")}_asWriteonly(t){return this._asStorage(t,"writeonly")}_asMutable(t){return this._asStorage(t,"mutable")}_asSampled(t){if(!this.usableAsSampled)throw new Error("Unusable as sampled");let r=t?.format??this.props.format;if(!Ne[r])throw new Error(`Unsupported storage texture format: ${r}`);return new er(t,this)}destroy(){this._destroyed||(this._destroyed=!0,this._texture?.destroy())}},dt={"1d":"1d","2d":"2d","2d-array":"2d_array",cube:"cube","cube-array":"cube_array","3d":"3d"},Zt=class{constructor(t,r,n){this.access=r;this._texture=n;this.dimension=t?.dimension??n.props.dimension??"2d",this._format=t?.format??n.props.format,this.texelDataType=Ne[this._format]}resourceType="texture-storage-view";texelDataType;dimension;_view;_format;get label(){return this._texture.label}$name(t){return this._texture.$name(t),this}unwrap(){return this._view||(this._view=this._texture.unwrap().createView({label:`${this.label??"<unnamed>"} - View`,format:this._format,dimension:this.dimension})),this._view}"~resolve"(t){let r=t.names.makeUnique(this.label),{group:n,binding:a}=t.allocateFixedEntry({storageTexture:this._format,access:this.access,viewDimension:this.dimension},this),o=`texture_storage_${dt[this.dimension]}`;return t.addDeclaration(`@group(${n}) @binding(${a}) var ${r}: ${o}<${this._format}, ${xn[this.access]}>;`),r}toString(){return`${this.resourceType}:${this.label??"<unnamed>"}`}},pt=class{constructor(t,r,n,a){this._format=t;this.dimension=r;this.access=n;this._membership=a;this.texelDataType=Ne[this._format]}resourceType="texture-storage-view";texelDataType;get label(){return this._membership.key}"~resolve"(t){let r=t.names.makeUnique(this.label),n=t.allocateLayoutEntry(this._membership.layout),a=`texture_storage_${dt[this.dimension]}`;return t.addDeclaration(`@group(${n}) @binding(${this._membership.idx}) var ${r}: ${a}<${this._format}, ${xn[this.access]}>;`),r}toString(){return`${this.resourceType}:${this.label??"<unnamed>"}`}},er=class{constructor(t,r){this._props=t;this._texture=r;this.dimension=t?.dimension??r.props.dimension??"2d",this._format=t?.format??r.props.format,this.channelDataType=fn[this._format]}resourceType="texture-sampled-view";channelDataType;dimension;_format;_view;get label(){return this._texture.label}$name(t){return this._texture.$name(t),this}unwrap(){return this._view||(this._view=this._texture.unwrap().createView({label:`${this.label??"<unnamed>"} - View`,...this._props})),this._view}"~resolve"(t){let r=t.names.makeUnique(this.label),n=(this._texture.props.sampleCount??1)>1,{group:a,binding:o}=t.allocateFixedEntry({texture:Tn[this.channelDataType.type],viewDimension:this.dimension,multisampled:n},this),s=n?"texture_multisampled_2d":`texture_${dt[this.dimension]}`;return t.addDeclaration(`@group(${a}) @binding(${o}) var ${r}: ${s}<${t.resolve(this.channelDataType)}>;`),r}toString(){return`${this.resourceType}:${this.label??"<unnamed>"}`}},lt=class{constructor(t,r,n,a){this.dimension=r;this._multisampled=n;this._membership=a;this.channelDataType=yn[t]}resourceType="texture-sampled-view";channelDataType;get label(){return this._membership.key}"~resolve"(t){let r=t.names.makeUnique(this.label),n=t.allocateLayoutEntry(this._membership.layout),a=this._multisampled?"texture_multisampled_2d":`texture_${dt[this.dimension]}`;return t.addDeclaration(`@group(${n}) @binding(${this._membership.idx}) var ${r}: ${a}<${t.resolve(this.channelDataType)}>;`),r}toString(){return`${this.resourceType}:${this.label??"<unnamed>"}`}};function tr(e){return!!e?.usableAsSampled}function ua(e){return!!e?.usableAsRender}var mt=class e extends Error{constructor(t){super(`Resource '${t.label??"<unnamed>"}' cannot be bound as 'sampled'. Use .$usage('sampled') to allow it.`),Object.setPrototypeOf(this,e.prototype)}};function gt(e){return new nr(e)}function ft(e){return!!e&&e.resourceType==="bind-group-layout"}function ar(e){return!!e&&e.resourceType==="bind-group"}var rr=class e extends Error{constructor(t,r){super(`Bind group '${t??"<unnamed>"}' is missing a required binding '${r}'`),Object.setPrototypeOf(this,e.prototype)}},bn=["compute"],ve=["compute","vertex","fragment"],nr=class{constructor(t){this.entries=t;let r=0;for(let[n,a]of Object.entries(t)){if(a===null){r++;continue}let o={idx:r,key:n,layout:this};if("uniform"in a&&(this.bound[n]=new Ge("uniform",a.uniform,o)),"storage"in a){let s="type"in a.storage?a.storage:a.storage(0);this.bound[n]=new Ge(a.access??"readonly",s,o)}"texture"in a&&(this.bound[n]=new lt(a.texture,a.viewDimension??"2d",a.multisampled??!1,o)),"storageTexture"in a&&(this.bound[n]=new pt(a.storageTexture,a.viewDimension??"2d",a.access??"writeonly",o)),"externalTexture"in a&&(this.bound[n]=new ut(o)),"sampler"in a&&(a.sampler==="comparison"?this.bound[n]=new it(o):this.bound[n]=new st(o)),"texture"in a||"storageTexture"in a||"externalTexture"in a||"sampler"in a?this.value[n]=this.bound[n]:Object.defineProperty(this.value,n,{get:()=>this.bound[n].value}),r++}}_label;_index;resourceType="bind-group-layout";bound={};value={};$=this.value;toString(){return`bindGroupLayout:${this._label??"<unnamed>"}`}get label(){return this._label}get index(){return this._index}$name(t){return this._label=t,this}$idx(t){return this._index=t,this}unwrap(t){return t.device.createBindGroupLayout({label:this.label??"<unnamed>",entries:Object.values(this.entries).map((n,a)=>{if(n===null)return null;let o=n.visibility,s={binding:a,visibility:0};if("uniform"in n)o=o??ve,s.buffer={type:"uniform"};else if("storage"in n)o=o??(n.access==="mutable"?bn:ve),s.buffer={type:n.access==="mutable"?"storage":"read-only-storage"};else if("sampler"in n)o=o??ve,s.sampler={type:n.sampler};else if("texture"in n)o=o??ve,s.texture={sampleType:n.texture,viewDimension:n.viewDimension??"2d",multisampled:n.multisampled??!1};else if("storageTexture"in n){let i=n.access??"writeonly";o=o??(i==="readonly"?ve:bn),s.storageTexture={format:n.storageTexture,access:{mutable:"read-write",readonly:"read-only",writeonly:"write-only"}[i],viewDimension:n.viewDimension??"2d"}}else"externalTexture"in n&&(o=o??ve,s.externalTexture={});return o?.includes("compute")&&(s.visibility|=GPUShaderStage.COMPUTE),o?.includes("vertex")&&(s.visibility|=GPUShaderStage.VERTEX),o?.includes("fragment")&&(s.visibility|=GPUShaderStage.FRAGMENT),s}).filter(n=>n!==null)})}},De=class{constructor(t,r){this.layout=t;this.entries=r;for(let n of Object.keys(t.entries))if(t.entries[n]!==null&&!(n in r))throw new rr(t.label,n)}resourceType="bind-group";unwrap(t){return t.device.createBindGroup({label:this.layout.label??"<unnamed>",layout:t.unwrap(this.layout),entries:Object.entries(this.layout.entries).map(([n,a],o)=>{if(a===null)return null;let s=this.entries[n];if(s===void 0)throw new Error(`'${n}' is a resource required to populate bind group layout '${this.layout.label??"<unnamed>"}'.`);if("uniform"in a){let i;if(Z(s)){if(!at(s))throw new Dt(s);i={buffer:t.unwrap(s)}}else i={buffer:s};return{binding:o,resource:i}}if("storage"in a){let i;if(Z(s)){if(!de(s))throw new $e(s);i={buffer:t.unwrap(s)}}else i={buffer:s};return{binding:o,resource:i}}if("texture"in a){let i;if(q(s)){if(!tr(s))throw new mt(s);i=t.unwrap(s.createView("sampled"))}else ze(s)?i=t.unwrap(s):i=s;return{binding:o,resource:i}}if("storageTexture"in a){let i;if(q(s)){if(!de(s))throw new $e(s);a.access==="readonly"?i=t.unwrap(s.createView("readonly")):a.access==="mutable"?i=t.unwrap(s.createView("mutable")):i=t.unwrap(s.createView("writeonly"))}else je(s)?i=t.unwrap(s):i=s;return{binding:o,resource:i}}if("sampler"in a)return We(s)||Me(s)?{binding:o,resource:t.unwrap(s)}:{binding:o,resource:s};if("externalTexture"in a)return{binding:o,resource:s};throw new Error(`Malformed bind group entry: ${s} (${JSON.stringify(s)})`)}).filter(n=>n!==null)})}};var hn="#CATCHALL#",sr=class{_stack=[];_itemDepth=0;get itemDepth(){return this._itemDepth}get topItem(){let t=this._stack[this._stack.length-1];if(!t||t.type!=="item")throw new Error("Internal error, expected item layer to be on top.");return t}pushItem(){this._itemDepth++,this._stack.push({type:"item",usedSlots:new Set})}popItem(){this.pop("item")}pushSlotBindings(t){this._stack.push({type:"slotBinding",bindingMap:new WeakMap(t)})}popSlotBindings(){this.pop("slotBinding")}pushFunctionScope(t,r,n){this._stack.push({type:"functionScope",args:t,returnType:r,externalMap:n})}popFunctionScope(){this.pop("functionScope")}pushBlockScope(){this._stack.push({type:"blockScope",declarations:new Map})}popBlockScope(){this.pop("blockScope")}pop(t){let r=this._stack[this._stack.length-1];if(!r||t&&r.type!==t)throw new Error(`Internal error, expected a ${t} layer to be on top.`);this._stack.pop(),t==="item"&&this._itemDepth--}readSlot(t){for(let r=this._stack.length-1;r>=0;--r){let n=this._stack[r];if(n?.type==="item")n.usedSlots.add(t);else if(n?.type==="slotBinding"){let a=n.bindingMap.get(t);if(a!==void 0)return a}else if(!(n?.type==="functionScope"||n?.type==="blockScope"))throw new Error("Unknown layer type.")}return t.defaultValue}getSnippetById(t){for(let r=this._stack.length-1;r>=0;--r){let n=this._stack[r];if(n?.type==="functionScope"){let a=n.args.find(s=>s.value===t);if(a!==void 0)return a;let o=n.externalMap[t];return o!==void 0?{value:o,dataType:z(o)?he(o):A}:void 0}if(n?.type==="blockScope"){let a=n.declarations.get(t);if(a!==void 0)return{value:t,dataType:a}}}}defineBlockVariable(t,r){for(let n=this._stack.length-1;n>=0;--n){let a=this._stack[n];if(a?.type==="blockScope")return a.declarations.set(t,r),{value:t,dataType:r}}throw new Error("No block scope found to define a variable in.")}},Tt=[""," "," "," "," "," "," "," "," "],or=Tt.length-1,ir=class{identLevel=0;get pre(){return Tt[this.identLevel]??Tt[or].repeat(this.identLevel/or)+Tt[this.identLevel%or]}indent(){let t=this.pre;return this.identLevel++,t}dedent(){return this.identLevel--,this.pre}},ur=class{_memoizedResolves=new WeakMap;_memoizedDerived=new WeakMap;_indentController=new ir;_jitTranspiler;_itemStateStack=new sr;_declarations=[];[y]={itemStateStack:this._itemStateStack};bindGroupLayoutsToPlaceholderMap=new Map;_nextFreeLayoutPlaceholderIdx=0;fixedBindings=[];callStack=[];names;constructor(t){this.names=t.names,this._jitTranspiler=t.jitTranspiler}get pre(){return this._indentController.pre}indent(){return this._indentController.indent()}dedent(){return this._indentController.dedent()}getById(t){let r=this._itemStateStack.getSnippetById(t);return r===void 0?null:r}defineVariable(t,r){return this._itemStateStack.defineBlockVariable(t,r)}pushBlockScope(){this._itemStateStack.pushBlockScope()}popBlockScope(){this._itemStateStack.popBlockScope()}transpileFn(t){if(!this._jitTranspiler)throw new Error("Tried to execute a tgpu.fn function without providing a JIT transpiler, or transpiling at build time.");return this._jitTranspiler.transpileFn(t)}fnToWgsl(t){this._itemStateStack.pushFunctionScope(t.args,t.returnType,t.externalMap);try{return{head:pr(this,t.args,t.returnType),body:rn(this,t.body)}}finally{this._itemStateStack.popFunctionScope()}}addDeclaration(t){this._declarations.push(t)}allocateLayoutEntry(t){let r=this.bindGroupLayoutsToPlaceholderMap,n=r.get(t);return n||(n=`#BIND_GROUP_LAYOUT_${this._nextFreeLayoutPlaceholderIdx++}#`,r.set(t,n)),n}allocateFixedEntry(t,r){let n=this.fixedBindings.length;return this.fixedBindings.push({layoutEntry:t,resource:r}),{group:hn,binding:n}}readSlot(t){let r=this._itemStateStack.readSlot(t);if(r===void 0)throw new vt(t);return r}withSlots(t,r){this._itemStateStack.pushSlotBindings(t);try{return r()}finally{this._itemStateStack.popSlotBindings()}}unwrap(t){if(Ve(t))return this.withSlots(t["~providing"].pairs,()=>this.unwrap(t["~providing"].inner));let r=t;for(;;)if(E(r))r=this.readSlot(r);else if(k(r))r=this._getOrCompute(r);else break;return r}_getOrCompute(t){let r=this._memoizedDerived.get(t)??[];this._itemStateStack.pushItem();try{for(let o of r)if([...o.slotToValueMap.entries()].every(([i,p])=>i.areEqual(this._itemStateStack.readSlot(i),p)))return o.result;At(Be.CPU);let n;try{n=t["~compute"]()}finally{Ut(Be.CPU)}let a=new Map;for(let o of this._itemStateStack.topItem.usedSlots)a.set(o,this._itemStateStack.readSlot(o));return r.push({slotToValueMap:a,result:n}),this._memoizedDerived.set(t,r),n}catch(n){throw n instanceof me?n.appendToTrace(t):new me(n,[t])}finally{this._itemStateStack.popItem()}}_getOrInstantiate(t){let r=this._memoizedResolves.get(t)??[];this._itemStateStack.pushItem();try{for(let o of r)if([...o.slotToValueMap.entries()].every(([i,p])=>i.areEqual(this._itemStateStack.readSlot(i),p)))return o.result;let n;_(t)?n=Gt(this,t):k(t)||E(t)?n=this.resolve(this.unwrap(t)):Vt(t)?n=t["~resolve"](this):n=this.resolveValue(t);let a=new Map;for(let o of this._itemStateStack.topItem.usedSlots)a.set(o,this._itemStateStack.readSlot(o));return r.push({slotToValueMap:a,result:n}),this._memoizedResolves.set(t,r),n}catch(n){throw n instanceof me?n.appendToTrace(t):new me(n,[t])}finally{this._itemStateStack.popItem()}}resolve(t){if(Ve(t))return this.withSlots(t["~providing"].pairs,()=>this.resolve(t["~providing"].inner));if(t&&typeof t=="object"||typeof t=="function"){if(this._itemStateStack.itemDepth===0)try{At(Be.GPU);let r=Dr(this,()=>this._getOrInstantiate(t));return`${[...this._declarations].join(`
24
+ ${g}`:`${e.pre}if (${u})
25
+ ${d}`}if(t[0]===v.let||t[0]===v.const){let[r,n,a]=t,o=a!==void 0?V(e,a):void 0;if(!o)throw new Error(`Cannot create variable '${n}' without an initial value.`);if(ve(o.dataType))throw new Error(`Cannot create variable '${n}' with loose data type.`);Ra(e,n,rr(o.dataType));let s=A(e,Ar(e,n));if(typeof a=="object"&&a[0]===v.objectExpr&&I(e.callStack[e.callStack.length-1])){let i=e.callStack[e.callStack.length-1],l=a[1],u={};for(let[c,y]of Object.entries(l)){if(!y)throw new Error(`Missing property ${c} in object literal`);u[c]=V(e,y)}let d=nr(e,i,u),g=e.resolve(i);return`${e.pre}var ${s} = ${g}(${d.map(c=>A(e,c)).join(", ")});`}return`${e.pre}var ${s} = ${A(e,o)};`}if(t[0]===v.block)return En(e,t);if(t[0]===v.for){let[r,n,a,o,s]=t,i=n?he(e,n):void 0,l=i?i.slice(0,-1):"",u=a?V(e,a):void 0,d=u;if(u){let h=W(e,[u],[L]);h?.[0]&&([d]=h)}let g=d?A(e,d):"",c=o?he(e,o):void 0,y=c?c.slice(0,-1):"";e.indent();let x=he(e,Bt(s));return e.dedent(),`${e.pre}for (${l}; ${g}; ${y})
26
+ ${x}`}if(t[0]===v.while){let[r,n,a]=t,o=V(e,n),s=o;if(o){let u=W(e,[o],[L]);u?.[0]&&([s]=u)}let i=A(e,s);e.indent();let l=he(e,Bt(a));return e.dedent(),`${e.pre}while (${i})
27
+ ${l}`}return t[0]===v.continue?`${e.pre}continue;`:t[0]===v.break?`${e.pre}break;`:`${e.pre}${A(e,V(e,t))};`}function Ln(e,t){return En(e,t)}var _n="#CATCHALL#",Ur=class{_stack=[];_itemDepth=0;get itemDepth(){return this._itemDepth}get topItem(){let t=this._stack[this._stack.length-1];if(!t||t.type!=="item")throw new Error("Internal error, expected item layer to be on top.");return t}pushItem(){this._itemDepth++,this._stack.push({type:"item",usedSlots:new Set})}popItem(){this.pop("item")}pushSlotBindings(t){this._stack.push({type:"slotBinding",bindingMap:new WeakMap(t)})}popSlotBindings(){this.pop("slotBinding")}pushFunctionScope(t,r,n){this._stack.push({type:"functionScope",args:t,returnType:r,externalMap:n})}popFunctionScope(){this.pop("functionScope")}pushBlockScope(){this._stack.push({type:"blockScope",declarations:new Map})}popBlockScope(){this.pop("blockScope")}pop(t){let r=this._stack[this._stack.length-1];if(!r||t&&r.type!==t)throw new Error(`Internal error, expected a ${t} layer to be on top.`);this._stack.pop(),t==="item"&&this._itemDepth--}readSlot(t){for(let r=this._stack.length-1;r>=0;--r){let n=this._stack[r];if(n?.type==="item")n.usedSlots.add(t);else if(n?.type==="slotBinding"){let a=n.bindingMap.get(t);if(a!==void 0)return a}else if(!(n?.type==="functionScope"||n?.type==="blockScope"))throw new Error("Unknown layer type.")}return t.defaultValue}getSnippetById(t){for(let r=this._stack.length-1;r>=0;--r){let n=this._stack[r];if(n?.type==="functionScope"){let a=n.args.find(s=>s.value===t);if(a!==void 0)return a;let o=n.externalMap[t];return o!=null?ar(o):void 0}if(n?.type==="blockScope"){let a=n.declarations.get(t);if(a!==void 0)return{value:t,dataType:a}}}}defineBlockVariable(t,r){for(let n=this._stack.length-1;n>=0;--n){let a=this._stack[n];if(a?.type==="blockScope")return a.declarations.set(t,r),{value:t,dataType:r}}throw new Error("No block scope found to define a variable in.")}},Rt=[""," "," "," "," "," "," "," "," "],Ir=Rt.length-1,Br=class{identLevel=0;get pre(){return Rt[this.identLevel]??Rt[Ir].repeat(this.identLevel/Ir)+Rt[this.identLevel%Ir]}indent(){let t=this.pre;return this.identLevel++,t}dedent(){return this.identLevel--,this.pre}},Rr=class{_memoizedResolves=new WeakMap;_memoizedDerived=new WeakMap;_indentController=new Br;_jitTranspiler;_itemStateStack=new Ur;_declarations=[];[m]={itemStateStack:this._itemStateStack};bindGroupLayoutsToPlaceholderMap=new Map;_nextFreeLayoutPlaceholderIdx=0;fixedBindings=[];callStack=[];names;constructor(t){this.names=t.names,this._jitTranspiler=t.jitTranspiler}get pre(){return this._indentController.pre}indent(){return this._indentController.indent()}dedent(){return this._indentController.dedent()}getById(t){let r=this._itemStateStack.getSnippetById(t);return r===void 0?null:r}defineVariable(t,r){return this._itemStateStack.defineBlockVariable(t,r)}pushBlockScope(){this._itemStateStack.pushBlockScope()}popBlockScope(){this._itemStateStack.popBlockScope()}transpileFn(t){if(!this._jitTranspiler)throw new Error("Tried to execute a tgpu.fn function without providing a JIT transpiler, or transpiling at build time.");return this._jitTranspiler.transpileFn(t)}fnToWgsl(t){this._itemStateStack.pushFunctionScope(t.args,t.returnType,t.externalMap);try{return{head:Cr(this,t.args,t.returnType),body:Ln(this,t.body)}}finally{this._itemStateStack.popFunctionScope()}}addDeclaration(t){this._declarations.push(t)}allocateLayoutEntry(t){let r=this.bindGroupLayoutsToPlaceholderMap,n=r.get(t);return n||(n=`#BIND_GROUP_LAYOUT_${this._nextFreeLayoutPlaceholderIdx++}#`,r.set(t,n)),n}allocateFixedEntry(t,r){let n=this.fixedBindings.length;return this.fixedBindings.push({layoutEntry:t,resource:r}),{group:_n,binding:n}}readSlot(t){let r=this._itemStateStack.readSlot(t);if(r===void 0)throw new _t(t);return r}withSlots(t,r){this._itemStateStack.pushSlotBindings(t);try{return r()}finally{this._itemStateStack.popSlotBindings()}}unwrap(t){if(Ne(t))return this.withSlots(t["~providing"].pairs,()=>this.unwrap(t["~providing"].inner));let r=t;for(;;)if(H(r))r=this.readSlot(r);else if(q(r))r=this._getOrCompute(r);else break;return r}_getOrCompute(t){let r=this._memoizedDerived.get(t)??[];this._itemStateStack.pushItem();try{for(let o of r)if([...o.slotToValueMap.entries()].every(([i,l])=>i.areEqual(this._itemStateStack.readSlot(i),l)))return o.result;Wt(Le.CPU);let n;try{n=t["~compute"]()}finally{Mt(Le.CPU)}let a=new Map;for(let o of this._itemStateStack.topItem.usedSlots)a.set(o,this._itemStateStack.readSlot(o));return r.push({slotToValueMap:a,result:n}),this._memoizedDerived.set(t,r),n}catch(n){throw n instanceof we?n.appendToTrace(t):new we(n,[t])}finally{this._itemStateStack.popItem()}}_getOrInstantiate(t){let r=this._memoizedResolves.get(t)??[];this._itemStateStack.pushItem();try{for(let o of r)if([...o.slotToValueMap.entries()].every(([i,l])=>i.areEqual(this._itemStateStack.readSlot(i),l)))return o.result;let n;$(t)?n=ur(this,t):q(t)||H(t)?n=this.resolve(this.unwrap(t)):je(t)?n=t["~resolve"](this):n=this.resolveValue(t);let a=new Map;for(let o of this._itemStateStack.topItem.usedSlots)a.set(o,this._itemStateStack.readSlot(o));return r.push({slotToValueMap:a,result:n}),this._memoizedResolves.set(t,r),n}catch(n){throw n instanceof we?n.appendToTrace(t):new we(n,[t])}finally{this._itemStateStack.popItem()}}resolve(t){if(Ne(t))return this.withSlots(t["~providing"].pairs,()=>this.resolve(t["~providing"].inner));if(t&&typeof t=="object"||typeof t=="function"){if(this._itemStateStack.itemDepth===0)try{Wt(Le.GPU);let r=Kr(this,()=>this._getOrInstantiate(t));return`${[...this._declarations].join(`
24
28
 
25
- `)}${r}`}finally{Ut(Be.GPU)}return this._getOrInstantiate(t)}return String(t)}resolveValue(t,r){if(z(t))return this.resolve(t);if(r&&G(r))return`array(${t.map(n=>this.resolveValue(n,r.elementType))})`;if(Array.isArray(t))return`array(${t.map(n=>this.resolveValue(n))})`;if(r&&b(r))return`${this.resolve(r)}(${Object.entries(r.propTypes).map(([n,a])=>this.resolveValue(t[n],a))})`;throw new Error(`Value ${t} (as json: ${JSON.stringify(t)}) of schema ${r} is not resolvable to WGSL`)}};function Fe(e,t){let r=new ur(t),n=r.resolve(e),a=r.bindGroupLayoutsToPlaceholderMap,o=[],s=new Set([...a.keys()].map(m=>m.index).filter(m=>m!==void 0)),i=Fr(s),p=r.fixedBindings.map((m,T)=>[String(T),m.layoutEntry]),u=()=>{let m=i.next().value,T=gt(Object.fromEntries(p));return o[m]=T,n=n.replaceAll(hn,String(m)),[m,new De(T,Object.fromEntries(r.fixedBindings.map((f,g)=>[String(g),f.resource])))]},d=p.length>0?u():null;for(let[m,T]of a.entries()){let f=m.index??i.next().value;o[f]=m,n=n.replaceAll(T,String(f))}return{code:n,bindGroupLayouts:o,catchall:d}}function pr(e,t,r){let n=t.map(a=>`${a.value}: ${e.resolve(a.dataType)}`).join(", ");return r!==void 0?`(${n}) -> ${xe(r)} ${e.resolve(r)}`:`(${n})`}function ee(e,t){let r=[];return typeof t=="string"&&(e.isEntry?(Array.isArray(e.argTypes)&&b(e.argTypes[0])&&r.push({In:e.argTypes[0]}),b(e.returnType)&&r.push({Out:e.returnType})):Array.isArray(e.argTypes)&&(zr(t,Array.isArray(e.argTypes)?e.argTypes:Object.values(e.argTypes),n=>r.push(n)),we(t,e.returnType,n=>r.push(n)))),{label:void 0,applyExternals(n){r.push(n)},resolve(n,a=""){let o={};for(let i of r)K(o,i);let s=n.names.makeUnique(this.label);if(typeof t=="string"){let i="";if(!e.isEntry)i=Array.isArray(e.argTypes)?"":pr(n,Object.entries(e.argTypes).map(([u,d])=>({value:u,dataType:d})),e.returnType);else{let u=Array.isArray(e.argTypes)&&b(e.argTypes[0])?"(in: In)":"()",d=C(e.returnType)?xe(e.returnType):"",m=e.returnType!==void 0?b(e.returnType)?"-> Out":`-> ${d!==""?d:"@location(0)"} ${n.resolve(e.returnType)}`:"";i=`${u} ${m} `}let p=ue(n,o,`${i}${t.trim()}`);n.addDeclaration(`${a}fn ${s}${p}`)}else{let i=Hr(t);if(i?.externals){let f=Object.fromEntries(Object.entries(i.externals).filter(([g])=>!(g in o)));K(o,f)}let p=i?.ast??n.transpileFn(String(t));p.argNames.type==="destructured-object"&&K(o,Object.fromEntries(p.argNames.props.map(({prop:f,alias:g})=>[g,f]))),!Array.isArray(e.argTypes)&&p.argNames.type==="identifiers"&&p.argNames.names[0]!==void 0&&K(o,{[p.argNames.names[0]]:Object.fromEntries(Object.keys(e.argTypes).map(f=>[f,f]))});let u=p.externalNames.filter(f=>!(f in o));if(u.length>0)throw new Ft(this.label,u);let d=Array.isArray(e.argTypes)?p.argNames.type==="identifiers"?e.argTypes.map((f,g)=>({value:(p.argNames.type==="identifiers"?p.argNames.names[g]:void 0)??`arg_${g}`,dataType:f})):[]:Object.entries(e.argTypes).map(([f,g])=>({value:f,dataType:g})),{head:m,body:T}=n.fnToWgsl({args:d,returnType:e.returnType,body:p.body,externalMap:o});n.addDeclaration(`${a}fn ${s}${n.resolve(m)}${n.resolve(T)}`)}return s}}}function wn(e){let t=0;return Object.fromEntries(Object.entries(e).map(([r,n])=>{if(Xe(n))return[r,n];let a=Q(n);return a!==void 0?(t=a+1,[r,n]):[r,Vr(n,{type:"@location",value:t++})]}))}function yt(e){return _(e)?Q(e)!==void 0?e:Er(0,e):Ct(wn(e))}function Ae(e){return Ct(wn(e))}function te(e,...t){return pa(e)?la(e,...t):e}function pa(e){return Array.isArray(e)&&"raw"in e&&Array.isArray(e.raw)&&e.raw.every(t=>typeof t=="string")}function la(e,...t){return e.slice(1).reduce((r,n,a)=>`${r}${t[a]}${n}`,e[0])}function Sn(e){let t={argTypes:e.in&&Object.keys(e.in).length!==0?[Ae(e.in)]:[],returnType:void 0,workgroupSize:[e.workgroupSize[0]??1,e.workgroupSize[1]??1,e.workgroupSize[2]??1],isEntry:!0},r=(n,...a)=>da(t,e.workgroupSize,te(n,...a));return Object.assign(Object.assign(r,t),{does:r})}function da(e,t,r){let n=ee(e,r),a=e.argTypes[0];return{shell:e,get label(){return n.label},$uses(o){return n.applyExternals(o),this},$name(o){return n.label=o,N(a)&&a.$name(`${o}_Input`),this},"~resolve"(o){return n.resolve(o,`@compute @workgroup_size(${t.join(", ")}) `)},toString(){return`computeFn:${this.label??"<unnamed>"}`}}}function vn(e,t){let r={argTypes:e,returnType:t,isEntry:!1},n=(a,...o)=>ga(r,te(a,...o));return Object.assign(Object.assign(n,r),{does:n})}function lr(e){return e?.resourceType==="function"}function ma([e,t]){return`${e.label??"<unnamed>"}=${t}`}function ga(e,t){let r=ee(e,t),n={shell:e,resourceType:"function",$uses(s){return r.applyExternals(s),this},$name(s){return r.label=s,this},with(s,i){return Dn(o,[[ie(s)?s.slot:s,i]])},"~resolve"(s){if(typeof t=="string")return r.resolve(s);let i=s;if(i.callStack===void 0)throw new Error("Cannot resolve a TGSL function outside of a generation context");try{return i.callStack.push(e.returnType),r.resolve(s)}finally{i.callStack.pop()}}},a=It((...s)=>{if(typeof t=="string")throw new Error("Cannot execute on the CPU functions constructed with raw WGSL");return t(...s)},(...s)=>({value:new ct(o,s.map(i=>i.value)),dataType:e.returnType??A}));a[y].implementation=t;let o=Object.assign(a,n);return Object.defineProperty(o,"label",{get:()=>r.label}),Object.defineProperty(o,"toString",{value:()=>`fn:${r.label??"<unnamed>"}`}),o}function Dn(e,t){let r={resourceType:"function",shell:e.shell,"~providing":{inner:e,pairs:t},$uses(o){return e.$uses(o),this},$name(o){return e.$name(o),this},with(o,s){return Dn(a,[...t,[ie(o)?o.slot:o,s]])}},n=It((...o)=>e(...o),(...o)=>({value:new ct(a,o.map(s=>s.value)),dataType:e.shell.returnType??A})),a=Object.assign(n,r);return Object.defineProperty(a,"label",{get:()=>e.label}),Object.defineProperty(a,"toString",{value(){return`fn:${e.label??"<unnamed>"}[${t.map(ma).join(", ")}]`}}),a[y].implementation=e[y].implementation,a}var ct=class{constructor(t,r){this._fn=t;this._params=r}get label(){return this._fn.label}"~resolve"(t){return t.resolve(`${t.resolve(this._fn)}(${this._params.map(r=>t.resolve(r)).join(", ")})`)}toString(){return`call:${this.label??"<unnamed>"}`}};function Fn(e){let t={argTypes:e.in&&Object.keys(e.in).length!==0?[Ae(e.in)]:[],targets:e.out,returnType:Object.keys(e.out).length!==0?yt(e.out):void 0,isEntry:!0},r=(n,...a)=>fa(t,te(n,...a));return Object.assign(Object.assign(r,t),{does:r})}function fa(e,t){let r=ee(e,t),n=e.returnType,a=e.argTypes[0];return typeof t=="string"&&we(t,n,s=>r.applyExternals(s)),{shell:e,outputType:n,get label(){return r.label},$uses(s){return r.applyExternals(s),this},$name(s){return r.label=s,N(n)&&n.$name(`${s}_Output`),N(a)&&a.$name(`${s}_Input`),this},"~resolve"(s){if(typeof t=="string")return r.resolve(s,"@fragment ");let i=s;if(i.callStack===void 0)throw new Error("Cannot resolve a TGSL function outside of a generation context");try{return i.callStack.push(n),r.resolve(s,"@fragment ")}finally{i.callStack.pop()}},toString(){return`fragmentFn:${this.label??"<unnamed>"}`}}}function An(e){let t={attributes:[e.in??{}],returnType:Object.keys(e.out).length!==0?yt(e.out):void 0,argTypes:e.in&&Object.keys(e.in).length!==0?[Ae(e.in)]:[],isEntry:!0},r=(n,...a)=>Ta(t,te(n,...a));return Object.assign(Object.assign(r,t),{does:r})}function Ta(e,t){let r=ee(e,t),n=e.returnType,a=e.argTypes[0];return typeof t=="string"&&we(t,n,o=>r.applyExternals(o)),{shell:e,outputType:n,inputType:a,get label(){return r.label},$uses(o){return r.applyExternals(o),this},$name(o){return r.label=o,N(n)&&n.$name(`${o}_Output`),N(a)&&a.$name(`${o}_Input`),this},"~resolve"(o){if(typeof t=="string")return r.resolve(o,"@vertex ");let s=o;if(s.callStack===void 0)throw new Error("Cannot resolve a TGSL function outside of a generation context");try{return s.callStack.push(n),r.resolve(o,"@vertex ")}finally{s.callStack.pop()}},toString(){return`vertexFn:${this.label??"<unnamed>"}`}}}var re=class{lastUniqueId=0;makeUnique(t){let r;return t?(r=t.replaceAll(/\s/g,"_"),r=r.replaceAll(/[^\w\d]/g,"")):r="item",`${r}_${this.lastUniqueId++}`}},ne=class{_usedNames=new Set;makeUnique(t){if(t===void 0)throw new Error("Unnamed item found when using a strict name registry");let r=0,n=t;for(;this._usedNames.has(n);)r++,n=`${t}_${r}`;return this._usedNames.add(n),n}};function Un(e){let{externals:t,template:r,names:n,unstable_jitTranspiler:a}=e,o={};K(o,t??{});let s={"~resolve"(p){return ue(p,o,r??"")},toString:()=>"<root>"},{code:i}=Fe(s,{names:n==="strict"?new ne:new re,jitTranspiler:a});return i}var Ke=class{constructor(t){this._make=t}_map=new WeakMap;getOrMake(t,...r){if(this._map.has(t))return this._map.get(t);let n=this._make(t,...r);return this._map.set(t,n),n}};function In(e,t,r){return new dr(new mr(e,t,r),{})}function Bn(e){return e?.resourceType==="compute-pipeline"}var dr=class e{constructor(t,r){this._core=t;this._priors=r}resourceType="compute-pipeline";get label(){return this._core.label}get rawPipeline(){return this._core.unwrap().pipeline}with(t,r){return new e(this._core,{bindGroupLayoutMap:new Map([...this._priors.bindGroupLayoutMap??[],[t,r]])})}dispatchWorkgroups(t,r,n){let a=this._core.unwrap(),{branch:o,label:s}=this._core,i=o.commandEncoder.beginComputePass({label:s??"<unnamed>"});i.setPipeline(a.pipeline);let p=new Set(a.bindGroupLayouts);if(a.bindGroupLayouts.forEach((u,d)=>{if(a.catchall&&d===a.catchall[0])i.setBindGroup(d,o.unwrap(a.catchall[1])),p.delete(u);else{let m=this._priors.bindGroupLayoutMap?.get(u);m!==void 0&&(p.delete(u),i.setBindGroup(d,o.unwrap(m)))}}),p.size>0)throw new ae(p);i.dispatchWorkgroups(t,r,n),i.end()}$name(t){return this._core.label=t,this}},mr=class{constructor(t,r,n){this.branch=t;this._slotBindings=r;this._entryFn=n}label;_memo;unwrap(){if(this._memo===void 0){let t=this.branch.device,{code:r,bindGroupLayouts:n,catchall:a}=Fe({"~resolve":o=>(o.withSlots(this._slotBindings,()=>{o.resolve(this._entryFn)}),""),toString:()=>`computePipeline:${this.label??"<unnamed>"}`},{names:this.branch.nameRegistry,jitTranspiler:this.branch.jitTranspiler});a!==null&&n[a[0]]?.$name(`${this.label??"<unnamed>"} - Automatic Bind Group & Layout`),this._memo={pipeline:t.createComputePipeline({label:this.label??"<unnamed>",layout:t.createPipelineLayout({label:`${this.label??"<unnamed>"} - Pipeline Layout`,bindGroupLayouts:n.map(o=>this.branch.unwrap(o))}),compute:{module:t.createShaderModule({label:`${this.label??"<unnamed>"} - Shader`,code:r})}}),bindGroupLayouts:n,catchall:a}}return this._memo}};function Tr(e,t="vertex"){return new fr(e,t)}function bt(e){return e?.resourceType==="vertex-layout"}var gr=Symbol("defaultAttribEntry");function xt(e,t,r,n,a){if(ye(t)||Cr(t)){let o=Q(t);return o!==void 0&&(n[a??gr]=o),xt(e,t.inner,V(r,W(t)),n)}if(b(t)){let o=r;return Object.fromEntries(Object.entries(t.propTypes).map(([s,i])=>{o=V(o,F(i));let p=[s,xt(e,i,o,n,s)];return o+=c(i),p}))}if(Y(t)){let o=r;return Object.fromEntries(Object.entries(t.propTypes).map(([s,i])=>{o=V(o,W(i));let p=[s,xt(e,i,o,n,s)];return o+=c(i),p}))}if("type"in t&&typeof t.type=="string"){if(_r.includes(t.type))return{_layout:e,format:t.type,offset:r};let o=Lr[t.type];if(o)return{_layout:e,format:o,offset:r}}throw new Error(`Unsupported data used in vertex layout: ${String(t)}`)}var fr=class{constructor(t,r){this.schemaForCount=t;this.stepMode=r;let n=t(0);this.stride=V(c(n.elementType),F(n)),this.attrib=xt(this,n.elementType,0,this._customLocationMap)}resourceType="vertex-layout";stride;attrib;_customLocationMap={};_label;get label(){return this._label}get vertexLayout(){if(this._customLocationMap[gr]!==void 0){if(typeof this.attrib.format!="string"||typeof this.attrib.offset!="number")throw new Error("Single attribute vertex layouts must have a format and offset.");return{arrayStride:this.stride,stepMode:this.stepMode,attributes:[{format:this.attrib.format,offset:this.attrib.offset,shaderLocation:this._customLocationMap[gr]}]}}if(!Object.keys(this.attrib).every(r=>this._customLocationMap[r]!==void 0))throw new Error("All attributes must have custom locations in order to unwrap a vertex layout.");return{arrayStride:this.stride,stepMode:this.stepMode,attributes:[...Object.entries(this.attrib).map(([r,n])=>({format:n.format,offset:n.offset,shaderLocation:this._customLocationMap[r]}))]}}$name(t){return this._label=t,this}};function ya(e){return typeof e?.loadOp=="string"}function Rn(e,t){if(_(e)){if(!ya(t))throw new Error("Expected a single color attachment, not a record.");return[t]}let r=[];for(let n of Object.keys(e)){let a=t[n];if(!a)throw new Error(`A color attachment by the name of '${n}' was not provided to the shader.`);r.push(a)}return r}function ca(e){return typeof e?.format=="string"}function Pn(e,t){if(_(e)){if(!ca(t))throw new Error("Expected a single color target configuration, not a record.");return[t]}let r=[];for(let n of Object.keys(e)){let a=t[n];if(!a)throw new Error(`A color target by the name of '${n}' was not provided to the shader.`);r.push(a)}return r}function _n(e){return new yr(new cr(e),{})}function Ln(e){return e?.resourceType==="render-pipeline"}var yr=class e{constructor(t,r){this.core=t;this.priors=r}resourceType="render-pipeline";get label(){return this.core.label}$name(t){return this.core.label=t,this}with(t,r){if(ft(t))return new e(this.core,{...this.priors,bindGroupLayoutMap:new Map([...this.priors.bindGroupLayoutMap??[],[t,r]])});if(bt(t))return new e(this.core,{...this.priors,vertexLayoutMap:new Map([...this.priors.vertexLayoutMap??[],[t,r]])});throw new Error("Unsupported value passed into .with()")}withColorAttachment(t){return new e(this.core,{...this.priors,colorAttachment:t})}withDepthStencilAttachment(t){return new e(this.core,{...this.priors,depthStencilAttachment:t})}draw(t,r,n,a){let o=this.core.unwrap(),{branch:s,fragmentFn:i}=this.core.options,u={colorAttachments:Rn(i.shell.targets,this.priors.colorAttachment??{}).map(g=>q(g.view)?{...g,view:s.unwrap(g.view).createView()}:g)};if(this.core.label!==void 0&&(u.label=this.core.label),this.priors.depthStencilAttachment!==void 0){let g=this.priors.depthStencilAttachment;q(g.view)?u.depthStencilAttachment={...g,view:s.unwrap(g.view).createView()}:u.depthStencilAttachment=g}let d=s.commandEncoder.beginRenderPass(u);d.setPipeline(o.pipeline);let m=new Set(o.bindGroupLayouts);o.bindGroupLayouts.forEach((g,D)=>{if(o.catchall&&D===o.catchall[0])d.setBindGroup(D,s.unwrap(o.catchall[1])),m.delete(g);else{let S=this.priors.bindGroupLayoutMap?.get(g);S!==void 0&&(m.delete(g),d.setBindGroup(D,s.unwrap(S)))}});let T=new Set(this.core.usedVertexLayouts);if(this.core.usedVertexLayouts.forEach((g,D)=>{let S=this.priors.vertexLayoutMap?.get(g);S&&(T.delete(g),d.setVertexBuffer(D,s.unwrap(S)))}),m.size>0)throw new ae(m);if(T.size>0)throw new Ie(T);d.draw(t,r,n,a),d.end(),s.flush()}},cr=class{constructor(t){this.options=t;let r=Xr(t.vertexFn.shell.attributes[0],t.vertexAttribs);this._vertexBufferLayouts=r.bufferDefinitions,this.usedVertexLayouts=r.usedVertexLayouts,this._targets=Pn(t.fragmentFn.shell.targets,t.targets)}label;usedVertexLayouts;_memo;_vertexBufferLayouts;_targets;unwrap(){if(this._memo===void 0){let{branch:t,vertexFn:r,fragmentFn:n,slotBindings:a,primitiveState:o,depthStencilState:s,multisampleState:i}=this.options,{code:p,bindGroupLayouts:u,catchall:d}=Fe({"~resolve":g=>(g.withSlots(a,()=>{g.resolve(r),g.resolve(n)}),""),toString:()=>`renderPipeline:${this.label??"<unnamed>"}`},{names:t.nameRegistry,jitTranspiler:t.jitTranspiler});d!==null&&u[d[0]]?.$name(`${this.label??"<unnamed>"} - Automatic Bind Group & Layout`);let m=t.device,T=m.createShaderModule({label:`${this.label??"<unnamed>"} - Shader`,code:p}),f={layout:m.createPipelineLayout({label:`${this.label??"<unnamed>"} - Pipeline Layout`,bindGroupLayouts:u.map(g=>t.unwrap(g))}),vertex:{module:T,buffers:this._vertexBufferLayouts},fragment:{module:T,targets:this._targets}};this.label!==void 0&&(f.label=this.label),o&&(f.primitive=o),s&&(f.depthStencil=s),i&&(f.multisample=i),this._memo={pipeline:m.createRenderPipeline(f),bindGroupLayouts:u,catchall:d}}return this._memo}};var xr=class e{constructor(t,r){this._getRoot=t;this._slotBindings=r}with(t,r){return new e(this._getRoot,[...this._slotBindings,[ie(t)?t.slot:t,r]])}withCompute(t){return new br(this._getRoot(),this._slotBindings,t)}withVertex(t,r){return new hr({branch:this._getRoot(),primitiveState:void 0,depthStencilState:void 0,slotBindings:this._slotBindings,vertexFn:t,vertexAttribs:r,multisampleState:void 0})}},br=class{constructor(t,r,n){this._root=t;this._slotBindings=r;this._entryFn=n}createPipeline(){return In(this._root,this._slotBindings,this._entryFn)}},hr=class{constructor(t){this._options=t}withFragment(t,r,n){return Ue(typeof t!="string","Just type mismatch validation"),Ue(typeof r!="string","Just type mismatch validation"),new wr({...this._options,fragmentFn:t,targets:r})}},wr=class e{constructor(t){this._options=t}withPrimitive(t){return new e({...this._options,primitiveState:t})}withDepthStencil(t){return new e({...this._options,depthStencilState:t})}withMultisample(t){return new e({...this._options,multisampleState:t})}createPipeline(){return _n(this._options)}},ht=class extends xr{constructor(r,n,a,o){super(()=>this,[]);this.device=r;this.nameRegistry=n;this.jitTranspiler=a;this._ownDevice=o;this["~unstable"]=this}"~unstable";_disposables=[];_unwrappedBindGroupLayouts=new Ke(r=>r.unwrap(this));_unwrappedBindGroups=new Ke(r=>r.unwrap(this));_commandEncoder=null;get commandEncoder(){return this._commandEncoder||(this._commandEncoder=this.device.createCommandEncoder()),this._commandEncoder}createBuffer(r,n){let a=dn(this,r,n);return this._disposables.push(a),a}createUniform(r,n){return this.createBuffer(r,n).$usage("uniform").as("uniform")}createMutable(r,n){return this.createBuffer(r,n).$usage("storage").as("mutable")}createReadonly(r,n){return this.createBuffer(r,n).$usage("storage").as("readonly")}createBindGroup(r,n){return new De(r,n)}destroy(){for(let r of this._disposables)r.destroy();this._ownDevice&&this.device.destroy()}createTexture(r){let n=cn(r,this);return this._disposables.push(n),n}unwrap(r){if(Bn(r))return r.rawPipeline;if(Ln(r))return r.core.unwrap().pipeline;if(ft(r))return this._unwrappedBindGroupLayouts.getOrMake(r);if(ar(r))return this._unwrappedBindGroups.getOrMake(r);if(Z(r))return r.buffer;if(q(r)||je(r)||ze(r))return r.unwrap();if(bt(r))return r.vertexLayout;if(We(r)){if("unwrap"in r)return r.unwrap(this);throw new Error("Cannot unwrap laid-out sampler.")}if(Me(r)){if("unwrap"in r)return r.unwrap(this);throw new Error("Cannot unwrap laid-out comparison sampler.")}throw new Error(`Unknown resource type: ${r}`)}beginRenderPass(r,n){let a=this.commandEncoder.beginRenderPass(r),o=new Map,s=new Map,i,p=()=>{if(!i)throw new Error("Cannot draw without a call to pass.setPipeline");let{core:u,priors:d}=i,m=u.unwrap();a.setPipeline(m.pipeline);let T=new Set(m.bindGroupLayouts);m.bindGroupLayouts.forEach((g,D)=>{if(m.catchall&&D===m.catchall[0])a.setBindGroup(D,this.unwrap(m.catchall[1])),T.delete(g);else{let S=d.bindGroupLayoutMap?.get(g)??o.get(g);S!==void 0&&(T.delete(g),ar(S)?a.setBindGroup(D,this.unwrap(S)):a.setBindGroup(D,S))}});let f=new Set;if(u.usedVertexLayouts.forEach((g,D)=>{let S=d.vertexLayoutMap?.get(g),I=S?{buffer:S,offset:void 0,size:void 0}:s.get(g);!I||!I.buffer?f.add(g):Z(I.buffer)?a.setVertexBuffer(D,this.unwrap(I.buffer),I.offset,I.size):a.setVertexBuffer(D,I.buffer,I.offset,I.size)}),T.size>0)throw new ae(T);if(f.size>0)throw new Ie(f)};n({setViewport(...u){a.setViewport(...u)},setScissorRect(...u){a.setScissorRect(...u)},setBlendConstant(...u){a.setBlendConstant(...u)},setStencilReference(...u){a.setStencilReference(...u)},beginOcclusionQuery(...u){a.beginOcclusionQuery(...u)},endOcclusionQuery(...u){a.endOcclusionQuery(...u)},executeBundles(...u){a.executeBundles(...u)},setPipeline(u){i=u},setIndexBuffer:(u,d,m,T)=>{Z(u)?a.setIndexBuffer(this.unwrap(u),d,m,T):a.setIndexBuffer(u,d,m,T)},setVertexBuffer(u,d,m,T){s.set(u,{buffer:d,offset:m,size:T})},setBindGroup(u,d){o.set(u,d)},draw(u,d,m,T){p(),a.draw(u,d,m,T)},drawIndexed(...u){p(),a.drawIndexed(...u)},drawIndirect(...u){p(),a.drawIndirect(...u)},drawIndexedIndirect(...u){p(),a.drawIndexedIndirect(...u)}}),a.end()}flush(){this._commandEncoder&&(this.device.queue.submit([this._commandEncoder.finish()]),this._commandEncoder=null)}};async function Cn(e){let{adapter:t,device:r,unstable_names:n="random",unstable_jitTranspiler:a}=e??{};if(!navigator.gpu)throw new Error("WebGPU is not supported by this browser.");let o=await navigator.gpu.requestAdapter(t);if(!o)throw new Error("Could not find a compatible GPU");return new ht(await o.requestDevice(r),n==="random"?new re:new ne,a,!0)}function Vn(e){let{device:t,unstable_names:r="random",unstable_jitTranspiler:n}=e??{};return new ht(t,r==="random"?new re:new ne,n,!1)}function wt(e){return new Sr(e)}var Sr=class{constructor(t=void 0){this.defaultValue=t}resourceType="slot";label;$name(t){return this.label=t,this}areEqual(t,r){return Object.is(t,r)}toString(){return`slot:${this.label??"<unnamed>"}`}get value(){let t=j();if(!t)throw new Error("Cannot access tgpu.slot's value outside of resolution.");return Ee(t.unwrap(this))}};function En(e,t){return new vr(e,t)}var vr=class{constructor(t,r=void 0){this.schema=t;this.defaultValue=r;this.slot=wt(r)}resourceType="accessor";label;slot;$name(t){return this.label=t,this.slot.$name(t),this}toString(){return`accessor:${this.label??"<unnamed>"}`}get value(){if(!j())throw new Error("Cannot access tgpu.accessor's value outside of resolution.");return new Proxy({"~resolve":r=>r.resolve(this),toString:()=>`.value:${this.label??"<unnamed>"}`,[y]:{dataType:this.schema}},M)}"~resolve"(t){let r=t.unwrap(this.slot);return Ze(r)?t.resolve(r):lr(r)?`${t.resolve(r)}()`:t.resolveValue(r,this.schema)}};function kn(e){return ba(e)}function xa([e,t]){return`${e.label??"<unnamed>"}=${t}`}function ba(e){return{resourceType:"derived","~compute":e,[Bt]:void 0,get value(){let r=j();if(!r)throw new Error("Cannot access tgpu.derived's value outside of resolution.");return Ee(r.unwrap(this))},with(r,n){return $n(this,[[r,n]])},toString(){return"derived"}}}function $n(e,t){return{resourceType:"derived",[Bt]:void 0,"~compute"(){throw new Error("'~compute' should never be read on bound derived items.")},"~providing":{inner:e,pairs:t},get value(){let n=j();if(!n)throw new Error("Cannot access tgpu.derived's value outside of resolution.");return Ee(n.unwrap(this))},with(n,a){return $n(e,[...t,[n,a]])},toString(){return`derived[${t.map(xa).join(", ")}]`}}}function On(e,t){return new St("private",e,t)}function Gn(e){return new St("workgroup",e)}var St=class{constructor(t,r,n){this.scope=t;this._dataType=r;this._initialValue=n}_label;$name(t){return this._label=t,this}"~resolve"(t){let r=t.names.makeUnique(this._label);return this._initialValue?t.addDeclaration(`var<${this.scope}> ${r}: ${t.resolve(this._dataType)} = ${t.resolveValue(this._initialValue,this._dataType)};`):t.addDeclaration(`var<${this.scope}> ${r}: ${t.resolve(this._dataType)};`),r}get label(){return this._label}toString(){return`var:${this.label??"<unnamed>"}`}get value(){if(!oe())throw new Error("Cannot access tgpu.var's value directly in JS.");return new Proxy({"~resolve":t=>t.resolve(this),toString:()=>`.value:${this.label??"<unnamed>"}`,[y]:{dataType:this._dataType}},M)}};var Wn={bindGroupLayout:gt,vertexLayout:Tr,init:Cn,initFromDevice:Vn,resolve:Un,"~unstable":{fn:vn,fragmentFn:Fn,vertexFn:An,computeFn:Sn,vertexLayout:Tr,derived:kn,slot:wt,accessor:En,privateVar:On,workgroupVar:Gn,const:jr,declare:Kr,sampler:mn,comparisonSampler:gn}},Mu=Wn;Object.assign(Wn,{__assignAst:Jr,__removedJsImpl:Yr});export{ae as MissingBindGroupsError,Ft as MissingLinksError,vt as MissingSlotValueError,Ie as MissingVertexBuffersError,Dt as NotUniformError,re as RandomNameRegistry,me as ResolutionError,ne as StrictNameRegistry,Mu as default,Z as isBuffer,Me as isComparisonSampler,k as isDerived,ze as isSampledTextureView,We as isSampler,E as isSlot,je as isStorageTextureView,q as isTexture,lr as isTgpuFn,ua as isUsableAsRender,tr as isUsableAsSampled,de as isUsableAsStorage,at as isUsableAsUniform,ia as isUsableAsVertex,Wn as tgpu,zt as unstable_asMutable,Kt as unstable_asReadonly,qt as unstable_asUniform};
29
+ `)}${r}`}finally{Mt(Le.GPU)}return this._getOrInstantiate(t)}return String(t)}resolveValue(t,r){if(J(t))return this.resolve(t);if(r&&z(r))return`array(${t.map(n=>this.resolveValue(n,r.elementType))})`;if(Array.isArray(t))return`array(${t.map(n=>this.resolveValue(n))})`;if(r&&I(r))return`${this.resolve(r)}(${Object.entries(r.propTypes).map(([n,a])=>this.resolveValue(t[n],a))})`;throw new Error(`Value ${t} (as json: ${JSON.stringify(t)}) of schema ${r} is not resolvable to WGSL`)}};function Ve(e,t){let r=new Rr(t),n=r.resolve(e),a=r.bindGroupLayoutsToPlaceholderMap,o=[],s=new Set([...a.keys()].map(g=>g.index).filter(g=>g!==void 0)),i=tn(s),l=r.fixedBindings.map((g,c)=>[String(c),g.layoutEntry]),u=()=>{let g=i.next().value,c=It(Object.fromEntries(l));return o[g]=c,n=n.replaceAll(_n,String(g)),[g,new Pe(c,Object.fromEntries(r.fixedBindings.map((y,x)=>[String(x),y.resource])))]},d=l.length>0?u():null;for(let[g,c]of a.entries()){let y=g.index??i.next().value;o[y]=g,n=n.replaceAll(c,String(y))}return{code:n,bindGroupLayouts:o,catchall:d}}function Cr(e,t,r){let n=t.map(a=>`${a.value}: ${e.resolve(a.dataType)}`).join(", ");return r!==void 0?`(${n}) -> ${Ie(r)} ${e.resolve(r)}`:`(${n})`}function oe(e,t){let r=[];typeof t=="string"&&(e.isEntry?(Array.isArray(e.argTypes)&&I(e.argTypes[0])&&r.push({In:e.argTypes[0]}),I(e.returnType)&&r.push({Out:e.returnType})):Array.isArray(e.argTypes)&&(dn(t,Array.isArray(e.argTypes)?e.argTypes:Object.values(e.argTypes),o=>r.push(o)),Be(t,e.returnType,o=>r.push(o))));let n={applyExternals(o){r.push(o)},resolve(o,s=""){let i={};for(let u of r)Q(i,u);let l=o.names.makeUnique(p(this));if(typeof t=="string"){let u="";if(!e.isEntry)u=Array.isArray(e.argTypes)?"":Cr(o,Object.entries(e.argTypes).map(([g,c])=>({value:g,dataType:c})),e.returnType);else{let g=Array.isArray(e.argTypes)&&I(e.argTypes[0])?"(in: In)":"()",c=j(e.returnType)?Ie(e.returnType):"",y=e.returnType!==void 0?I(e.returnType)?"-> Out":`-> ${c!==""?c:"@location(0)"} ${o.resolve(e.returnType)}`:"";u=`${g} ${y} `}let d=ye(o,i,`${u}${t.trim()}`);o.addDeclaration(`${s}fn ${l}${d}`)}else{let u=gn(t);if(u?.externals){let h=Object.fromEntries(Object.entries(u.externals).filter(([T])=>!(T in i)));Q(i,h)}let d=u?.ast??o.transpileFn(String(t));d.argNames.type==="destructured-object"&&Q(i,Object.fromEntries(d.argNames.props.map(({prop:h,alias:T})=>[T,h]))),!Array.isArray(e.argTypes)&&d.argNames.type==="identifiers"&&d.argNames.names[0]!==void 0&&Q(i,{[d.argNames.names[0]]:Object.fromEntries(Object.keys(e.argTypes).map(h=>[h,h]))});let g=d.externalNames.filter(h=>!(h in i));if(g.length>0)throw new Gt(p(this),g);let c=Array.isArray(e.argTypes)?d.argNames.type==="identifiers"?e.argTypes.map((h,T)=>({value:(d.argNames.type==="identifiers"?d.argNames.names[T]:void 0)??`arg_${T}`,dataType:h})):[]:Object.entries(e.argTypes).map(([h,T])=>({value:h,dataType:T})),{head:y,body:x}=o.fnToWgsl({args:c,returnType:e.returnType,body:d.body,externalMap:i});o.addDeclaration(`${s}fn ${l}${o.resolve(y)}${o.resolve(x)}`)}return l}},a=p(t);return a!==void 0&&w(n,a),n}function On(e){let t=0;return Object.fromEntries(Object.entries(e).map(([r,n])=>{if(ut(n))return[r,n];let a=ee(n);return a!==void 0?(t=a+1,[r,n]):[r,Yt(t++,n)]}))}function Ct(e){return $(e)?rt(e)?void 0:ee(e)!==void 0?e:Yt(0,e):Qt(On(e))}function $e(e){return Qt(On(e))}function se(e,...t){return Ca(e)?Pa(e,...t):e}function Ca(e){return Array.isArray(e)&&"raw"in e&&Array.isArray(e.raw)&&e.raw.every(t=>typeof t=="string")}function Pa(e,...t){return e.slice(1).reduce((r,n,a)=>`${r}${t[a]}${n}`,e[0])}function Gn(e){let t={argTypes:e.in&&Object.keys(e.in).length!==0?[$e(e.in)]:[],returnType:void 0,workgroupSize:[e.workgroupSize[0]??1,e.workgroupSize[1]??1,e.workgroupSize[2]??1],isEntry:!0},r=(n,...a)=>Va(t,e.workgroupSize,se(n,...a));return Object.assign(Object.assign(r,t),{does:r})}function Va(e,t,r){let n=oe(e,r),a=e.argTypes[0];return{shell:e,$uses(o){return n.applyExternals(o),this},[b]:n,$name(o){return w(n,o),N(a)&&a.$name(`${o}_Input`),this},"~resolve"(o){return n.resolve(o,`@compute @workgroup_size(${t.join(", ")}) `)},toString(){return`computeFn:${p(n)??"<unnamed>"}`}}}function Wn(e,t){let r={[m]:!0,argTypes:e,returnType:t,isEntry:!1},n=(a,...o)=>ka(r,se(a,...o));return Object.assign(Object.assign(n,r),{does:n})}function Pr(e){return e?.resourceType==="function"}function $a([e,t]){return`${p(e)??"<unnamed>"}=${t}`}function ka(e,t){let r=oe(e,t),n={[m]:{implementation:t,argTypes:e.argTypes},shell:e,resourceType:"function",$uses(s){return r.applyExternals(s),this},[b]:r,$name(s){return w(r,s),this},with(s,i){return Mn(o,[[ge(s)?s.slot:s,i]])},"~resolve"(s){if(typeof t=="string")return r.resolve(s);let i=s;if(i.callStack===void 0)throw new Error("Cannot resolve a TGSL function outside of a generation context");try{return i.callStack.push(e.returnType),r.resolve(s)}finally{i.callStack.pop()}}},a=zt((...s)=>{if(typeof t=="string")throw new Error("Cannot execute on the CPU functions constructed with raw WGSL");return t(...s)},(...s)=>({value:new Pt(o,s.map(i=>i.value)),dataType:e.returnType??U}),e.argTypes);a[m].implementation=t;let o=Object.assign(a,n);return Object.defineProperty(o,"toString",{value(){return`fn:${p(r)??"<unnamed>"}`}}),o}function Mn(e,t){let r={[m]:{implementation:e[m].implementation,argTypes:e[m].argTypes},resourceType:"function",shell:e.shell,"~providing":{inner:e,pairs:t},$uses(o){return e.$uses(o),this},[b]:e,$name(o){return e.$name(o),this},with(o,s){return Mn(a,[...t,[ge(o)?o.slot:o,s]])}},n=zt((...o)=>e(...o),(...o)=>({value:new Pt(a,o.map(s=>s.value)),dataType:e.shell.returnType??U}),e.shell.argTypes),a=Object.assign(n,r);return Object.defineProperty(a,"toString",{value(){return`fn:${p(e)??"<unnamed>"}[${t.map($a).join(", ")}]`}}),a[m].implementation=e[m].implementation,a}var Pt=class{constructor(t,r){this._fn=t;this._params=r;this[b]=t}[b];"~resolve"(t){return t.resolve(`${t.resolve(this._fn)}(${this._params.map(r=>t.resolve(r)).join(", ")})`)}toString(){return`call:${p(this)??"<unnamed>"}`}};function Nn(e){let t={argTypes:e.in&&Object.keys(e.in).length!==0?[$e(e.in)]:[],targets:e.out,returnType:Ct(e.out),isEntry:!0},r=(n,...a)=>Ea(t,se(n,...a));return Object.assign(Object.assign(r,t),{does:r})}function Ea(e,t){let r=oe(e,t),n=e.returnType,a=e.argTypes[0];return typeof t=="string"&&Be(t,n,s=>r.applyExternals(s)),{shell:e,outputType:n,$uses(s){return r.applyExternals(s),this},[b]:r,$name(s){return w(r,s),N(n)&&n.$name(`${s}_Output`),N(a)&&a.$name(`${s}_Input`),this},"~resolve"(s){if(typeof t=="string")return r.resolve(s,"@fragment ");let i=s;if(i.callStack===void 0)throw new Error("Cannot resolve a TGSL function outside of a generation context");try{return i.callStack.push(n),r.resolve(s,"@fragment ")}finally{i.callStack.pop()}},toString(){return`fragmentFn:${p(r)??"<unnamed>"}`}}}function jn(e){let t={attributes:[e.in??{}],returnType:Object.keys(e.out).length!==0?Ct(e.out):void 0,argTypes:e.in&&Object.keys(e.in).length!==0?[$e(e.in)]:[],isEntry:!0},r=(n,...a)=>La(t,se(n,...a));return Object.assign(Object.assign(r,t),{does:r})}function La(e,t){let r=oe(e,t),n=e.returnType,a=e.argTypes[0];return typeof t=="string"&&Be(t,n,o=>r.applyExternals(o)),{shell:e,outputType:n,inputType:a,$uses(o){return r.applyExternals(o),this},[b]:r,$name(o){return w(r,o),N(n)&&n.$name(`${o}_Output`),N(a)&&a.$name(`${o}_Input`),this},"~resolve"(o){if(typeof t=="string")return r.resolve(o,"@vertex ");let s=o;if(s.callStack===void 0)throw new Error("Cannot resolve a TGSL function outside of a generation context");try{return s.callStack.push(n),r.resolve(o,"@vertex ")}finally{s.callStack.pop()}},toString(){return`vertexFn:${p(r)??"<unnamed>"}`}}}var ie=class{lastUniqueId=0;makeUnique(t){let r;return t?(r=t.replaceAll(/\s/g,"_"),r=r.replaceAll(/[^\w\d]/g,"")):r="item",`${r}_${this.lastUniqueId++}`}},ue=class{_usedNames=new Set;makeUnique(t){if(t===void 0)throw new Error("Unnamed item found when using a strict name registry");let r=0,n=t;for(;this._usedNames.has(n);)r++,n=`${t}_${r}`;return this._usedNames.add(n),n}};function zn(e){let{externals:t,template:r,names:n,unstable_jitTranspiler:a}=e,o={};Q(o,t??{});let s={"~resolve"(l){return ye(l,o,r??"")},toString:()=>"<root>"},{code:i}=Ve(s,{names:n==="strict"?new ue:new ie,jitTranspiler:a});return i}var tt=class{constructor(t){this._make=t}_map=new WeakMap;getOrMake(t,...r){if(this._map.has(t))return this._map.get(t);let n=this._make(t,...r);return this._map.set(t,n),n}};function Kn(e,t,r){return new Vr(new $r(e,t,r),{})}function Hn(e){let t=e;return t?.resourceType==="compute-pipeline"&&!!t[m]}var Vr=class e{constructor(t,r){this._core=t;this._priors=r;this[m]={get rawPipeline(){return t.unwrap().pipeline}},this[b]=t}[m];resourceType="compute-pipeline";[b];get rawPipeline(){return this._core.unwrap().pipeline}with(t,r){return new e(this._core,{bindGroupLayoutMap:new Map([...this._priors.bindGroupLayoutMap??[],[t,r]])})}dispatchWorkgroups(t,r,n){let a=this._core.unwrap(),{branch:o}=this._core,s=o.commandEncoder.beginComputePass({label:p(this._core)??"<unnamed>"});s.setPipeline(a.pipeline);let i=new Set(a.bindGroupLayouts);if(a.bindGroupLayouts.forEach((l,u)=>{if(a.catchall&&u===a.catchall[0])s.setBindGroup(u,o.unwrap(a.catchall[1])),i.delete(l);else{let d=this._priors.bindGroupLayoutMap?.get(l);d!==void 0&&(i.delete(l),s.setBindGroup(u,o.unwrap(d)))}}),i.size>0)throw new le(i);s.dispatchWorkgroups(t,r,n),s.end()}$name(t){return w(this._core,t),this}},$r=class{constructor(t,r,n){this.branch=t;this._slotBindings=r;this._entryFn=n}_memo;unwrap(){if(this._memo===void 0){let t=this.branch.device,{code:r,bindGroupLayouts:n,catchall:a}=Ve({"~resolve":o=>(o.withSlots(this._slotBindings,()=>{o.resolve(this._entryFn)}),""),toString:()=>`computePipeline:${p(this)??"<unnamed>"}`},{names:this.branch.nameRegistry,jitTranspiler:this.branch.jitTranspiler});a!==null&&n[a[0]]?.$name(`${p(this)??"<unnamed>"} - Automatic Bind Group & Layout`),this._memo={pipeline:t.createComputePipeline({label:p(this)??"<unnamed>",layout:t.createPipelineLayout({label:`${p(this)??"<unnamed>"} - Pipeline Layout`,bindGroupLayouts:n.map(o=>this.branch.unwrap(o))}),compute:{module:t.createShaderModule({label:`${p(this)??"<unnamed>"} - Shader`,code:r})}}),bindGroupLayouts:n,catchall:a}}return this._memo}};function Lr(e,t="vertex"){return new Er(e,t)}function $t(e){return e?.resourceType==="vertex-layout"}var kr=Symbol("defaultAttribEntry");function Vt(e,t,r,n,a){if(Se(t)||en(t)){let o=ee(t);return o!==void 0&&(n[a??kr]=o),Vt(e,t.inner,_(r,K(t)),n)}if(I(t)){let o=r;return Object.fromEntries(Object.entries(t.propTypes).map(([s,i])=>{o=_(o,P(i));let l=[s,Vt(e,i,o,n,s)];return o+=S(i),l}))}if(Z(t)){let o=r;return Object.fromEntries(Object.entries(t.propTypes).map(([s,i])=>{o=_(o,K(i));let l=[s,Vt(e,i,o,n,s)];return o+=S(i),l}))}if("type"in t&&typeof t.type=="string"){if(Hr.includes(t.type))return{_layout:e,format:t.type,offset:r};let o=qr[t.type];if(o)return{_layout:e,format:o,offset:r}}throw new Error(`Unsupported data used in vertex layout: ${String(t)}`)}var Er=class{constructor(t,r){this.schemaForCount=t;this.stepMode=r;let n=t(0);this.stride=_(S(n.elementType),P(n)),this.attrib=Vt(this,n.elementType,0,this._customLocationMap)}resourceType="vertex-layout";stride;attrib;_customLocationMap={};get vertexLayout(){if(this._customLocationMap[kr]!==void 0){if(typeof this.attrib.format!="string"||typeof this.attrib.offset!="number")throw new Error("Single attribute vertex layouts must have a format and offset.");return{arrayStride:this.stride,stepMode:this.stepMode,attributes:[{format:this.attrib.format,offset:this.attrib.offset,shaderLocation:this._customLocationMap[kr]}]}}if(!Object.keys(this.attrib).every(r=>this._customLocationMap[r]!==void 0))throw new Error("All attributes must have custom locations in order to unwrap a vertex layout.");return{arrayStride:this.stride,stepMode:this.stepMode,attributes:[...Object.entries(this.attrib).map(([r,n])=>({format:n.format,offset:n.offset,shaderLocation:this._customLocationMap[r]}))]}}$name(t){return w(this,t),this}};function _a(e){return typeof e?.loadOp=="string"}function qn(e,t){if($(e)){if(!_a(t))throw new Error("Expected a single color attachment, not a record.");return[t]}let r=[];for(let n of Object.keys(e)){let a=t[n];if(!a)throw new Error(`A color attachment by the name of '${n}' was not provided to the shader.`);r.push(a)}return r}function Oa(e){return typeof e?.format=="string"}function Jn(e,t){if($(e)){if(rt(e))return[];if(!Oa(t))throw new Error("Expected a single color target configuration, not a record.");return[t]}let r=[];for(let n of Object.keys(e)){let a=t[n];if(!a)throw new Error(`A color target by the name of '${n}' was not provided to the shader.`);r.push(a)}return r}function Yn(e){return new _r(new Or(e),{})}function Qn(e){let t=e;return t?.resourceType==="render-pipeline"&&!!t[m]}var _r=class e{[m];resourceType="render-pipeline";[b];constructor(t,r){this[m]={core:t,priors:r},this[b]=t}$name(t){return w(this[m].core,t),this}with(t,r){let n=this[m];if(Ut(t))return new e(n.core,{...n.priors,bindGroupLayoutMap:new Map([...n.priors.bindGroupLayoutMap??[],[t,r]])});if($t(t))return new e(n.core,{...n.priors,vertexLayoutMap:new Map([...n.priors.vertexLayoutMap??[],[t,r]])});throw new Error("Unsupported value passed into .with()")}withColorAttachment(t){let r=this[m];return new e(r.core,{...r.priors,colorAttachment:t})}withDepthStencilAttachment(t){let r=this[m];return new e(r.core,{...r.priors,depthStencilAttachment:t})}draw(t,r,n,a){let o=this[m],s=o.core.unwrap(),{branch:i,fragmentFn:l}=o.core.options,d={colorAttachments:qn(l.shell.targets,o.priors.colorAttachment??{}).map(T=>X(T.view)?{...T,view:i.unwrap(T.view).createView()}:T)},g=p(o.core);if(g!==void 0&&(d.label=g),o.priors.depthStencilAttachment!==void 0){let T=o.priors.depthStencilAttachment;X(T.view)?d.depthStencilAttachment={...T,view:i.unwrap(T.view).createView()}:d.depthStencilAttachment=T}let c=i.commandEncoder.beginRenderPass(d);c.setPipeline(s.pipeline);let y=new Set(s.bindGroupLayouts);s.bindGroupLayouts.forEach((T,D)=>{if(s.catchall&&D===s.catchall[0])c.setBindGroup(D,i.unwrap(s.catchall[1])),y.delete(T);else{let ke=o.priors.bindGroupLayoutMap?.get(T);ke!==void 0&&(y.delete(T),c.setBindGroup(D,i.unwrap(ke)))}});let x=new Set(o.core.usedVertexLayouts);if(o.core.usedVertexLayouts.forEach((T,D)=>{let ke=o.priors.vertexLayoutMap?.get(T);ke&&(x.delete(T),c.setVertexBuffer(D,i.unwrap(ke)))}),y.size>0)throw new le(y);if(x.size>0)throw new Ee(x);c.draw(t,r,n,a),c.end(),i.flush()}},Or=class{constructor(t){this.options=t;let r=Tn(t.vertexFn.shell.attributes[0],t.vertexAttribs);this._vertexBufferLayouts=r.bufferDefinitions,this.usedVertexLayouts=r.usedVertexLayouts,this._targets=Jn(t.fragmentFn.shell.targets,t.targets)}usedVertexLayouts;_memo;_vertexBufferLayouts;_targets;unwrap(){if(this._memo===void 0){let{branch:t,vertexFn:r,fragmentFn:n,slotBindings:a,primitiveState:o,depthStencilState:s,multisampleState:i}=this.options,{code:l,bindGroupLayouts:u,catchall:d}=Ve({"~resolve":h=>(h.withSlots(a,()=>{h.resolve(r),h.resolve(n)}),""),toString:()=>`renderPipeline:${p(this)??"<unnamed>"}`},{names:t.nameRegistry,jitTranspiler:t.jitTranspiler});d!==null&&u[d[0]]?.$name(`${p(this)??"<unnamed>"} - Automatic Bind Group & Layout`);let g=t.device,c=g.createShaderModule({label:`${p(this)??"<unnamed>"} - Shader`,code:l}),y={layout:g.createPipelineLayout({label:`${p(this)??"<unnamed>"} - Pipeline Layout`,bindGroupLayouts:u.map(h=>t.unwrap(h))}),vertex:{module:c,buffers:this._vertexBufferLayouts},fragment:{module:c,targets:this._targets}},x=p(this);x!==void 0&&(y.label=x),o&&(y.primitive=o),s&&(y.depthStencil=s),i&&(y.multisample=i),this._memo={pipeline:g.createRenderPipeline(y),bindGroupLayouts:u,catchall:d}}return this._memo}};var Gr=class e{constructor(t,r){this._getRoot=t;this._slotBindings=r}with(t,r){return new e(this._getRoot,[...this._slotBindings,[ge(t)?t.slot:t,r]])}withCompute(t){return new Wr(this._getRoot(),this._slotBindings,t)}withVertex(t,r){return new Mr({branch:this._getRoot(),primitiveState:void 0,depthStencilState:void 0,slotBindings:this._slotBindings,vertexFn:t,vertexAttribs:r,multisampleState:void 0})}},Wr=class{constructor(t,r,n){this._root=t;this._slotBindings=r;this._entryFn=n}createPipeline(){return Kn(this._root,this._slotBindings,this._entryFn)}},Mr=class{constructor(t){this._options=t}withFragment(t,r,n){return pe(typeof t!="string","Just type mismatch validation"),pe(typeof r!="string","Just type mismatch validation"),new Nr({...this._options,fragmentFn:t,targets:r})}},Nr=class e{constructor(t){this._options=t}withPrimitive(t){return new e({...this._options,primitiveState:t})}withDepthStencil(t){return new e({...this._options,depthStencilState:t})}withMultisample(t){return new e({...this._options,multisampleState:t})}createPipeline(){return Yn(this._options)}},kt=class extends Gr{constructor(r,n,a,o){super(()=>this,[]);this.device=r;this.nameRegistry=n;this.jitTranspiler=a;this._ownDevice=o;this["~unstable"]=this}"~unstable";_disposables=[];_unwrappedBindGroupLayouts=new tt(r=>r.unwrap(this));_unwrappedBindGroups=new tt(r=>r.unwrap(this));_commandEncoder=null;get commandEncoder(){return this._commandEncoder||(this._commandEncoder=this.device.createCommandEncoder()),this._commandEncoder}createBuffer(r,n){let a=Fn(this,r,n);return this._disposables.push(a),a}createUniform(r,n){return this.createBuffer(r,n).$usage("uniform").as("uniform")}createMutable(r,n){return this.createBuffer(r,n).$usage("storage").as("mutable")}createReadonly(r,n){return this.createBuffer(r,n).$usage("storage").as("readonly")}createBindGroup(r,n){return new Pe(r,n)}destroy(){for(let r of this._disposables)r.destroy();this._ownDevice&&this.device.destroy()}createTexture(r){let n=Cn(r,this);return this._disposables.push(n),n}unwrap(r){if(Hn(r))return r[m].rawPipeline;if(Qn(r))return r[m].core.unwrap().pipeline;if(Ut(r))return this._unwrappedBindGroupLayouts.getOrMake(r);if(Fr(r))return this._unwrappedBindGroups.getOrMake(r);if(ae(r))return r.buffer;if(X(r))return r[m].unwrap();if(Ze(r)){if(r[m].unwrap)return r[m].unwrap();throw new Error("Cannot unwrap laid-out texture view.")}if(et(r)){if(r[m].unwrap)return r[m].unwrap();throw new Error("Cannot unwrap laid-out texture view.")}if($t(r))return r.vertexLayout;if(Ye(r)){if(r[m].unwrap)return r[m].unwrap(this);throw new Error("Cannot unwrap laid-out sampler.")}if(Qe(r)){if(r[m].unwrap)return r[m].unwrap(this);throw new Error("Cannot unwrap laid-out comparison sampler.")}throw new Error(`Unknown resource type: ${r}`)}beginRenderPass(r,n){let a=this.commandEncoder.beginRenderPass(r),o=new Map,s=new Map,i,l=()=>{if(!i)throw new Error("Cannot draw without a call to pass.setPipeline");let{core:u,priors:d}=i[m],g=u.unwrap();a.setPipeline(g.pipeline);let c=new Set(g.bindGroupLayouts);g.bindGroupLayouts.forEach((x,h)=>{if(g.catchall&&h===g.catchall[0])a.setBindGroup(h,this.unwrap(g.catchall[1])),c.delete(x);else{let T=d.bindGroupLayoutMap?.get(x)??o.get(x);T!==void 0&&(c.delete(x),Fr(T)?a.setBindGroup(h,this.unwrap(T)):a.setBindGroup(h,T))}});let y=new Set;if(u.usedVertexLayouts.forEach((x,h)=>{let T=d.vertexLayoutMap?.get(x),D=T?{buffer:T,offset:void 0,size:void 0}:s.get(x);!D||!D.buffer?y.add(x):ae(D.buffer)?a.setVertexBuffer(h,this.unwrap(D.buffer),D.offset,D.size):a.setVertexBuffer(h,D.buffer,D.offset,D.size)}),c.size>0)throw new le(c);if(y.size>0)throw new Ee(y)};n({setViewport(...u){a.setViewport(...u)},setScissorRect(...u){a.setScissorRect(...u)},setBlendConstant(...u){a.setBlendConstant(...u)},setStencilReference(...u){a.setStencilReference(...u)},beginOcclusionQuery(...u){a.beginOcclusionQuery(...u)},endOcclusionQuery(...u){a.endOcclusionQuery(...u)},executeBundles(...u){a.executeBundles(...u)},setPipeline(u){i=u},setIndexBuffer:(u,d,g,c)=>{ae(u)?a.setIndexBuffer(this.unwrap(u),d,g,c):a.setIndexBuffer(u,d,g,c)},setVertexBuffer(u,d,g,c){s.set(u,{buffer:d,offset:g,size:c})},setBindGroup(u,d){o.set(u,d)},draw(u,d,g,c){l(),a.draw(u,d,g,c)},drawIndexed(...u){l(),a.drawIndexed(...u)},drawIndirect(...u){l(),a.drawIndirect(...u)},drawIndexedIndirect(...u){l(),a.drawIndexedIndirect(...u)}}),a.end()}flush(){this._commandEncoder&&(this.device.queue.submit([this._commandEncoder.finish()]),this._commandEncoder=null)}};async function Xn(e){let{adapter:t,device:r,unstable_names:n="random",unstable_jitTranspiler:a}=e??{};if(!navigator.gpu)throw new Error("WebGPU is not supported by this browser.");let o=await navigator.gpu.requestAdapter(t);if(!o)throw new Error("Could not find a compatible GPU");return new kt(await o.requestDevice(r),n==="random"?new ie:new ue,a,!0)}function Zn(e){let{device:t,unstable_names:r="random",unstable_jitTranspiler:n}=e??{};return new kt(t,r==="random"?new ie:new ue,n,!1)}function Et(e){return new jr(e)}var jr=class{constructor(t=void 0){this.defaultValue=t}resourceType="slot";$name(t){return w(this,t),this}areEqual(t,r){return Object.is(t,r)}toString(){return`slot:${p(this)??"<unnamed>"}`}get value(){let t=G();if(!t)throw new Error("Cannot access tgpu.slot's value outside of resolution.");return ze(t.unwrap(this))}};function ea(e,t){return new zr(e,t)}var zr=class{constructor(t,r=void 0){this.schema=t;this.defaultValue=r;this.slot=Et(r),this[b]=this.slot}resourceType="accessor";slot;[b];$name(t){return this.slot.$name(t),this}toString(){return`accessor:${p(this)??"<unnamed>"}`}get value(){if(!G())throw new Error("Cannot access tgpu.accessor's value outside of resolution.");return new Proxy({"~resolve":r=>r.resolve(this),toString:()=>`.value:${p(this)??"<unnamed>"}`,[m]:{dataType:this.schema}},Y)}"~resolve"(t){let r=t.unwrap(this.slot);return lt(r)?t.resolve(r):Pr(r)?`${t.resolve(r)}()`:t.resolveValue(r,this.schema)}};function ta(e){return Wa(e)}function Ga([e,t]){return`${p(e)??"<unnamed>"}=${t}`}function Wa(e){if(G())throw new Error("Cannot create tgpu.derived objects at the resolution stage.");return{resourceType:"derived","~compute":e,[Nt]:void 0,get value(){let r=G();if(!r)throw new Error("Cannot access tgpu.derived's value outside of resolution.");return ze(r.unwrap(this))},with(r,n){return ra(this,[[r,n]])},toString(){return"derived"}}}function ra(e,t){return{resourceType:"derived",[Nt]:void 0,"~compute"(){throw new Error("'~compute' should never be read on bound derived items.")},"~providing":{inner:e,pairs:t},get value(){let n=G();if(!n)throw new Error("Cannot access tgpu.derived's value outside of resolution.");return ze(n.unwrap(this))},with(n,a){return ra(e,[...t,[n,a]])},toString(){return`derived[${t.map(Ga).join(", ")}]`}}}function na(e,t){return new Lt("private",e,t)}function aa(e){return new Lt("workgroup",e)}var Lt=class{constructor(t,r,n){this.scope=t;this._dataType=r;this._initialValue=n}"~resolve"(t){let r=t.names.makeUnique(p(this));return this._initialValue?t.addDeclaration(`var<${this.scope}> ${r}: ${t.resolve(this._dataType)} = ${t.resolveValue(this._initialValue,this._dataType)};`):t.addDeclaration(`var<${this.scope}> ${r}: ${t.resolve(this._dataType)};`),r}$name(t){return w(this,t),this}toString(){return`var:${p(this)??"<unnamed>"}`}get value(){if(!de())throw new Error("Cannot access tgpu.var's value directly in JS.");return new Proxy({"~resolve":t=>t.resolve(this),toString:()=>`.value:${p(this)??"<unnamed>"}`,[m]:{dataType:this._dataType}},Y)}};var oa={bindGroupLayout:It,vertexLayout:Lr,init:Xn,initFromDevice:Zn,resolve:zn,"~unstable":{fn:Wn,fragmentFn:Nn,vertexFn:jn,computeFn:Gn,vertexLayout:Lr,derived:ta,slot:Et,accessor:ea,privateVar:na,workgroupVar:aa,const:ln,declare:mn,sampler:An,comparisonSampler:In}},jp=oa;Object.assign(oa,{__assignAst:cn,__removedJsImpl:yn});export{le as MissingBindGroupsError,Gt as MissingLinksError,_t as MissingSlotValueError,Ee as MissingVertexBuffersError,Ot as NotUniformError,ie as RandomNameRegistry,we as ResolutionError,ue as StrictNameRegistry,jp as default,ae as isBuffer,Qe as isComparisonSampler,q as isDerived,et as isSampledTextureView,Ye as isSampler,H as isSlot,Ze as isStorageTextureView,X as isTexture,Pr as isTgpuFn,Fa as isUsableAsRender,Sr as isUsableAsSampled,xe as isUsableAsStorage,xt as isUsableAsUniform,Da as isUsableAsVertex,oa as tgpu,mr as unstable_asMutable,fr as unstable_asReadonly,gr as unstable_asUniform};
26
30
  //# sourceMappingURL=index.js.map