2022-01-17 14:46:45 +01:00
2022-02-13 09:50:27 +01:00
var CanvasKitInit = ( ( ) => {
2022-01-17 14:46:45 +01:00
var _scriptDir = typeof document !== 'undefined' && document . currentScript ? document . currentScript . src : undefined ;
if ( typeof _ _filename !== 'undefined' ) _scriptDir = _scriptDir || _ _filename ;
return (
2023-12-20 09:52:22 +01:00
function ( moduleArg = { } ) {
2022-01-17 14:46:45 +01:00
2023-12-20 09:52:22 +01:00
var r = moduleArg , aa , ba ; r . ready = new Promise ( ( a , b ) => { aa = a ; ba = b } ) ;
( function ( a ) { a . Md = a . Md || [ ] ; a . Md . push ( function ( ) { a . MakeSWCanvasSurface = function ( b ) { var c = b , d = "undefined" !== typeof OffscreenCanvas && c instanceof OffscreenCanvas ; if ( ! ( "undefined" !== typeof HTMLCanvasElement && c instanceof HTMLCanvasElement || d || ( c = document . getElementById ( b ) , c ) ) ) throw "Canvas with id " + b + " was not found" ; if ( b = a . MakeSurface ( c . width , c . height ) ) b . me = c ; return b } ; a . MakeCanvasSurface || ( a . MakeCanvasSurface = a . MakeSWCanvasSurface ) ; a . MakeSurface = function ( b , c ) { var d = { width : b , height : c , colorType : a . ColorType . RGBA _8888 ,
alphaType : a . AlphaType . Unpremul , colorSpace : a . ColorSpace . SRGB } , f = b * c * 4 , k = a . _malloc ( f ) ; if ( d = a . Surface . _makeRasterDirect ( d , k , 4 * b ) ) d . me = null , d . Ue = b , d . Re = c , d . Se = f , d . xe = k , d . getCanvas ( ) . clear ( a . TRANSPARENT ) ; return d } ; a . MakeRasterDirectSurface = function ( b , c , d ) { return a . Surface . _makeRasterDirect ( b , c . byteOffset , d ) } ; a . Surface . prototype . flush = function ( b ) { a . Jd ( this . Id ) ; this . _flush ( ) ; if ( this . me ) { var c = new Uint8ClampedArray ( a . HEAPU8 . buffer , this . xe , this . Se ) ; c = new ImageData ( c , this . Ue , this . Re ) ; b ? this . me . getContext ( "2d" ) . putImageData ( c ,
0 , 0 , b [ 0 ] , b [ 1 ] , b [ 2 ] - b [ 0 ] , b [ 3 ] - b [ 1 ] ) : this . me . getContext ( "2d" ) . putImageData ( c , 0 , 0 ) } } ; a . Surface . prototype . dispose = function ( ) { this . xe && a . _free ( this . xe ) ; this . delete ( ) } ; a . Jd = a . Jd || function ( ) { } ; a . ne = a . ne || function ( ) { return null } } ) } ) ( r ) ;
( function ( a ) { a . Md = a . Md || [ ] ; a . Md . push ( function ( ) { function b ( m , p , w ) { return m && m . hasOwnProperty ( p ) ? m [ p ] : w } function c ( m ) { var p = da ( ea ) ; ea [ p ] = m ; return p } function d ( m ) { return m . naturalHeight || m . videoHeight || m . displayHeight || m . height } function f ( m ) { return m . naturalWidth || m . videoWidth || m . displayWidth || m . width } function k ( m , p , w , y ) { m . bindTexture ( m . TEXTURE _2D , p ) ; y || w . alphaType !== a . AlphaType . Premul || m . pixelStorei ( m . UNPACK _PREMULTIPLY _ALPHA _WEBGL , ! 0 ) ; return p } function l ( m , p , w ) { w || p . alphaType !== a . AlphaType . Premul ||
m . pixelStorei ( m . UNPACK _PREMULTIPLY _ALPHA _WEBGL , ! 1 ) ; m . bindTexture ( m . TEXTURE _2D , null ) } a . GetWebGLContext = function ( m , p ) { if ( ! m ) throw "null canvas passed into makeWebGLContext" ; var w = { alpha : b ( p , "alpha" , 1 ) , depth : b ( p , "depth" , 1 ) , stencil : b ( p , "stencil" , 8 ) , antialias : b ( p , "antialias" , 0 ) , premultipliedAlpha : b ( p , "premultipliedAlpha" , 1 ) , preserveDrawingBuffer : b ( p , "preserveDrawingBuffer" , 0 ) , preferLowPowerToHighPerformance : b ( p , "preferLowPowerToHighPerformance" , 0 ) , failIfMajorPerformanceCaveat : b ( p , "failIfMajorPerformanceCaveat" ,
0 ) , enableExtensionsByDefault : b ( p , "enableExtensionsByDefault" , 1 ) , explicitSwapControl : b ( p , "explicitSwapControl" , 0 ) , renderViaOffscreenBackBuffer : b ( p , "renderViaOffscreenBackBuffer" , 0 ) } ; w . majorVersion = p && p . majorVersion ? p . majorVersion : "undefined" !== typeof WebGL2RenderingContext ? 2 : 1 ; if ( w . explicitSwapControl ) throw "explicitSwapControl is not supported" ; m = fa ( m , w ) ; if ( ! m ) return 0 ; ha ( m ) ; v . Ud . getExtension ( "WEBGL_debug_renderer_info" ) ; return m } ; a . deleteContext = function ( m ) { v === ia [ m ] && ( v = null ) ; "object" == typeof JSEvents &&
JSEvents . yf ( ia [ m ] . Ud . canvas ) ; ia [ m ] && ia [ m ] . Ud . canvas && ( ia [ m ] . Ud . canvas . Oe = void 0 ) ; ia [ m ] = null } ; a . _setTextureCleanup ( { deleteTexture : function ( m , p ) { var w = ea [ p ] ; w && ia [ m ] . Ud . deleteTexture ( w ) ; ea [ p ] = null } } ) ; a . MakeWebGLContext = function ( m ) { if ( ! this . Jd ( m ) ) return null ; var p = this . _MakeGrContext ( ) ; if ( ! p ) return null ; p . Id = m ; var w = p . delete . bind ( p ) ; p [ "delete" ] = function ( ) { a . Jd ( this . Id ) ; w ( ) } . bind ( p ) ; return v . ze = p } ; a . MakeGrContext = a . MakeWebGLContext ; a . GrDirectContext . prototype . getResourceCacheLimitBytes = function ( ) { a . Jd ( this . Id ) ;
this . _getResourceCacheLimitBytes ( ) } ; a . GrDirectContext . prototype . getResourceCacheUsageBytes = function ( ) { a . Jd ( this . Id ) ; this . _getResourceCacheUsageBytes ( ) } ; a . GrDirectContext . prototype . releaseResourcesAndAbandonContext = function ( ) { a . Jd ( this . Id ) ; this . _releaseResourcesAndAbandonContext ( ) } ; a . GrDirectContext . prototype . setResourceCacheLimitBytes = function ( m ) { a . Jd ( this . Id ) ; this . _setResourceCacheLimitBytes ( m ) } ; a . MakeOnScreenGLSurface = function ( m , p , w , y , B , D ) { if ( ! this . Jd ( m . Id ) ) return null ; p = void 0 === B || void 0 === D ?
this . _MakeOnScreenGLSurface ( m , p , w , y ) : this . _MakeOnScreenGLSurface ( m , p , w , y , B , D ) ; if ( ! p ) return null ; p . Id = m . Id ; return p } ; a . MakeRenderTarget = function ( ) { var m = arguments [ 0 ] ; if ( ! this . Jd ( m . Id ) ) return null ; if ( 3 === arguments . length ) { var p = this . _MakeRenderTargetWH ( m , arguments [ 1 ] , arguments [ 2 ] ) ; if ( ! p ) return null } else if ( 2 === arguments . length ) { if ( p = this . _MakeRenderTargetII ( m , arguments [ 1 ] ) , ! p ) return null } else return null ; p . Id = m . Id ; return p } ; a . MakeWebGLCanvasSurface = function ( m , p , w ) { p = p || null ; var y = m , B = "undefined" !==
typeof OffscreenCanvas && y instanceof OffscreenCanvas ; if ( ! ( "undefined" !== typeof HTMLCanvasElement && y instanceof HTMLCanvasElement || B || ( y = document . getElementById ( m ) , y ) ) ) throw "Canvas with id " + m + " was not found" ; m = this . GetWebGLContext ( y , w ) ; if ( ! m || 0 > m ) throw "failed to create webgl context: err " + m ; m = this . MakeWebGLContext ( m ) ; p = this . MakeOnScreenGLSurface ( m , y . width , y . height , p ) ; return p ? p : ( p = y . cloneNode ( ! 0 ) , y . parentNode . replaceChild ( p , y ) , p . classList . add ( "ck-replaced" ) , a . MakeSWCanvasSurface ( p ) ) } ; a . MakeCanvasSurface =
a . MakeWebGLCanvasSurface ; a . Surface . prototype . makeImageFromTexture = function ( m , p ) { a . Jd ( this . Id ) ; m = c ( m ) ; if ( p = this . _makeImageFromTexture ( this . Id , m , p ) ) p . he = m ; return p } ; a . Surface . prototype . makeImageFromTextureSource = function ( m , p , w ) { p || ( p = { height : d ( m ) , width : f ( m ) , colorType : a . ColorType . RGBA _8888 , alphaType : w ? a . AlphaType . Premul : a . AlphaType . Unpremul } ) ; p . colorSpace || ( p . colorSpace = a . ColorSpace . SRGB ) ; a . Jd ( this . Id ) ; var y = v . Ud ; w = k ( y , y . createTexture ( ) , p , w ) ; 2 === v . version ? y . texImage2D ( y . TEXTURE _2D , 0 , y . RGBA , p . width , p . height ,
0 , y . RGBA , y . UNSIGNED _BYTE , m ) : y . texImage2D ( y . TEXTURE _2D , 0 , y . RGBA , y . RGBA , y . UNSIGNED _BYTE , m ) ; l ( y , p ) ; this . _resetContext ( ) ; return this . makeImageFromTexture ( w , p ) } ; a . Surface . prototype . updateTextureFromSource = function ( m , p , w ) { if ( m . he ) { a . Jd ( this . Id ) ; var y = m . getImageInfo ( ) , B = v . Ud , D = k ( B , ea [ m . he ] , y , w ) ; 2 === v . version ? B . texImage2D ( B . TEXTURE _2D , 0 , B . RGBA , f ( p ) , d ( p ) , 0 , B . RGBA , B . UNSIGNED _BYTE , p ) : B . texImage2D ( B . TEXTURE _2D , 0 , B . RGBA , B . RGBA , B . UNSIGNED _BYTE , p ) ; l ( B , y , w ) ; this . _resetContext ( ) ; ea [ m . he ] = null ; m . he = c ( D ) ; y . colorSpace =
m . getColorSpace ( ) ; p = this . _makeImageFromTexture ( this . Id , m . he , y ) ; w = m . kd . Kd ; B = m . kd . Pd ; m . kd . Kd = p . kd . Kd ; m . kd . Pd = p . kd . Pd ; p . kd . Kd = w ; p . kd . Pd = B ; p . delete ( ) ; y . colorSpace . delete ( ) } } ; a . MakeLazyImageFromTextureSource = function ( m , p , w ) { p || ( p = { height : d ( m ) , width : f ( m ) , colorType : a . ColorType . RGBA _8888 , alphaType : w ? a . AlphaType . Premul : a . AlphaType . Unpremul } ) ; p . colorSpace || ( p . colorSpace = a . ColorSpace . SRGB ) ; var y = { makeTexture : function ( ) { var B = v , D = B . Ud , u = k ( D , D . createTexture ( ) , p , w ) ; 2 === B . version ? D . texImage2D ( D . TEXTURE _2D , 0 , D . RGBA ,
p . width , p . height , 0 , D . RGBA , D . UNSIGNED _BYTE , m ) : D . texImage2D ( D . TEXTURE _2D , 0 , D . RGBA , D . RGBA , D . UNSIGNED _BYTE , m ) ; l ( D , p , w ) ; return c ( u ) } , freeSrc : function ( ) { } } ; "VideoFrame" === m . constructor . name && ( y . freeSrc = function ( ) { m . close ( ) } ) ; return a . Image . _makeFromGenerator ( p , y ) } ; a . Jd = function ( m ) { return m ? ha ( m ) : ! 1 } ; a . ne = function ( ) { return v && v . ze && ! v . ze . isDeleted ( ) ? v . ze : null } } ) } ) ( r ) ;
( function ( a ) { function b ( g ) { return ( f ( 255 * g [ 3 ] ) << 24 | f ( 255 * g [ 0 ] ) << 16 | f ( 255 * g [ 1 ] ) << 8 | f ( 255 * g [ 2 ] ) << 0 ) >>> 0 } function c ( g ) { if ( g && g . _ck ) return g ; if ( g instanceof Float32Array ) { for ( var e = Math . floor ( g . length / 4 ) , h = new Uint32Array ( e ) , n = 0 ; n < e ; n ++ ) h [ n ] = b ( g . slice ( 4 * n , 4 * ( n + 1 ) ) ) ; return h } if ( g instanceof Uint32Array ) return g ; if ( g instanceof Array && g [ 0 ] instanceof Float32Array ) return g . map ( b ) } function d ( g ) { if ( void 0 === g ) return 1 ; var e = parseFloat ( g ) ; return g && - 1 !== g . indexOf ( "%" ) ? e / 100 : e } function f ( g ) { return Math . round ( Math . max ( 0 ,
Math . min ( g || 0 , 255 ) ) ) } function k ( g , e ) { e && e . _ck || a . _free ( g ) } function l ( g , e , h ) { if ( ! g || ! g . length ) return M ; if ( g && g . _ck ) return g . byteOffset ; var n = a [ e ] . BYTES _PER _ELEMENT ; h || ( h = a . _malloc ( g . length * n ) ) ; a [ e ] . set ( g , h / n ) ; return h } function m ( g ) { var e = { Rd : M , count : g . length , colorType : a . ColorType . RGBA _F32 } ; if ( g instanceof Float32Array ) e . Rd = l ( g , "HEAPF32" ) , e . count = g . length / 4 ; else if ( g instanceof Uint32Array ) e . Rd = l ( g , "HEAPU32" ) , e . colorType = a . ColorType . RGBA _8888 ; else if ( g instanceof Array ) { if ( g && g . length ) { for ( var h = a . _malloc ( 16 *
g . length ) , n = 0 , t = h / 4 , x = 0 ; x < g . length ; x ++ ) for ( var z = 0 ; 4 > z ; z ++ ) a . HEAPF32 [ t + n ] = g [ x ] [ z ] , n ++ ; g = h } else g = M ; e . Rd = g } else throw "Invalid argument to copyFlexibleColorArray, Not a color array " + typeof g ; return e } function p ( g ) { if ( ! g ) return M ; var e = T . toTypedArray ( ) ; if ( g . length ) { if ( 6 === g . length || 9 === g . length ) return l ( g , "HEAPF32" , H ) , 6 === g . length && a . HEAPF32 . set ( fd , 6 + H / 4 ) , H ; if ( 16 === g . length ) return e [ 0 ] = g [ 0 ] , e [ 1 ] = g [ 1 ] , e [ 2 ] = g [ 3 ] , e [ 3 ] = g [ 4 ] , e [ 4 ] = g [ 5 ] , e [ 5 ] = g [ 7 ] , e [ 6 ] = g [ 12 ] , e [ 7 ] = g [ 13 ] , e [ 8 ] = g [ 15 ] , H ; throw "invalid matrix size" ;
} if ( void 0 === g . m11 ) throw "invalid matrix argument" ; e [ 0 ] = g . m11 ; e [ 1 ] = g . m21 ; e [ 2 ] = g . m41 ; e [ 3 ] = g . m12 ; e [ 4 ] = g . m22 ; e [ 5 ] = g . m42 ; e [ 6 ] = g . m14 ; e [ 7 ] = g . m24 ; e [ 8 ] = g . m44 ; return H } function w ( g ) { if ( ! g ) return M ; var e = Y . toTypedArray ( ) ; if ( g . length ) { if ( 16 !== g . length && 6 !== g . length && 9 !== g . length ) throw "invalid matrix size" ; if ( 16 === g . length ) return l ( g , "HEAPF32" , ca ) ; e . fill ( 0 ) ; e [ 0 ] = g [ 0 ] ; e [ 1 ] = g [ 1 ] ; e [ 3 ] = g [ 2 ] ; e [ 4 ] = g [ 3 ] ; e [ 5 ] = g [ 4 ] ; e [ 7 ] = g [ 5 ] ; e [ 10 ] = 1 ; e [ 12 ] = g [ 6 ] ; e [ 13 ] = g [ 7 ] ; e [ 15 ] = g [ 8 ] ; 6 === g . length && ( e [ 12 ] = 0 , e [ 13 ] = 0 , e [ 15 ] = 1 ) ; return ca } if ( void 0 ===
g . m11 ) throw "invalid matrix argument" ; e [ 0 ] = g . m11 ; e [ 1 ] = g . m21 ; e [ 2 ] = g . m31 ; e [ 3 ] = g . m41 ; e [ 4 ] = g . m12 ; e [ 5 ] = g . m22 ; e [ 6 ] = g . m32 ; e [ 7 ] = g . m42 ; e [ 8 ] = g . m13 ; e [ 9 ] = g . m23 ; e [ 10 ] = g . m33 ; e [ 11 ] = g . m43 ; e [ 12 ] = g . m14 ; e [ 13 ] = g . m24 ; e [ 14 ] = g . m34 ; e [ 15 ] = g . m44 ; return ca } function y ( g , e ) { return l ( g , "HEAPF32" , e || va ) } function B ( g , e , h , n ) { var t = Ma . toTypedArray ( ) ; t [ 0 ] = g ; t [ 1 ] = e ; t [ 2 ] = h ; t [ 3 ] = n ; return va } function D ( g ) { for ( var e = new Float32Array ( 4 ) , h = 0 ; 4 > h ; h ++ ) e [ h ] = a . HEAPF32 [ g / 4 + h ] ; return e } function u ( g , e ) { return l ( g , "HEAPF32" , e || X ) } function F ( g , e ) { return l ( g ,
"HEAPF32" , e || Eb ) } a . Color = function ( g , e , h , n ) { void 0 === n && ( n = 1 ) ; return a . Color4f ( f ( g ) / 255 , f ( e ) / 255 , f ( h ) / 255 , n ) } ; a . ColorAsInt = function ( g , e , h , n ) { void 0 === n && ( n = 255 ) ; return ( f ( n ) << 24 | f ( g ) << 16 | f ( e ) << 8 | f ( h ) << 0 & 268435455 ) >>> 0 } ; a . Color4f = function ( g , e , h , n ) { void 0 === n && ( n = 1 ) ; return Float32Array . of ( g , e , h , n ) } ; Object . defineProperty ( a , "TRANSPARENT" , { get : function ( ) { return a . Color4f ( 0 , 0 , 0 , 0 ) } } ) ; Object . defineProperty ( a , "BLACK" , { get : function ( ) { return a . Color4f ( 0 , 0 , 0 , 1 ) } } ) ; Object . defineProperty ( a , "WHITE" , { get : function ( ) { return a . Color4f ( 1 ,
2023-10-28 19:10:11 +02:00
1 , 1 , 1 ) } } ) ; Object . defineProperty ( a , "RED" , { get : function ( ) { return a . Color4f ( 1 , 0 , 0 , 1 ) } } ) ; Object . defineProperty ( a , "GREEN" , { get : function ( ) { return a . Color4f ( 0 , 1 , 0 , 1 ) } } ) ; Object . defineProperty ( a , "BLUE" , { get : function ( ) { return a . Color4f ( 0 , 0 , 1 , 1 ) } } ) ; Object . defineProperty ( a , "YELLOW" , { get : function ( ) { return a . Color4f ( 1 , 1 , 0 , 1 ) } } ) ; Object . defineProperty ( a , "CYAN" , { get : function ( ) { return a . Color4f ( 0 , 1 , 1 , 1 ) } } ) ; Object . defineProperty ( a , "MAGENTA" , { get : function ( ) { return a . Color4f ( 1 , 0 , 1 , 1 ) } } ) ; a . getColorComponents = function ( g ) { return [ Math . floor ( 255 *
2023-12-20 09:52:22 +01:00
g [ 0 ] ) , Math . floor ( 255 * g [ 1 ] ) , Math . floor ( 255 * g [ 2 ] ) , g [ 3 ] ] } ; a . parseColorString = function ( g , e ) { g = g . toLowerCase ( ) ; if ( g . startsWith ( "#" ) ) { e = 255 ; switch ( g . length ) { case 9 : e = parseInt ( g . slice ( 7 , 9 ) , 16 ) ; case 7 : var h = parseInt ( g . slice ( 1 , 3 ) , 16 ) ; var n = parseInt ( g . slice ( 3 , 5 ) , 16 ) ; var t = parseInt ( g . slice ( 5 , 7 ) , 16 ) ; break ; case 5 : e = 17 * parseInt ( g . slice ( 4 , 5 ) , 16 ) ; case 4 : h = 17 * parseInt ( g . slice ( 1 , 2 ) , 16 ) , n = 17 * parseInt ( g . slice ( 2 , 3 ) , 16 ) , t = 17 * parseInt ( g . slice ( 3 , 4 ) , 16 ) } return a . Color ( h , n , t , e / 255 ) } return g . startsWith ( "rgba" ) ? ( g = g . slice ( 5 ,
- 1 ) , g = g . split ( "," ) , a . Color ( + g [ 0 ] , + g [ 1 ] , + g [ 2 ] , d ( g [ 3 ] ) ) ) : g . startsWith ( "rgb" ) ? ( g = g . slice ( 4 , - 1 ) , g = g . split ( "," ) , a . Color ( + g [ 0 ] , + g [ 1 ] , + g [ 2 ] , d ( g [ 3 ] ) ) ) : g . startsWith ( "gray(" ) || g . startsWith ( "hsl" ) || ! e || ( g = e [ g ] , void 0 === g ) ? a . BLACK : g } ; a . multiplyByAlpha = function ( g , e ) { g = g . slice ( ) ; g [ 3 ] = Math . max ( 0 , Math . min ( g [ 3 ] * e , 1 ) ) ; return g } ; a . Malloc = function ( g , e ) { var h = a . _malloc ( e * g . BYTES _PER _ELEMENT ) ; return { _ck : ! 0 , length : e , byteOffset : h , be : null , subarray : function ( n , t ) { n = this . toTypedArray ( ) . subarray ( n , t ) ; n . _ck = ! 0 ; return n } , toTypedArray : function ( ) { if ( this . be &&
this . be . length ) return this . be ; this . be = new g ( a . HEAPU8 . buffer , h , e ) ; this . be . _ck = ! 0 ; return this . be } } } ; a . Free = function ( g ) { a . _free ( g . byteOffset ) ; g . byteOffset = M ; g . toTypedArray = null ; g . be = null } ; var H = M , T , ca = M , Y , va = M , Ma , na , X = M , fc , Ba = M , gc , Fb = M , hc , Gb = M , hb , Sa = M , ic , Eb = M , jc , kc = M , fd = Float32Array . of ( 0 , 0 , 1 ) , M = 0 ; a . onRuntimeInitialized = function ( ) { function g ( e , h , n , t , x , z , E ) { z || ( z = 4 * t . width , t . colorType === a . ColorType . RGBA _F16 ? z *= 2 : t . colorType === a . ColorType . RGBA _F32 && ( z *= 4 ) ) ; var J = z * t . height ; var I = x ? x . byteOffset : a . _malloc ( J ) ;
if ( E ? ! e . _readPixels ( t , I , z , h , n , E ) : ! e . _readPixels ( t , I , z , h , n ) ) return x || a . _free ( I ) , null ; if ( x ) return x . toTypedArray ( ) ; switch ( t . colorType ) { case a . ColorType . RGBA _8888 : case a . ColorType . RGBA _F16 : e = ( new Uint8Array ( a . HEAPU8 . buffer , I , J ) ) . slice ( ) ; break ; case a . ColorType . RGBA _F32 : e = ( new Float32Array ( a . HEAPU8 . buffer , I , J ) ) . slice ( ) ; break ; default : return null } a . _free ( I ) ; return e } Ma = a . Malloc ( Float32Array , 4 ) ; va = Ma . byteOffset ; Y = a . Malloc ( Float32Array , 16 ) ; ca = Y . byteOffset ; T = a . Malloc ( Float32Array , 9 ) ; H = T . byteOffset ; ic = a . Malloc ( Float32Array ,
12 ) ; Eb = ic . byteOffset ; jc = a . Malloc ( Float32Array , 12 ) ; kc = jc . byteOffset ; na = a . Malloc ( Float32Array , 4 ) ; X = na . byteOffset ; fc = a . Malloc ( Float32Array , 4 ) ; Ba = fc . byteOffset ; gc = a . Malloc ( Float32Array , 3 ) ; Fb = gc . byteOffset ; hc = a . Malloc ( Float32Array , 3 ) ; Gb = hc . byteOffset ; hb = a . Malloc ( Int32Array , 4 ) ; Sa = hb . byteOffset ; a . ColorSpace . SRGB = a . ColorSpace . _MakeSRGB ( ) ; a . ColorSpace . DISPLAY _P3 = a . ColorSpace . _MakeDisplayP3 ( ) ; a . ColorSpace . ADOBE _RGB = a . ColorSpace . _MakeAdobeRGB ( ) ; a . GlyphRunFlags = { IsWhiteSpace : a . _GlyphRunFlags _isWhiteSpace } ; a . Path . MakeFromCmds =
function ( e ) { var h = l ( e , "HEAPF32" ) , n = a . Path . _MakeFromCmds ( h , e . length ) ; k ( h , e ) ; return n } ; a . Path . MakeFromVerbsPointsWeights = function ( e , h , n ) { var t = l ( e , "HEAPU8" ) , x = l ( h , "HEAPF32" ) , z = l ( n , "HEAPF32" ) , E = a . Path . _MakeFromVerbsPointsWeights ( t , e . length , x , h . length , z , n && n . length || 0 ) ; k ( t , e ) ; k ( x , h ) ; k ( z , n ) ; return E } ; a . Path . prototype . addArc = function ( e , h , n ) { e = u ( e ) ; this . _addArc ( e , h , n ) ; return this } ; a . Path . prototype . addCircle = function ( e , h , n , t ) { this . _addCircle ( e , h , n , ! ! t ) ; return this } ; a . Path . prototype . addOval = function ( e , h , n ) { void 0 ===
n && ( n = 1 ) ; e = u ( e ) ; this . _addOval ( e , ! ! h , n ) ; return this } ; a . Path . prototype . addPath = function ( ) { var e = Array . prototype . slice . call ( arguments ) , h = e [ 0 ] , n = ! 1 ; "boolean" === typeof e [ e . length - 1 ] && ( n = e . pop ( ) ) ; if ( 1 === e . length ) this . _addPath ( h , 1 , 0 , 0 , 0 , 1 , 0 , 0 , 0 , 1 , n ) ; else if ( 2 === e . length ) e = e [ 1 ] , this . _addPath ( h , e [ 0 ] , e [ 1 ] , e [ 2 ] , e [ 3 ] , e [ 4 ] , e [ 5 ] , e [ 6 ] || 0 , e [ 7 ] || 0 , e [ 8 ] || 1 , n ) ; else if ( 7 === e . length || 10 === e . length ) this . _addPath ( h , e [ 1 ] , e [ 2 ] , e [ 3 ] , e [ 4 ] , e [ 5 ] , e [ 6 ] , e [ 7 ] || 0 , e [ 8 ] || 0 , e [ 9 ] || 1 , n ) ; else return null ; return this } ; a . Path . prototype . addPoly =
function ( e , h ) { var n = l ( e , "HEAPF32" ) ; this . _addPoly ( n , e . length / 2 , h ) ; k ( n , e ) ; return this } ; a . Path . prototype . addRect = function ( e , h ) { e = u ( e ) ; this . _addRect ( e , ! ! h ) ; return this } ; a . Path . prototype . addRRect = function ( e , h ) { e = F ( e ) ; this . _addRRect ( e , ! ! h ) ; return this } ; a . Path . prototype . addVerbsPointsWeights = function ( e , h , n ) { var t = l ( e , "HEAPU8" ) , x = l ( h , "HEAPF32" ) , z = l ( n , "HEAPF32" ) ; this . _addVerbsPointsWeights ( t , e . length , x , h . length , z , n && n . length || 0 ) ; k ( t , e ) ; k ( x , h ) ; k ( z , n ) } ; a . Path . prototype . arc = function ( e , h , n , t , x , z ) { e = a . LTRBRect ( e -
n , h - n , e + n , h + n ) ; x = ( x - t ) / Math . PI * 180 - 360 * ! ! z ; z = new a . Path ; z . addArc ( e , t / Math . PI * 180 , x ) ; this . addPath ( z , ! 0 ) ; z . delete ( ) ; return this } ; a . Path . prototype . arcToOval = function ( e , h , n , t ) { e = u ( e ) ; this . _arcToOval ( e , h , n , t ) ; return this } ; a . Path . prototype . arcToRotated = function ( e , h , n , t , x , z , E ) { this . _arcToRotated ( e , h , n , ! ! t , ! ! x , z , E ) ; return this } ; a . Path . prototype . arcToTangent = function ( e , h , n , t , x ) { this . _arcToTangent ( e , h , n , t , x ) ; return this } ; a . Path . prototype . close = function ( ) { this . _close ( ) ; return this } ; a . Path . prototype . conicTo =
function ( e , h , n , t , x ) { this . _conicTo ( e , h , n , t , x ) ; return this } ; a . Path . prototype . computeTightBounds = function ( e ) { this . _computeTightBounds ( X ) ; var h = na . toTypedArray ( ) ; return e ? ( e . set ( h ) , e ) : h . slice ( ) } ; a . Path . prototype . cubicTo = function ( e , h , n , t , x , z ) { this . _cubicTo ( e , h , n , t , x , z ) ; return this } ; a . Path . prototype . dash = function ( e , h , n ) { return this . _dash ( e , h , n ) ? this : null } ; a . Path . prototype . getBounds = function ( e ) { this . _getBounds ( X ) ; var h = na . toTypedArray ( ) ; return e ? ( e . set ( h ) , e ) : h . slice ( ) } ; a . Path . prototype . lineTo = function ( e ,
h ) { this . _lineTo ( e , h ) ; return this } ; a . Path . prototype . moveTo = function ( e , h ) { this . _moveTo ( e , h ) ; return this } ; a . Path . prototype . offset = function ( e , h ) { this . _transform ( 1 , 0 , e , 0 , 1 , h , 0 , 0 , 1 ) ; return this } ; a . Path . prototype . quadTo = function ( e , h , n , t ) { this . _quadTo ( e , h , n , t ) ; return this } ; a . Path . prototype . rArcTo = function ( e , h , n , t , x , z , E ) { this . _rArcTo ( e , h , n , t , x , z , E ) ; return this } ; a . Path . prototype . rConicTo = function ( e , h , n , t , x ) { this . _rConicTo ( e , h , n , t , x ) ; return this } ; a . Path . prototype . rCubicTo = function ( e , h , n , t , x , z ) { this . _rCubicTo ( e ,
h , n , t , x , z ) ; return this } ; a . Path . prototype . rLineTo = function ( e , h ) { this . _rLineTo ( e , h ) ; return this } ; a . Path . prototype . rMoveTo = function ( e , h ) { this . _rMoveTo ( e , h ) ; return this } ; a . Path . prototype . rQuadTo = function ( e , h , n , t ) { this . _rQuadTo ( e , h , n , t ) ; return this } ; a . Path . prototype . stroke = function ( e ) { e = e || { } ; e . width = e . width || 1 ; e . miter _limit = e . miter _limit || 4 ; e . cap = e . cap || a . StrokeCap . Butt ; e . join = e . join || a . StrokeJoin . Miter ; e . precision = e . precision || 1 ; return this . _stroke ( e ) ? this : null } ; a . Path . prototype . transform = function ( ) { if ( 1 ===
arguments . length ) { var e = arguments [ 0 ] ; this . _transform ( e [ 0 ] , e [ 1 ] , e [ 2 ] , e [ 3 ] , e [ 4 ] , e [ 5 ] , e [ 6 ] || 0 , e [ 7 ] || 0 , e [ 8 ] || 1 ) } else if ( 6 === arguments . length || 9 === arguments . length ) e = arguments , this . _transform ( e [ 0 ] , e [ 1 ] , e [ 2 ] , e [ 3 ] , e [ 4 ] , e [ 5 ] , e [ 6 ] || 0 , e [ 7 ] || 0 , e [ 8 ] || 1 ) ; else throw "transform expected to take 1 or 9 arguments. Got " + arguments . length ; return this } ; a . Path . prototype . trim = function ( e , h , n ) { return this . _trim ( e , h , ! ! n ) ? this : null } ; a . Image . prototype . encodeToBytes = function ( e , h ) { var n = a . ne ( ) ; e = e || a . ImageFormat . PNG ; h = h || 100 ;
return n ? this . _encodeToBytes ( e , h , n ) : this . _encodeToBytes ( e , h ) } ; a . Image . prototype . makeShaderCubic = function ( e , h , n , t , x ) { x = p ( x ) ; return this . _makeShaderCubic ( e , h , n , t , x ) } ; a . Image . prototype . makeShaderOptions = function ( e , h , n , t , x ) { x = p ( x ) ; return this . _makeShaderOptions ( e , h , n , t , x ) } ; a . Image . prototype . readPixels = function ( e , h , n , t , x ) { var z = a . ne ( ) ; return g ( this , e , h , n , t , x , z ) } ; a . Canvas . prototype . clear = function ( e ) { a . Jd ( this . Id ) ; e = y ( e ) ; this . _clear ( e ) } ; a . Canvas . prototype . clipRRect = function ( e , h , n ) { a . Jd ( this . Id ) ; e = F ( e ) ; this . _clipRRect ( e ,
h , n ) } ; a . Canvas . prototype . clipRect = function ( e , h , n ) { a . Jd ( this . Id ) ; e = u ( e ) ; this . _clipRect ( e , h , n ) } ; a . Canvas . prototype . concat = function ( e ) { a . Jd ( this . Id ) ; e = w ( e ) ; this . _concat ( e ) } ; a . Canvas . prototype . drawArc = function ( e , h , n , t , x ) { a . Jd ( this . Id ) ; e = u ( e ) ; this . _drawArc ( e , h , n , t , x ) } ; a . Canvas . prototype . drawAtlas = function ( e , h , n , t , x , z , E ) { if ( e && t && h && n && h . length === n . length ) { a . Jd ( this . Id ) ; x || ( x = a . BlendMode . SrcOver ) ; var J = l ( h , "HEAPF32" ) , I = l ( n , "HEAPF32" ) , U = n . length / 4 , V = l ( c ( z ) , "HEAPU32" ) ; if ( E && "B" in E && "C" in E ) this . _drawAtlasCubic ( e ,
I , J , V , U , x , E . B , E . C , t ) ; else { let q = a . FilterMode . Linear , A = a . MipmapMode . None ; E && ( q = E . filter , "mipmap" in E && ( A = E . mipmap ) ) ; this . _drawAtlasOptions ( e , I , J , V , U , x , q , A , t ) } k ( J , h ) ; k ( I , n ) ; k ( V , z ) } } ; a . Canvas . prototype . drawCircle = function ( e , h , n , t ) { a . Jd ( this . Id ) ; this . _drawCircle ( e , h , n , t ) } ; a . Canvas . prototype . drawColor = function ( e , h ) { a . Jd ( this . Id ) ; e = y ( e ) ; void 0 !== h ? this . _drawColor ( e , h ) : this . _drawColor ( e ) } ; a . Canvas . prototype . drawColorInt = function ( e , h ) { a . Jd ( this . Id ) ; this . _drawColorInt ( e , h || a . BlendMode . SrcOver ) } ; a . Canvas . prototype . drawColorComponents =
function ( e , h , n , t , x ) { a . Jd ( this . Id ) ; e = B ( e , h , n , t ) ; void 0 !== x ? this . _drawColor ( e , x ) : this . _drawColor ( e ) } ; a . Canvas . prototype . drawDRRect = function ( e , h , n ) { a . Jd ( this . Id ) ; e = F ( e , Eb ) ; h = F ( h , kc ) ; this . _drawDRRect ( e , h , n ) } ; a . Canvas . prototype . drawImage = function ( e , h , n , t ) { a . Jd ( this . Id ) ; this . _drawImage ( e , h , n , t || null ) } ; a . Canvas . prototype . drawImageCubic = function ( e , h , n , t , x , z ) { a . Jd ( this . Id ) ; this . _drawImageCubic ( e , h , n , t , x , z || null ) } ; a . Canvas . prototype . drawImageOptions = function ( e , h , n , t , x , z ) { a . Jd ( this . Id ) ; this . _drawImageOptions ( e ,
h , n , t , x , z || null ) } ; a . Canvas . prototype . drawImageNine = function ( e , h , n , t , x ) { a . Jd ( this . Id ) ; h = l ( h , "HEAP32" , Sa ) ; n = u ( n ) ; this . _drawImageNine ( e , h , n , t , x || null ) } ; a . Canvas . prototype . drawImageRect = function ( e , h , n , t , x ) { a . Jd ( this . Id ) ; u ( h , X ) ; u ( n , Ba ) ; this . _drawImageRect ( e , X , Ba , t , ! ! x ) } ; a . Canvas . prototype . drawImageRectCubic = function ( e , h , n , t , x , z ) { a . Jd ( this . Id ) ; u ( h , X ) ; u ( n , Ba ) ; this . _drawImageRectCubic ( e , X , Ba , t , x , z || null ) } ; a . Canvas . prototype . drawImageRectOptions = function ( e , h , n , t , x , z ) { a . Jd ( this . Id ) ; u ( h , X ) ; u ( n , Ba ) ; this . _drawImageRectOptions ( e ,
X , Ba , t , x , z || null ) } ; a . Canvas . prototype . drawLine = function ( e , h , n , t , x ) { a . Jd ( this . Id ) ; this . _drawLine ( e , h , n , t , x ) } ; a . Canvas . prototype . drawOval = function ( e , h ) { a . Jd ( this . Id ) ; e = u ( e ) ; this . _drawOval ( e , h ) } ; a . Canvas . prototype . drawPaint = function ( e ) { a . Jd ( this . Id ) ; this . _drawPaint ( e ) } ; a . Canvas . prototype . drawParagraph = function ( e , h , n ) { a . Jd ( this . Id ) ; this . _drawParagraph ( e , h , n ) } ; a . Canvas . prototype . drawPatch = function ( e , h , n , t , x ) { if ( 24 > e . length ) throw "Need 12 cubic points" ; if ( h && 4 > h . length ) throw "Need 4 colors" ; if ( n && 8 > n . length ) throw "Need 4 shader coordinates" ;
a . Jd ( this . Id ) ; const z = l ( e , "HEAPF32" ) , E = h ? l ( c ( h ) , "HEAPU32" ) : M , J = n ? l ( n , "HEAPF32" ) : M ; t || ( t = a . BlendMode . Modulate ) ; this . _drawPatch ( z , E , J , t , x ) ; k ( J , n ) ; k ( E , h ) ; k ( z , e ) } ; a . Canvas . prototype . drawPath = function ( e , h ) { a . Jd ( this . Id ) ; this . _drawPath ( e , h ) } ; a . Canvas . prototype . drawPicture = function ( e ) { a . Jd ( this . Id ) ; this . _drawPicture ( e ) } ; a . Canvas . prototype . drawPoints = function ( e , h , n ) { a . Jd ( this . Id ) ; var t = l ( h , "HEAPF32" ) ; this . _drawPoints ( e , t , h . length / 2 , n ) ; k ( t , h ) } ; a . Canvas . prototype . drawRRect = function ( e , h ) { a . Jd ( this . Id ) ; e = F ( e ) ;
this . _drawRRect ( e , h ) } ; a . Canvas . prototype . drawRect = function ( e , h ) { a . Jd ( this . Id ) ; e = u ( e ) ; this . _drawRect ( e , h ) } ; a . Canvas . prototype . drawRect4f = function ( e , h , n , t , x ) { a . Jd ( this . Id ) ; this . _drawRect4f ( e , h , n , t , x ) } ; a . Canvas . prototype . drawShadow = function ( e , h , n , t , x , z , E ) { a . Jd ( this . Id ) ; var J = l ( x , "HEAPF32" ) , I = l ( z , "HEAPF32" ) ; h = l ( h , "HEAPF32" , Fb ) ; n = l ( n , "HEAPF32" , Gb ) ; this . _drawShadow ( e , h , n , t , J , I , E ) ; k ( J , x ) ; k ( I , z ) } ; a . getShadowLocalBounds = function ( e , h , n , t , x , z , E ) { e = p ( e ) ; n = l ( n , "HEAPF32" , Fb ) ; t = l ( t , "HEAPF32" , Gb ) ; if ( ! this . _getShadowLocalBounds ( e ,
h , n , t , x , z , X ) ) return null ; h = na . toTypedArray ( ) ; return E ? ( E . set ( h ) , E ) : h . slice ( ) } ; a . Canvas . prototype . drawTextBlob = function ( e , h , n , t ) { a . Jd ( this . Id ) ; this . _drawTextBlob ( e , h , n , t ) } ; a . Canvas . prototype . drawVertices = function ( e , h , n ) { a . Jd ( this . Id ) ; this . _drawVertices ( e , h , n ) } ; a . Canvas . prototype . getDeviceClipBounds = function ( e ) { this . _getDeviceClipBounds ( Sa ) ; var h = hb . toTypedArray ( ) ; e ? e . set ( h ) : e = h . slice ( ) ; return e } ; a . Canvas . prototype . getLocalToDevice = function ( ) { this . _getLocalToDevice ( ca ) ; for ( var e = ca , h = Array ( 16 ) , n = 0 ; 16 >
n ; n ++ ) h [ n ] = a . HEAPF32 [ e / 4 + n ] ; return h } ; a . Canvas . prototype . getTotalMatrix = function ( ) { this . _getTotalMatrix ( H ) ; for ( var e = Array ( 9 ) , h = 0 ; 9 > h ; h ++ ) e [ h ] = a . HEAPF32 [ H / 4 + h ] ; return e } ; a . Canvas . prototype . makeSurface = function ( e ) { e = this . _makeSurface ( e ) ; e . Id = this . Id ; return e } ; a . Canvas . prototype . readPixels = function ( e , h , n , t , x ) { a . Jd ( this . Id ) ; return g ( this , e , h , n , t , x ) } ; a . Canvas . prototype . saveLayer = function ( e , h , n , t ) { h = u ( h ) ; return this . _saveLayer ( e || null , h , n || null , t || 0 ) } ; a . Canvas . prototype . writePixels = function ( e , h , n , t , x ,
z , E , J ) { if ( e . byteLength % ( h * n ) ) throw "pixels length must be a multiple of the srcWidth * srcHeight" ; a . Jd ( this . Id ) ; var I = e . byteLength / ( h * n ) ; z = z || a . AlphaType . Unpremul ; E = E || a . ColorType . RGBA _8888 ; J = J || a . ColorSpace . SRGB ; var U = I * h ; I = l ( e , "HEAPU8" ) ; h = this . _writePixels ( { width : h , height : n , colorType : E , alphaType : z , colorSpace : J } , I , U , t , x ) ; k ( I , e ) ; return h } ; a . ColorFilter . MakeBlend = function ( e , h , n ) { e = y ( e ) ; n = n || a . ColorSpace . SRGB ; return a . ColorFilter . _MakeBlend ( e , h , n ) } ; a . ColorFilter . MakeMatrix = function ( e ) { if ( ! e || 20 !== e . length ) throw "invalid color matrix" ;
var h = l ( e , "HEAPF32" ) , n = a . ColorFilter . _makeMatrix ( h ) ; k ( h , e ) ; return n } ; a . ContourMeasure . prototype . getPosTan = function ( e , h ) { this . _getPosTan ( e , X ) ; e = na . toTypedArray ( ) ; return h ? ( h . set ( e ) , h ) : e . slice ( ) } ; a . ImageFilter . prototype . getOutputBounds = function ( e , h , n ) { e = u ( e , X ) ; h = p ( h ) ; this . _getOutputBounds ( e , h , Sa ) ; h = hb . toTypedArray ( ) ; return n ? ( n . set ( h ) , n ) : h . slice ( ) } ; a . ImageFilter . MakeDropShadow = function ( e , h , n , t , x , z ) { x = y ( x , va ) ; return a . ImageFilter . _MakeDropShadow ( e , h , n , t , x , z ) } ; a . ImageFilter . MakeDropShadowOnly = function ( e ,
h , n , t , x , z ) { x = y ( x , va ) ; return a . ImageFilter . _MakeDropShadowOnly ( e , h , n , t , x , z ) } ; a . ImageFilter . MakeImage = function ( e , h , n , t ) { n = u ( n , X ) ; t = u ( t , Ba ) ; if ( "B" in h && "C" in h ) return a . ImageFilter . _MakeImageCubic ( e , h . B , h . C , n , t ) ; const x = h . filter ; let z = a . MipmapMode . None ; "mipmap" in h && ( z = h . mipmap ) ; return a . ImageFilter . _MakeImageOptions ( e , x , z , n , t ) } ; a . ImageFilter . MakeMatrixTransform = function ( e , h , n ) { e = p ( e ) ; if ( "B" in h && "C" in h ) return a . ImageFilter . _MakeMatrixTransformCubic ( e , h . B , h . C , n ) ; const t = h . filter ; let x = a . MipmapMode . None ;
"mipmap" in h && ( x = h . mipmap ) ; return a . ImageFilter . _MakeMatrixTransformOptions ( e , t , x , n ) } ; a . Paint . prototype . getColor = function ( ) { this . _getColor ( va ) ; return D ( va ) } ; a . Paint . prototype . setColor = function ( e , h ) { h = h || null ; e = y ( e ) ; this . _setColor ( e , h ) } ; a . Paint . prototype . setColorComponents = function ( e , h , n , t , x ) { x = x || null ; e = B ( e , h , n , t ) ; this . _setColor ( e , x ) } ; a . Path . prototype . getPoint = function ( e , h ) { this . _getPoint ( e , X ) ; e = na . toTypedArray ( ) ; return h ? ( h [ 0 ] = e [ 0 ] , h [ 1 ] = e [ 1 ] , h ) : e . slice ( 0 , 2 ) } ; a . Picture . prototype . makeShader = function ( e ,
h , n , t , x ) { t = p ( t ) ; x = u ( x ) ; return this . _makeShader ( e , h , n , t , x ) } ; a . Picture . prototype . cullRect = function ( e ) { this . _cullRect ( X ) ; var h = na . toTypedArray ( ) ; return e ? ( e . set ( h ) , e ) : h . slice ( ) } ; a . PictureRecorder . prototype . beginRecording = function ( e , h ) { e = u ( e ) ; return this . _beginRecording ( e , ! ! h ) } ; a . Surface . prototype . getCanvas = function ( ) { var e = this . _getCanvas ( ) ; e . Id = this . Id ; return e } ; a . Surface . prototype . makeImageSnapshot = function ( e ) { a . Jd ( this . Id ) ; e = l ( e , "HEAP32" , Sa ) ; return this . _makeImageSnapshot ( e ) } ; a . Surface . prototype . makeSurface =
function ( e ) { a . Jd ( this . Id ) ; e = this . _makeSurface ( e ) ; e . Id = this . Id ; return e } ; a . Surface . prototype . Te = function ( e , h ) { this . ge || ( this . ge = this . getCanvas ( ) ) ; return requestAnimationFrame ( function ( ) { a . Jd ( this . Id ) ; e ( this . ge ) ; this . flush ( h ) } . bind ( this ) ) } ; a . Surface . prototype . requestAnimationFrame || ( a . Surface . prototype . requestAnimationFrame = a . Surface . prototype . Te ) ; a . Surface . prototype . Qe = function ( e , h ) { this . ge || ( this . ge = this . getCanvas ( ) ) ; requestAnimationFrame ( function ( ) { a . Jd ( this . Id ) ; e ( this . ge ) ; this . flush ( h ) ; this . dispose ( ) } . bind ( this ) ) } ;
a . Surface . prototype . drawOnce || ( a . Surface . prototype . drawOnce = a . Surface . prototype . Qe ) ; a . PathEffect . MakeDash = function ( e , h ) { h || ( h = 0 ) ; if ( ! e . length || 1 === e . length % 2 ) throw "Intervals array must have even length" ; var n = l ( e , "HEAPF32" ) ; h = a . PathEffect . _MakeDash ( n , e . length , h ) ; k ( n , e ) ; return h } ; a . PathEffect . MakeLine2D = function ( e , h ) { h = p ( h ) ; return a . PathEffect . _MakeLine2D ( e , h ) } ; a . PathEffect . MakePath2D = function ( e , h ) { e = p ( e ) ; return a . PathEffect . _MakePath2D ( e , h ) } ; a . Shader . MakeColor = function ( e , h ) { h = h || null ; e = y ( e ) ; return a . Shader . _MakeColor ( e ,
h ) } ; a . Shader . Blend = a . Shader . MakeBlend ; a . Shader . Color = a . Shader . MakeColor ; a . Shader . MakeLinearGradient = function ( e , h , n , t , x , z , E , J ) { J = J || null ; var I = m ( n ) , U = l ( t , "HEAPF32" ) ; E = E || 0 ; z = p ( z ) ; var V = na . toTypedArray ( ) ; V . set ( e ) ; V . set ( h , 2 ) ; e = a . Shader . _MakeLinearGradient ( X , I . Rd , I . colorType , U , I . count , x , E , z , J ) ; k ( I . Rd , n ) ; t && k ( U , t ) ; return e } ; a . Shader . MakeRadialGradient = function ( e , h , n , t , x , z , E , J ) { J = J || null ; var I = m ( n ) , U = l ( t , "HEAPF32" ) ; E = E || 0 ; z = p ( z ) ; e = a . Shader . _MakeRadialGradient ( e [ 0 ] , e [ 1 ] , h , I . Rd , I . colorType , U , I . count , x , E ,
z , J ) ; k ( I . Rd , n ) ; t && k ( U , t ) ; return e } ; a . Shader . MakeSweepGradient = function ( e , h , n , t , x , z , E , J , I , U ) { U = U || null ; var V = m ( n ) , q = l ( t , "HEAPF32" ) ; E = E || 0 ; J = J || 0 ; I = I || 360 ; z = p ( z ) ; e = a . Shader . _MakeSweepGradient ( e , h , V . Rd , V . colorType , q , V . count , x , J , I , E , z , U ) ; k ( V . Rd , n ) ; t && k ( q , t ) ; return e } ; a . Shader . MakeTwoPointConicalGradient = function ( e , h , n , t , x , z , E , J , I , U ) { U = U || null ; var V = m ( x ) , q = l ( z , "HEAPF32" ) ; I = I || 0 ; J = p ( J ) ; var A = na . toTypedArray ( ) ; A . set ( e ) ; A . set ( n , 2 ) ; e = a . Shader . _MakeTwoPointConicalGradient ( X , h , t , V . Rd , V . colorType , q , V . count , E ,
I , J , U ) ; k ( V . Rd , x ) ; z && k ( q , z ) ; return e } ; a . Vertices . prototype . bounds = function ( e ) { this . _bounds ( X ) ; var h = na . toTypedArray ( ) ; return e ? ( e . set ( h ) , e ) : h . slice ( ) } ; a . Md && a . Md . forEach ( function ( e ) { e ( ) } ) } ; a . computeTonalColors = function ( g ) { var e = l ( g . ambient , "HEAPF32" ) , h = l ( g . spot , "HEAPF32" ) ; this . _computeTonalColors ( e , h ) ; var n = { ambient : D ( e ) , spot : D ( h ) } ; k ( e , g . ambient ) ; k ( h , g . spot ) ; return n } ; a . LTRBRect = function ( g , e , h , n ) { return Float32Array . of ( g , e , h , n ) } ; a . XYWHRect = function ( g , e , h , n ) { return Float32Array . of ( g , e , g + h , e + n ) } ; a . LTRBiRect =
function ( g , e , h , n ) { return Int32Array . of ( g , e , h , n ) } ; a . XYWHiRect = function ( g , e , h , n ) { return Int32Array . of ( g , e , g + h , e + n ) } ; a . RRectXY = function ( g , e , h ) { return Float32Array . of ( g [ 0 ] , g [ 1 ] , g [ 2 ] , g [ 3 ] , e , h , e , h , e , h , e , h ) } ; a . MakeAnimatedImageFromEncoded = function ( g ) { g = new Uint8Array ( g ) ; var e = a . _malloc ( g . byteLength ) ; a . HEAPU8 . set ( g , e ) ; return ( g = a . _decodeAnimatedImage ( e , g . byteLength ) ) ? g : null } ; a . MakeImageFromEncoded = function ( g ) { g = new Uint8Array ( g ) ; var e = a . _malloc ( g . byteLength ) ; a . HEAPU8 . set ( g , e ) ; return ( g = a . _decodeImage ( e , g . byteLength ) ) ?
g : null } ; var Ta = null ; a . MakeImageFromCanvasImageSource = function ( g ) { var e = g . width , h = g . height ; Ta || ( Ta = document . createElement ( "canvas" ) ) ; Ta . width = e ; Ta . height = h ; var n = Ta . getContext ( "2d" , { willReadFrequently : ! 0 } ) ; n . drawImage ( g , 0 , 0 ) ; g = n . getImageData ( 0 , 0 , e , h ) ; return a . MakeImage ( { width : e , height : h , alphaType : a . AlphaType . Unpremul , colorType : a . ColorType . RGBA _8888 , colorSpace : a . ColorSpace . SRGB } , g . data , 4 * e ) } ; a . MakeImage = function ( g , e , h ) { var n = a . _malloc ( e . length ) ; a . HEAPU8 . set ( e , n ) ; return a . _MakeImage ( g , n , e . length , h ) } ;
a . MakeVertices = function ( g , e , h , n , t , x ) { var z = t && t . length || 0 , E = 0 ; h && h . length && ( E |= 1 ) ; n && n . length && ( E |= 2 ) ; void 0 === x || x || ( E |= 4 ) ; g = new a . _VerticesBuilder ( g , e . length / 2 , z , E ) ; l ( e , "HEAPF32" , g . positions ( ) ) ; g . texCoords ( ) && l ( h , "HEAPF32" , g . texCoords ( ) ) ; g . colors ( ) && l ( c ( n ) , "HEAPU32" , g . colors ( ) ) ; g . indices ( ) && l ( t , "HEAPU16" , g . indices ( ) ) ; return g . detach ( ) } ; ( function ( g ) { g . Md = g . Md || [ ] ; g . Md . push ( function ( ) { function e ( q ) { q && ( q . dir = 0 === q . dir ? g . TextDirection . RTL : g . TextDirection . LTR ) ; return q } function h ( q ) { if ( ! q || ! q . length ) return [ ] ;
for ( var A = [ ] , P = 0 ; P < q . length ; P += 5 ) { var Z = g . LTRBRect ( q [ P ] , q [ P + 1 ] , q [ P + 2 ] , q [ P + 3 ] ) , za = g . TextDirection . LTR ; 0 === q [ P + 4 ] && ( za = g . TextDirection . RTL ) ; A . push ( { rect : Z , dir : za } ) } g . _free ( q . byteOffset ) ; return A } function n ( q ) { q = q || { } ; void 0 === q . weight && ( q . weight = g . FontWeight . Normal ) ; q . width = q . width || g . FontWidth . Normal ; q . slant = q . slant || g . FontSlant . Upright ; return q } function t ( q ) { if ( ! q || ! q . length ) return M ; for ( var A = [ ] , P = 0 ; P < q . length ; P ++ ) { var Z = x ( q [ P ] ) ; A . push ( Z ) } return l ( A , "HEAPU32" ) } function x ( q ) { if ( J [ q ] ) return J [ q ] ; var A =
ja ( q ) + 1 , P = g . _malloc ( A ) ; ka ( q , C , P , A ) ; return J [ q ] = P } function z ( q ) { q . _colorPtr = y ( q . color ) ; q . _foregroundColorPtr = M ; q . _backgroundColorPtr = M ; q . _decorationColorPtr = M ; q . foregroundColor && ( q . _foregroundColorPtr = y ( q . foregroundColor , I ) ) ; q . backgroundColor && ( q . _backgroundColorPtr = y ( q . backgroundColor , U ) ) ; q . decorationColor && ( q . _decorationColorPtr = y ( q . decorationColor , V ) ) ; Array . isArray ( q . fontFamilies ) && q . fontFamilies . length ? ( q . _fontFamiliesPtr = t ( q . fontFamilies ) , q . _fontFamiliesLen = q . fontFamilies . length ) : ( q . _fontFamiliesPtr =
M , q . _fontFamiliesLen = 0 ) ; if ( q . locale ) { var A = q . locale ; q . _localePtr = x ( A ) ; q . _localeLen = ja ( A ) + 1 } else q . _localePtr = M , q . _localeLen = 0 ; if ( Array . isArray ( q . shadows ) && q . shadows . length ) { A = q . shadows ; var P = A . map ( function ( qa ) { return qa . color || g . BLACK } ) , Z = A . map ( function ( qa ) { return qa . blurRadius || 0 } ) ; q . _shadowLen = A . length ; for ( var za = g . _malloc ( 8 * A . length ) , Hb = za / 4 , Ib = 0 ; Ib < A . length ; Ib ++ ) { var lc = A [ Ib ] . offset || [ 0 , 0 ] ; g . HEAPF32 [ Hb ] = lc [ 0 ] ; g . HEAPF32 [ Hb + 1 ] = lc [ 1 ] ; Hb += 2 } q . _shadowColorsPtr = m ( P ) . Rd ; q . _shadowOffsetsPtr = za ; q . _shadowBlurRadiiPtr =
l ( Z , "HEAPF32" ) } else q . _shadowLen = 0 , q . _shadowColorsPtr = M , q . _shadowOffsetsPtr = M , q . _shadowBlurRadiiPtr = M ; Array . isArray ( q . fontFeatures ) && q . fontFeatures . length ? ( A = q . fontFeatures , P = A . map ( function ( qa ) { return qa . name } ) , Z = A . map ( function ( qa ) { return qa . value } ) , q . _fontFeatureLen = A . length , q . _fontFeatureNamesPtr = t ( P ) , q . _fontFeatureValuesPtr = l ( Z , "HEAPU32" ) ) : ( q . _fontFeatureLen = 0 , q . _fontFeatureNamesPtr = M , q . _fontFeatureValuesPtr = M ) ; Array . isArray ( q . fontVariations ) && q . fontVariations . length ? ( A = q . fontVariations , P = A . map ( function ( qa ) { return qa . axis } ) ,
Z = A . map ( function ( qa ) { return qa . value } ) , q . _fontVariationLen = A . length , q . _fontVariationAxesPtr = t ( P ) , q . _fontVariationValuesPtr = l ( Z , "HEAPF32" ) ) : ( q . _fontVariationLen = 0 , q . _fontVariationAxesPtr = M , q . _fontVariationValuesPtr = M ) } function E ( q ) { g . _free ( q . _fontFamiliesPtr ) ; g . _free ( q . _shadowColorsPtr ) ; g . _free ( q . _shadowOffsetsPtr ) ; g . _free ( q . _shadowBlurRadiiPtr ) ; g . _free ( q . _fontFeatureNamesPtr ) ; g . _free ( q . _fontFeatureValuesPtr ) ; g . _free ( q . _fontVariationAxesPtr ) ; g . _free ( q . _fontVariationValuesPtr ) } g . Paragraph . prototype . getRectsForRange =
function ( q , A , P , Z ) { q = this . _getRectsForRange ( q , A , P , Z ) ; return h ( q ) } ; g . Paragraph . prototype . getRectsForPlaceholders = function ( ) { var q = this . _getRectsForPlaceholders ( ) ; return h ( q ) } ; g . Paragraph . prototype . getGlyphInfoAt = function ( q ) { return e ( this . _getGlyphInfoAt ( q ) ) } ; g . Paragraph . prototype . getClosestGlyphInfoAtCoordinate = function ( q , A ) { return e ( this . _getClosestGlyphInfoAtCoordinate ( q , A ) ) } ; g . TypefaceFontProvider . prototype . registerFont = function ( q , A ) { q = g . Typeface . MakeFreeTypeFaceFromData ( q ) ; if ( ! q ) return null ; A = x ( A ) ;
this . _registerFont ( q , A ) } ; g . ParagraphStyle = function ( q ) { q . disableHinting = q . disableHinting || ! 1 ; if ( q . ellipsis ) { var A = q . ellipsis ; q . _ellipsisPtr = x ( A ) ; q . _ellipsisLen = ja ( A ) + 1 } else q . _ellipsisPtr = M , q . _ellipsisLen = 0 ; null == q . heightMultiplier && ( q . heightMultiplier = - 1 ) ; q . maxLines = q . maxLines || 0 ; q . replaceTabCharacters = q . replaceTabCharacters || ! 1 ; A = ( A = q . strutStyle ) || { } ; A . strutEnabled = A . strutEnabled || ! 1 ; A . strutEnabled && Array . isArray ( A . fontFamilies ) && A . fontFamilies . length ? ( A . _fontFamiliesPtr = t ( A . fontFamilies ) , A . _fontFamiliesLen =
A . fontFamilies . length ) : ( A . _fontFamiliesPtr = M , A . _fontFamiliesLen = 0 ) ; A . fontStyle = n ( A . fontStyle ) ; null == A . fontSize && ( A . fontSize = - 1 ) ; null == A . heightMultiplier && ( A . heightMultiplier = - 1 ) ; A . halfLeading = A . halfLeading || ! 1 ; A . leading = A . leading || 0 ; A . forceStrutHeight = A . forceStrutHeight || ! 1 ; q . strutStyle = A ; q . textAlign = q . textAlign || g . TextAlign . Start ; q . textDirection = q . textDirection || g . TextDirection . LTR ; q . textHeightBehavior = q . textHeightBehavior || g . TextHeightBehavior . All ; q . textStyle = g . TextStyle ( q . textStyle ) ; q . applyRoundingHack =
! 1 !== q . applyRoundingHack ; return q } ; g . TextStyle = function ( q ) { q . color || ( q . color = g . BLACK ) ; q . decoration = q . decoration || 0 ; q . decorationThickness = q . decorationThickness || 0 ; q . decorationStyle = q . decorationStyle || g . DecorationStyle . Solid ; q . textBaseline = q . textBaseline || g . TextBaseline . Alphabetic ; null == q . fontSize && ( q . fontSize = - 1 ) ; q . letterSpacing = q . letterSpacing || 0 ; q . wordSpacing = q . wordSpacing || 0 ; null == q . heightMultiplier && ( q . heightMultiplier = - 1 ) ; q . halfLeading = q . halfLeading || ! 1 ; q . fontStyle = n ( q . fontStyle ) ; return q } ; var J =
{ } , I = g . _malloc ( 16 ) , U = g . _malloc ( 16 ) , V = g . _malloc ( 16 ) ; g . ParagraphBuilder . Make = function ( q , A ) { z ( q . textStyle ) ; A = g . ParagraphBuilder . _Make ( q , A ) ; E ( q . textStyle ) ; return A } ; g . ParagraphBuilder . MakeFromFontProvider = function ( q , A ) { z ( q . textStyle ) ; A = g . ParagraphBuilder . _MakeFromFontProvider ( q , A ) ; E ( q . textStyle ) ; return A } ; g . ParagraphBuilder . MakeFromFontCollection = function ( q , A ) { z ( q . textStyle ) ; A = g . ParagraphBuilder . _MakeFromFontCollection ( q , A ) ; E ( q . textStyle ) ; return A } ; g . ParagraphBuilder . ShapeText = function ( q , A , P ) { let Z = 0 ;
for ( const za of A ) Z += za . length ; if ( Z !== q . length ) throw "Accumulated block lengths must equal text.length" ; return g . ParagraphBuilder . _ShapeText ( q , A , P ) } ; g . ParagraphBuilder . prototype . pushStyle = function ( q ) { z ( q ) ; this . _pushStyle ( q ) ; E ( q ) } ; g . ParagraphBuilder . prototype . pushPaintStyle = function ( q , A , P ) { z ( q ) ; this . _pushPaintStyle ( q , A , P ) ; E ( q ) } ; g . ParagraphBuilder . prototype . addPlaceholder = function ( q , A , P , Z , za ) { P = P || g . PlaceholderAlignment . Baseline ; Z = Z || g . TextBaseline . Alphabetic ; this . _addPlaceholder ( q || 0 , A || 0 , P , Z , za || 0 ) } ;
g . ParagraphBuilder . prototype . setWordsUtf8 = function ( q ) { var A = l ( q , "HEAPU32" ) ; this . _setWordsUtf8 ( A , q && q . length || 0 ) ; k ( A , q ) } ; g . ParagraphBuilder . prototype . setWordsUtf16 = function ( q ) { var A = l ( q , "HEAPU32" ) ; this . _setWordsUtf16 ( A , q && q . length || 0 ) ; k ( A , q ) } ; g . ParagraphBuilder . prototype . setGraphemeBreaksUtf8 = function ( q ) { var A = l ( q , "HEAPU32" ) ; this . _setGraphemeBreaksUtf8 ( A , q && q . length || 0 ) ; k ( A , q ) } ; g . ParagraphBuilder . prototype . setGraphemeBreaksUtf16 = function ( q ) { var A = l ( q , "HEAPU32" ) ; this . _setGraphemeBreaksUtf16 ( A , q && q . length ||
0 ) ; k ( A , q ) } ; g . ParagraphBuilder . prototype . setLineBreaksUtf8 = function ( q ) { var A = l ( q , "HEAPU32" ) ; this . _setLineBreaksUtf8 ( A , q && q . length || 0 ) ; k ( A , q ) } ; g . ParagraphBuilder . prototype . setLineBreaksUtf16 = function ( q ) { var A = l ( q , "HEAPU32" ) ; this . _setLineBreaksUtf16 ( A , q && q . length || 0 ) ; k ( A , q ) } } ) } ) ( r ) ; a . Md = a . Md || [ ] ; a . Md . push ( function ( ) { a . Path . prototype . op = function ( g , e ) { return this . _op ( g , e ) ? this : null } ; a . Path . prototype . simplify = function ( ) { return this . _simplify ( ) ? this : null } } ) ; a . Md = a . Md || [ ] ; a . Md . push ( function ( ) { a . Canvas . prototype . drawText =
function ( g , e , h , n , t ) { var x = ja ( g ) , z = a . _malloc ( x + 1 ) ; ka ( g , C , z , x + 1 ) ; this . _drawSimpleText ( z , x , e , h , t , n ) ; a . _free ( z ) } ; a . Canvas . prototype . drawGlyphs = function ( g , e , h , n , t , x ) { if ( ! ( 2 * g . length <= e . length ) ) throw "Not enough positions for the array of gyphs" ; a . Jd ( this . Id ) ; const z = l ( g , "HEAPU16" ) , E = l ( e , "HEAPF32" ) ; this . _drawGlyphs ( g . length , z , E , h , n , t , x ) ; k ( E , e ) ; k ( z , g ) } ; a . Font . prototype . getGlyphBounds = function ( g , e , h ) { var n = l ( g , "HEAPU16" ) , t = a . _malloc ( 16 * g . length ) ; this . _getGlyphWidthBounds ( n , g . length , M , t , e || null ) ; e = new Float32Array ( a . HEAPU8 . buffer ,
t , 4 * g . length ) ; k ( n , g ) ; if ( h ) return h . set ( e ) , a . _free ( t ) , h ; g = Float32Array . from ( e ) ; a . _free ( t ) ; return g } ; a . Font . prototype . getGlyphIDs = function ( g , e , h ) { e || ( e = g . length ) ; var n = ja ( g ) + 1 , t = a . _malloc ( n ) ; ka ( g , C , t , n ) ; g = a . _malloc ( 2 * e ) ; e = this . _getGlyphIDs ( t , n - 1 , e , g ) ; a . _free ( t ) ; if ( 0 > e ) return a . _free ( g ) , null ; t = new Uint16Array ( a . HEAPU8 . buffer , g , e ) ; if ( h ) return h . set ( t ) , a . _free ( g ) , h ; h = Uint16Array . from ( t ) ; a . _free ( g ) ; return h } ; a . Font . prototype . getGlyphIntercepts = function ( g , e , h , n ) { var t = l ( g , "HEAPU16" ) , x = l ( e , "HEAPF32" ) ; return this . _getGlyphIntercepts ( t ,
g . length , ! ( g && g . _ck ) , x , e . length , ! ( e && e . _ck ) , h , n ) } ; a . Font . prototype . getGlyphWidths = function ( g , e , h ) { var n = l ( g , "HEAPU16" ) , t = a . _malloc ( 4 * g . length ) ; this . _getGlyphWidthBounds ( n , g . length , t , M , e || null ) ; e = new Float32Array ( a . HEAPU8 . buffer , t , g . length ) ; k ( n , g ) ; if ( h ) return h . set ( e ) , a . _free ( t ) , h ; g = Float32Array . from ( e ) ; a . _free ( t ) ; return g } ; a . FontMgr . FromData = function ( ) { if ( ! arguments . length ) return null ; var g = arguments ; 1 === g . length && Array . isArray ( g [ 0 ] ) && ( g = arguments [ 0 ] ) ; if ( ! g . length ) return null ; for ( var e = [ ] , h = [ ] , n =
0 ; n < g . length ; n ++ ) { var t = new Uint8Array ( g [ n ] ) , x = l ( t , "HEAPU8" ) ; e . push ( x ) ; h . push ( t . byteLength ) } e = l ( e , "HEAPU32" ) ; h = l ( h , "HEAPU32" ) ; g = a . FontMgr . _fromData ( e , h , g . length ) ; a . _free ( e ) ; a . _free ( h ) ; return g } ; a . Typeface . MakeFreeTypeFaceFromData = function ( g ) { g = new Uint8Array ( g ) ; var e = l ( g , "HEAPU8" ) ; return ( g = a . Typeface . _MakeFreeTypeFaceFromData ( e , g . byteLength ) ) ? g : null } ; a . Typeface . prototype . getGlyphIDs = function ( g , e , h ) { e || ( e = g . length ) ; var n = ja ( g ) + 1 , t = a . _malloc ( n ) ; ka ( g , C , t , n ) ; g = a . _malloc ( 2 * e ) ; e = this . _getGlyphIDs ( t , n - 1 ,
e , g ) ; a . _free ( t ) ; if ( 0 > e ) return a . _free ( g ) , null ; t = new Uint16Array ( a . HEAPU8 . buffer , g , e ) ; if ( h ) return h . set ( t ) , a . _free ( g ) , h ; h = Uint16Array . from ( t ) ; a . _free ( g ) ; return h } ; a . TextBlob . MakeOnPath = function ( g , e , h , n ) { if ( g && g . length && e && e . countPoints ( ) ) { if ( 1 === e . countPoints ( ) ) return this . MakeFromText ( g , h ) ; n || ( n = 0 ) ; var t = h . getGlyphIDs ( g ) ; t = h . getGlyphWidths ( t ) ; var x = [ ] ; e = new a . ContourMeasureIter ( e , ! 1 , 1 ) ; for ( var z = e . next ( ) , E = new Float32Array ( 4 ) , J = 0 ; J < g . length && z ; J ++ ) { var I = t [ J ] ; n += I / 2 ; if ( n > z . length ( ) ) { z . delete ( ) ; z =
e . next ( ) ; if ( ! z ) { g = g . substring ( 0 , J ) ; break } n = I / 2 } z . getPosTan ( n , E ) ; var U = E [ 2 ] , V = E [ 3 ] ; x . push ( U , V , E [ 0 ] - I / 2 * U , E [ 1 ] - I / 2 * V ) ; n += I / 2 } g = this . MakeFromRSXform ( g , x , h ) ; z && z . delete ( ) ; e . delete ( ) ; return g } } ; a . TextBlob . MakeFromRSXform = function ( g , e , h ) { var n = ja ( g ) + 1 , t = a . _malloc ( n ) ; ka ( g , C , t , n ) ; g = l ( e , "HEAPF32" ) ; h = a . TextBlob . _MakeFromRSXform ( t , n - 1 , g , h ) ; a . _free ( t ) ; return h ? h : null } ; a . TextBlob . MakeFromRSXformGlyphs = function ( g , e , h ) { var n = l ( g , "HEAPU16" ) ; e = l ( e , "HEAPF32" ) ; h = a . TextBlob . _MakeFromRSXformGlyphs ( n , 2 * g . length , e , h ) ; k ( n ,
g ) ; return h ? h : null } ; a . TextBlob . MakeFromGlyphs = function ( g , e ) { var h = l ( g , "HEAPU16" ) ; e = a . TextBlob . _MakeFromGlyphs ( h , 2 * g . length , e ) ; k ( h , g ) ; return e ? e : null } ; a . TextBlob . MakeFromText = function ( g , e ) { var h = ja ( g ) + 1 , n = a . _malloc ( h ) ; ka ( g , C , n , h ) ; g = a . TextBlob . _MakeFromText ( n , h - 1 , e ) ; a . _free ( n ) ; return g ? g : null } ; a . MallocGlyphIDs = function ( g ) { return a . Malloc ( Uint16Array , g ) } } ) ; a . Md = a . Md || [ ] ; a . Md . push ( function ( ) { a . MakePicture = function ( g ) { g = new Uint8Array ( g ) ; var e = a . _malloc ( g . byteLength ) ; a . HEAPU8 . set ( g , e ) ; return ( g = a . _MakePicture ( e ,
g . byteLength ) ) ? g : null } } ) ; a . Md = a . Md || [ ] ; a . Md . push ( function ( ) { a . RuntimeEffect . Make = function ( g , e ) { return a . RuntimeEffect . _Make ( g , { onError : e || function ( h ) { console . log ( "RuntimeEffect error" , h ) } } ) } ; a . RuntimeEffect . MakeForBlender = function ( g , e ) { return a . RuntimeEffect . _MakeForBlender ( g , { onError : e || function ( h ) { console . log ( "RuntimeEffect error" , h ) } } ) } ; a . RuntimeEffect . prototype . makeShader = function ( g , e ) { var h = ! g . _ck , n = l ( g , "HEAPF32" ) ; e = p ( e ) ; return this . _makeShader ( n , 4 * g . length , h , e ) } ; a . RuntimeEffect . prototype . makeShaderWithChildren =
function ( g , e , h ) { var n = ! g . _ck , t = l ( g , "HEAPF32" ) ; h = p ( h ) ; for ( var x = [ ] , z = 0 ; z < e . length ; z ++ ) x . push ( e [ z ] . kd . Kd ) ; e = l ( x , "HEAPU32" ) ; return this . _makeShaderWithChildren ( t , 4 * g . length , n , e , x . length , h ) } ; a . RuntimeEffect . prototype . makeBlender = function ( g ) { var e = ! g . _ck , h = l ( g , "HEAPF32" ) ; return this . _makeBlender ( h , 4 * g . length , e ) } } ) } ) ( r ) ;
var la = Object . assign ( { } , r ) , ma = "./this.program" , oa = ( a , b ) => { throw b ; } , pa = "object" == typeof window , ra = "function" == typeof importScripts , sa = "object" == typeof process && "object" == typeof process . versions && "string" == typeof process . versions . node , ta = "" , ua , wa , xa ;
if ( sa ) { var fs = require ( "fs" ) , ya = require ( "path" ) ; ta = ra ? ya . dirname ( ta ) + "/" : _ _dirname + "/" ; ua = ( a , b ) => { a = a . startsWith ( "file://" ) ? new URL ( a ) : ya . normalize ( a ) ; return fs . readFileSync ( a , b ? void 0 : "utf8" ) } ; xa = a => { a = ua ( a , ! 0 ) ; a . buffer || ( a = new Uint8Array ( a ) ) ; return a } ; wa = ( a , b , c , d = ! 0 ) => { a = a . startsWith ( "file://" ) ? new URL ( a ) : ya . normalize ( a ) ; fs . readFile ( a , d ? void 0 : "utf8" , ( f , k ) => { f ? c ( f ) : b ( d ? k . buffer : k ) } ) } ; ! r . thisProgram && 1 < process . argv . length && ( ma = process . argv [ 1 ] . replace ( /\\/g , "/" ) ) ; process . argv . slice ( 2 ) ; oa = ( a , b ) => { process . exitCode =
a ; throw b ; } ; r . inspect = ( ) => "[Emscripten Module object]" } else if ( pa || ra ) ra ? ta = self . location . href : "undefined" != typeof document && document . currentScript && ( ta = document . currentScript . src ) , _scriptDir && ( ta = _scriptDir ) , 0 !== ta . indexOf ( "blob:" ) ? ta = ta . substr ( 0 , ta . replace ( /[?#].*/ , "" ) . lastIndexOf ( "/" ) + 1 ) : ta = "" , ua = a => { var b = new XMLHttpRequest ; b . open ( "GET" , a , ! 1 ) ; b . send ( null ) ; return b . responseText } , ra && ( xa = a => { var b = new XMLHttpRequest ; b . open ( "GET" , a , ! 1 ) ; b . responseType = "arraybuffer" ; b . send ( null ) ; return new Uint8Array ( b . response ) } ) ,
wa = ( a , b , c ) => { var d = new XMLHttpRequest ; d . open ( "GET" , a , ! 0 ) ; d . responseType = "arraybuffer" ; d . onload = ( ) => { 200 == d . status || 0 == d . status && d . response ? b ( d . response ) : c ( ) } ; d . onerror = c ; d . send ( null ) } ; var Aa = r . print || console . log . bind ( console ) , Ca = r . printErr || console . error . bind ( console ) ; Object . assign ( r , la ) ; la = null ; r . thisProgram && ( ma = r . thisProgram ) ; r . quit && ( oa = r . quit ) ; var Da ; r . wasmBinary && ( Da = r . wasmBinary ) ; var noExitRuntime = r . noExitRuntime || ! 0 ; "object" != typeof WebAssembly && Ea ( "no native wasm support detected" ) ;
var Fa , G , Ga = ! 1 , Ha , C , Ia , Ja , K , L , N , Ka ; function La ( ) { var a = Fa . buffer ; r . HEAP8 = Ha = new Int8Array ( a ) ; r . HEAP16 = Ia = new Int16Array ( a ) ; r . HEAP32 = K = new Int32Array ( a ) ; r . HEAPU8 = C = new Uint8Array ( a ) ; r . HEAPU16 = Ja = new Uint16Array ( a ) ; r . HEAPU32 = L = new Uint32Array ( a ) ; r . HEAPF32 = N = new Float32Array ( a ) ; r . HEAPF64 = Ka = new Float64Array ( a ) } var Na , Oa = [ ] , Pa = [ ] , Qa = [ ] ; function Ra ( ) { var a = r . preRun . shift ( ) ; Oa . unshift ( a ) } var Ua = 0 , Va = null , Wa = null ;
function Ea ( a ) { if ( r . onAbort ) r . onAbort ( a ) ; a = "Aborted(" + a + ")" ; Ca ( a ) ; Ga = ! 0 ; a = new WebAssembly . RuntimeError ( a + ". Build with -sASSERTIONS for more info." ) ; ba ( a ) ; throw a ; } function Xa ( a ) { return a . startsWith ( "data:application/octet-stream;base64," ) } var Ya ; Ya = "canvaskit.wasm" ; if ( ! Xa ( Ya ) ) { var Za = Ya ; Ya = r . locateFile ? r . locateFile ( Za , ta ) : ta + Za } function $a ( a ) { if ( a == Ya && Da ) return new Uint8Array ( Da ) ; if ( xa ) return xa ( a ) ; throw "both async and sync fetching of the wasm failed" ; }
function ab ( a ) { if ( ! Da && ( pa || ra ) ) { if ( "function" == typeof fetch && ! a . startsWith ( "file://" ) ) return fetch ( a , { credentials : "same-origin" } ) . then ( b => { if ( ! b . ok ) throw "failed to load wasm binary file at '" + a + "'" ; return b . arrayBuffer ( ) } ) . catch ( ( ) => $a ( a ) ) ; if ( wa ) return new Promise ( ( b , c ) => { wa ( a , d => b ( new Uint8Array ( d ) ) , c ) } ) } return Promise . resolve ( ) . then ( ( ) => $a ( a ) ) } function bb ( a , b , c ) { return ab ( a ) . then ( d => WebAssembly . instantiate ( d , b ) ) . then ( d => d ) . then ( c , d => { Ca ( "failed to asynchronously prepare wasm: " + d ) ; Ea ( d ) } ) }
function cb ( a , b ) { var c = Ya ; return Da || "function" != typeof WebAssembly . instantiateStreaming || Xa ( c ) || c . startsWith ( "file://" ) || sa || "function" != typeof fetch ? bb ( c , a , b ) : fetch ( c , { credentials : "same-origin" } ) . then ( d => WebAssembly . instantiateStreaming ( d , a ) . then ( b , function ( f ) { Ca ( "wasm streaming compile failed: " + f ) ; Ca ( "falling back to ArrayBuffer instantiation" ) ; return bb ( c , a , b ) } ) ) } function db ( a ) { this . name = "ExitStatus" ; this . message = ` Program terminated with exit( ${ a } ) ` ; this . status = a } var eb = a => { for ( ; 0 < a . length ; ) a . shift ( ) ( r ) } ;
function fb ( a ) { this . Kd = a - 24 ; this . Pe = function ( b ) { L [ this . Kd + 4 >> 2 ] = b } ; this . we = function ( b ) { L [ this . Kd + 8 >> 2 ] = b } ; this . Zd = function ( b , c ) { this . ve ( ) ; this . Pe ( b ) ; this . we ( c ) } ; this . ve = function ( ) { L [ this . Kd + 16 >> 2 ] = 0 } }
var gb = 0 , ib = 0 , jb = "undefined" != typeof TextDecoder ? new TextDecoder ( "utf8" ) : void 0 , kb = ( a , b , c ) => { var d = b + c ; for ( c = b ; a [ c ] && ! ( c >= d ) ; ) ++ c ; if ( 16 < c - b && a . buffer && jb ) return jb . decode ( a . subarray ( b , c ) ) ; for ( d = "" ; b < c ; ) { var f = a [ b ++ ] ; if ( f & 128 ) { var k = a [ b ++ ] & 63 ; if ( 192 == ( f & 224 ) ) d += String . fromCharCode ( ( f & 31 ) << 6 | k ) ; else { var l = a [ b ++ ] & 63 ; f = 224 == ( f & 240 ) ? ( f & 15 ) << 12 | k << 6 | l : ( f & 7 ) << 18 | k << 12 | l << 6 | a [ b ++ ] & 63 ; 65536 > f ? d += String . fromCharCode ( f ) : ( f -= 65536 , d += String . fromCharCode ( 55296 | f >> 10 , 56320 | f & 1023 ) ) } } else d += String . fromCharCode ( f ) } return d } ,
lb = { } ; function mb ( a ) { for ( ; a . length ; ) { var b = a . pop ( ) ; a . pop ( ) ( b ) } } function nb ( a ) { return this . fromWireType ( K [ a >> 2 ] ) } var ob = { } , pb = { } , qb = { } , rb = void 0 ; function sb ( a ) { throw new rb ( a ) ; }
function tb ( a , b , c ) { function d ( m ) { m = c ( m ) ; m . length !== a . length && sb ( "Mismatched type converter count" ) ; for ( var p = 0 ; p < a . length ; ++ p ) ub ( a [ p ] , m [ p ] ) } a . forEach ( function ( m ) { qb [ m ] = b } ) ; var f = Array ( b . length ) , k = [ ] , l = 0 ; b . forEach ( ( m , p ) => { pb . hasOwnProperty ( m ) ? f [ p ] = pb [ m ] : ( k . push ( m ) , ob . hasOwnProperty ( m ) || ( ob [ m ] = [ ] ) , ob [ m ] . push ( ( ) => { f [ p ] = pb [ m ] ; ++ l ; l === k . length && d ( f ) } ) ) } ) ; 0 === k . length && d ( f ) }
function vb ( a ) { switch ( a ) { case 1 : return 0 ; case 2 : return 1 ; case 4 : return 2 ; case 8 : return 3 ; default : throw new TypeError ( ` Unknown type size: ${ a } ` ) ; } } var wb = void 0 ; function O ( a ) { for ( var b = "" ; C [ a ] ; ) b += wb [ C [ a ++ ] ] ; return b } var xb = void 0 ; function Q ( a ) { throw new xb ( a ) ; }
function yb ( a , b , c = { } ) { var d = b . name ; a || Q ( ` type " ${ d } " must have a positive integer typeid pointer ` ) ; if ( pb . hasOwnProperty ( a ) ) { if ( c . ff ) return ; Q ( ` Cannot register type ' ${ d } ' twice ` ) } pb [ a ] = b ; delete qb [ a ] ; ob . hasOwnProperty ( a ) && ( b = ob [ a ] , delete ob [ a ] , b . forEach ( f => f ( ) ) ) } function ub ( a , b , c = { } ) { if ( ! ( "argPackAdvance" in b ) ) throw new TypeError ( "registerType registeredInstance requires argPackAdvance" ) ; yb ( a , b , c ) } function zb ( a ) { Q ( a . kd . Nd . Ld . name + " instance already deleted" ) } var Ab = ! 1 ; function Bb ( ) { }
function Cb ( a ) { -- a . count . value ; 0 === a . count . value && ( a . Pd ? a . Td . Xd ( a . Pd ) : a . Nd . Ld . Xd ( a . Kd ) ) } function Db ( a , b , c ) { if ( b === c ) return a ; if ( void 0 === c . Qd ) return null ; a = Db ( a , b , c . Qd ) ; return null === a ? null : c . Ye ( a ) } var Jb = { } , Kb = [ ] ; function Lb ( ) { for ( ; Kb . length ; ) { var a = Kb . pop ( ) ; a . kd . ee = ! 1 ; a [ "delete" ] ( ) } } var Mb = void 0 , Nb = { } ; function Ob ( a , b ) { for ( void 0 === b && Q ( "ptr should not be undefined" ) ; a . Qd ; ) b = a . ke ( b ) , a = a . Qd ; return Nb [ b ] }
function Pb ( a , b ) { b . Nd && b . Kd || sb ( "makeClassHandle requires ptr and ptrType" ) ; ! ! b . Td !== ! ! b . Pd && sb ( "Both smartPtrType and smartPtr must be specified" ) ; b . count = { value : 1 } ; return Qb ( Object . create ( a , { kd : { value : b } } ) ) } function Qb ( a ) { if ( "undefined" === typeof FinalizationRegistry ) return Qb = b => b , a ; Ab = new FinalizationRegistry ( b => { Cb ( b . kd ) } ) ; Qb = b => { var c = b . kd ; c . Pd && Ab . register ( b , { kd : c } , b ) ; return b } ; Bb = b => { Ab . unregister ( b ) } ; return Qb ( a ) } function Rb ( ) { }
function Sb ( a ) { if ( void 0 === a ) return "_unknown" ; a = a . replace ( /[^a-zA-Z0-9_]/g , "$" ) ; var b = a . charCodeAt ( 0 ) ; return 48 <= b && 57 >= b ? ` _ ${ a } ` : a } function Tb ( a , b ) { a = Sb ( a ) ; return { [ a ] : function ( ) { return b . apply ( this , arguments ) } } [ a ] }
function Ub ( a , b , c ) { if ( void 0 === a [ b ] . Od ) { var d = a [ b ] ; a [ b ] = function ( ) { a [ b ] . Od . hasOwnProperty ( arguments . length ) || Q ( ` Function ' ${ c } ' called with an invalid number of arguments ( ${ arguments . length } ) - expects one of ( ${ a [ b ] . Od } )! ` ) ; return a [ b ] . Od [ arguments . length ] . apply ( this , arguments ) } ; a [ b ] . Od = [ ] ; a [ b ] . Od [ d . ce ] = d } }
function Vb ( a , b , c ) { r . hasOwnProperty ( a ) ? ( ( void 0 === c || void 0 !== r [ a ] . Od && void 0 !== r [ a ] . Od [ c ] ) && Q ( ` Cannot register public name ' ${ a } ' twice ` ) , Ub ( r , a , a ) , r . hasOwnProperty ( c ) && Q ( ` Cannot register multiple overloads of a function with the same number of arguments ( ${ c } )! ` ) , r [ a ] . Od [ c ] = b ) : ( r [ a ] = b , void 0 !== c && ( r [ a ] . xf = c ) ) } function Wb ( a , b , c , d , f , k , l , m ) { this . name = a ; this . constructor = b ; this . fe = c ; this . Xd = d ; this . Qd = f ; this . af = k ; this . ke = l ; this . Ye = m ; this . kf = [ ] }
function Xb ( a , b , c ) { for ( ; b !== c ; ) b . ke || Q ( ` Expected null or instance of ${ c . name } , got an instance of ${ b . name } ` ) , a = b . ke ( a ) , b = b . Qd ; return a } function Yb ( a , b ) { if ( null === b ) return this . Ae && Q ( ` null is not a valid ${ this . name } ` ) , 0 ; b . kd || Q ( ` Cannot pass " ${ Zb ( b ) } " as a ${ this . name } ` ) ; b . kd . Kd || Q ( ` Cannot pass deleted object as a pointer of type ${ this . name } ` ) ; return Xb ( b . kd . Kd , b . kd . Nd . Ld , this . Ld ) }
function $b ( a , b ) { if ( null === b ) { this . Ae && Q ( ` null is not a valid ${ this . name } ` ) ; if ( this . pe ) { var c = this . Be ( ) ; null !== a && a . push ( this . Xd , c ) ; return c } return 0 } b . kd || Q ( ` Cannot pass " ${ Zb ( b ) } " as a ${ this . name } ` ) ; b . kd . Kd || Q ( ` Cannot pass deleted object as a pointer of type ${ this . name } ` ) ; ! this . oe && b . kd . Nd . oe && Q ( ` Cannot convert argument of type ${ b . kd . Td ? b . kd . Td . name : b . kd . Nd . name } to parameter type ${ this . name } ` ) ; c = Xb ( b . kd . Kd , b . kd . Nd . Ld , this . Ld ) ; if ( this . pe ) switch ( void 0 === b . kd . Pd && Q ( "Passing raw pointer to smart pointer is illegal" ) ,
this . qf ) { case 0 : b . kd . Td === this ? c = b . kd . Pd : Q ( ` Cannot convert argument of type ${ b . kd . Td ? b . kd . Td . name : b . kd . Nd . name } to parameter type ${ this . name } ` ) ; break ; case 1 : c = b . kd . Pd ; break ; case 2 : if ( b . kd . Td === this ) c = b . kd . Pd ; else { var d = b . clone ( ) ; c = this . lf ( c , ac ( function ( ) { d [ "delete" ] ( ) } ) ) ; null !== a && a . push ( this . Xd , c ) } break ; default : Q ( "Unsupporting sharing policy" ) } return c }
function bc ( a , b ) { if ( null === b ) return this . Ae && Q ( ` null is not a valid ${ this . name } ` ) , 0 ; b . kd || Q ( ` Cannot pass " ${ Zb ( b ) } " as a ${ this . name } ` ) ; b . kd . Kd || Q ( ` Cannot pass deleted object as a pointer of type ${ this . name } ` ) ; b . kd . Nd . oe && Q ( ` Cannot convert argument of type ${ b . kd . Nd . name } to parameter type ${ this . name } ` ) ; return Xb ( b . kd . Kd , b . kd . Nd . Ld , this . Ld ) }
function cc ( a , b , c , d , f , k , l , m , p , w , y ) { this . name = a ; this . Ld = b ; this . Ae = c ; this . oe = d ; this . pe = f ; this . jf = k ; this . qf = l ; this . Ke = m ; this . Be = p ; this . lf = w ; this . Xd = y ; f || void 0 !== b . Qd ? this . toWireType = $b : ( this . toWireType = d ? Yb : bc , this . Sd = null ) } function dc ( a , b , c ) { r . hasOwnProperty ( a ) || sb ( "Replacing nonexistant public symbol" ) ; void 0 !== r [ a ] . Od && void 0 !== c ? r [ a ] . Od [ c ] = b : ( r [ a ] = b , r [ a ] . ce = c ) }
var ec = ( a , b ) => { var c = [ ] ; return function ( ) { c . length = 0 ; Object . assign ( c , arguments ) ; if ( a . includes ( "j" ) ) { var d = r [ "dynCall_" + a ] ; d = c && c . length ? d . apply ( null , [ b ] . concat ( c ) ) : d . call ( null , b ) } else d = Na . get ( b ) . apply ( null , c ) ; return d } } ; function mc ( a , b ) { a = O ( a ) ; var c = a . includes ( "j" ) ? ec ( a , b ) : Na . get ( b ) ; "function" != typeof c && Q ( ` unknown function pointer with signature ${ a } : ${ b } ` ) ; return c } var nc = void 0 ; function oc ( a ) { a = pc ( a ) ; var b = O ( a ) ; qc ( a ) ; return b }
function rc ( a , b ) { function c ( k ) { f [ k ] || pb [ k ] || ( qb [ k ] ? qb [ k ] . forEach ( c ) : ( d . push ( k ) , f [ k ] = ! 0 ) ) } var d = [ ] , f = { } ; b . forEach ( c ) ; throw new nc ( ` ${ a } : ` + d . map ( oc ) . join ( [ ", " ] ) ) ; }
function sc ( a , b , c , d , f ) { var k = b . length ; 2 > k && Q ( "argTypes array size mismatch! Must at least get return value and 'this' types!" ) ; var l = null !== b [ 1 ] && null !== c , m = ! 1 ; for ( c = 1 ; c < b . length ; ++ c ) if ( null !== b [ c ] && void 0 === b [ c ] . Sd ) { m = ! 0 ; break } var p = "void" !== b [ 0 ] . name , w = k - 2 , y = Array ( w ) , B = [ ] , D = [ ] ; return function ( ) { arguments . length !== w && Q ( ` function ${ a } called with ${ arguments . length } arguments, expected ${ w } args! ` ) ; D . length = 0 ; B . length = l ? 2 : 1 ; B [ 0 ] = f ; if ( l ) { var u = b [ 1 ] . toWireType ( D , this ) ; B [ 1 ] = u } for ( var F = 0 ; F < w ; ++ F ) y [ F ] =
b [ F + 2 ] . toWireType ( D , arguments [ F ] ) , B . push ( y [ F ] ) ; F = d . apply ( null , B ) ; if ( m ) mb ( D ) ; else for ( var H = l ? 1 : 2 ; H < b . length ; H ++ ) { var T = 1 === H ? u : y [ H - 2 ] ; null !== b [ H ] . Sd && b [ H ] . Sd ( T ) } u = p ? b [ 0 ] . fromWireType ( F ) : void 0 ; return u } } function tc ( a , b ) { for ( var c = [ ] , d = 0 ; d < a ; d ++ ) c . push ( L [ b + 4 * d >> 2 ] ) ; return c } function uc ( ) { this . Wd = [ void 0 ] ; this . Ie = [ ] } var vc = new uc ; function wc ( a ) { a >= vc . Zd && 0 === -- vc . get ( a ) . Le && vc . we ( a ) }
var xc = a => { a || Q ( "Cannot use deleted val. handle = " + a ) ; return vc . get ( a ) . value } , ac = a => { switch ( a ) { case void 0 : return 1 ; case null : return 2 ; case ! 0 : return 3 ; case ! 1 : return 4 ; default : return vc . ve ( { Le : 1 , value : a } ) } } ; function yc ( a , b , c ) { switch ( b ) { case 0 : return function ( d ) { return this . fromWireType ( ( c ? Ha : C ) [ d ] ) } ; case 1 : return function ( d ) { return this . fromWireType ( ( c ? Ia : Ja ) [ d >> 1 ] ) } ; case 2 : return function ( d ) { return this . fromWireType ( ( c ? K : L ) [ d >> 2 ] ) } ; default : throw new TypeError ( "Unknown integer type: " + a ) ; } }
function zc ( a , b ) { var c = pb [ a ] ; void 0 === c && Q ( b + " has unknown type " + oc ( a ) ) ; return c } function Zb ( a ) { if ( null === a ) return "null" ; var b = typeof a ; return "object" === b || "array" === b || "function" === b ? a . toString ( ) : "" + a } function Ac ( a , b ) { switch ( b ) { case 2 : return function ( c ) { return this . fromWireType ( N [ c >> 2 ] ) } ; case 3 : return function ( c ) { return this . fromWireType ( Ka [ c >> 3 ] ) } ; default : throw new TypeError ( "Unknown float type: " + a ) ; } }
function Bc ( a , b , c ) { switch ( b ) { case 0 : return c ? function ( d ) { return Ha [ d ] } : function ( d ) { return C [ d ] } ; case 1 : return c ? function ( d ) { return Ia [ d >> 1 ] } : function ( d ) { return Ja [ d >> 1 ] } ; case 2 : return c ? function ( d ) { return K [ d >> 2 ] } : function ( d ) { return L [ d >> 2 ] } ; default : throw new TypeError ( "Unknown integer type: " + a ) ; } }
var ka = ( a , b , c , d ) => { if ( ! ( 0 < d ) ) return 0 ; var f = c ; d = c + d - 1 ; for ( var k = 0 ; k < a . length ; ++ k ) { var l = a . charCodeAt ( k ) ; if ( 55296 <= l && 57343 >= l ) { var m = a . charCodeAt ( ++ k ) ; l = 65536 + ( ( l & 1023 ) << 10 ) | m & 1023 } if ( 127 >= l ) { if ( c >= d ) break ; b [ c ++ ] = l } else { if ( 2047 >= l ) { if ( c + 1 >= d ) break ; b [ c ++ ] = 192 | l >> 6 } else { if ( 65535 >= l ) { if ( c + 2 >= d ) break ; b [ c ++ ] = 224 | l >> 12 } else { if ( c + 3 >= d ) break ; b [ c ++ ] = 240 | l >> 18 ; b [ c ++ ] = 128 | l >> 12 & 63 } b [ c ++ ] = 128 | l >> 6 & 63 } b [ c ++ ] = 128 | l & 63 } } b [ c ] = 0 ; return c - f } , ja = a => { for ( var b = 0 , c = 0 ; c < a . length ; ++ c ) { var d = a . charCodeAt ( c ) ; 127 >= d ? b ++ : 2047 >=
d ? b += 2 : 55296 <= d && 57343 >= d ? ( b += 4 , ++ c ) : b += 3 } return b } , Cc = "undefined" != typeof TextDecoder ? new TextDecoder ( "utf-16le" ) : void 0 , Dc = ( a , b ) => { var c = a >> 1 ; for ( var d = c + b / 2 ; ! ( c >= d ) && Ja [ c ] ; ) ++ c ; c <<= 1 ; if ( 32 < c - a && Cc ) return Cc . decode ( C . subarray ( a , c ) ) ; c = "" ; for ( d = 0 ; ! ( d >= b / 2 ) ; ++ d ) { var f = Ia [ a + 2 * d >> 1 ] ; if ( 0 == f ) break ; c += String . fromCharCode ( f ) } return c } , Ec = ( a , b , c ) => { void 0 === c && ( c = 2147483647 ) ; if ( 2 > c ) return 0 ; c -= 2 ; var d = b ; c = c < 2 * a . length ? c / 2 : a . length ; for ( var f = 0 ; f < c ; ++ f ) Ia [ b >> 1 ] = a . charCodeAt ( f ) , b += 2 ; Ia [ b >> 1 ] = 0 ; return b - d } ,
Fc = a => 2 * a . length , Gc = ( a , b ) => { for ( var c = 0 , d = "" ; ! ( c >= b / 4 ) ; ) { var f = K [ a + 4 * c >> 2 ] ; if ( 0 == f ) break ; ++ c ; 65536 <= f ? ( f -= 65536 , d += String . fromCharCode ( 55296 | f >> 10 , 56320 | f & 1023 ) ) : d += String . fromCharCode ( f ) } return d } , Hc = ( a , b , c ) => { void 0 === c && ( c = 2147483647 ) ; if ( 4 > c ) return 0 ; var d = b ; c = d + c - 4 ; for ( var f = 0 ; f < a . length ; ++ f ) { var k = a . charCodeAt ( f ) ; if ( 55296 <= k && 57343 >= k ) { var l = a . charCodeAt ( ++ f ) ; k = 65536 + ( ( k & 1023 ) << 10 ) | l & 1023 } K [ b >> 2 ] = k ; b += 4 ; if ( b + 4 > c ) break } K [ b >> 2 ] = 0 ; return b - d } , Ic = a => { for ( var b = 0 , c = 0 ; c < a . length ; ++ c ) { var d = a . charCodeAt ( c ) ;
55296 <= d && 57343 >= d && ++ c ; b += 4 } return b } , Jc = { } ; function Kc ( a ) { var b = Jc [ a ] ; return void 0 === b ? O ( a ) : b } var Lc = [ ] ;
function Mc ( ) { function a ( b ) { b . $$$embind _global$$$ = b ; var c = "object" == typeof $$$embind _global$$$ && b . $$$embind _global$$$ == b ; c || delete b . $$$embind _global$$$ ; return c } if ( "object" == typeof globalThis ) return globalThis ; if ( "object" == typeof $$$embind _global$$$ ) return $$$embind _global$$$ ; "object" == typeof global && a ( global ) ? $$$embind _global$$$ = global : "object" == typeof self && a ( self ) && ( $$$embind _global$$$ = self ) ; if ( "object" == typeof $$$embind _global$$$ ) return $$$embind _global$$$ ; throw Error ( "unable to get global object." ) ;
} function Nc ( a ) { var b = Lc . length ; Lc . push ( a ) ; return b } function Oc ( a , b ) { for ( var c = Array ( a ) , d = 0 ; d < a ; ++ d ) c [ d ] = zc ( L [ b + 4 * d >> 2 ] , "parameter " + d ) ; return c } var Pc = [ ] ; function Qc ( a ) { var b = Array ( a + 1 ) ; return function ( c , d , f ) { b [ 0 ] = c ; for ( var k = 0 ; k < a ; ++ k ) { var l = zc ( L [ d + 4 * k >> 2 ] , "parameter " + k ) ; b [ k + 1 ] = l . readValueFromPointer ( f ) ; f += l . argPackAdvance } c = new ( c . bind . apply ( c , b ) ) ; return ac ( c ) } } var Rc = { } ;
function Sc ( a ) { var b = a . getExtension ( "ANGLE_instanced_arrays" ) ; b && ( a . vertexAttribDivisor = function ( c , d ) { b . vertexAttribDivisorANGLE ( c , d ) } , a . drawArraysInstanced = function ( c , d , f , k ) { b . drawArraysInstancedANGLE ( c , d , f , k ) } , a . drawElementsInstanced = function ( c , d , f , k , l ) { b . drawElementsInstancedANGLE ( c , d , f , k , l ) } ) }
function Tc ( a ) { var b = a . getExtension ( "OES_vertex_array_object" ) ; b && ( a . createVertexArray = function ( ) { return b . createVertexArrayOES ( ) } , a . deleteVertexArray = function ( c ) { b . deleteVertexArrayOES ( c ) } , a . bindVertexArray = function ( c ) { b . bindVertexArrayOES ( c ) } , a . isVertexArray = function ( c ) { return b . isVertexArrayOES ( c ) } ) } function Uc ( a ) { var b = a . getExtension ( "WEBGL_draw_buffers" ) ; b && ( a . drawBuffers = function ( c , d ) { b . drawBuffersWEBGL ( c , d ) } ) }
var Vc = 1 , Wc = [ ] , Xc = [ ] , Yc = [ ] , Zc = [ ] , ea = [ ] , $c = [ ] , ad = [ ] , ia = [ ] , bd = [ ] , cd = [ ] , dd = { } , ed = { } , gd = 4 ; function R ( a ) { hd || ( hd = a ) } function da ( a ) { for ( var b = Vc ++ , c = a . length ; c < b ; c ++ ) a [ c ] = null ; return b } function fa ( a , b ) { a . Zd || ( a . Zd = a . getContext , a . getContext = function ( d , f ) { f = a . Zd ( d , f ) ; return "webgl" == d == f instanceof WebGLRenderingContext ? f : null } ) ; var c = 1 < b . majorVersion ? a . getContext ( "webgl2" , b ) : a . getContext ( "webgl" , b ) ; return c ? jd ( c , b ) : 0 }
function jd ( a , b ) { var c = da ( ia ) , d = { handle : c , attributes : b , version : b . majorVersion , Ud : a } ; a . canvas && ( a . canvas . Oe = d ) ; ia [ c ] = d ; ( "undefined" == typeof b . Ze || b . Ze ) && kd ( d ) ; return c } function ha ( a ) { v = ia [ a ] ; r . vf = S = v && v . Ud ; return ! ( a && ! S ) }
function kd ( a ) { a || ( a = v ) ; if ( ! a . gf ) { a . gf = ! 0 ; var b = a . Ud ; Sc ( b ) ; Tc ( b ) ; Uc ( b ) ; b . Fe = b . getExtension ( "WEBGL_draw_instanced_base_vertex_base_instance" ) ; b . Je = b . getExtension ( "WEBGL_multi_draw_instanced_base_vertex_base_instance" ) ; 2 <= a . version && ( b . Ge = b . getExtension ( "EXT_disjoint_timer_query_webgl2" ) ) ; if ( 2 > a . version || ! b . Ge ) b . Ge = b . getExtension ( "EXT_disjoint_timer_query" ) ; b . wf = b . getExtension ( "WEBGL_multi_draw" ) ; ( b . getSupportedExtensions ( ) || [ ] ) . forEach ( function ( c ) { c . includes ( "lose_context" ) || c . includes ( "debug" ) || b . getExtension ( c ) } ) } }
var v , hd , ld = { } , nd = ( ) => { if ( ! md ) { var a = { USER : "web_user" , LOGNAME : "web_user" , PATH : "/" , PWD : "/" , HOME : "/home/web_user" , LANG : ( "object" == typeof navigator && navigator . languages && navigator . languages [ 0 ] || "C" ) . replace ( "-" , "_" ) + ".UTF-8" , _ : ma || "./this.program" } , b ; for ( b in ld ) void 0 === ld [ b ] ? delete a [ b ] : a [ b ] = ld [ b ] ; var c = [ ] ; for ( b in a ) c . push ( ` ${ b } = ${ a [ b ] } ` ) ; md = c } return md } , md , od = [ null , [ ] , [ ] ] ; function pd ( a ) { S . bindVertexArray ( ad [ a ] ) }
function qd ( a , b ) { for ( var c = 0 ; c < a ; c ++ ) { var d = K [ b + 4 * c >> 2 ] ; S . deleteVertexArray ( ad [ d ] ) ; ad [ d ] = null } } var rd = [ ] ; function sd ( a , b , c , d ) { S . drawElements ( a , b , c , d ) } function td ( a , b , c , d ) { for ( var f = 0 ; f < a ; f ++ ) { var k = S [ c ] ( ) , l = k && da ( d ) ; k ? ( k . name = l , d [ l ] = k ) : R ( 1282 ) ; K [ b + 4 * f >> 2 ] = l } } function ud ( a , b ) { td ( a , b , "createVertexArray" , ad ) }
function vd ( a , b , c ) { if ( b ) { var d = void 0 ; switch ( a ) { case 36346 : d = 1 ; break ; case 36344 : 0 != c && 1 != c && R ( 1280 ) ; return ; case 34814 : case 36345 : d = 0 ; break ; case 34466 : var f = S . getParameter ( 34467 ) ; d = f ? f . length : 0 ; break ; case 33309 : if ( 2 > v . version ) { R ( 1282 ) ; return } d = 2 * ( S . getSupportedExtensions ( ) || [ ] ) . length ; break ; case 33307 : case 33308 : if ( 2 > v . version ) { R ( 1280 ) ; return } d = 33307 == a ? 3 : 0 } if ( void 0 === d ) switch ( f = S . getParameter ( a ) , typeof f ) { case "number" : d = f ; break ; case "boolean" : d = f ? 1 : 0 ; break ; case "string" : R ( 1280 ) ; return ; case "object" : if ( null ===
f ) switch ( a ) { case 34964 : case 35725 : case 34965 : case 36006 : case 36007 : case 32873 : case 34229 : case 36662 : case 36663 : case 35053 : case 35055 : case 36010 : case 35097 : case 35869 : case 32874 : case 36389 : case 35983 : case 35368 : case 34068 : d = 0 ; break ; default : R ( 1280 ) ; return } else { if ( f instanceof Float32Array || f instanceof Uint32Array || f instanceof Int32Array || f instanceof Array ) { for ( a = 0 ; a < f . length ; ++ a ) switch ( c ) { case 0 : K [ b + 4 * a >> 2 ] = f [ a ] ; break ; case 2 : N [ b + 4 * a >> 2 ] = f [ a ] ; break ; case 4 : Ha [ b + a >> 0 ] = f [ a ] ? 1 : 0 } return } try { d = f . name | 0 } catch ( k ) { R ( 1280 ) ;
Ca ( "GL_INVALID_ENUM in glGet" + c + "v: Unknown object returned from WebGL getParameter(" + a + ")! (error: " + k + ")" ) ; return } } break ; default : R ( 1280 ) ; Ca ( "GL_INVALID_ENUM in glGet" + c + "v: Native code calling glGet" + c + "v(" + a + ") and it returns " + f + " of type " + typeof f + "!" ) ; return } switch ( c ) { case 1 : c = d ; L [ b >> 2 ] = c ; L [ b + 4 >> 2 ] = ( c - L [ b >> 2 ] ) / 4294967296 ; break ; case 0 : K [ b >> 2 ] = d ; break ; case 2 : N [ b >> 2 ] = d ; break ; case 4 : Ha [ b >> 0 ] = d ? 1 : 0 } } else R ( 1281 ) } var xd = a => { var b = ja ( a ) + 1 , c = wd ( b ) ; c && ka ( a , C , c , b ) ; return c } ;
function yd ( a ) { return "]" == a . slice ( - 1 ) && a . lastIndexOf ( "[" ) } function zd ( a ) { a -= 5120 ; return 0 == a ? Ha : 1 == a ? C : 2 == a ? Ia : 4 == a ? K : 6 == a ? N : 5 == a || 28922 == a || 28520 == a || 30779 == a || 30782 == a ? L : Ja } function Ad ( a , b , c , d , f ) { a = zd ( a ) ; var k = 31 - Math . clz32 ( a . BYTES _PER _ELEMENT ) , l = gd ; return a . subarray ( f >> k , f + d * ( c * ( { 5 : 3 , 6 : 4 , 8 : 2 , 29502 : 3 , 29504 : 4 , 26917 : 2 , 26918 : 2 , 29846 : 3 , 29847 : 4 } [ b - 6402 ] || 1 ) * ( 1 << k ) + l - 1 & - l ) >> k ) }
function W ( a ) { var b = S . We ; if ( b ) { var c = b . je [ a ] ; "number" == typeof c && ( b . je [ a ] = c = S . getUniformLocation ( b , b . Me [ a ] + ( 0 < c ? "[" + c + "]" : "" ) ) ) ; return c } R ( 1282 ) } var Bd = [ ] , Cd = [ ] , Dd = a => 0 === a % 4 && ( 0 !== a % 100 || 0 === a % 400 ) , Ed = [ 31 , 29 , 31 , 30 , 31 , 30 , 31 , 31 , 30 , 31 , 30 , 31 ] , Fd = [ 31 , 28 , 31 , 30 , 31 , 30 , 31 , 31 , 30 , 31 , 30 , 31 ] ; function Gd ( a ) { var b = Array ( ja ( a ) + 1 ) ; ka ( a , b , 0 , b . length ) ; return b }
var Hd = ( a , b , c , d ) => { function f ( u , F , H ) { for ( u = "number" == typeof u ? u . toString ( ) : u || "" ; u . length < F ; ) u = H [ 0 ] + u ; return u } function k ( u , F ) { return f ( u , F , "0" ) } function l ( u , F ) { function H ( ca ) { return 0 > ca ? - 1 : 0 < ca ? 1 : 0 } var T ; 0 === ( T = H ( u . getFullYear ( ) - F . getFullYear ( ) ) ) && 0 === ( T = H ( u . getMonth ( ) - F . getMonth ( ) ) ) && ( T = H ( u . getDate ( ) - F . getDate ( ) ) ) ; return T } function m ( u ) { switch ( u . getDay ( ) ) { case 0 : return new Date ( u . getFullYear ( ) - 1 , 11 , 29 ) ; case 1 : return u ; case 2 : return new Date ( u . getFullYear ( ) , 0 , 3 ) ; case 3 : return new Date ( u . getFullYear ( ) ,
0 , 2 ) ; case 4 : return new Date ( u . getFullYear ( ) , 0 , 1 ) ; case 5 : return new Date ( u . getFullYear ( ) - 1 , 11 , 31 ) ; case 6 : return new Date ( u . getFullYear ( ) - 1 , 11 , 30 ) } } function p ( u ) { var F = u . $d ; for ( u = new Date ( ( new Date ( u . ae + 1900 , 0 , 1 ) ) . getTime ( ) ) ; 0 < F ; ) { var H = u . getMonth ( ) , T = ( Dd ( u . getFullYear ( ) ) ? Ed : Fd ) [ H ] ; if ( F > T - u . getDate ( ) ) F -= T - u . getDate ( ) + 1 , u . setDate ( 1 ) , 11 > H ? u . setMonth ( H + 1 ) : ( u . setMonth ( 0 ) , u . setFullYear ( u . getFullYear ( ) + 1 ) ) ; else { u . setDate ( u . getDate ( ) + F ) ; break } } H = new Date ( u . getFullYear ( ) + 1 , 0 , 4 ) ; F = m ( new Date ( u . getFullYear ( ) ,
0 , 4 ) ) ; H = m ( H ) ; return 0 >= l ( F , u ) ? 0 >= l ( H , u ) ? u . getFullYear ( ) + 1 : u . getFullYear ( ) : u . getFullYear ( ) - 1 } var w = K [ d + 40 >> 2 ] ; d = { tf : K [ d >> 2 ] , sf : K [ d + 4 >> 2 ] , te : K [ d + 8 >> 2 ] , Ce : K [ d + 12 >> 2 ] , ue : K [ d + 16 >> 2 ] , ae : K [ d + 20 >> 2 ] , Vd : K [ d + 24 >> 2 ] , $d : K [ d + 28 >> 2 ] , zf : K [ d + 32 >> 2 ] , rf : K [ d + 36 >> 2 ] , uf : w ? w ? kb ( C , w ) : "" : "" } ; c = c ? kb ( C , c ) : "" ; w = { "%c" : "%a %b %d %H:%M:%S %Y" , "%D" : "%m/%d/%y" , "%F" : "%Y-%m-%d" , "%h" : "%b" , "%r" : "%I:%M:%S %p" , "%R" : "%H:%M" , "%T" : "%H:%M:%S" , "%x" : "%m/%d/%y" , "%X" : "%H:%M:%S" , "%Ec" : "%c" , "%EC" : "%C" , "%Ex" : "%m/%d/%y" , "%EX" : "%H:%M:%S" , "%Ey" : "%y" ,
"%EY" : "%Y" , "%Od" : "%d" , "%Oe" : "%e" , "%OH" : "%H" , "%OI" : "%I" , "%Om" : "%m" , "%OM" : "%M" , "%OS" : "%S" , "%Ou" : "%u" , "%OU" : "%U" , "%OV" : "%V" , "%Ow" : "%w" , "%OW" : "%W" , "%Oy" : "%y" } ; for ( var y in w ) c = c . replace ( new RegExp ( y , "g" ) , w [ y ] ) ; var B = "Sunday Monday Tuesday Wednesday Thursday Friday Saturday" . split ( " " ) , D = "January February March April May June July August September October November December" . split ( " " ) ; w = { "%a" : u => B [ u . Vd ] . substring ( 0 , 3 ) , "%A" : u => B [ u . Vd ] , "%b" : u => D [ u . ue ] . substring ( 0 , 3 ) , "%B" : u => D [ u . ue ] , "%C" : u => k ( ( u . ae + 1900 ) /
100 | 0 , 2 ) , "%d" : u => k ( u . Ce , 2 ) , "%e" : u => f ( u . Ce , 2 , " " ) , "%g" : u => p ( u ) . toString ( ) . substring ( 2 ) , "%G" : u => p ( u ) , "%H" : u => k ( u . te , 2 ) , "%I" : u => { u = u . te ; 0 == u ? u = 12 : 12 < u && ( u -= 12 ) ; return k ( u , 2 ) } , "%j" : u => { for ( var F = 0 , H = 0 ; H <= u . ue - 1 ; F += ( Dd ( u . ae + 1900 ) ? Ed : Fd ) [ H ++ ] ) ; return k ( u . Ce + F , 3 ) } , "%m" : u => k ( u . ue + 1 , 2 ) , "%M" : u => k ( u . sf , 2 ) , "%n" : ( ) => "\n" , "%p" : u => 0 <= u . te && 12 > u . te ? "AM" : "PM" , "%S" : u => k ( u . tf , 2 ) , "%t" : ( ) => "\t" , "%u" : u => u . Vd || 7 , "%U" : u => k ( Math . floor ( ( u . $d + 7 - u . Vd ) / 7 ) , 2 ) , "%V" : u => { var F = Math . floor ( ( u . $d + 7 - ( u . Vd + 6 ) % 7 ) / 7 ) ; 2 >= ( u . Vd + 371 - u . $d -
2 ) % 7 && F ++ ; if ( F ) 53 == F && ( H = ( u . Vd + 371 - u . $d ) % 7 , 4 == H || 3 == H && Dd ( u . ae ) || ( F = 1 ) ) ; else { F = 52 ; var H = ( u . Vd + 7 - u . $d - 1 ) % 7 ; ( 4 == H || 5 == H && Dd ( u . ae % 400 - 1 ) ) && F ++ } return k ( F , 2 ) } , "%w" : u => u . Vd , "%W" : u => k ( Math . floor ( ( u . $d + 7 - ( u . Vd + 6 ) % 7 ) / 7 ) , 2 ) , "%y" : u => ( u . ae + 1900 ) . toString ( ) . substring ( 2 ) , "%Y" : u => u . ae + 1900 , "%z" : u => { u = u . rf ; var F = 0 <= u ; u = Math . abs ( u ) / 60 ; return ( F ? "+" : "-" ) + String ( "0000" + ( u / 60 * 100 + u % 60 ) ) . slice ( - 4 ) } , "%Z" : u => u . uf , "%%" : ( ) => "%" } ; c = c . replace ( /%%/g , "\x00\x00" ) ; for ( y in w ) c . includes ( y ) && ( c = c . replace ( new RegExp ( y , "g" ) , w [ y ] ( d ) ) ) ;
c = c . replace ( /\0\0/g , "%" ) ; y = Gd ( c ) ; if ( y . length > b ) return 0 ; Ha . set ( y , a ) ; return y . length - 1 } ; rb = r . InternalError = class extends Error { constructor ( a ) { super ( a ) ; this . name = "InternalError" } } ; for ( var Id = Array ( 256 ) , Jd = 0 ; 256 > Jd ; ++ Jd ) Id [ Jd ] = String . fromCharCode ( Jd ) ; wb = Id ; xb = r . BindingError = class extends Error { constructor ( a ) { super ( a ) ; this . name = "BindingError" } } ;
Rb . prototype . isAliasOf = function ( a ) { if ( ! ( this instanceof Rb && a instanceof Rb ) ) return ! 1 ; var b = this . kd . Nd . Ld , c = this . kd . Kd , d = a . kd . Nd . Ld ; for ( a = a . kd . Kd ; b . Qd ; ) c = b . ke ( c ) , b = b . Qd ; for ( ; d . Qd ; ) a = d . ke ( a ) , d = d . Qd ; return b === d && c === a } ;
Rb . prototype . clone = function ( ) { this . kd . Kd || zb ( this ) ; if ( this . kd . ie ) return this . kd . count . value += 1 , this ; var a = Qb , b = Object , c = b . create , d = Object . getPrototypeOf ( this ) , f = this . kd ; a = a ( c . call ( b , d , { kd : { value : { count : f . count , ee : f . ee , ie : f . ie , Kd : f . Kd , Nd : f . Nd , Pd : f . Pd , Td : f . Td } } } ) ) ; a . kd . count . value += 1 ; a . kd . ee = ! 1 ; return a } ; Rb . prototype [ "delete" ] = function ( ) { this . kd . Kd || zb ( this ) ; this . kd . ee && ! this . kd . ie && Q ( "Object already scheduled for deletion" ) ; Bb ( this ) ; Cb ( this . kd ) ; this . kd . ie || ( this . kd . Pd = void 0 , this . kd . Kd = void 0 ) } ;
Rb . prototype . isDeleted = function ( ) { return ! this . kd . Kd } ; Rb . prototype . deleteLater = function ( ) { this . kd . Kd || zb ( this ) ; this . kd . ee && ! this . kd . ie && Q ( "Object already scheduled for deletion" ) ; Kb . push ( this ) ; 1 === Kb . length && Mb && Mb ( Lb ) ; this . kd . ee = ! 0 ; return this } ; r . getInheritedInstanceCount = function ( ) { return Object . keys ( Nb ) . length } ; r . getLiveInheritedInstances = function ( ) { var a = [ ] , b ; for ( b in Nb ) Nb . hasOwnProperty ( b ) && a . push ( Nb [ b ] ) ; return a } ; r . flushPendingDeletes = Lb ; r . setDelayFunction = function ( a ) { Mb = a ; Kb . length && Mb && Mb ( Lb ) } ;
cc . prototype . bf = function ( a ) { this . Ke && ( a = this . Ke ( a ) ) ; return a } ; cc . prototype . Ee = function ( a ) { this . Xd && this . Xd ( a ) } ; cc . prototype . argPackAdvance = 8 ; cc . prototype . readValueFromPointer = nb ; cc . prototype . deleteObject = function ( a ) { if ( null !== a ) a [ "delete" ] ( ) } ;
cc . prototype . fromWireType = function ( a ) { function b ( ) { return this . pe ? Pb ( this . Ld . fe , { Nd : this . jf , Kd : c , Td : this , Pd : a } ) : Pb ( this . Ld . fe , { Nd : this , Kd : a } ) } var c = this . bf ( a ) ; if ( ! c ) return this . Ee ( a ) , null ; var d = Ob ( this . Ld , c ) ; if ( void 0 !== d ) { if ( 0 === d . kd . count . value ) return d . kd . Kd = c , d . kd . Pd = a , d . clone ( ) ; d = d . clone ( ) ; this . Ee ( a ) ; return d } d = this . Ld . af ( c ) ; d = Jb [ d ] ; if ( ! d ) return b . call ( this ) ; d = this . oe ? d . Ve : d . pointerType ; var f = Db ( c , this . Ld , d . Ld ) ; return null === f ? b . call ( this ) : this . pe ? Pb ( d . Ld . fe , { Nd : d , Kd : f , Td : this , Pd : a } ) : Pb ( d . Ld . fe ,
{ Nd : d , Kd : f } ) } ; nc = r . UnboundTypeError = function ( a , b ) { var c = Tb ( b , function ( d ) { this . name = b ; this . message = d ; d = Error ( d ) . stack ; void 0 !== d && ( this . stack = this . toString ( ) + "\n" + d . replace ( /^Error(:[^\n]*)?\n/ , "" ) ) } ) ; c . prototype = Object . create ( a . prototype ) ; c . prototype . constructor = c ; c . prototype . toString = function ( ) { return void 0 === this . message ? this . name : ` ${ this . name } : ${ this . message } ` } ; return c } ( Error , "UnboundTypeError" ) ;
Object . assign ( uc . prototype , { get ( a ) { return this . Wd [ a ] } , has ( a ) { return void 0 !== this . Wd [ a ] } , ve ( a ) { var b = this . Ie . pop ( ) || this . Wd . length ; this . Wd [ b ] = a ; return b } , we ( a ) { this . Wd [ a ] = void 0 ; this . Ie . push ( a ) } } ) ; vc . Wd . push ( { value : void 0 } , { value : null } , { value : ! 0 } , { value : ! 1 } ) ; vc . Zd = vc . Wd . length ; r . count _emval _handles = function ( ) { for ( var a = 0 , b = vc . Zd ; b < vc . Wd . length ; ++ b ) void 0 !== vc . Wd [ b ] && ++ a ; return a } ; for ( var S , Kd = 0 ; 32 > Kd ; ++ Kd ) rd . push ( Array ( Kd ) ) ; var Ld = new Float32Array ( 288 ) ;
for ( Kd = 0 ; 288 > Kd ; ++ Kd ) Bd [ Kd ] = Ld . subarray ( 0 , Kd + 1 ) ; var Md = new Int32Array ( 288 ) ; for ( Kd = 0 ; 288 > Kd ; ++ Kd ) Cd [ Kd ] = Md . subarray ( 0 , Kd + 1 ) ;
var $d = { H : function ( a , b , c ) { ( new fb ( a ) ) . Zd ( b , c ) ; gb = a ; ib ++ ; throw gb ; } , U : function ( ) { return 0 } , vb : ( ) => { } , xb : function ( ) { return 0 } , sb : ( ) => { } , tb : ( ) => { } , V : function ( ) { } , ub : ( ) => { } , C : function ( a ) { var b = lb [ a ] ; delete lb [ a ] ; var c = b . Be , d = b . Xd , f = b . He , k = f . map ( l => l . ef ) . concat ( f . map ( l => l . nf ) ) ; tb ( [ a ] , k , l => { var m = { } ; f . forEach ( ( p , w ) => { var y = l [ w ] , B = p . cf , D = p . df , u = l [ w + f . length ] , F = p . mf , H = p . pf ; m [ p . $e ] = { read : T => y . fromWireType ( B ( D , T ) ) , write : ( T , ca ) => { var Y = [ ] ; F ( H , T , u . toWireType ( Y , ca ) ) ; mb ( Y ) } } } ) ; return [ { name : b . name , fromWireType : function ( p ) { var w =
{ } , y ; for ( y in m ) w [ y ] = m [ y ] . read ( p ) ; d ( p ) ; return w } , toWireType : function ( p , w ) { for ( var y in m ) if ( ! ( y in w ) ) throw new TypeError ( ` Missing field: " ${ y } " ` ) ; var B = c ( ) ; for ( y in m ) m [ y ] . write ( B , w [ y ] ) ; null !== p && p . push ( d , B ) ; return B } , argPackAdvance : 8 , readValueFromPointer : nb , Sd : d } ] } ) } , kb : function ( ) { } , Bb : function ( a , b , c , d , f ) { var k = vb ( c ) ; b = O ( b ) ; ub ( a , { name : b , fromWireType : function ( l ) { return ! ! l } , toWireType : function ( l , m ) { return m ? d : f } , argPackAdvance : 8 , readValueFromPointer : function ( l ) { if ( 1 === c ) var m = Ha ; else if ( 2 === c ) m = Ia ;
else if ( 4 === c ) m = K ; else throw new TypeError ( "Unknown boolean type size: " + b ) ; return this . fromWireType ( m [ l >> k ] ) } , Sd : null } ) } , l : function ( a , b , c , d , f , k , l , m , p , w , y , B , D ) { y = O ( y ) ; k = mc ( f , k ) ; m && ( m = mc ( l , m ) ) ; w && ( w = mc ( p , w ) ) ; D = mc ( B , D ) ; var u = Sb ( y ) ; Vb ( u , function ( ) { rc ( ` Cannot construct ${ y } due to unbound types ` , [ d ] ) } ) ; tb ( [ a , b , c ] , d ? [ d ] : [ ] , function ( F ) { F = F [ 0 ] ; if ( d ) { var H = F . Ld ; var T = H . fe } else T = Rb . prototype ; F = Tb ( u , function ( ) { if ( Object . getPrototypeOf ( this ) !== ca ) throw new xb ( "Use 'new' to construct " + y ) ; if ( void 0 === Y . Yd ) throw new xb ( y +
" has no accessible constructor" ) ; var Ma = Y . Yd [ arguments . length ] ; if ( void 0 === Ma ) throw new xb ( ` Tried to invoke ctor of ${ y } with invalid number of parameters ( ${ arguments . length } ) - expected ( ${ Object . keys ( Y . Yd ) . toString ( ) } ) parameters instead! ` ) ; return Ma . apply ( this , arguments ) } ) ; var ca = Object . create ( T , { constructor : { value : F } } ) ; F . prototype = ca ; var Y = new Wb ( y , F , ca , D , H , k , m , w ) ; Y . Qd && ( void 0 === Y . Qd . le && ( Y . Qd . le = [ ] ) , Y . Qd . le . push ( Y ) ) ; H = new cc ( y , Y , ! 0 , ! 1 , ! 1 ) ; T = new cc ( y + "*" , Y , ! 1 , ! 1 , ! 1 ) ; var va = new cc ( y + " const*" ,
Y , ! 1 , ! 0 , ! 1 ) ; Jb [ a ] = { pointerType : T , Ve : va } ; dc ( u , F ) ; return [ H , T , va ] } ) } , e : function ( a , b , c , d , f , k , l ) { var m = tc ( c , d ) ; b = O ( b ) ; k = mc ( f , k ) ; tb ( [ ] , [ a ] , function ( p ) { function w ( ) { rc ( ` Cannot call ${ y } due to unbound types ` , m ) } p = p [ 0 ] ; var y = ` ${ p . name } . ${ b } ` ; b . startsWith ( "@@" ) && ( b = Symbol [ b . substring ( 2 ) ] ) ; var B = p . Ld . constructor ; void 0 === B [ b ] ? ( w . ce = c - 1 , B [ b ] = w ) : ( Ub ( B , b , y ) , B [ b ] . Od [ c - 1 ] = w ) ; tb ( [ ] , m , function ( D ) { D = [ D [ 0 ] , null ] . concat ( D . slice ( 1 ) ) ; D = sc ( y , D , null , k , l ) ; void 0 === B [ b ] . Od ? ( D . ce = c - 1 , B [ b ] = D ) : B [ b ] . Od [ c - 1 ] = D ; if ( p . Ld . le ) for ( const u of p . Ld . le ) u . constructor . hasOwnProperty ( b ) ||
( u . constructor [ b ] = D ) ; return [ ] } ) ; return [ ] } ) } , A : function ( a , b , c , d , f , k ) { var l = tc ( b , c ) ; f = mc ( d , f ) ; tb ( [ ] , [ a ] , function ( m ) { m = m [ 0 ] ; var p = ` constructor ${ m . name } ` ; void 0 === m . Ld . Yd && ( m . Ld . Yd = [ ] ) ; if ( void 0 !== m . Ld . Yd [ b - 1 ] ) throw new xb ( ` Cannot register multiple constructors with identical number of parameters ( ${ b - 1 } ) for class ' ${ m . name } '! Overload resolution is currently only performed using the parameter count, not actual type info! ` ) ; m . Ld . Yd [ b - 1 ] = ( ) => { rc ( ` Cannot construct ${ m . name } due to unbound types ` , l ) } ;
tb ( [ ] , l , function ( w ) { w . splice ( 1 , 0 , null ) ; m . Ld . Yd [ b - 1 ] = sc ( p , w , null , f , k ) ; return [ ] } ) ; return [ ] } ) } , a : function ( a , b , c , d , f , k , l , m ) { var p = tc ( c , d ) ; b = O ( b ) ; k = mc ( f , k ) ; tb ( [ ] , [ a ] , function ( w ) { function y ( ) { rc ( ` Cannot call ${ B } due to unbound types ` , p ) } w = w [ 0 ] ; var B = ` ${ w . name } . ${ b } ` ; b . startsWith ( "@@" ) && ( b = Symbol [ b . substring ( 2 ) ] ) ; m && w . Ld . kf . push ( b ) ; var D = w . Ld . fe , u = D [ b ] ; void 0 === u || void 0 === u . Od && u . className !== w . name && u . ce === c - 2 ? ( y . ce = c - 2 , y . className = w . name , D [ b ] = y ) : ( Ub ( D , b , B ) , D [ b ] . Od [ c - 2 ] = y ) ; tb ( [ ] , p , function ( F ) { F = sc ( B , F ,
w , k , l ) ; void 0 === D [ b ] . Od ? ( F . ce = c - 2 , D [ b ] = F ) : D [ b ] . Od [ c - 2 ] = F ; return [ ] } ) ; return [ ] } ) } , t : function ( a , b , c ) { a = O ( a ) ; tb ( [ ] , [ b ] , function ( d ) { d = d [ 0 ] ; r [ a ] = d . fromWireType ( c ) ; return [ ] } ) } , Ab : function ( a , b ) { b = O ( b ) ; ub ( a , { name : b , fromWireType : function ( c ) { var d = xc ( c ) ; wc ( c ) ; return d } , toWireType : function ( c , d ) { return ac ( d ) } , argPackAdvance : 8 , readValueFromPointer : nb , Sd : null } ) } , j : function ( a , b , c , d ) { function f ( ) { } c = vb ( c ) ; b = O ( b ) ; f . values = { } ; ub ( a , { name : b , constructor : f , fromWireType : function ( k ) { return this . constructor . values [ k ] } , toWireType : function ( k ,
l ) { return l . value } , argPackAdvance : 8 , readValueFromPointer : yc ( b , c , d ) , Sd : null } ) ; Vb ( b , f ) } , b : function ( a , b , c ) { var d = zc ( a , "enum" ) ; b = O ( b ) ; a = d . constructor ; d = Object . create ( d . constructor . prototype , { value : { value : c } , constructor : { value : Tb ( ` ${ d . name } _ ${ b } ` , function ( ) { } ) } } ) ; a . values [ c ] = d ; a [ b ] = d } , X : function ( a , b , c ) { c = vb ( c ) ; b = O ( b ) ; ub ( a , { name : b , fromWireType : function ( d ) { return d } , toWireType : function ( d , f ) { return f } , argPackAdvance : 8 , readValueFromPointer : Ac ( b , c ) , Sd : null } ) } , v : function ( a , b , c , d , f , k ) { var l = tc ( b , c ) ; a = O ( a ) ; f =
mc ( d , f ) ; Vb ( a , function ( ) { rc ( ` Cannot call ${ a } due to unbound types ` , l ) } , b - 1 ) ; tb ( [ ] , l , function ( m ) { m = [ m [ 0 ] , null ] . concat ( m . slice ( 1 ) ) ; dc ( a , sc ( a , m , null , f , k ) , b - 1 ) ; return [ ] } ) } , E : function ( a , b , c , d , f ) { b = O ( b ) ; - 1 === f && ( f = 4294967295 ) ; f = vb ( c ) ; var k = m => m ; if ( 0 === d ) { var l = 32 - 8 * c ; k = m => m << l >>> l } c = b . includes ( "unsigned" ) ? function ( m , p ) { return p >>> 0 } : function ( m , p ) { return p } ; ub ( a , { name : b , fromWireType : k , toWireType : c , argPackAdvance : 8 , readValueFromPointer : Bc ( b , f , 0 !== d ) , Sd : null } ) } , s : function ( a , b , c ) { function d ( k ) { k >>= 2 ; var l =
L ; return new f ( l . buffer , l [ k + 1 ] , l [ k ] ) } var f = [ Int8Array , Uint8Array , Int16Array , Uint16Array , Int32Array , Uint32Array , Float32Array , Float64Array ] [ b ] ; c = O ( c ) ; ub ( a , { name : c , fromWireType : d , argPackAdvance : 8 , readValueFromPointer : d } , { ff : ! 0 } ) } , q : function ( a , b , c , d , f , k , l , m , p , w , y , B ) { c = O ( c ) ; k = mc ( f , k ) ; m = mc ( l , m ) ; w = mc ( p , w ) ; B = mc ( y , B ) ; tb ( [ a ] , [ b ] , function ( D ) { D = D [ 0 ] ; return [ new cc ( c , D . Ld , ! 1 , ! 1 , ! 0 , D , d , k , m , w , B ) ] } ) } , W : function ( a , b ) { b = O ( b ) ; var c = "std::string" === b ; ub ( a , { name : b , fromWireType : function ( d ) { var f = L [ d >> 2 ] , k = d + 4 ; if ( c ) for ( var l =
k , m = 0 ; m <= f ; ++ m ) { var p = k + m ; if ( m == f || 0 == C [ p ] ) { l = l ? kb ( C , l , p - l ) : "" ; if ( void 0 === w ) var w = l ; else w += String . fromCharCode ( 0 ) , w += l ; l = p + 1 } } else { w = Array ( f ) ; for ( m = 0 ; m < f ; ++ m ) w [ m ] = String . fromCharCode ( C [ k + m ] ) ; w = w . join ( "" ) } qc ( d ) ; return w } , toWireType : function ( d , f ) { f instanceof ArrayBuffer && ( f = new Uint8Array ( f ) ) ; var k = "string" == typeof f ; k || f instanceof Uint8Array || f instanceof Uint8ClampedArray || f instanceof Int8Array || Q ( "Cannot pass non-string to std::string" ) ; var l = c && k ? ja ( f ) : f . length ; var m = wd ( 4 + l + 1 ) , p = m + 4 ; L [ m >> 2 ] =
l ; if ( c && k ) ka ( f , C , p , l + 1 ) ; else if ( k ) for ( k = 0 ; k < l ; ++ k ) { var w = f . charCodeAt ( k ) ; 255 < w && ( qc ( p ) , Q ( "String has UTF-16 code units that do not fit in 8 bits" ) ) ; C [ p + k ] = w } else for ( k = 0 ; k < l ; ++ k ) C [ p + k ] = f [ k ] ; null !== d && d . push ( qc , m ) ; return m } , argPackAdvance : 8 , readValueFromPointer : nb , Sd : function ( d ) { qc ( d ) } } ) } , N : function ( a , b , c ) { c = O ( c ) ; if ( 2 === b ) { var d = Dc ; var f = Ec ; var k = Fc ; var l = ( ) => Ja ; var m = 1 } else 4 === b && ( d = Gc , f = Hc , k = Ic , l = ( ) => L , m = 2 ) ; ub ( a , { name : c , fromWireType : function ( p ) { for ( var w = L [ p >> 2 ] , y = l ( ) , B , D = p + 4 , u = 0 ; u <= w ; ++ u ) { var F =
p + 4 + u * b ; if ( u == w || 0 == y [ F >> m ] ) D = d ( D , F - D ) , void 0 === B ? B = D : ( B += String . fromCharCode ( 0 ) , B += D ) , D = F + b } qc ( p ) ; return B } , toWireType : function ( p , w ) { "string" != typeof w && Q ( ` Cannot pass non-string to C++ string type ${ c } ` ) ; var y = k ( w ) , B = wd ( 4 + y + b ) ; L [ B >> 2 ] = y >> m ; f ( w , B + 4 , y + b ) ; null !== p && p . push ( qc , B ) ; return B } , argPackAdvance : 8 , readValueFromPointer : nb , Sd : function ( p ) { qc ( p ) } } ) } , D : function ( a , b , c , d , f , k ) { lb [ a ] = { name : O ( b ) , Be : mc ( c , d ) , Xd : mc ( f , k ) , He : [ ] } } , d : function ( a , b , c , d , f , k , l , m , p , w ) { lb [ a ] . He . push ( { $e : O ( b ) , ef : c , cf : mc ( d , f ) , df : k ,
nf : l , mf : mc ( m , p ) , pf : w } ) } , Cb : function ( a , b ) { b = O ( b ) ; ub ( a , { hf : ! 0 , name : b , argPackAdvance : 0 , fromWireType : function ( ) { } , toWireType : function ( ) { } } ) } , zb : ( ) => ! 0 , ob : ( ) => { throw Infinity ; } , F : function ( a , b , c ) { a = xc ( a ) ; b = zc ( b , "emval::as" ) ; var d = [ ] , f = ac ( d ) ; L [ c >> 2 ] = f ; return b . toWireType ( d , a ) } , P : function ( a , b , c , d , f ) { a = Lc [ a ] ; b = xc ( b ) ; c = Kc ( c ) ; var k = [ ] ; L [ d >> 2 ] = ac ( k ) ; return a ( b , c , k , f ) } , u : function ( a , b , c , d ) { a = Lc [ a ] ; b = xc ( b ) ; c = Kc ( c ) ; a ( b , c , null , d ) } , c : wc , K : function ( a ) { if ( 0 === a ) return ac ( Mc ( ) ) ; a = Kc ( a ) ; return ac ( Mc ( ) [ a ] ) } , r : function ( a ,
b ) { var c = Oc ( a , b ) , d = c [ 0 ] ; b = d . name + "_$" + c . slice ( 1 ) . map ( function ( l ) { return l . name } ) . join ( "_" ) + "$" ; var f = Pc [ b ] ; if ( void 0 !== f ) return f ; var k = Array ( a - 1 ) ; f = Nc ( ( l , m , p , w ) => { for ( var y = 0 , B = 0 ; B < a - 1 ; ++ B ) k [ B ] = c [ B + 1 ] . readValueFromPointer ( w + y ) , y += c [ B + 1 ] . argPackAdvance ; l = l [ m ] . apply ( l , k ) ; for ( B = 0 ; B < a - 1 ; ++ B ) c [ B + 1 ] . Xe && c [ B + 1 ] . Xe ( k [ B ] ) ; if ( ! d . hf ) return d . toWireType ( p , l ) } ) ; return Pc [ b ] = f } , z : function ( a , b ) { a = xc ( a ) ; b = xc ( b ) ; return ac ( a [ b ] ) } , m : function ( a ) { 4 < a && ( vc . get ( a ) . Le += 1 ) } , J : function ( a , b , c , d ) { a = xc ( a ) ; var f = Rc [ b ] ; f || ( f =
Qc ( b ) , Rc [ b ] = f ) ; return f ( a , c , d ) } , I : function ( ) { return ac ( [ ] ) } , f : function ( a ) { return ac ( Kc ( a ) ) } , G : function ( ) { return ac ( { } ) } , eb : function ( a ) { a = xc ( a ) ; return ! a } , B : function ( a ) { var b = xc ( a ) ; mb ( b ) ; wc ( a ) } , i : function ( a , b , c ) { a = xc ( a ) ; b = xc ( b ) ; c = xc ( c ) ; a [ b ] = c } , g : function ( a , b ) { a = zc ( a , "_emval_take_value" ) ; a = a . readValueFromPointer ( b ) ; return ac ( a ) } , hb : function ( ) { return - 52 } , ib : function ( ) { } , h : ( ) => { Ea ( "" ) } , yb : ( ) => performance . now ( ) , pb : a => { var b = C . length ; a >>>= 0 ; if ( 2147483648 < a ) return ! 1 ; for ( var c = 1 ; 4 >= c ; c *= 2 ) { var d = b * ( 1 + . 2 / c ) ;
d = Math . min ( d , a + 100663296 ) ; var f = Math ; d = Math . max ( a , d ) ; a : { f = f . min . call ( f , 2147483648 , d + ( 65536 - d % 65536 ) % 65536 ) - Fa . buffer . byteLength + 65535 >>> 16 ; try { Fa . grow ( f ) ; La ( ) ; var k = 1 ; break a } catch ( l ) { } k = void 0 } if ( k ) return ! 0 } return ! 1 } , fb : function ( ) { return v ? v . handle : 0 } , qb : ( a , b ) => { var c = 0 ; nd ( ) . forEach ( function ( d , f ) { var k = b + c ; f = L [ a + 4 * f >> 2 ] = k ; for ( k = 0 ; k < d . length ; ++ k ) Ha [ f ++ >> 0 ] = d . charCodeAt ( k ) ; Ha [ f >> 0 ] = 0 ; c += d . length + 1 } ) ; return 0 } , rb : ( a , b ) => { var c = nd ( ) ; L [ a >> 2 ] = c . length ; var d = 0 ; c . forEach ( function ( f ) { d += f . length + 1 } ) ; L [ b >>
2 ] = d ; return 0 } , Db : a => { if ( ! noExitRuntime ) { if ( r . onExit ) r . onExit ( a ) ; Ga = ! 0 } oa ( a , new db ( a ) ) } , M : ( ) => 52 , gb : function ( ) { return 52 } , wb : ( ) => 52 , jb : function ( ) { return 70 } , T : ( a , b , c , d ) => { for ( var f = 0 , k = 0 ; k < c ; k ++ ) { var l = L [ b >> 2 ] , m = L [ b + 4 >> 2 ] ; b += 8 ; for ( var p = 0 ; p < m ; p ++ ) { var w = C [ l + p ] , y = od [ a ] ; 0 === w || 10 === w ? ( ( 1 === a ? Aa : Ca ) ( kb ( y , 0 ) ) , y . length = 0 ) : y . push ( w ) } f += m } L [ d >> 2 ] = f ; return 0 } , Wc : function ( a ) { S . activeTexture ( a ) } , Xc : function ( a , b ) { S . attachShader ( Xc [ a ] , $c [ b ] ) } , Yc : function ( a , b , c ) { S . bindAttribLocation ( Xc [ a ] , b , c ? kb ( C , c ) : "" ) } , Zc : function ( a ,
b ) { 35051 == a ? S . ye = b : 35052 == a && ( S . de = b ) ; S . bindBuffer ( a , Wc [ b ] ) } , $ : function ( a , b ) { S . bindFramebuffer ( a , Yc [ b ] ) } , _b : function ( a , b ) { S . bindRenderbuffer ( a , Zc [ b ] ) } , Kb : function ( a , b ) { S . bindSampler ( a , bd [ b ] ) } , _c : function ( a , b ) { S . bindTexture ( a , ea [ b ] ) } , sc : pd , vc : pd , $c : function ( a , b , c , d ) { S . blendColor ( a , b , c , d ) } , aa : function ( a ) { S . blendEquation ( a ) } , ba : function ( a , b ) { S . blendFunc ( a , b ) } , Ub : function ( a , b , c , d , f , k , l , m , p , w ) { S . blitFramebuffer ( a , b , c , d , f , k , l , m , p , w ) } , ca : function ( a , b , c , d ) { 2 <= v . version ? c && b ? S . bufferData ( a , C , d , c , b ) : S . bufferData ( a ,
b , d ) : S . bufferData ( a , c ? C . subarray ( c , c + b ) : b , d ) } , da : function ( a , b , c , d ) { 2 <= v . version ? c && S . bufferSubData ( a , b , C , d , c ) : S . bufferSubData ( a , b , C . subarray ( d , d + c ) ) } , $b : function ( a ) { return S . checkFramebufferStatus ( a ) } , R : function ( a ) { S . clear ( a ) } , _ : function ( a , b , c , d ) { S . clearColor ( a , b , c , d ) } , S : function ( a ) { S . clearStencil ( a ) } , mb : function ( a , b , c , d ) { return S . clientWaitSync ( cd [ a ] , b , ( c >>> 0 ) + 4294967296 * d ) } , ea : function ( a , b , c , d ) { S . colorMask ( ! ! a , ! ! b , ! ! c , ! ! d ) } , fa : function ( a ) { S . compileShader ( $c [ a ] ) } , ga : function ( a , b , c , d , f , k , l , m ) { 2 <=
v . version ? S . de || ! l ? S . compressedTexImage2D ( a , b , c , d , f , k , l , m ) : S . compressedTexImage2D ( a , b , c , d , f , k , C , m , l ) : S . compressedTexImage2D ( a , b , c , d , f , k , m ? C . subarray ( m , m + l ) : null ) } , ha : function ( a , b , c , d , f , k , l , m , p ) { 2 <= v . version ? S . de || ! m ? S . compressedTexSubImage2D ( a , b , c , d , f , k , l , m , p ) : S . compressedTexSubImage2D ( a , b , c , d , f , k , l , C , p , m ) : S . compressedTexSubImage2D ( a , b , c , d , f , k , l , p ? C . subarray ( p , p + m ) : null ) } , Sb : function ( a , b , c , d , f ) { S . copyBufferSubData ( a , b , c , d , f ) } , ia : function ( a , b , c , d , f , k , l , m ) { S . copyTexSubImage2D ( a , b , c , d , f , k , l , m ) } , ja : function ( ) { var a =
da ( Xc ) , b = S . createProgram ( ) ; b . name = a ; b . se = b . qe = b . re = 0 ; b . De = 1 ; Xc [ a ] = b ; return a } , ka : function ( a ) { var b = da ( $c ) ; $c [ b ] = S . createShader ( a ) ; return b } , la : function ( a ) { S . cullFace ( a ) } , ma : function ( a , b ) { for ( var c = 0 ; c < a ; c ++ ) { var d = K [ b + 4 * c >> 2 ] , f = Wc [ d ] ; f && ( S . deleteBuffer ( f ) , f . name = 0 , Wc [ d ] = null , d == S . ye && ( S . ye = 0 ) , d == S . de && ( S . de = 0 ) ) } } , ac : function ( a , b ) { for ( var c = 0 ; c < a ; ++ c ) { var d = K [ b + 4 * c >> 2 ] , f = Yc [ d ] ; f && ( S . deleteFramebuffer ( f ) , f . name = 0 , Yc [ d ] = null ) } } , na : function ( a ) { if ( a ) { var b = Xc [ a ] ; b ? ( S . deleteProgram ( b ) , b . name = 0 , Xc [ a ] = null ) :
R ( 1281 ) } } , bc : function ( a , b ) { for ( var c = 0 ; c < a ; c ++ ) { var d = K [ b + 4 * c >> 2 ] , f = Zc [ d ] ; f && ( S . deleteRenderbuffer ( f ) , f . name = 0 , Zc [ d ] = null ) } } , Lb : function ( a , b ) { for ( var c = 0 ; c < a ; c ++ ) { var d = K [ b + 4 * c >> 2 ] , f = bd [ d ] ; f && ( S . deleteSampler ( f ) , f . name = 0 , bd [ d ] = null ) } } , oa : function ( a ) { if ( a ) { var b = $c [ a ] ; b ? ( S . deleteShader ( b ) , $c [ a ] = null ) : R ( 1281 ) } } , Tb : function ( a ) { if ( a ) { var b = cd [ a ] ; b ? ( S . deleteSync ( b ) , b . name = 0 , cd [ a ] = null ) : R ( 1281 ) } } , pa : function ( a , b ) { for ( var c = 0 ; c < a ; c ++ ) { var d = K [ b + 4 * c >> 2 ] , f = ea [ d ] ; f && ( S . deleteTexture ( f ) , f . name = 0 , ea [ d ] = null ) } } ,
tc : qd , wc : qd , qa : function ( a ) { S . depthMask ( ! ! a ) } , ra : function ( a ) { S . disable ( a ) } , sa : function ( a ) { S . disableVertexAttribArray ( a ) } , ta : function ( a , b , c ) { S . drawArrays ( a , b , c ) } , qc : function ( a , b , c , d ) { S . drawArraysInstanced ( a , b , c , d ) } , oc : function ( a , b , c , d , f ) { S . Fe . drawArraysInstancedBaseInstanceWEBGL ( a , b , c , d , f ) } , mc : function ( a , b ) { for ( var c = rd [ a ] , d = 0 ; d < a ; d ++ ) c [ d ] = K [ b + 4 * d >> 2 ] ; S . drawBuffers ( c ) } , ua : sd , rc : function ( a , b , c , d , f ) { S . drawElementsInstanced ( a , b , c , d , f ) } , pc : function ( a , b , c , d , f , k , l ) { S . Fe . drawElementsInstancedBaseVertexBaseInstanceWEBGL ( a ,
b , c , d , f , k , l ) } , gc : function ( a , b , c , d , f , k ) { sd ( a , d , f , k ) } , va : function ( a ) { S . enable ( a ) } , wa : function ( a ) { S . enableVertexAttribArray ( a ) } , Qb : function ( a , b ) { return ( a = S . fenceSync ( a , b ) ) ? ( b = da ( cd ) , a . name = b , cd [ b ] = a , b ) : 0 } , xa : function ( ) { S . finish ( ) } , ya : function ( ) { S . flush ( ) } , cc : function ( a , b , c , d ) { S . framebufferRenderbuffer ( a , b , c , Zc [ d ] ) } , dc : function ( a , b , c , d , f ) { S . framebufferTexture2D ( a , b , c , ea [ d ] , f ) } , za : function ( a ) { S . frontFace ( a ) } , Aa : function ( a , b ) { td ( a , b , "createBuffer" , Wc ) } , ec : function ( a , b ) { td ( a , b , "createFramebuffer" , Yc ) } , fc : function ( a ,
b ) { td ( a , b , "createRenderbuffer" , Zc ) } , Mb : function ( a , b ) { td ( a , b , "createSampler" , bd ) } , Ba : function ( a , b ) { td ( a , b , "createTexture" , ea ) } , uc : ud , xc : ud , Wb : function ( a ) { S . generateMipmap ( a ) } , Ca : function ( a , b , c ) { c ? K [ c >> 2 ] = S . getBufferParameter ( a , b ) : R ( 1281 ) } , Da : function ( ) { var a = S . getError ( ) || hd ; hd = 0 ; return a } , Ea : function ( a , b ) { vd ( a , b , 2 ) } , Xb : function ( a , b , c , d ) { a = S . getFramebufferAttachmentParameter ( a , b , c ) ; if ( a instanceof WebGLRenderbuffer || a instanceof WebGLTexture ) a = a . name | 0 ; K [ d >> 2 ] = a } , L : function ( a , b ) { vd ( a , b , 0 ) } , Fa : function ( a ,
b , c , d ) { a = S . getProgramInfoLog ( Xc [ a ] ) ; null === a && ( a = "(unknown error)" ) ; b = 0 < b && d ? ka ( a , C , d , b ) : 0 ; c && ( K [ c >> 2 ] = b ) } , Ga : function ( a , b , c ) { if ( c ) if ( a >= Vc ) R ( 1281 ) ; else if ( a = Xc [ a ] , 35716 == b ) a = S . getProgramInfoLog ( a ) , null === a && ( a = "(unknown error)" ) , K [ c >> 2 ] = a . length + 1 ; else if ( 35719 == b ) { if ( ! a . se ) for ( b = 0 ; b < S . getProgramParameter ( a , 35718 ) ; ++ b ) a . se = Math . max ( a . se , S . getActiveUniform ( a , b ) . name . length + 1 ) ; K [ c >> 2 ] = a . se } else if ( 35722 == b ) { if ( ! a . qe ) for ( b = 0 ; b < S . getProgramParameter ( a , 35721 ) ; ++ b ) a . qe = Math . max ( a . qe , S . getActiveAttrib ( a ,
b ) . name . length + 1 ) ; K [ c >> 2 ] = a . qe } else if ( 35381 == b ) { if ( ! a . re ) for ( b = 0 ; b < S . getProgramParameter ( a , 35382 ) ; ++ b ) a . re = Math . max ( a . re , S . getActiveUniformBlockName ( a , b ) . length + 1 ) ; K [ c >> 2 ] = a . re } else K [ c >> 2 ] = S . getProgramParameter ( a , b ) ; else R ( 1281 ) } , Yb : function ( a , b , c ) { c ? K [ c >> 2 ] = S . getRenderbufferParameter ( a , b ) : R ( 1281 ) } , Ha : function ( a , b , c , d ) { a = S . getShaderInfoLog ( $c [ a ] ) ; null === a && ( a = "(unknown error)" ) ; b = 0 < b && d ? ka ( a , C , d , b ) : 0 ; c && ( K [ c >> 2 ] = b ) } , Hb : function ( a , b , c , d ) { a = S . getShaderPrecisionFormat ( a , b ) ; K [ c >> 2 ] = a . rangeMin ; K [ c + 4 >>
2 ] = a . rangeMax ; K [ d >> 2 ] = a . precision } , Ia : function ( a , b , c ) { c ? 35716 == b ? ( a = S . getShaderInfoLog ( $c [ a ] ) , null === a && ( a = "(unknown error)" ) , K [ c >> 2 ] = a ? a . length + 1 : 0 ) : 35720 == b ? ( a = S . getShaderSource ( $c [ a ] ) , K [ c >> 2 ] = a ? a . length + 1 : 0 ) : K [ c >> 2 ] = S . getShaderParameter ( $c [ a ] , b ) : R ( 1281 ) } , Q : function ( a ) { var b = dd [ a ] ; if ( ! b ) { switch ( a ) { case 7939 : b = S . getSupportedExtensions ( ) || [ ] ; b = b . concat ( b . map ( function ( d ) { return "GL_" + d } ) ) ; b = xd ( b . join ( " " ) ) ; break ; case 7936 : case 7937 : case 37445 : case 37446 : ( b = S . getParameter ( a ) ) || R ( 1280 ) ; b = b && xd ( b ) ; break ;
case 7938 : b = S . getParameter ( 7938 ) ; b = 2 <= v . version ? "OpenGL ES 3.0 (" + b + ")" : "OpenGL ES 2.0 (" + b + ")" ; b = xd ( b ) ; break ; case 35724 : b = S . getParameter ( 35724 ) ; var c = b . match ( /^WebGL GLSL ES ([0-9]\.[0-9][0-9]?)(?:$| .*)/ ) ; null !== c && ( 3 == c [ 1 ] . length && ( c [ 1 ] += "0" ) , b = "OpenGL ES GLSL ES " + c [ 1 ] + " (" + b + ")" ) ; b = xd ( b ) ; break ; default : R ( 1280 ) } dd [ a ] = b } return b } , db : function ( a , b ) { if ( 2 > v . version ) return R ( 1282 ) , 0 ; var c = ed [ a ] ; if ( c ) return 0 > b || b >= c . length ? ( R ( 1281 ) , 0 ) : c [ b ] ; switch ( a ) { case 7939 : return c = S . getSupportedExtensions ( ) || [ ] ,
c = c . concat ( c . map ( function ( d ) { return "GL_" + d } ) ) , c = c . map ( function ( d ) { return xd ( d ) } ) , c = ed [ a ] = c , 0 > b || b >= c . length ? ( R ( 1281 ) , 0 ) : c [ b ] ; default : return R ( 1280 ) , 0 } } , Ja : function ( a , b ) { b = b ? kb ( C , b ) : "" ; if ( a = Xc [ a ] ) { var c = a , d = c . je , f = c . Ne , k ; if ( ! d ) for ( c . je = d = { } , c . Me = { } , k = 0 ; k < S . getProgramParameter ( c , 35718 ) ; ++ k ) { var l = S . getActiveUniform ( c , k ) ; var m = l . name ; l = l . size ; var p = yd ( m ) ; p = 0 < p ? m . slice ( 0 , p ) : m ; var w = c . De ; c . De += l ; f [ p ] = [ l , w ] ; for ( m = 0 ; m < l ; ++ m ) d [ w ] = m , c . Me [ w ++ ] = p } c = a . je ; d = 0 ; f = b ; k = yd ( b ) ; 0 < k && ( d = parseInt ( b . slice ( k + 1 ) ) >>> 0 , f = b . slice ( 0 ,
k ) ) ; if ( ( f = a . Ne [ f ] ) && d < f [ 0 ] && ( d += f [ 1 ] , c [ d ] = c [ d ] || S . getUniformLocation ( a , b ) ) ) return d } else R ( 1281 ) ; return - 1 } , Ib : function ( a , b , c ) { for ( var d = rd [ b ] , f = 0 ; f < b ; f ++ ) d [ f ] = K [ c + 4 * f >> 2 ] ; S . invalidateFramebuffer ( a , d ) } , Jb : function ( a , b , c , d , f , k , l ) { for ( var m = rd [ b ] , p = 0 ; p < b ; p ++ ) m [ p ] = K [ c + 4 * p >> 2 ] ; S . invalidateSubFramebuffer ( a , m , d , f , k , l ) } , Rb : function ( a ) { return S . isSync ( cd [ a ] ) } , Ka : function ( a ) { return ( a = ea [ a ] ) ? S . isTexture ( a ) : 0 } , La : function ( a ) { S . lineWidth ( a ) } , Ma : function ( a ) { a = Xc [ a ] ; S . linkProgram ( a ) ; a . je = 0 ; a . Ne = { } } , kc : function ( a ,
b , c , d , f , k ) { S . Je . multiDrawArraysInstancedBaseInstanceWEBGL ( a , K , b >> 2 , K , c >> 2 , K , d >> 2 , L , f >> 2 , k ) } , lc : function ( a , b , c , d , f , k , l , m ) { S . Je . multiDrawElementsInstancedBaseVertexBaseInstanceWEBGL ( a , K , b >> 2 , c , K , d >> 2 , K , f >> 2 , K , k >> 2 , L , l >> 2 , m ) } , Na : function ( a , b ) { 3317 == a && ( gd = b ) ; S . pixelStorei ( a , b ) } , nc : function ( a ) { S . readBuffer ( a ) } , Oa : function ( a , b , c , d , f , k , l ) { if ( 2 <= v . version ) if ( S . ye ) S . readPixels ( a , b , c , d , f , k , l ) ; else { var m = zd ( k ) ; S . readPixels ( a , b , c , d , f , k , m , l >> 31 - Math . clz32 ( m . BYTES _PER _ELEMENT ) ) } else ( l = Ad ( k , f , c , d , l ) ) ? S . readPixels ( a ,
b , c , d , f , k , l ) : R ( 1280 ) } , Zb : function ( a , b , c , d ) { S . renderbufferStorage ( a , b , c , d ) } , Vb : function ( a , b , c , d , f ) { S . renderbufferStorageMultisample ( a , b , c , d , f ) } , Nb : function ( a , b , c ) { S . samplerParameterf ( bd [ a ] , b , c ) } , Ob : function ( a , b , c ) { S . samplerParameteri ( bd [ a ] , b , c ) } , Pb : function ( a , b , c ) { S . samplerParameteri ( bd [ a ] , b , K [ c >> 2 ] ) } , Pa : function ( a , b , c , d ) { S . scissor ( a , b , c , d ) } , Qa : function ( a , b , c , d ) { for ( var f = "" , k = 0 ; k < b ; ++ k ) { var l = d ? K [ d + 4 * k >> 2 ] : - 1 , m = K [ c + 4 * k >> 2 ] ; l = m ? kb ( C , m , 0 > l ? void 0 : l ) : "" ; f += l } S . shaderSource ( $c [ a ] , f ) } , Ra : function ( a , b ,
c ) { S . stencilFunc ( a , b , c ) } , Sa : function ( a , b , c , d ) { S . stencilFuncSeparate ( a , b , c , d ) } , Ta : function ( a ) { S . stencilMask ( a ) } , Ua : function ( a , b ) { S . stencilMaskSeparate ( a , b ) } , Va : function ( a , b , c ) { S . stencilOp ( a , b , c ) } , Wa : function ( a , b , c , d ) { S . stencilOpSeparate ( a , b , c , d ) } , Xa : function ( a , b , c , d , f , k , l , m , p ) { if ( 2 <= v . version ) if ( S . de ) S . texImage2D ( a , b , c , d , f , k , l , m , p ) ; else if ( p ) { var w = zd ( m ) ; S . texImage2D ( a , b , c , d , f , k , l , m , w , p >> 31 - Math . clz32 ( w . BYTES _PER _ELEMENT ) ) } else S . texImage2D ( a , b , c , d , f , k , l , m , null ) ; else S . texImage2D ( a , b , c , d , f , k , l , m , p ?
Ad ( m , l , d , f , p ) : null ) } , Ya : function ( a , b , c ) { S . texParameterf ( a , b , c ) } , Za : function ( a , b , c ) { S . texParameterf ( a , b , N [ c >> 2 ] ) } , _a : function ( a , b , c ) { S . texParameteri ( a , b , c ) } , $a : function ( a , b , c ) { S . texParameteri ( a , b , K [ c >> 2 ] ) } , hc : function ( a , b , c , d , f ) { S . texStorage2D ( a , b , c , d , f ) } , ab : function ( a , b , c , d , f , k , l , m , p ) { if ( 2 <= v . version ) if ( S . de ) S . texSubImage2D ( a , b , c , d , f , k , l , m , p ) ; else if ( p ) { var w = zd ( m ) ; S . texSubImage2D ( a , b , c , d , f , k , l , m , w , p >> 31 - Math . clz32 ( w . BYTES _PER _ELEMENT ) ) } else S . texSubImage2D ( a , b , c , d , f , k , l , m , null ) ; else w = null , p && ( w =
Ad ( m , l , f , k , p ) ) , S . texSubImage2D ( a , b , c , d , f , k , l , m , w ) } , bb : function ( a , b ) { S . uniform1f ( W ( a ) , b ) } , cb : function ( a , b , c ) { if ( 2 <= v . version ) b && S . uniform1fv ( W ( a ) , N , c >> 2 , b ) ; else { if ( 288 >= b ) for ( var d = Bd [ b - 1 ] , f = 0 ; f < b ; ++ f ) d [ f ] = N [ c + 4 * f >> 2 ] ; else d = N . subarray ( c >> 2 , c + 4 * b >> 2 ) ; S . uniform1fv ( W ( a ) , d ) } } , Sc : function ( a , b ) { S . uniform1i ( W ( a ) , b ) } , Tc : function ( a , b , c ) { if ( 2 <= v . version ) b && S . uniform1iv ( W ( a ) , K , c >> 2 , b ) ; else { if ( 288 >= b ) for ( var d = Cd [ b - 1 ] , f = 0 ; f < b ; ++ f ) d [ f ] = K [ c + 4 * f >> 2 ] ; else d = K . subarray ( c >> 2 , c + 4 * b >> 2 ) ; S . uniform1iv ( W ( a ) , d ) } } , Uc : function ( a ,
b , c ) { S . uniform2f ( W ( a ) , b , c ) } , Vc : function ( a , b , c ) { if ( 2 <= v . version ) b && S . uniform2fv ( W ( a ) , N , c >> 2 , 2 * b ) ; else { if ( 144 >= b ) for ( var d = Bd [ 2 * b - 1 ] , f = 0 ; f < 2 * b ; f += 2 ) d [ f ] = N [ c + 4 * f >> 2 ] , d [ f + 1 ] = N [ c + ( 4 * f + 4 ) >> 2 ] ; else d = N . subarray ( c >> 2 , c + 8 * b >> 2 ) ; S . uniform2fv ( W ( a ) , d ) } } , Rc : function ( a , b , c ) { S . uniform2i ( W ( a ) , b , c ) } , Qc : function ( a , b , c ) { if ( 2 <= v . version ) b && S . uniform2iv ( W ( a ) , K , c >> 2 , 2 * b ) ; else { if ( 144 >= b ) for ( var d = Cd [ 2 * b - 1 ] , f = 0 ; f < 2 * b ; f += 2 ) d [ f ] = K [ c + 4 * f >> 2 ] , d [ f + 1 ] = K [ c + ( 4 * f + 4 ) >> 2 ] ; else d = K . subarray ( c >> 2 , c + 8 * b >> 2 ) ; S . uniform2iv ( W ( a ) , d ) } } , Pc : function ( a ,
b , c , d ) { S . uniform3f ( W ( a ) , b , c , d ) } , Oc : function ( a , b , c ) { if ( 2 <= v . version ) b && S . uniform3fv ( W ( a ) , N , c >> 2 , 3 * b ) ; else { if ( 96 >= b ) for ( var d = Bd [ 3 * b - 1 ] , f = 0 ; f < 3 * b ; f += 3 ) d [ f ] = N [ c + 4 * f >> 2 ] , d [ f + 1 ] = N [ c + ( 4 * f + 4 ) >> 2 ] , d [ f + 2 ] = N [ c + ( 4 * f + 8 ) >> 2 ] ; else d = N . subarray ( c >> 2 , c + 12 * b >> 2 ) ; S . uniform3fv ( W ( a ) , d ) } } , Nc : function ( a , b , c , d ) { S . uniform3i ( W ( a ) , b , c , d ) } , Mc : function ( a , b , c ) { if ( 2 <= v . version ) b && S . uniform3iv ( W ( a ) , K , c >> 2 , 3 * b ) ; else { if ( 96 >= b ) for ( var d = Cd [ 3 * b - 1 ] , f = 0 ; f < 3 * b ; f += 3 ) d [ f ] = K [ c + 4 * f >> 2 ] , d [ f + 1 ] = K [ c + ( 4 * f + 4 ) >> 2 ] , d [ f + 2 ] = K [ c + ( 4 * f + 8 ) >> 2 ] ; else d =
K . subarray ( c >> 2 , c + 12 * b >> 2 ) ; S . uniform3iv ( W ( a ) , d ) } } , Lc : function ( a , b , c , d , f ) { S . uniform4f ( W ( a ) , b , c , d , f ) } , Kc : function ( a , b , c ) { if ( 2 <= v . version ) b && S . uniform4fv ( W ( a ) , N , c >> 2 , 4 * b ) ; else { if ( 72 >= b ) { var d = Bd [ 4 * b - 1 ] , f = N ; c >>= 2 ; for ( var k = 0 ; k < 4 * b ; k += 4 ) { var l = c + k ; d [ k ] = f [ l ] ; d [ k + 1 ] = f [ l + 1 ] ; d [ k + 2 ] = f [ l + 2 ] ; d [ k + 3 ] = f [ l + 3 ] } } else d = N . subarray ( c >> 2 , c + 16 * b >> 2 ) ; S . uniform4fv ( W ( a ) , d ) } } , yc : function ( a , b , c , d , f ) { S . uniform4i ( W ( a ) , b , c , d , f ) } , zc : function ( a , b , c ) { if ( 2 <= v . version ) b && S . uniform4iv ( W ( a ) , K , c >> 2 , 4 * b ) ; else { if ( 72 >= b ) for ( var d = Cd [ 4 * b -
1 ] , f = 0 ; f < 4 * b ; f += 4 ) d [ f ] = K [ c + 4 * f >> 2 ] , d [ f + 1 ] = K [ c + ( 4 * f + 4 ) >> 2 ] , d [ f + 2 ] = K [ c + ( 4 * f + 8 ) >> 2 ] , d [ f + 3 ] = K [ c + ( 4 * f + 12 ) >> 2 ] ; else d = K . subarray ( c >> 2 , c + 16 * b >> 2 ) ; S . uniform4iv ( W ( a ) , d ) } } , Ac : function ( a , b , c , d ) { if ( 2 <= v . version ) b && S . uniformMatrix2fv ( W ( a ) , ! ! c , N , d >> 2 , 4 * b ) ; else { if ( 72 >= b ) for ( var f = Bd [ 4 * b - 1 ] , k = 0 ; k < 4 * b ; k += 4 ) f [ k ] = N [ d + 4 * k >> 2 ] , f [ k + 1 ] = N [ d + ( 4 * k + 4 ) >> 2 ] , f [ k + 2 ] = N [ d + ( 4 * k + 8 ) >> 2 ] , f [ k + 3 ] = N [ d + ( 4 * k + 12 ) >> 2 ] ; else f = N . subarray ( d >> 2 , d + 16 * b >> 2 ) ; S . uniformMatrix2fv ( W ( a ) , ! ! c , f ) } } , Bc : function ( a , b , c , d ) { if ( 2 <= v . version ) b && S . uniformMatrix3fv ( W ( a ) ,
! ! c , N , d >> 2 , 9 * b ) ; else { if ( 32 >= b ) for ( var f = Bd [ 9 * b - 1 ] , k = 0 ; k < 9 * b ; k += 9 ) f [ k ] = N [ d + 4 * k >> 2 ] , f [ k + 1 ] = N [ d + ( 4 * k + 4 ) >> 2 ] , f [ k + 2 ] = N [ d + ( 4 * k + 8 ) >> 2 ] , f [ k + 3 ] = N [ d + ( 4 * k + 12 ) >> 2 ] , f [ k + 4 ] = N [ d + ( 4 * k + 16 ) >> 2 ] , f [ k + 5 ] = N [ d + ( 4 * k + 20 ) >> 2 ] , f [ k + 6 ] = N [ d + ( 4 * k + 24 ) >> 2 ] , f [ k + 7 ] = N [ d + ( 4 * k + 28 ) >> 2 ] , f [ k + 8 ] = N [ d + ( 4 * k + 32 ) >> 2 ] ; else f = N . subarray ( d >> 2 , d + 36 * b >> 2 ) ; S . uniformMatrix3fv ( W ( a ) , ! ! c , f ) } } , Cc : function ( a , b , c , d ) { if ( 2 <= v . version ) b && S . uniformMatrix4fv ( W ( a ) , ! ! c , N , d >> 2 , 16 * b ) ; else { if ( 18 >= b ) { var f = Bd [ 16 * b - 1 ] , k = N ; d >>= 2 ; for ( var l = 0 ; l < 16 * b ; l += 16 ) { var m = d + l ; f [ l ] =
k [ m ] ; f [ l + 1 ] = k [ m + 1 ] ; f [ l + 2 ] = k [ m + 2 ] ; f [ l + 3 ] = k [ m + 3 ] ; f [ l + 4 ] = k [ m + 4 ] ; f [ l + 5 ] = k [ m + 5 ] ; f [ l + 6 ] = k [ m + 6 ] ; f [ l + 7 ] = k [ m + 7 ] ; f [ l + 8 ] = k [ m + 8 ] ; f [ l + 9 ] = k [ m + 9 ] ; f [ l + 10 ] = k [ m + 10 ] ; f [ l + 11 ] = k [ m + 11 ] ; f [ l + 12 ] = k [ m + 12 ] ; f [ l + 13 ] = k [ m + 13 ] ; f [ l + 14 ] = k [ m + 14 ] ; f [ l + 15 ] = k [ m + 15 ] } } else f = N . subarray ( d >> 2 , d + 64 * b >> 2 ) ; S . uniformMatrix4fv ( W ( a ) , ! ! c , f ) } } , Dc : function ( a ) { a = Xc [ a ] ; S . useProgram ( a ) ; S . We = a } , Ec : function ( a , b ) { S . vertexAttrib1f ( a , b ) } , Fc : function ( a , b ) { S . vertexAttrib2f ( a , N [ b >> 2 ] , N [ b + 4 >> 2 ] ) } , Gc : function ( a , b ) { S . vertexAttrib3f ( a , N [ b >> 2 ] , N [ b + 4 >> 2 ] , N [ b + 8 >> 2 ] ) } ,
Hc : function ( a , b ) { S . vertexAttrib4f ( a , N [ b >> 2 ] , N [ b + 4 >> 2 ] , N [ b + 8 >> 2 ] , N [ b + 12 >> 2 ] ) } , ic : function ( a , b ) { S . vertexAttribDivisor ( a , b ) } , jc : function ( a , b , c , d , f ) { S . vertexAttribIPointer ( a , b , c , d , f ) } , Ic : function ( a , b , c , d , f , k ) { S . vertexAttribPointer ( a , b , c , ! ! d , f , k ) } , Jc : function ( a , b , c , d ) { S . viewport ( a , b , c , d ) } , lb : function ( a , b , c , d ) { S . waitSync ( cd [ a ] , b , ( c >>> 0 ) + 4294967296 * d ) } , o : Nd , n : Od , k : Pd , O : Qd , Z : Rd , Y : Sd , x : Td , y : Ud , p : Vd , w : Wd , Eb : Xd , Fb : Yd , Gb : Zd , nb : ( a , b , c , d ) => Hd ( a , b , c , d ) } ;
( function ( ) { function a ( c ) { G = c = c . exports ; Fa = G . ad ; La ( ) ; Na = G . cd ; Pa . unshift ( G . bd ) ; Ua -- ; r . monitorRunDependencies && r . monitorRunDependencies ( Ua ) ; if ( 0 == Ua && ( null !== Va && ( clearInterval ( Va ) , Va = null ) , Wa ) ) { var d = Wa ; Wa = null ; d ( ) } return c } var b = { a : $d } ; Ua ++ ; r . monitorRunDependencies && r . monitorRunDependencies ( Ua ) ; if ( r . instantiateWasm ) try { return r . instantiateWasm ( b , a ) } catch ( c ) { Ca ( "Module.instantiateWasm callback failed with error: " + c ) , ba ( c ) } cb ( b , function ( c ) { a ( c . instance ) } ) . catch ( ba ) ; return { } } ) ( ) ;
var qc = r . _free = a => ( qc = r . _free = G . dd ) ( a ) , wd = r . _malloc = a => ( wd = r . _malloc = G . ed ) ( a ) , pc = a => ( pc = G . fd ) ( a ) ; r . _ _embind _initialize _bindings = ( ) => ( r . _ _embind _initialize _bindings = G . gd ) ( ) ; var ae = ( a , b ) => ( ae = G . hd ) ( a , b ) , be = ( ) => ( be = G . id ) ( ) , ce = a => ( ce = G . jd ) ( a ) ; r . dynCall _viji = ( a , b , c , d , f ) => ( r . dynCall _viji = G . ld ) ( a , b , c , d , f ) ; r . dynCall _vijiii = ( a , b , c , d , f , k , l ) => ( r . dynCall _vijiii = G . md ) ( a , b , c , d , f , k , l ) ; r . dynCall _viiiiij = ( a , b , c , d , f , k , l , m ) => ( r . dynCall _viiiiij = G . nd ) ( a , b , c , d , f , k , l , m ) ;
r . dynCall _iiiji = ( a , b , c , d , f , k ) => ( r . dynCall _iiiji = G . od ) ( a , b , c , d , f , k ) ; r . dynCall _jii = ( a , b , c ) => ( r . dynCall _jii = G . pd ) ( a , b , c ) ; r . dynCall _vij = ( a , b , c , d ) => ( r . dynCall _vij = G . qd ) ( a , b , c , d ) ; r . dynCall _iiij = ( a , b , c , d , f ) => ( r . dynCall _iiij = G . rd ) ( a , b , c , d , f ) ; r . dynCall _iiiij = ( a , b , c , d , f , k ) => ( r . dynCall _iiiij = G . sd ) ( a , b , c , d , f , k ) ; r . dynCall _viij = ( a , b , c , d , f ) => ( r . dynCall _viij = G . td ) ( a , b , c , d , f ) ; r . dynCall _viiij = ( a , b , c , d , f , k ) => ( r . dynCall _viiij = G . ud ) ( a , b , c , d , f , k ) ; r . dynCall _ji = ( a , b ) => ( r . dynCall _ji = G . vd ) ( a , b ) ;
r . dynCall _iij = ( a , b , c , d ) => ( r . dynCall _iij = G . wd ) ( a , b , c , d ) ; r . dynCall _jiiiiii = ( a , b , c , d , f , k , l ) => ( r . dynCall _jiiiiii = G . xd ) ( a , b , c , d , f , k , l ) ; r . dynCall _jiiiiji = ( a , b , c , d , f , k , l , m ) => ( r . dynCall _jiiiiji = G . yd ) ( a , b , c , d , f , k , l , m ) ; r . dynCall _iijj = ( a , b , c , d , f , k ) => ( r . dynCall _iijj = G . zd ) ( a , b , c , d , f , k ) ; r . dynCall _iiji = ( a , b , c , d , f ) => ( r . dynCall _iiji = G . Ad ) ( a , b , c , d , f ) ; r . dynCall _iijjiii = ( a , b , c , d , f , k , l , m , p ) => ( r . dynCall _iijjiii = G . Bd ) ( a , b , c , d , f , k , l , m , p ) ;
r . dynCall _vijjjii = ( a , b , c , d , f , k , l , m , p , w ) => ( r . dynCall _vijjjii = G . Cd ) ( a , b , c , d , f , k , l , m , p , w ) ; r . dynCall _jiji = ( a , b , c , d , f ) => ( r . dynCall _jiji = G . Dd ) ( a , b , c , d , f ) ; r . dynCall _viijii = ( a , b , c , d , f , k , l ) => ( r . dynCall _viijii = G . Ed ) ( a , b , c , d , f , k , l ) ; r . dynCall _iiiiij = ( a , b , c , d , f , k , l ) => ( r . dynCall _iiiiij = G . Fd ) ( a , b , c , d , f , k , l ) ; r . dynCall _iiiiijj = ( a , b , c , d , f , k , l , m , p ) => ( r . dynCall _iiiiijj = G . Gd ) ( a , b , c , d , f , k , l , m , p ) ; r . dynCall _iiiiiijj = ( a , b , c , d , f , k , l , m , p , w ) => ( r . dynCall _iiiiiijj = G . Hd ) ( a , b , c , d , f , k , l , m , p , w ) ;
function Wd ( a , b , c , d , f ) { var k = be ( ) ; try { Na . get ( a ) ( b , c , d , f ) } catch ( l ) { ce ( k ) ; if ( l !== l + 0 ) throw l ; ae ( 1 , 0 ) } } function Od ( a , b , c ) { var d = be ( ) ; try { return Na . get ( a ) ( b , c ) } catch ( f ) { ce ( d ) ; if ( f !== f + 0 ) throw f ; ae ( 1 , 0 ) } } function Ud ( a , b , c ) { var d = be ( ) ; try { Na . get ( a ) ( b , c ) } catch ( f ) { ce ( d ) ; if ( f !== f + 0 ) throw f ; ae ( 1 , 0 ) } } function Nd ( a , b ) { var c = be ( ) ; try { return Na . get ( a ) ( b ) } catch ( d ) { ce ( c ) ; if ( d !== d + 0 ) throw d ; ae ( 1 , 0 ) } } function Td ( a , b ) { var c = be ( ) ; try { Na . get ( a ) ( b ) } catch ( d ) { ce ( c ) ; if ( d !== d + 0 ) throw d ; ae ( 1 , 0 ) } }
function Pd ( a , b , c , d ) { var f = be ( ) ; try { return Na . get ( a ) ( b , c , d ) } catch ( k ) { ce ( f ) ; if ( k !== k + 0 ) throw k ; ae ( 1 , 0 ) } } function Zd ( a , b , c , d , f , k , l , m , p , w ) { var y = be ( ) ; try { Na . get ( a ) ( b , c , d , f , k , l , m , p , w ) } catch ( B ) { ce ( y ) ; if ( B !== B + 0 ) throw B ; ae ( 1 , 0 ) } } function Vd ( a , b , c , d ) { var f = be ( ) ; try { Na . get ( a ) ( b , c , d ) } catch ( k ) { ce ( f ) ; if ( k !== k + 0 ) throw k ; ae ( 1 , 0 ) } } function Yd ( a , b , c , d , f , k , l ) { var m = be ( ) ; try { Na . get ( a ) ( b , c , d , f , k , l ) } catch ( p ) { ce ( m ) ; if ( p !== p + 0 ) throw p ; ae ( 1 , 0 ) } }
function Qd ( a , b , c , d , f ) { var k = be ( ) ; try { return Na . get ( a ) ( b , c , d , f ) } catch ( l ) { ce ( k ) ; if ( l !== l + 0 ) throw l ; ae ( 1 , 0 ) } } function Rd ( a , b , c , d , f , k , l ) { var m = be ( ) ; try { return Na . get ( a ) ( b , c , d , f , k , l ) } catch ( p ) { ce ( m ) ; if ( p !== p + 0 ) throw p ; ae ( 1 , 0 ) } } function Xd ( a , b , c , d , f , k ) { var l = be ( ) ; try { Na . get ( a ) ( b , c , d , f , k ) } catch ( m ) { ce ( l ) ; if ( m !== m + 0 ) throw m ; ae ( 1 , 0 ) } } function Sd ( a , b , c , d , f , k , l , m , p , w ) { var y = be ( ) ; try { return Na . get ( a ) ( b , c , d , f , k , l , m , p , w ) } catch ( B ) { ce ( y ) ; if ( B !== B + 0 ) throw B ; ae ( 1 , 0 ) } } var de ; Wa = function ee ( ) { de || fe ( ) ; de || ( Wa = ee ) } ;
function fe ( ) { function a ( ) { if ( ! de && ( de = ! 0 , r . calledRun = ! 0 , ! Ga ) ) { eb ( Pa ) ; aa ( r ) ; if ( r . onRuntimeInitialized ) r . onRuntimeInitialized ( ) ; if ( r . postRun ) for ( "function" == typeof r . postRun && ( r . postRun = [ r . postRun ] ) ; r . postRun . length ; ) { var b = r . postRun . shift ( ) ; Qa . unshift ( b ) } eb ( Qa ) } } if ( ! ( 0 < Ua ) ) { if ( r . preRun ) for ( "function" == typeof r . preRun && ( r . preRun = [ r . preRun ] ) ; r . preRun . length ; ) Ra ( ) ; eb ( Oa ) ; 0 < Ua || ( r . setStatus ? ( r . setStatus ( "Running..." ) , setTimeout ( function ( ) { setTimeout ( function ( ) { r . setStatus ( "" ) } , 1 ) ; a ( ) } , 1 ) ) : a ( ) ) } }
if ( r . preInit ) for ( "function" == typeof r . preInit && ( r . preInit = [ r . preInit ] ) ; 0 < r . preInit . length ; ) r . preInit . pop ( ) ( ) ; fe ( ) ;
2022-01-17 14:46:45 +01:00
2023-12-20 09:52:22 +01:00
return moduleArg . ready
2022-01-17 14:46:45 +01:00
}
2023-10-28 19:10:11 +02:00
2022-01-17 14:46:45 +01:00
) ;
} ) ( ) ;
if ( typeof exports === 'object' && typeof module === 'object' )
module . exports = CanvasKitInit ;
else if ( typeof define === 'function' && define [ 'amd' ] )
2023-12-20 09:52:22 +01:00
define ( [ ] , ( ) => CanvasKitInit ) ;