quake2ts 0.0.233 → 0.0.235

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (37) hide show
  1. package/package.json +4 -2
  2. package/packages/client/dist/browser/index.global.js +49 -16
  3. package/packages/client/dist/browser/index.global.js.map +1 -1
  4. package/packages/client/dist/cjs/index.cjs +4469 -131
  5. package/packages/client/dist/cjs/index.cjs.map +1 -1
  6. package/packages/client/dist/esm/index.js +4469 -131
  7. package/packages/client/dist/esm/index.js.map +1 -1
  8. package/packages/client/dist/tsconfig.tsbuildinfo +1 -1
  9. package/packages/engine/dist/browser/index.global.js +56 -20
  10. package/packages/engine/dist/browser/index.global.js.map +1 -1
  11. package/packages/engine/dist/cjs/index.cjs +4584 -237
  12. package/packages/engine/dist/cjs/index.cjs.map +1 -1
  13. package/packages/engine/dist/esm/index.js +4584 -237
  14. package/packages/engine/dist/esm/index.js.map +1 -1
  15. package/packages/engine/dist/tsconfig.tsbuildinfo +1 -1
  16. package/packages/engine/dist/types/demo/parser.d.ts +12 -3
  17. package/packages/engine/dist/types/demo/parser.d.ts.map +1 -1
  18. package/packages/engine/dist/types/render/bsp/geometry.d.ts +1 -0
  19. package/packages/engine/dist/types/render/bsp/geometry.d.ts.map +1 -1
  20. package/packages/engine/dist/types/render/bsp/renderer.d.ts.map +1 -1
  21. package/packages/engine/dist/types/render/bsp/surface.d.ts.map +1 -1
  22. package/packages/engine/dist/types/render/bspPipeline.d.ts +4 -2
  23. package/packages/engine/dist/types/render/bspPipeline.d.ts.map +1 -1
  24. package/packages/game/dist/browser/index.global.js.map +1 -1
  25. package/packages/game/dist/cjs/index.cjs.map +1 -1
  26. package/packages/game/dist/esm/index.js.map +1 -1
  27. package/packages/game/dist/tsconfig.tsbuildinfo +1 -1
  28. package/packages/shared/dist/browser/index.global.js +1 -1
  29. package/packages/shared/dist/browser/index.global.js.map +1 -1
  30. package/packages/shared/dist/cjs/index.cjs +10 -0
  31. package/packages/shared/dist/cjs/index.cjs.map +1 -1
  32. package/packages/shared/dist/esm/index.js +10 -0
  33. package/packages/shared/dist/esm/index.js.map +1 -1
  34. package/packages/shared/dist/tsconfig.tsbuildinfo +1 -1
  35. package/packages/shared/dist/types/io/binaryStream.d.ts +2 -0
  36. package/packages/shared/dist/types/io/binaryStream.d.ts.map +1 -1
  37. package/packages/tools/dist/tsconfig.tsbuildinfo +1 -1
@@ -2219,11 +2219,21 @@ var BinaryStream = class {
2219
2219
  this.offset += 2;
2220
2220
  return value;
2221
2221
  }
2222
+ readUShort() {
2223
+ const value = this.view.getUint16(this.offset, true);
2224
+ this.offset += 2;
2225
+ return value;
2226
+ }
2222
2227
  readLong() {
2223
2228
  const value = this.view.getInt32(this.offset, true);
2224
2229
  this.offset += 4;
2225
2230
  return value;
2226
2231
  }
2232
+ readULong() {
2233
+ const value = this.view.getUint32(this.offset, true);
2234
+ this.offset += 4;
2235
+ return value;
2236
+ }
2227
2237
  readFloat() {
2228
2238
  const value = this.view.getFloat32(this.offset, true);
2229
2239
  this.offset += 4;
@@ -2352,11 +2362,13 @@ const int MAX_DLIGHTS = ${MAX_DLIGHTS};
2352
2362
 
2353
2363
  in vec2 v_texCoord;
2354
2364
  in vec2 v_lightmapCoord;
2365
+ in float v_lightmapStep;
2355
2366
  in vec3 v_position;
2356
2367
 
2357
2368
  uniform sampler2D u_diffuseMap;
2358
2369
  uniform sampler2D u_lightmapAtlas;
2359
2370
  uniform vec4 u_lightStyleFactors;
2371
+ uniform vec4 u_styleLayerMapping; // 0, 1, 2... or -1 if invalid
2360
2372
  uniform float u_alpha;
2361
2373
  uniform bool u_applyLightmap;
2362
2374
  uniform bool u_warp;
@@ -2390,9 +2402,35 @@ void main() {
2390
2402
  vec3 totalLight = vec3(1.0);
2391
2403
 
2392
2404
  if (u_applyLightmap) {
2393
- vec3 light = texture(u_lightmapAtlas, warpCoords(v_lightmapCoord)).rgb;
2394
- float styleScale = dot(u_lightStyleFactors, vec4(1.0));
2395
- totalLight = light * styleScale;
2405
+ // Multi-style lightmap accumulation
2406
+ vec3 light = vec3(0.0);
2407
+ bool hasLight = false;
2408
+
2409
+ vec2 lmBase = warpCoords(v_lightmapCoord);
2410
+
2411
+ // Loop unrolled-ish
2412
+ for (int i = 0; i < 4; i++) {
2413
+ // We can access vec4 components by index in newer GLSL ES, or use direct access
2414
+ float layer = u_styleLayerMapping[i];
2415
+ float factor = u_lightStyleFactors[i];
2416
+
2417
+ if (layer >= -0.5) { // Valid layer (check >= 0 approx)
2418
+ // Offset V by layer * step
2419
+ // Since we packed vertically
2420
+ vec2 offset = vec2(0.0, layer * v_lightmapStep);
2421
+ light += texture(u_lightmapAtlas, lmBase + offset).rgb * factor;
2422
+ hasLight = true;
2423
+ }
2424
+ }
2425
+
2426
+ // If no valid lightmaps found (e.g. unlit surface?), default to full bright?
2427
+ // Or if u_applyLightmap is true, there should be at least one style.
2428
+ // Fallback to 1.0 if accumulator is empty?
2429
+ // In Q2, unlit surfs are fullbright (or use minlight).
2430
+ // If hasLight is false, it means no styles are active.
2431
+ if (!hasLight) light = vec3(1.0);
2432
+
2433
+ totalLight = light; // Dynamic lights add on top or multiply? Q2 adds.
2396
2434
 
2397
2435
  // Add dynamic lights
2398
2436
  for (int i = 0; i < MAX_DLIGHTS; i++) {
@@ -2678,138 +2716,4329 @@ var Camera = class {
2678
2716
  this.updateMatrices();
2679
2717
  return this._projectionMatrix;
2680
2718
  }
2681
- get viewProjectionMatrix() {
2682
- this.updateMatrices();
2683
- return this._viewProjectionMatrix;
2719
+ get viewProjectionMatrix() {
2720
+ this.updateMatrices();
2721
+ return this._viewProjectionMatrix;
2722
+ }
2723
+ getViewmodelProjectionMatrix(fov) {
2724
+ const projectionMatrix = mat4_exports.create();
2725
+ mat4_exports.perspective(
2726
+ projectionMatrix,
2727
+ fov * DEG2RAD,
2728
+ this._aspect,
2729
+ this._near,
2730
+ this._far
2731
+ );
2732
+ return projectionMatrix;
2733
+ }
2734
+ updateMatrices() {
2735
+ if (!this._dirty) {
2736
+ return;
2737
+ }
2738
+ mat4_exports.perspective(
2739
+ this._projectionMatrix,
2740
+ this._fov * DEG2RAD,
2741
+ this._aspect,
2742
+ this._near,
2743
+ this._far
2744
+ );
2745
+ const quakeToGl = mat4_exports.fromValues(
2746
+ 0,
2747
+ -1,
2748
+ 0,
2749
+ 0,
2750
+ // column 0: Quake X -> WebGL (0, -1, 0)
2751
+ 0,
2752
+ 0,
2753
+ 1,
2754
+ 0,
2755
+ // column 1: Quake Y -> WebGL (0, 0, 1)
2756
+ -1,
2757
+ 0,
2758
+ 0,
2759
+ 0,
2760
+ // column 2: Quake Z -> WebGL (-1, 0, 0)
2761
+ 0,
2762
+ 0,
2763
+ 0,
2764
+ 1
2765
+ // column 3: no translation
2766
+ );
2767
+ const pitch = this._angles[0] + this._bobAngles[0] + this._kickAngles[0];
2768
+ const yaw = this._angles[1] + this._bobAngles[1] + this._kickAngles[1];
2769
+ const roll = this._angles[2] + this._bobAngles[2] + this._kickAngles[2] + this._rollAngle;
2770
+ const pitchRad = pitch * DEG2RAD;
2771
+ const yawRad = yaw * DEG2RAD;
2772
+ const rollRad = roll * DEG2RAD;
2773
+ const rotationQuake = mat4_exports.create();
2774
+ mat4_exports.identity(rotationQuake);
2775
+ mat4_exports.rotateZ(rotationQuake, rotationQuake, -yawRad);
2776
+ mat4_exports.rotateY(rotationQuake, rotationQuake, -pitchRad);
2777
+ mat4_exports.rotateX(rotationQuake, rotationQuake, -rollRad);
2778
+ const rotationGl = mat4_exports.create();
2779
+ mat4_exports.multiply(rotationGl, quakeToGl, rotationQuake);
2780
+ const positionWithOffset = vec3_exports.add(vec3_exports.create(), this._position, this._bobOffset);
2781
+ const negativePosition = vec3_exports.negate(vec3_exports.create(), positionWithOffset);
2782
+ const rotatedPosQuake = vec3_exports.create();
2783
+ vec3_exports.transformMat4(rotatedPosQuake, negativePosition, rotationQuake);
2784
+ const translationGl = vec3_exports.fromValues(
2785
+ rotatedPosQuake[1] || 0,
2786
+ // Y in Quake -> X in WebGL (negation already applied above)
2787
+ rotatedPosQuake[2] || 0,
2788
+ // Z in Quake -> Y in WebGL
2789
+ rotatedPosQuake[0] || 0
2790
+ // X in Quake -> Z in WebGL (negation already applied above)
2791
+ );
2792
+ mat4_exports.copy(this._viewMatrix, rotationGl);
2793
+ this._viewMatrix[12] = translationGl[0];
2794
+ this._viewMatrix[13] = translationGl[1];
2795
+ this._viewMatrix[14] = translationGl[2];
2796
+ mat4_exports.multiply(
2797
+ this._viewProjectionMatrix,
2798
+ this._projectionMatrix,
2799
+ this._viewMatrix
2800
+ );
2801
+ this._dirty = false;
2802
+ }
2803
+ };
2804
+ var DemoReader = class {
2805
+ constructor(buffer) {
2806
+ this.buffer = buffer;
2807
+ this.view = new DataView(buffer);
2808
+ this.offset = 0;
2809
+ }
2810
+ /**
2811
+ * Checks if there are more blocks to read.
2812
+ */
2813
+ hasMore() {
2814
+ return this.offset < this.buffer.byteLength;
2815
+ }
2816
+ /**
2817
+ * Reads the next message block from the demo file.
2818
+ * Format is [Length (4 bytes)] + [Message Block (Length bytes)].
2819
+ * Returns null if end of file or incomplete block.
2820
+ */
2821
+ readNextBlock() {
2822
+ if (this.offset + 4 > this.buffer.byteLength) {
2823
+ return null;
2824
+ }
2825
+ const length2 = this.view.getInt32(this.offset, true);
2826
+ this.offset += 4;
2827
+ if (length2 < 0 || length2 > 262144) {
2828
+ console.warn(`DemoReader: Invalid block length ${length2} at offset ${this.offset - 4}`);
2829
+ return null;
2830
+ }
2831
+ if (this.offset + length2 > this.buffer.byteLength) {
2832
+ console.warn(`DemoReader: Incomplete block. Expected ${length2} bytes, but only ${this.buffer.byteLength - this.offset} remain.`);
2833
+ return null;
2834
+ }
2835
+ const blockData = this.buffer.slice(this.offset, this.offset + length2);
2836
+ this.offset += length2;
2837
+ return {
2838
+ length: length2,
2839
+ data: new BinaryStream(blockData)
2840
+ };
2841
+ }
2842
+ /**
2843
+ * Resets the reader to the beginning.
2844
+ */
2845
+ reset() {
2846
+ this.offset = 0;
2847
+ }
2848
+ getOffset() {
2849
+ return this.offset;
2850
+ }
2851
+ };
2852
+ var Z_FIXED$1 = 4;
2853
+ var Z_BINARY = 0;
2854
+ var Z_TEXT = 1;
2855
+ var Z_UNKNOWN$1 = 2;
2856
+ function zero$1(buf) {
2857
+ let len2 = buf.length;
2858
+ while (--len2 >= 0) {
2859
+ buf[len2] = 0;
2860
+ }
2861
+ }
2862
+ var STORED_BLOCK = 0;
2863
+ var STATIC_TREES = 1;
2864
+ var DYN_TREES = 2;
2865
+ var MIN_MATCH$1 = 3;
2866
+ var MAX_MATCH$1 = 258;
2867
+ var LENGTH_CODES$1 = 29;
2868
+ var LITERALS$1 = 256;
2869
+ var L_CODES$1 = LITERALS$1 + 1 + LENGTH_CODES$1;
2870
+ var D_CODES$1 = 30;
2871
+ var BL_CODES$1 = 19;
2872
+ var HEAP_SIZE$1 = 2 * L_CODES$1 + 1;
2873
+ var MAX_BITS$1 = 15;
2874
+ var Buf_size = 16;
2875
+ var MAX_BL_BITS = 7;
2876
+ var END_BLOCK = 256;
2877
+ var REP_3_6 = 16;
2878
+ var REPZ_3_10 = 17;
2879
+ var REPZ_11_138 = 18;
2880
+ var extra_lbits = (
2881
+ /* extra bits for each length code */
2882
+ new Uint8Array([0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 0])
2883
+ );
2884
+ var extra_dbits = (
2885
+ /* extra bits for each distance code */
2886
+ new Uint8Array([0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13])
2887
+ );
2888
+ var extra_blbits = (
2889
+ /* extra bits for each bit length code */
2890
+ new Uint8Array([0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 3, 7])
2891
+ );
2892
+ var bl_order = new Uint8Array([16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15]);
2893
+ var DIST_CODE_LEN = 512;
2894
+ var static_ltree = new Array((L_CODES$1 + 2) * 2);
2895
+ zero$1(static_ltree);
2896
+ var static_dtree = new Array(D_CODES$1 * 2);
2897
+ zero$1(static_dtree);
2898
+ var _dist_code = new Array(DIST_CODE_LEN);
2899
+ zero$1(_dist_code);
2900
+ var _length_code = new Array(MAX_MATCH$1 - MIN_MATCH$1 + 1);
2901
+ zero$1(_length_code);
2902
+ var base_length = new Array(LENGTH_CODES$1);
2903
+ zero$1(base_length);
2904
+ var base_dist = new Array(D_CODES$1);
2905
+ zero$1(base_dist);
2906
+ function StaticTreeDesc(static_tree, extra_bits, extra_base, elems, max_length) {
2907
+ this.static_tree = static_tree;
2908
+ this.extra_bits = extra_bits;
2909
+ this.extra_base = extra_base;
2910
+ this.elems = elems;
2911
+ this.max_length = max_length;
2912
+ this.has_stree = static_tree && static_tree.length;
2913
+ }
2914
+ var static_l_desc;
2915
+ var static_d_desc;
2916
+ var static_bl_desc;
2917
+ function TreeDesc(dyn_tree, stat_desc) {
2918
+ this.dyn_tree = dyn_tree;
2919
+ this.max_code = 0;
2920
+ this.stat_desc = stat_desc;
2921
+ }
2922
+ var d_code = (dist2) => {
2923
+ return dist2 < 256 ? _dist_code[dist2] : _dist_code[256 + (dist2 >>> 7)];
2924
+ };
2925
+ var put_short = (s, w) => {
2926
+ s.pending_buf[s.pending++] = w & 255;
2927
+ s.pending_buf[s.pending++] = w >>> 8 & 255;
2928
+ };
2929
+ var send_bits = (s, value, length2) => {
2930
+ if (s.bi_valid > Buf_size - length2) {
2931
+ s.bi_buf |= value << s.bi_valid & 65535;
2932
+ put_short(s, s.bi_buf);
2933
+ s.bi_buf = value >> Buf_size - s.bi_valid;
2934
+ s.bi_valid += length2 - Buf_size;
2935
+ } else {
2936
+ s.bi_buf |= value << s.bi_valid & 65535;
2937
+ s.bi_valid += length2;
2938
+ }
2939
+ };
2940
+ var send_code = (s, c, tree) => {
2941
+ send_bits(
2942
+ s,
2943
+ tree[c * 2],
2944
+ tree[c * 2 + 1]
2945
+ /*.Len*/
2946
+ );
2947
+ };
2948
+ var bi_reverse = (code, len2) => {
2949
+ let res = 0;
2950
+ do {
2951
+ res |= code & 1;
2952
+ code >>>= 1;
2953
+ res <<= 1;
2954
+ } while (--len2 > 0);
2955
+ return res >>> 1;
2956
+ };
2957
+ var bi_flush = (s) => {
2958
+ if (s.bi_valid === 16) {
2959
+ put_short(s, s.bi_buf);
2960
+ s.bi_buf = 0;
2961
+ s.bi_valid = 0;
2962
+ } else if (s.bi_valid >= 8) {
2963
+ s.pending_buf[s.pending++] = s.bi_buf & 255;
2964
+ s.bi_buf >>= 8;
2965
+ s.bi_valid -= 8;
2966
+ }
2967
+ };
2968
+ var gen_bitlen = (s, desc) => {
2969
+ const tree = desc.dyn_tree;
2970
+ const max_code = desc.max_code;
2971
+ const stree = desc.stat_desc.static_tree;
2972
+ const has_stree = desc.stat_desc.has_stree;
2973
+ const extra = desc.stat_desc.extra_bits;
2974
+ const base = desc.stat_desc.extra_base;
2975
+ const max_length = desc.stat_desc.max_length;
2976
+ let h;
2977
+ let n, m;
2978
+ let bits;
2979
+ let xbits;
2980
+ let f;
2981
+ let overflow = 0;
2982
+ for (bits = 0; bits <= MAX_BITS$1; bits++) {
2983
+ s.bl_count[bits] = 0;
2984
+ }
2985
+ tree[s.heap[s.heap_max] * 2 + 1] = 0;
2986
+ for (h = s.heap_max + 1; h < HEAP_SIZE$1; h++) {
2987
+ n = s.heap[h];
2988
+ bits = tree[tree[n * 2 + 1] * 2 + 1] + 1;
2989
+ if (bits > max_length) {
2990
+ bits = max_length;
2991
+ overflow++;
2992
+ }
2993
+ tree[n * 2 + 1] = bits;
2994
+ if (n > max_code) {
2995
+ continue;
2996
+ }
2997
+ s.bl_count[bits]++;
2998
+ xbits = 0;
2999
+ if (n >= base) {
3000
+ xbits = extra[n - base];
3001
+ }
3002
+ f = tree[n * 2];
3003
+ s.opt_len += f * (bits + xbits);
3004
+ if (has_stree) {
3005
+ s.static_len += f * (stree[n * 2 + 1] + xbits);
3006
+ }
3007
+ }
3008
+ if (overflow === 0) {
3009
+ return;
3010
+ }
3011
+ do {
3012
+ bits = max_length - 1;
3013
+ while (s.bl_count[bits] === 0) {
3014
+ bits--;
3015
+ }
3016
+ s.bl_count[bits]--;
3017
+ s.bl_count[bits + 1] += 2;
3018
+ s.bl_count[max_length]--;
3019
+ overflow -= 2;
3020
+ } while (overflow > 0);
3021
+ for (bits = max_length; bits !== 0; bits--) {
3022
+ n = s.bl_count[bits];
3023
+ while (n !== 0) {
3024
+ m = s.heap[--h];
3025
+ if (m > max_code) {
3026
+ continue;
3027
+ }
3028
+ if (tree[m * 2 + 1] !== bits) {
3029
+ s.opt_len += (bits - tree[m * 2 + 1]) * tree[m * 2];
3030
+ tree[m * 2 + 1] = bits;
3031
+ }
3032
+ n--;
3033
+ }
3034
+ }
3035
+ };
3036
+ var gen_codes = (tree, max_code, bl_count) => {
3037
+ const next_code = new Array(MAX_BITS$1 + 1);
3038
+ let code = 0;
3039
+ let bits;
3040
+ let n;
3041
+ for (bits = 1; bits <= MAX_BITS$1; bits++) {
3042
+ code = code + bl_count[bits - 1] << 1;
3043
+ next_code[bits] = code;
3044
+ }
3045
+ for (n = 0; n <= max_code; n++) {
3046
+ let len2 = tree[n * 2 + 1];
3047
+ if (len2 === 0) {
3048
+ continue;
3049
+ }
3050
+ tree[n * 2] = bi_reverse(next_code[len2]++, len2);
3051
+ }
3052
+ };
3053
+ var tr_static_init = () => {
3054
+ let n;
3055
+ let bits;
3056
+ let length2;
3057
+ let code;
3058
+ let dist2;
3059
+ const bl_count = new Array(MAX_BITS$1 + 1);
3060
+ length2 = 0;
3061
+ for (code = 0; code < LENGTH_CODES$1 - 1; code++) {
3062
+ base_length[code] = length2;
3063
+ for (n = 0; n < 1 << extra_lbits[code]; n++) {
3064
+ _length_code[length2++] = code;
3065
+ }
3066
+ }
3067
+ _length_code[length2 - 1] = code;
3068
+ dist2 = 0;
3069
+ for (code = 0; code < 16; code++) {
3070
+ base_dist[code] = dist2;
3071
+ for (n = 0; n < 1 << extra_dbits[code]; n++) {
3072
+ _dist_code[dist2++] = code;
3073
+ }
3074
+ }
3075
+ dist2 >>= 7;
3076
+ for (; code < D_CODES$1; code++) {
3077
+ base_dist[code] = dist2 << 7;
3078
+ for (n = 0; n < 1 << extra_dbits[code] - 7; n++) {
3079
+ _dist_code[256 + dist2++] = code;
3080
+ }
3081
+ }
3082
+ for (bits = 0; bits <= MAX_BITS$1; bits++) {
3083
+ bl_count[bits] = 0;
3084
+ }
3085
+ n = 0;
3086
+ while (n <= 143) {
3087
+ static_ltree[n * 2 + 1] = 8;
3088
+ n++;
3089
+ bl_count[8]++;
3090
+ }
3091
+ while (n <= 255) {
3092
+ static_ltree[n * 2 + 1] = 9;
3093
+ n++;
3094
+ bl_count[9]++;
3095
+ }
3096
+ while (n <= 279) {
3097
+ static_ltree[n * 2 + 1] = 7;
3098
+ n++;
3099
+ bl_count[7]++;
3100
+ }
3101
+ while (n <= 287) {
3102
+ static_ltree[n * 2 + 1] = 8;
3103
+ n++;
3104
+ bl_count[8]++;
3105
+ }
3106
+ gen_codes(static_ltree, L_CODES$1 + 1, bl_count);
3107
+ for (n = 0; n < D_CODES$1; n++) {
3108
+ static_dtree[n * 2 + 1] = 5;
3109
+ static_dtree[n * 2] = bi_reverse(n, 5);
3110
+ }
3111
+ static_l_desc = new StaticTreeDesc(static_ltree, extra_lbits, LITERALS$1 + 1, L_CODES$1, MAX_BITS$1);
3112
+ static_d_desc = new StaticTreeDesc(static_dtree, extra_dbits, 0, D_CODES$1, MAX_BITS$1);
3113
+ static_bl_desc = new StaticTreeDesc(new Array(0), extra_blbits, 0, BL_CODES$1, MAX_BL_BITS);
3114
+ };
3115
+ var init_block = (s) => {
3116
+ let n;
3117
+ for (n = 0; n < L_CODES$1; n++) {
3118
+ s.dyn_ltree[n * 2] = 0;
3119
+ }
3120
+ for (n = 0; n < D_CODES$1; n++) {
3121
+ s.dyn_dtree[n * 2] = 0;
3122
+ }
3123
+ for (n = 0; n < BL_CODES$1; n++) {
3124
+ s.bl_tree[n * 2] = 0;
3125
+ }
3126
+ s.dyn_ltree[END_BLOCK * 2] = 1;
3127
+ s.opt_len = s.static_len = 0;
3128
+ s.sym_next = s.matches = 0;
3129
+ };
3130
+ var bi_windup = (s) => {
3131
+ if (s.bi_valid > 8) {
3132
+ put_short(s, s.bi_buf);
3133
+ } else if (s.bi_valid > 0) {
3134
+ s.pending_buf[s.pending++] = s.bi_buf;
3135
+ }
3136
+ s.bi_buf = 0;
3137
+ s.bi_valid = 0;
3138
+ };
3139
+ var smaller = (tree, n, m, depth) => {
3140
+ const _n2 = n * 2;
3141
+ const _m2 = m * 2;
3142
+ return tree[_n2] < tree[_m2] || tree[_n2] === tree[_m2] && depth[n] <= depth[m];
3143
+ };
3144
+ var pqdownheap = (s, tree, k) => {
3145
+ const v = s.heap[k];
3146
+ let j = k << 1;
3147
+ while (j <= s.heap_len) {
3148
+ if (j < s.heap_len && smaller(tree, s.heap[j + 1], s.heap[j], s.depth)) {
3149
+ j++;
3150
+ }
3151
+ if (smaller(tree, v, s.heap[j], s.depth)) {
3152
+ break;
3153
+ }
3154
+ s.heap[k] = s.heap[j];
3155
+ k = j;
3156
+ j <<= 1;
3157
+ }
3158
+ s.heap[k] = v;
3159
+ };
3160
+ var compress_block = (s, ltree, dtree) => {
3161
+ let dist2;
3162
+ let lc;
3163
+ let sx = 0;
3164
+ let code;
3165
+ let extra;
3166
+ if (s.sym_next !== 0) {
3167
+ do {
3168
+ dist2 = s.pending_buf[s.sym_buf + sx++] & 255;
3169
+ dist2 += (s.pending_buf[s.sym_buf + sx++] & 255) << 8;
3170
+ lc = s.pending_buf[s.sym_buf + sx++];
3171
+ if (dist2 === 0) {
3172
+ send_code(s, lc, ltree);
3173
+ } else {
3174
+ code = _length_code[lc];
3175
+ send_code(s, code + LITERALS$1 + 1, ltree);
3176
+ extra = extra_lbits[code];
3177
+ if (extra !== 0) {
3178
+ lc -= base_length[code];
3179
+ send_bits(s, lc, extra);
3180
+ }
3181
+ dist2--;
3182
+ code = d_code(dist2);
3183
+ send_code(s, code, dtree);
3184
+ extra = extra_dbits[code];
3185
+ if (extra !== 0) {
3186
+ dist2 -= base_dist[code];
3187
+ send_bits(s, dist2, extra);
3188
+ }
3189
+ }
3190
+ } while (sx < s.sym_next);
3191
+ }
3192
+ send_code(s, END_BLOCK, ltree);
3193
+ };
3194
+ var build_tree = (s, desc) => {
3195
+ const tree = desc.dyn_tree;
3196
+ const stree = desc.stat_desc.static_tree;
3197
+ const has_stree = desc.stat_desc.has_stree;
3198
+ const elems = desc.stat_desc.elems;
3199
+ let n, m;
3200
+ let max_code = -1;
3201
+ let node;
3202
+ s.heap_len = 0;
3203
+ s.heap_max = HEAP_SIZE$1;
3204
+ for (n = 0; n < elems; n++) {
3205
+ if (tree[n * 2] !== 0) {
3206
+ s.heap[++s.heap_len] = max_code = n;
3207
+ s.depth[n] = 0;
3208
+ } else {
3209
+ tree[n * 2 + 1] = 0;
3210
+ }
3211
+ }
3212
+ while (s.heap_len < 2) {
3213
+ node = s.heap[++s.heap_len] = max_code < 2 ? ++max_code : 0;
3214
+ tree[node * 2] = 1;
3215
+ s.depth[node] = 0;
3216
+ s.opt_len--;
3217
+ if (has_stree) {
3218
+ s.static_len -= stree[node * 2 + 1];
3219
+ }
3220
+ }
3221
+ desc.max_code = max_code;
3222
+ for (n = s.heap_len >> 1; n >= 1; n--) {
3223
+ pqdownheap(s, tree, n);
3224
+ }
3225
+ node = elems;
3226
+ do {
3227
+ n = s.heap[
3228
+ 1
3229
+ /*SMALLEST*/
3230
+ ];
3231
+ s.heap[
3232
+ 1
3233
+ /*SMALLEST*/
3234
+ ] = s.heap[s.heap_len--];
3235
+ pqdownheap(
3236
+ s,
3237
+ tree,
3238
+ 1
3239
+ /*SMALLEST*/
3240
+ );
3241
+ m = s.heap[
3242
+ 1
3243
+ /*SMALLEST*/
3244
+ ];
3245
+ s.heap[--s.heap_max] = n;
3246
+ s.heap[--s.heap_max] = m;
3247
+ tree[node * 2] = tree[n * 2] + tree[m * 2];
3248
+ s.depth[node] = (s.depth[n] >= s.depth[m] ? s.depth[n] : s.depth[m]) + 1;
3249
+ tree[n * 2 + 1] = tree[m * 2 + 1] = node;
3250
+ s.heap[
3251
+ 1
3252
+ /*SMALLEST*/
3253
+ ] = node++;
3254
+ pqdownheap(
3255
+ s,
3256
+ tree,
3257
+ 1
3258
+ /*SMALLEST*/
3259
+ );
3260
+ } while (s.heap_len >= 2);
3261
+ s.heap[--s.heap_max] = s.heap[
3262
+ 1
3263
+ /*SMALLEST*/
3264
+ ];
3265
+ gen_bitlen(s, desc);
3266
+ gen_codes(tree, max_code, s.bl_count);
3267
+ };
3268
+ var scan_tree = (s, tree, max_code) => {
3269
+ let n;
3270
+ let prevlen = -1;
3271
+ let curlen;
3272
+ let nextlen = tree[0 * 2 + 1];
3273
+ let count = 0;
3274
+ let max_count = 7;
3275
+ let min_count = 4;
3276
+ if (nextlen === 0) {
3277
+ max_count = 138;
3278
+ min_count = 3;
3279
+ }
3280
+ tree[(max_code + 1) * 2 + 1] = 65535;
3281
+ for (n = 0; n <= max_code; n++) {
3282
+ curlen = nextlen;
3283
+ nextlen = tree[(n + 1) * 2 + 1];
3284
+ if (++count < max_count && curlen === nextlen) {
3285
+ continue;
3286
+ } else if (count < min_count) {
3287
+ s.bl_tree[curlen * 2] += count;
3288
+ } else if (curlen !== 0) {
3289
+ if (curlen !== prevlen) {
3290
+ s.bl_tree[curlen * 2]++;
3291
+ }
3292
+ s.bl_tree[REP_3_6 * 2]++;
3293
+ } else if (count <= 10) {
3294
+ s.bl_tree[REPZ_3_10 * 2]++;
3295
+ } else {
3296
+ s.bl_tree[REPZ_11_138 * 2]++;
3297
+ }
3298
+ count = 0;
3299
+ prevlen = curlen;
3300
+ if (nextlen === 0) {
3301
+ max_count = 138;
3302
+ min_count = 3;
3303
+ } else if (curlen === nextlen) {
3304
+ max_count = 6;
3305
+ min_count = 3;
3306
+ } else {
3307
+ max_count = 7;
3308
+ min_count = 4;
3309
+ }
3310
+ }
3311
+ };
3312
+ var send_tree = (s, tree, max_code) => {
3313
+ let n;
3314
+ let prevlen = -1;
3315
+ let curlen;
3316
+ let nextlen = tree[0 * 2 + 1];
3317
+ let count = 0;
3318
+ let max_count = 7;
3319
+ let min_count = 4;
3320
+ if (nextlen === 0) {
3321
+ max_count = 138;
3322
+ min_count = 3;
3323
+ }
3324
+ for (n = 0; n <= max_code; n++) {
3325
+ curlen = nextlen;
3326
+ nextlen = tree[(n + 1) * 2 + 1];
3327
+ if (++count < max_count && curlen === nextlen) {
3328
+ continue;
3329
+ } else if (count < min_count) {
3330
+ do {
3331
+ send_code(s, curlen, s.bl_tree);
3332
+ } while (--count !== 0);
3333
+ } else if (curlen !== 0) {
3334
+ if (curlen !== prevlen) {
3335
+ send_code(s, curlen, s.bl_tree);
3336
+ count--;
3337
+ }
3338
+ send_code(s, REP_3_6, s.bl_tree);
3339
+ send_bits(s, count - 3, 2);
3340
+ } else if (count <= 10) {
3341
+ send_code(s, REPZ_3_10, s.bl_tree);
3342
+ send_bits(s, count - 3, 3);
3343
+ } else {
3344
+ send_code(s, REPZ_11_138, s.bl_tree);
3345
+ send_bits(s, count - 11, 7);
3346
+ }
3347
+ count = 0;
3348
+ prevlen = curlen;
3349
+ if (nextlen === 0) {
3350
+ max_count = 138;
3351
+ min_count = 3;
3352
+ } else if (curlen === nextlen) {
3353
+ max_count = 6;
3354
+ min_count = 3;
3355
+ } else {
3356
+ max_count = 7;
3357
+ min_count = 4;
3358
+ }
3359
+ }
3360
+ };
3361
+ var build_bl_tree = (s) => {
3362
+ let max_blindex;
3363
+ scan_tree(s, s.dyn_ltree, s.l_desc.max_code);
3364
+ scan_tree(s, s.dyn_dtree, s.d_desc.max_code);
3365
+ build_tree(s, s.bl_desc);
3366
+ for (max_blindex = BL_CODES$1 - 1; max_blindex >= 3; max_blindex--) {
3367
+ if (s.bl_tree[bl_order[max_blindex] * 2 + 1] !== 0) {
3368
+ break;
3369
+ }
3370
+ }
3371
+ s.opt_len += 3 * (max_blindex + 1) + 5 + 5 + 4;
3372
+ return max_blindex;
3373
+ };
3374
+ var send_all_trees = (s, lcodes, dcodes, blcodes) => {
3375
+ let rank2;
3376
+ send_bits(s, lcodes - 257, 5);
3377
+ send_bits(s, dcodes - 1, 5);
3378
+ send_bits(s, blcodes - 4, 4);
3379
+ for (rank2 = 0; rank2 < blcodes; rank2++) {
3380
+ send_bits(s, s.bl_tree[bl_order[rank2] * 2 + 1], 3);
3381
+ }
3382
+ send_tree(s, s.dyn_ltree, lcodes - 1);
3383
+ send_tree(s, s.dyn_dtree, dcodes - 1);
3384
+ };
3385
+ var detect_data_type = (s) => {
3386
+ let block_mask = 4093624447;
3387
+ let n;
3388
+ for (n = 0; n <= 31; n++, block_mask >>>= 1) {
3389
+ if (block_mask & 1 && s.dyn_ltree[n * 2] !== 0) {
3390
+ return Z_BINARY;
3391
+ }
3392
+ }
3393
+ if (s.dyn_ltree[9 * 2] !== 0 || s.dyn_ltree[10 * 2] !== 0 || s.dyn_ltree[13 * 2] !== 0) {
3394
+ return Z_TEXT;
3395
+ }
3396
+ for (n = 32; n < LITERALS$1; n++) {
3397
+ if (s.dyn_ltree[n * 2] !== 0) {
3398
+ return Z_TEXT;
3399
+ }
3400
+ }
3401
+ return Z_BINARY;
3402
+ };
3403
+ var static_init_done = false;
3404
+ var _tr_init$1 = (s) => {
3405
+ if (!static_init_done) {
3406
+ tr_static_init();
3407
+ static_init_done = true;
3408
+ }
3409
+ s.l_desc = new TreeDesc(s.dyn_ltree, static_l_desc);
3410
+ s.d_desc = new TreeDesc(s.dyn_dtree, static_d_desc);
3411
+ s.bl_desc = new TreeDesc(s.bl_tree, static_bl_desc);
3412
+ s.bi_buf = 0;
3413
+ s.bi_valid = 0;
3414
+ init_block(s);
3415
+ };
3416
+ var _tr_stored_block$1 = (s, buf, stored_len, last) => {
3417
+ send_bits(s, (STORED_BLOCK << 1) + (last ? 1 : 0), 3);
3418
+ bi_windup(s);
3419
+ put_short(s, stored_len);
3420
+ put_short(s, ~stored_len);
3421
+ if (stored_len) {
3422
+ s.pending_buf.set(s.window.subarray(buf, buf + stored_len), s.pending);
3423
+ }
3424
+ s.pending += stored_len;
3425
+ };
3426
+ var _tr_align$1 = (s) => {
3427
+ send_bits(s, STATIC_TREES << 1, 3);
3428
+ send_code(s, END_BLOCK, static_ltree);
3429
+ bi_flush(s);
3430
+ };
3431
+ var _tr_flush_block$1 = (s, buf, stored_len, last) => {
3432
+ let opt_lenb, static_lenb;
3433
+ let max_blindex = 0;
3434
+ if (s.level > 0) {
3435
+ if (s.strm.data_type === Z_UNKNOWN$1) {
3436
+ s.strm.data_type = detect_data_type(s);
3437
+ }
3438
+ build_tree(s, s.l_desc);
3439
+ build_tree(s, s.d_desc);
3440
+ max_blindex = build_bl_tree(s);
3441
+ opt_lenb = s.opt_len + 3 + 7 >>> 3;
3442
+ static_lenb = s.static_len + 3 + 7 >>> 3;
3443
+ if (static_lenb <= opt_lenb) {
3444
+ opt_lenb = static_lenb;
3445
+ }
3446
+ } else {
3447
+ opt_lenb = static_lenb = stored_len + 5;
3448
+ }
3449
+ if (stored_len + 4 <= opt_lenb && buf !== -1) {
3450
+ _tr_stored_block$1(s, buf, stored_len, last);
3451
+ } else if (s.strategy === Z_FIXED$1 || static_lenb === opt_lenb) {
3452
+ send_bits(s, (STATIC_TREES << 1) + (last ? 1 : 0), 3);
3453
+ compress_block(s, static_ltree, static_dtree);
3454
+ } else {
3455
+ send_bits(s, (DYN_TREES << 1) + (last ? 1 : 0), 3);
3456
+ send_all_trees(s, s.l_desc.max_code + 1, s.d_desc.max_code + 1, max_blindex + 1);
3457
+ compress_block(s, s.dyn_ltree, s.dyn_dtree);
3458
+ }
3459
+ init_block(s);
3460
+ if (last) {
3461
+ bi_windup(s);
3462
+ }
3463
+ };
3464
+ var _tr_tally$1 = (s, dist2, lc) => {
3465
+ s.pending_buf[s.sym_buf + s.sym_next++] = dist2;
3466
+ s.pending_buf[s.sym_buf + s.sym_next++] = dist2 >> 8;
3467
+ s.pending_buf[s.sym_buf + s.sym_next++] = lc;
3468
+ if (dist2 === 0) {
3469
+ s.dyn_ltree[lc * 2]++;
3470
+ } else {
3471
+ s.matches++;
3472
+ dist2--;
3473
+ s.dyn_ltree[(_length_code[lc] + LITERALS$1 + 1) * 2]++;
3474
+ s.dyn_dtree[d_code(dist2) * 2]++;
3475
+ }
3476
+ return s.sym_next === s.sym_end;
3477
+ };
3478
+ var _tr_init_1 = _tr_init$1;
3479
+ var _tr_stored_block_1 = _tr_stored_block$1;
3480
+ var _tr_flush_block_1 = _tr_flush_block$1;
3481
+ var _tr_tally_1 = _tr_tally$1;
3482
+ var _tr_align_1 = _tr_align$1;
3483
+ var trees = {
3484
+ _tr_init: _tr_init_1,
3485
+ _tr_stored_block: _tr_stored_block_1,
3486
+ _tr_flush_block: _tr_flush_block_1,
3487
+ _tr_tally: _tr_tally_1,
3488
+ _tr_align: _tr_align_1
3489
+ };
3490
+ var adler32 = (adler, buf, len2, pos) => {
3491
+ let s1 = adler & 65535 | 0, s2 = adler >>> 16 & 65535 | 0, n = 0;
3492
+ while (len2 !== 0) {
3493
+ n = len2 > 2e3 ? 2e3 : len2;
3494
+ len2 -= n;
3495
+ do {
3496
+ s1 = s1 + buf[pos++] | 0;
3497
+ s2 = s2 + s1 | 0;
3498
+ } while (--n);
3499
+ s1 %= 65521;
3500
+ s2 %= 65521;
3501
+ }
3502
+ return s1 | s2 << 16 | 0;
3503
+ };
3504
+ var adler32_1 = adler32;
3505
+ var makeTable = () => {
3506
+ let c, table = [];
3507
+ for (var n = 0; n < 256; n++) {
3508
+ c = n;
3509
+ for (var k = 0; k < 8; k++) {
3510
+ c = c & 1 ? 3988292384 ^ c >>> 1 : c >>> 1;
3511
+ }
3512
+ table[n] = c;
3513
+ }
3514
+ return table;
3515
+ };
3516
+ var crcTable = new Uint32Array(makeTable());
3517
+ var crc322 = (crc, buf, len2, pos) => {
3518
+ const t = crcTable;
3519
+ const end = pos + len2;
3520
+ crc ^= -1;
3521
+ for (let i = pos; i < end; i++) {
3522
+ crc = crc >>> 8 ^ t[(crc ^ buf[i]) & 255];
3523
+ }
3524
+ return crc ^ -1;
3525
+ };
3526
+ var crc32_1 = crc322;
3527
+ var messages = {
3528
+ 2: "need dictionary",
3529
+ /* Z_NEED_DICT 2 */
3530
+ 1: "stream end",
3531
+ /* Z_STREAM_END 1 */
3532
+ 0: "",
3533
+ /* Z_OK 0 */
3534
+ "-1": "file error",
3535
+ /* Z_ERRNO (-1) */
3536
+ "-2": "stream error",
3537
+ /* Z_STREAM_ERROR (-2) */
3538
+ "-3": "data error",
3539
+ /* Z_DATA_ERROR (-3) */
3540
+ "-4": "insufficient memory",
3541
+ /* Z_MEM_ERROR (-4) */
3542
+ "-5": "buffer error",
3543
+ /* Z_BUF_ERROR (-5) */
3544
+ "-6": "incompatible version"
3545
+ /* Z_VERSION_ERROR (-6) */
3546
+ };
3547
+ var constants$2 = {
3548
+ /* Allowed flush values; see deflate() and inflate() below for details */
3549
+ Z_NO_FLUSH: 0,
3550
+ Z_PARTIAL_FLUSH: 1,
3551
+ Z_SYNC_FLUSH: 2,
3552
+ Z_FULL_FLUSH: 3,
3553
+ Z_FINISH: 4,
3554
+ Z_BLOCK: 5,
3555
+ Z_TREES: 6,
3556
+ /* Return codes for the compression/decompression functions. Negative values
3557
+ * are errors, positive values are used for special but normal events.
3558
+ */
3559
+ Z_OK: 0,
3560
+ Z_STREAM_END: 1,
3561
+ Z_NEED_DICT: 2,
3562
+ Z_ERRNO: -1,
3563
+ Z_STREAM_ERROR: -2,
3564
+ Z_DATA_ERROR: -3,
3565
+ Z_MEM_ERROR: -4,
3566
+ Z_BUF_ERROR: -5,
3567
+ //Z_VERSION_ERROR: -6,
3568
+ /* compression levels */
3569
+ Z_NO_COMPRESSION: 0,
3570
+ Z_BEST_SPEED: 1,
3571
+ Z_BEST_COMPRESSION: 9,
3572
+ Z_DEFAULT_COMPRESSION: -1,
3573
+ Z_FILTERED: 1,
3574
+ Z_HUFFMAN_ONLY: 2,
3575
+ Z_RLE: 3,
3576
+ Z_FIXED: 4,
3577
+ Z_DEFAULT_STRATEGY: 0,
3578
+ /* Possible values of the data_type field (though see inflate()) */
3579
+ Z_BINARY: 0,
3580
+ Z_TEXT: 1,
3581
+ //Z_ASCII: 1, // = Z_TEXT (deprecated)
3582
+ Z_UNKNOWN: 2,
3583
+ /* The deflate compression method */
3584
+ Z_DEFLATED: 8
3585
+ //Z_NULL: null // Use -1 or null inline, depending on var type
3586
+ };
3587
+ var { _tr_init, _tr_stored_block, _tr_flush_block, _tr_tally, _tr_align } = trees;
3588
+ var {
3589
+ Z_NO_FLUSH: Z_NO_FLUSH$2,
3590
+ Z_PARTIAL_FLUSH,
3591
+ Z_FULL_FLUSH: Z_FULL_FLUSH$1,
3592
+ Z_FINISH: Z_FINISH$3,
3593
+ Z_BLOCK: Z_BLOCK$1,
3594
+ Z_OK: Z_OK$3,
3595
+ Z_STREAM_END: Z_STREAM_END$3,
3596
+ Z_STREAM_ERROR: Z_STREAM_ERROR$2,
3597
+ Z_DATA_ERROR: Z_DATA_ERROR$2,
3598
+ Z_BUF_ERROR: Z_BUF_ERROR$1,
3599
+ Z_DEFAULT_COMPRESSION: Z_DEFAULT_COMPRESSION$1,
3600
+ Z_FILTERED,
3601
+ Z_HUFFMAN_ONLY,
3602
+ Z_RLE,
3603
+ Z_FIXED,
3604
+ Z_DEFAULT_STRATEGY: Z_DEFAULT_STRATEGY$1,
3605
+ Z_UNKNOWN,
3606
+ Z_DEFLATED: Z_DEFLATED$2
3607
+ } = constants$2;
3608
+ var MAX_MEM_LEVEL = 9;
3609
+ var MAX_WBITS$1 = 15;
3610
+ var DEF_MEM_LEVEL = 8;
3611
+ var LENGTH_CODES = 29;
3612
+ var LITERALS = 256;
3613
+ var L_CODES = LITERALS + 1 + LENGTH_CODES;
3614
+ var D_CODES = 30;
3615
+ var BL_CODES = 19;
3616
+ var HEAP_SIZE = 2 * L_CODES + 1;
3617
+ var MAX_BITS = 15;
3618
+ var MIN_MATCH = 3;
3619
+ var MAX_MATCH = 258;
3620
+ var MIN_LOOKAHEAD = MAX_MATCH + MIN_MATCH + 1;
3621
+ var PRESET_DICT = 32;
3622
+ var INIT_STATE = 42;
3623
+ var GZIP_STATE = 57;
3624
+ var EXTRA_STATE = 69;
3625
+ var NAME_STATE = 73;
3626
+ var COMMENT_STATE = 91;
3627
+ var HCRC_STATE = 103;
3628
+ var BUSY_STATE = 113;
3629
+ var FINISH_STATE = 666;
3630
+ var BS_NEED_MORE = 1;
3631
+ var BS_BLOCK_DONE = 2;
3632
+ var BS_FINISH_STARTED = 3;
3633
+ var BS_FINISH_DONE = 4;
3634
+ var OS_CODE = 3;
3635
+ var err = (strm, errorCode) => {
3636
+ strm.msg = messages[errorCode];
3637
+ return errorCode;
3638
+ };
3639
+ var rank = (f) => {
3640
+ return f * 2 - (f > 4 ? 9 : 0);
3641
+ };
3642
+ var zero2 = (buf) => {
3643
+ let len2 = buf.length;
3644
+ while (--len2 >= 0) {
3645
+ buf[len2] = 0;
3646
+ }
3647
+ };
3648
+ var slide_hash = (s) => {
3649
+ let n, m;
3650
+ let p;
3651
+ let wsize = s.w_size;
3652
+ n = s.hash_size;
3653
+ p = n;
3654
+ do {
3655
+ m = s.head[--p];
3656
+ s.head[p] = m >= wsize ? m - wsize : 0;
3657
+ } while (--n);
3658
+ n = wsize;
3659
+ p = n;
3660
+ do {
3661
+ m = s.prev[--p];
3662
+ s.prev[p] = m >= wsize ? m - wsize : 0;
3663
+ } while (--n);
3664
+ };
3665
+ var HASH_ZLIB = (s, prev, data) => (prev << s.hash_shift ^ data) & s.hash_mask;
3666
+ var HASH = HASH_ZLIB;
3667
+ var flush_pending = (strm) => {
3668
+ const s = strm.state;
3669
+ let len2 = s.pending;
3670
+ if (len2 > strm.avail_out) {
3671
+ len2 = strm.avail_out;
3672
+ }
3673
+ if (len2 === 0) {
3674
+ return;
3675
+ }
3676
+ strm.output.set(s.pending_buf.subarray(s.pending_out, s.pending_out + len2), strm.next_out);
3677
+ strm.next_out += len2;
3678
+ s.pending_out += len2;
3679
+ strm.total_out += len2;
3680
+ strm.avail_out -= len2;
3681
+ s.pending -= len2;
3682
+ if (s.pending === 0) {
3683
+ s.pending_out = 0;
3684
+ }
3685
+ };
3686
+ var flush_block_only = (s, last) => {
3687
+ _tr_flush_block(s, s.block_start >= 0 ? s.block_start : -1, s.strstart - s.block_start, last);
3688
+ s.block_start = s.strstart;
3689
+ flush_pending(s.strm);
3690
+ };
3691
+ var put_byte = (s, b) => {
3692
+ s.pending_buf[s.pending++] = b;
3693
+ };
3694
+ var putShortMSB = (s, b) => {
3695
+ s.pending_buf[s.pending++] = b >>> 8 & 255;
3696
+ s.pending_buf[s.pending++] = b & 255;
3697
+ };
3698
+ var read_buf = (strm, buf, start, size) => {
3699
+ let len2 = strm.avail_in;
3700
+ if (len2 > size) {
3701
+ len2 = size;
3702
+ }
3703
+ if (len2 === 0) {
3704
+ return 0;
3705
+ }
3706
+ strm.avail_in -= len2;
3707
+ buf.set(strm.input.subarray(strm.next_in, strm.next_in + len2), start);
3708
+ if (strm.state.wrap === 1) {
3709
+ strm.adler = adler32_1(strm.adler, buf, len2, start);
3710
+ } else if (strm.state.wrap === 2) {
3711
+ strm.adler = crc32_1(strm.adler, buf, len2, start);
3712
+ }
3713
+ strm.next_in += len2;
3714
+ strm.total_in += len2;
3715
+ return len2;
3716
+ };
3717
+ var longest_match = (s, cur_match) => {
3718
+ let chain_length = s.max_chain_length;
3719
+ let scan = s.strstart;
3720
+ let match;
3721
+ let len2;
3722
+ let best_len = s.prev_length;
3723
+ let nice_match = s.nice_match;
3724
+ const limit = s.strstart > s.w_size - MIN_LOOKAHEAD ? s.strstart - (s.w_size - MIN_LOOKAHEAD) : 0;
3725
+ const _win = s.window;
3726
+ const wmask = s.w_mask;
3727
+ const prev = s.prev;
3728
+ const strend = s.strstart + MAX_MATCH;
3729
+ let scan_end1 = _win[scan + best_len - 1];
3730
+ let scan_end = _win[scan + best_len];
3731
+ if (s.prev_length >= s.good_match) {
3732
+ chain_length >>= 2;
3733
+ }
3734
+ if (nice_match > s.lookahead) {
3735
+ nice_match = s.lookahead;
3736
+ }
3737
+ do {
3738
+ match = cur_match;
3739
+ if (_win[match + best_len] !== scan_end || _win[match + best_len - 1] !== scan_end1 || _win[match] !== _win[scan] || _win[++match] !== _win[scan + 1]) {
3740
+ continue;
3741
+ }
3742
+ scan += 2;
3743
+ match++;
3744
+ do {
3745
+ } while (_win[++scan] === _win[++match] && _win[++scan] === _win[++match] && _win[++scan] === _win[++match] && _win[++scan] === _win[++match] && _win[++scan] === _win[++match] && _win[++scan] === _win[++match] && _win[++scan] === _win[++match] && _win[++scan] === _win[++match] && scan < strend);
3746
+ len2 = MAX_MATCH - (strend - scan);
3747
+ scan = strend - MAX_MATCH;
3748
+ if (len2 > best_len) {
3749
+ s.match_start = cur_match;
3750
+ best_len = len2;
3751
+ if (len2 >= nice_match) {
3752
+ break;
3753
+ }
3754
+ scan_end1 = _win[scan + best_len - 1];
3755
+ scan_end = _win[scan + best_len];
3756
+ }
3757
+ } while ((cur_match = prev[cur_match & wmask]) > limit && --chain_length !== 0);
3758
+ if (best_len <= s.lookahead) {
3759
+ return best_len;
3760
+ }
3761
+ return s.lookahead;
3762
+ };
3763
+ var fill_window = (s) => {
3764
+ const _w_size = s.w_size;
3765
+ let n, more, str3;
3766
+ do {
3767
+ more = s.window_size - s.lookahead - s.strstart;
3768
+ if (s.strstart >= _w_size + (_w_size - MIN_LOOKAHEAD)) {
3769
+ s.window.set(s.window.subarray(_w_size, _w_size + _w_size - more), 0);
3770
+ s.match_start -= _w_size;
3771
+ s.strstart -= _w_size;
3772
+ s.block_start -= _w_size;
3773
+ if (s.insert > s.strstart) {
3774
+ s.insert = s.strstart;
3775
+ }
3776
+ slide_hash(s);
3777
+ more += _w_size;
3778
+ }
3779
+ if (s.strm.avail_in === 0) {
3780
+ break;
3781
+ }
3782
+ n = read_buf(s.strm, s.window, s.strstart + s.lookahead, more);
3783
+ s.lookahead += n;
3784
+ if (s.lookahead + s.insert >= MIN_MATCH) {
3785
+ str3 = s.strstart - s.insert;
3786
+ s.ins_h = s.window[str3];
3787
+ s.ins_h = HASH(s, s.ins_h, s.window[str3 + 1]);
3788
+ while (s.insert) {
3789
+ s.ins_h = HASH(s, s.ins_h, s.window[str3 + MIN_MATCH - 1]);
3790
+ s.prev[str3 & s.w_mask] = s.head[s.ins_h];
3791
+ s.head[s.ins_h] = str3;
3792
+ str3++;
3793
+ s.insert--;
3794
+ if (s.lookahead + s.insert < MIN_MATCH) {
3795
+ break;
3796
+ }
3797
+ }
3798
+ }
3799
+ } while (s.lookahead < MIN_LOOKAHEAD && s.strm.avail_in !== 0);
3800
+ };
3801
+ var deflate_stored = (s, flush) => {
3802
+ let min_block = s.pending_buf_size - 5 > s.w_size ? s.w_size : s.pending_buf_size - 5;
3803
+ let len2, left, have, last = 0;
3804
+ let used = s.strm.avail_in;
3805
+ do {
3806
+ len2 = 65535;
3807
+ have = s.bi_valid + 42 >> 3;
3808
+ if (s.strm.avail_out < have) {
3809
+ break;
3810
+ }
3811
+ have = s.strm.avail_out - have;
3812
+ left = s.strstart - s.block_start;
3813
+ if (len2 > left + s.strm.avail_in) {
3814
+ len2 = left + s.strm.avail_in;
3815
+ }
3816
+ if (len2 > have) {
3817
+ len2 = have;
3818
+ }
3819
+ if (len2 < min_block && (len2 === 0 && flush !== Z_FINISH$3 || flush === Z_NO_FLUSH$2 || len2 !== left + s.strm.avail_in)) {
3820
+ break;
3821
+ }
3822
+ last = flush === Z_FINISH$3 && len2 === left + s.strm.avail_in ? 1 : 0;
3823
+ _tr_stored_block(s, 0, 0, last);
3824
+ s.pending_buf[s.pending - 4] = len2;
3825
+ s.pending_buf[s.pending - 3] = len2 >> 8;
3826
+ s.pending_buf[s.pending - 2] = ~len2;
3827
+ s.pending_buf[s.pending - 1] = ~len2 >> 8;
3828
+ flush_pending(s.strm);
3829
+ if (left) {
3830
+ if (left > len2) {
3831
+ left = len2;
3832
+ }
3833
+ s.strm.output.set(s.window.subarray(s.block_start, s.block_start + left), s.strm.next_out);
3834
+ s.strm.next_out += left;
3835
+ s.strm.avail_out -= left;
3836
+ s.strm.total_out += left;
3837
+ s.block_start += left;
3838
+ len2 -= left;
3839
+ }
3840
+ if (len2) {
3841
+ read_buf(s.strm, s.strm.output, s.strm.next_out, len2);
3842
+ s.strm.next_out += len2;
3843
+ s.strm.avail_out -= len2;
3844
+ s.strm.total_out += len2;
3845
+ }
3846
+ } while (last === 0);
3847
+ used -= s.strm.avail_in;
3848
+ if (used) {
3849
+ if (used >= s.w_size) {
3850
+ s.matches = 2;
3851
+ s.window.set(s.strm.input.subarray(s.strm.next_in - s.w_size, s.strm.next_in), 0);
3852
+ s.strstart = s.w_size;
3853
+ s.insert = s.strstart;
3854
+ } else {
3855
+ if (s.window_size - s.strstart <= used) {
3856
+ s.strstart -= s.w_size;
3857
+ s.window.set(s.window.subarray(s.w_size, s.w_size + s.strstart), 0);
3858
+ if (s.matches < 2) {
3859
+ s.matches++;
3860
+ }
3861
+ if (s.insert > s.strstart) {
3862
+ s.insert = s.strstart;
3863
+ }
3864
+ }
3865
+ s.window.set(s.strm.input.subarray(s.strm.next_in - used, s.strm.next_in), s.strstart);
3866
+ s.strstart += used;
3867
+ s.insert += used > s.w_size - s.insert ? s.w_size - s.insert : used;
3868
+ }
3869
+ s.block_start = s.strstart;
3870
+ }
3871
+ if (s.high_water < s.strstart) {
3872
+ s.high_water = s.strstart;
3873
+ }
3874
+ if (last) {
3875
+ return BS_FINISH_DONE;
3876
+ }
3877
+ if (flush !== Z_NO_FLUSH$2 && flush !== Z_FINISH$3 && s.strm.avail_in === 0 && s.strstart === s.block_start) {
3878
+ return BS_BLOCK_DONE;
3879
+ }
3880
+ have = s.window_size - s.strstart;
3881
+ if (s.strm.avail_in > have && s.block_start >= s.w_size) {
3882
+ s.block_start -= s.w_size;
3883
+ s.strstart -= s.w_size;
3884
+ s.window.set(s.window.subarray(s.w_size, s.w_size + s.strstart), 0);
3885
+ if (s.matches < 2) {
3886
+ s.matches++;
3887
+ }
3888
+ have += s.w_size;
3889
+ if (s.insert > s.strstart) {
3890
+ s.insert = s.strstart;
3891
+ }
3892
+ }
3893
+ if (have > s.strm.avail_in) {
3894
+ have = s.strm.avail_in;
3895
+ }
3896
+ if (have) {
3897
+ read_buf(s.strm, s.window, s.strstart, have);
3898
+ s.strstart += have;
3899
+ s.insert += have > s.w_size - s.insert ? s.w_size - s.insert : have;
3900
+ }
3901
+ if (s.high_water < s.strstart) {
3902
+ s.high_water = s.strstart;
3903
+ }
3904
+ have = s.bi_valid + 42 >> 3;
3905
+ have = s.pending_buf_size - have > 65535 ? 65535 : s.pending_buf_size - have;
3906
+ min_block = have > s.w_size ? s.w_size : have;
3907
+ left = s.strstart - s.block_start;
3908
+ if (left >= min_block || (left || flush === Z_FINISH$3) && flush !== Z_NO_FLUSH$2 && s.strm.avail_in === 0 && left <= have) {
3909
+ len2 = left > have ? have : left;
3910
+ last = flush === Z_FINISH$3 && s.strm.avail_in === 0 && len2 === left ? 1 : 0;
3911
+ _tr_stored_block(s, s.block_start, len2, last);
3912
+ s.block_start += len2;
3913
+ flush_pending(s.strm);
3914
+ }
3915
+ return last ? BS_FINISH_STARTED : BS_NEED_MORE;
3916
+ };
3917
+ var deflate_fast = (s, flush) => {
3918
+ let hash_head;
3919
+ let bflush;
3920
+ for (; ; ) {
3921
+ if (s.lookahead < MIN_LOOKAHEAD) {
3922
+ fill_window(s);
3923
+ if (s.lookahead < MIN_LOOKAHEAD && flush === Z_NO_FLUSH$2) {
3924
+ return BS_NEED_MORE;
3925
+ }
3926
+ if (s.lookahead === 0) {
3927
+ break;
3928
+ }
3929
+ }
3930
+ hash_head = 0;
3931
+ if (s.lookahead >= MIN_MATCH) {
3932
+ s.ins_h = HASH(s, s.ins_h, s.window[s.strstart + MIN_MATCH - 1]);
3933
+ hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];
3934
+ s.head[s.ins_h] = s.strstart;
3935
+ }
3936
+ if (hash_head !== 0 && s.strstart - hash_head <= s.w_size - MIN_LOOKAHEAD) {
3937
+ s.match_length = longest_match(s, hash_head);
3938
+ }
3939
+ if (s.match_length >= MIN_MATCH) {
3940
+ bflush = _tr_tally(s, s.strstart - s.match_start, s.match_length - MIN_MATCH);
3941
+ s.lookahead -= s.match_length;
3942
+ if (s.match_length <= s.max_lazy_match && s.lookahead >= MIN_MATCH) {
3943
+ s.match_length--;
3944
+ do {
3945
+ s.strstart++;
3946
+ s.ins_h = HASH(s, s.ins_h, s.window[s.strstart + MIN_MATCH - 1]);
3947
+ hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];
3948
+ s.head[s.ins_h] = s.strstart;
3949
+ } while (--s.match_length !== 0);
3950
+ s.strstart++;
3951
+ } else {
3952
+ s.strstart += s.match_length;
3953
+ s.match_length = 0;
3954
+ s.ins_h = s.window[s.strstart];
3955
+ s.ins_h = HASH(s, s.ins_h, s.window[s.strstart + 1]);
3956
+ }
3957
+ } else {
3958
+ bflush = _tr_tally(s, 0, s.window[s.strstart]);
3959
+ s.lookahead--;
3960
+ s.strstart++;
3961
+ }
3962
+ if (bflush) {
3963
+ flush_block_only(s, false);
3964
+ if (s.strm.avail_out === 0) {
3965
+ return BS_NEED_MORE;
3966
+ }
3967
+ }
3968
+ }
3969
+ s.insert = s.strstart < MIN_MATCH - 1 ? s.strstart : MIN_MATCH - 1;
3970
+ if (flush === Z_FINISH$3) {
3971
+ flush_block_only(s, true);
3972
+ if (s.strm.avail_out === 0) {
3973
+ return BS_FINISH_STARTED;
3974
+ }
3975
+ return BS_FINISH_DONE;
3976
+ }
3977
+ if (s.sym_next) {
3978
+ flush_block_only(s, false);
3979
+ if (s.strm.avail_out === 0) {
3980
+ return BS_NEED_MORE;
3981
+ }
3982
+ }
3983
+ return BS_BLOCK_DONE;
3984
+ };
3985
+ var deflate_slow = (s, flush) => {
3986
+ let hash_head;
3987
+ let bflush;
3988
+ let max_insert;
3989
+ for (; ; ) {
3990
+ if (s.lookahead < MIN_LOOKAHEAD) {
3991
+ fill_window(s);
3992
+ if (s.lookahead < MIN_LOOKAHEAD && flush === Z_NO_FLUSH$2) {
3993
+ return BS_NEED_MORE;
3994
+ }
3995
+ if (s.lookahead === 0) {
3996
+ break;
3997
+ }
3998
+ }
3999
+ hash_head = 0;
4000
+ if (s.lookahead >= MIN_MATCH) {
4001
+ s.ins_h = HASH(s, s.ins_h, s.window[s.strstart + MIN_MATCH - 1]);
4002
+ hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];
4003
+ s.head[s.ins_h] = s.strstart;
4004
+ }
4005
+ s.prev_length = s.match_length;
4006
+ s.prev_match = s.match_start;
4007
+ s.match_length = MIN_MATCH - 1;
4008
+ if (hash_head !== 0 && s.prev_length < s.max_lazy_match && s.strstart - hash_head <= s.w_size - MIN_LOOKAHEAD) {
4009
+ s.match_length = longest_match(s, hash_head);
4010
+ if (s.match_length <= 5 && (s.strategy === Z_FILTERED || s.match_length === MIN_MATCH && s.strstart - s.match_start > 4096)) {
4011
+ s.match_length = MIN_MATCH - 1;
4012
+ }
4013
+ }
4014
+ if (s.prev_length >= MIN_MATCH && s.match_length <= s.prev_length) {
4015
+ max_insert = s.strstart + s.lookahead - MIN_MATCH;
4016
+ bflush = _tr_tally(s, s.strstart - 1 - s.prev_match, s.prev_length - MIN_MATCH);
4017
+ s.lookahead -= s.prev_length - 1;
4018
+ s.prev_length -= 2;
4019
+ do {
4020
+ if (++s.strstart <= max_insert) {
4021
+ s.ins_h = HASH(s, s.ins_h, s.window[s.strstart + MIN_MATCH - 1]);
4022
+ hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];
4023
+ s.head[s.ins_h] = s.strstart;
4024
+ }
4025
+ } while (--s.prev_length !== 0);
4026
+ s.match_available = 0;
4027
+ s.match_length = MIN_MATCH - 1;
4028
+ s.strstart++;
4029
+ if (bflush) {
4030
+ flush_block_only(s, false);
4031
+ if (s.strm.avail_out === 0) {
4032
+ return BS_NEED_MORE;
4033
+ }
4034
+ }
4035
+ } else if (s.match_available) {
4036
+ bflush = _tr_tally(s, 0, s.window[s.strstart - 1]);
4037
+ if (bflush) {
4038
+ flush_block_only(s, false);
4039
+ }
4040
+ s.strstart++;
4041
+ s.lookahead--;
4042
+ if (s.strm.avail_out === 0) {
4043
+ return BS_NEED_MORE;
4044
+ }
4045
+ } else {
4046
+ s.match_available = 1;
4047
+ s.strstart++;
4048
+ s.lookahead--;
4049
+ }
4050
+ }
4051
+ if (s.match_available) {
4052
+ bflush = _tr_tally(s, 0, s.window[s.strstart - 1]);
4053
+ s.match_available = 0;
4054
+ }
4055
+ s.insert = s.strstart < MIN_MATCH - 1 ? s.strstart : MIN_MATCH - 1;
4056
+ if (flush === Z_FINISH$3) {
4057
+ flush_block_only(s, true);
4058
+ if (s.strm.avail_out === 0) {
4059
+ return BS_FINISH_STARTED;
4060
+ }
4061
+ return BS_FINISH_DONE;
4062
+ }
4063
+ if (s.sym_next) {
4064
+ flush_block_only(s, false);
4065
+ if (s.strm.avail_out === 0) {
4066
+ return BS_NEED_MORE;
4067
+ }
4068
+ }
4069
+ return BS_BLOCK_DONE;
4070
+ };
4071
+ var deflate_rle = (s, flush) => {
4072
+ let bflush;
4073
+ let prev;
4074
+ let scan, strend;
4075
+ const _win = s.window;
4076
+ for (; ; ) {
4077
+ if (s.lookahead <= MAX_MATCH) {
4078
+ fill_window(s);
4079
+ if (s.lookahead <= MAX_MATCH && flush === Z_NO_FLUSH$2) {
4080
+ return BS_NEED_MORE;
4081
+ }
4082
+ if (s.lookahead === 0) {
4083
+ break;
4084
+ }
4085
+ }
4086
+ s.match_length = 0;
4087
+ if (s.lookahead >= MIN_MATCH && s.strstart > 0) {
4088
+ scan = s.strstart - 1;
4089
+ prev = _win[scan];
4090
+ if (prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan]) {
4091
+ strend = s.strstart + MAX_MATCH;
4092
+ do {
4093
+ } while (prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan] && scan < strend);
4094
+ s.match_length = MAX_MATCH - (strend - scan);
4095
+ if (s.match_length > s.lookahead) {
4096
+ s.match_length = s.lookahead;
4097
+ }
4098
+ }
4099
+ }
4100
+ if (s.match_length >= MIN_MATCH) {
4101
+ bflush = _tr_tally(s, 1, s.match_length - MIN_MATCH);
4102
+ s.lookahead -= s.match_length;
4103
+ s.strstart += s.match_length;
4104
+ s.match_length = 0;
4105
+ } else {
4106
+ bflush = _tr_tally(s, 0, s.window[s.strstart]);
4107
+ s.lookahead--;
4108
+ s.strstart++;
4109
+ }
4110
+ if (bflush) {
4111
+ flush_block_only(s, false);
4112
+ if (s.strm.avail_out === 0) {
4113
+ return BS_NEED_MORE;
4114
+ }
4115
+ }
4116
+ }
4117
+ s.insert = 0;
4118
+ if (flush === Z_FINISH$3) {
4119
+ flush_block_only(s, true);
4120
+ if (s.strm.avail_out === 0) {
4121
+ return BS_FINISH_STARTED;
4122
+ }
4123
+ return BS_FINISH_DONE;
4124
+ }
4125
+ if (s.sym_next) {
4126
+ flush_block_only(s, false);
4127
+ if (s.strm.avail_out === 0) {
4128
+ return BS_NEED_MORE;
4129
+ }
4130
+ }
4131
+ return BS_BLOCK_DONE;
4132
+ };
4133
+ var deflate_huff = (s, flush) => {
4134
+ let bflush;
4135
+ for (; ; ) {
4136
+ if (s.lookahead === 0) {
4137
+ fill_window(s);
4138
+ if (s.lookahead === 0) {
4139
+ if (flush === Z_NO_FLUSH$2) {
4140
+ return BS_NEED_MORE;
4141
+ }
4142
+ break;
4143
+ }
4144
+ }
4145
+ s.match_length = 0;
4146
+ bflush = _tr_tally(s, 0, s.window[s.strstart]);
4147
+ s.lookahead--;
4148
+ s.strstart++;
4149
+ if (bflush) {
4150
+ flush_block_only(s, false);
4151
+ if (s.strm.avail_out === 0) {
4152
+ return BS_NEED_MORE;
4153
+ }
4154
+ }
4155
+ }
4156
+ s.insert = 0;
4157
+ if (flush === Z_FINISH$3) {
4158
+ flush_block_only(s, true);
4159
+ if (s.strm.avail_out === 0) {
4160
+ return BS_FINISH_STARTED;
4161
+ }
4162
+ return BS_FINISH_DONE;
4163
+ }
4164
+ if (s.sym_next) {
4165
+ flush_block_only(s, false);
4166
+ if (s.strm.avail_out === 0) {
4167
+ return BS_NEED_MORE;
4168
+ }
4169
+ }
4170
+ return BS_BLOCK_DONE;
4171
+ };
4172
+ function Config(good_length, max_lazy, nice_length, max_chain, func) {
4173
+ this.good_length = good_length;
4174
+ this.max_lazy = max_lazy;
4175
+ this.nice_length = nice_length;
4176
+ this.max_chain = max_chain;
4177
+ this.func = func;
4178
+ }
4179
+ var configuration_table = [
4180
+ /* good lazy nice chain */
4181
+ new Config(0, 0, 0, 0, deflate_stored),
4182
+ /* 0 store only */
4183
+ new Config(4, 4, 8, 4, deflate_fast),
4184
+ /* 1 max speed, no lazy matches */
4185
+ new Config(4, 5, 16, 8, deflate_fast),
4186
+ /* 2 */
4187
+ new Config(4, 6, 32, 32, deflate_fast),
4188
+ /* 3 */
4189
+ new Config(4, 4, 16, 16, deflate_slow),
4190
+ /* 4 lazy matches */
4191
+ new Config(8, 16, 32, 32, deflate_slow),
4192
+ /* 5 */
4193
+ new Config(8, 16, 128, 128, deflate_slow),
4194
+ /* 6 */
4195
+ new Config(8, 32, 128, 256, deflate_slow),
4196
+ /* 7 */
4197
+ new Config(32, 128, 258, 1024, deflate_slow),
4198
+ /* 8 */
4199
+ new Config(32, 258, 258, 4096, deflate_slow)
4200
+ /* 9 max compression */
4201
+ ];
4202
+ var lm_init = (s) => {
4203
+ s.window_size = 2 * s.w_size;
4204
+ zero2(s.head);
4205
+ s.max_lazy_match = configuration_table[s.level].max_lazy;
4206
+ s.good_match = configuration_table[s.level].good_length;
4207
+ s.nice_match = configuration_table[s.level].nice_length;
4208
+ s.max_chain_length = configuration_table[s.level].max_chain;
4209
+ s.strstart = 0;
4210
+ s.block_start = 0;
4211
+ s.lookahead = 0;
4212
+ s.insert = 0;
4213
+ s.match_length = s.prev_length = MIN_MATCH - 1;
4214
+ s.match_available = 0;
4215
+ s.ins_h = 0;
4216
+ };
4217
+ function DeflateState() {
4218
+ this.strm = null;
4219
+ this.status = 0;
4220
+ this.pending_buf = null;
4221
+ this.pending_buf_size = 0;
4222
+ this.pending_out = 0;
4223
+ this.pending = 0;
4224
+ this.wrap = 0;
4225
+ this.gzhead = null;
4226
+ this.gzindex = 0;
4227
+ this.method = Z_DEFLATED$2;
4228
+ this.last_flush = -1;
4229
+ this.w_size = 0;
4230
+ this.w_bits = 0;
4231
+ this.w_mask = 0;
4232
+ this.window = null;
4233
+ this.window_size = 0;
4234
+ this.prev = null;
4235
+ this.head = null;
4236
+ this.ins_h = 0;
4237
+ this.hash_size = 0;
4238
+ this.hash_bits = 0;
4239
+ this.hash_mask = 0;
4240
+ this.hash_shift = 0;
4241
+ this.block_start = 0;
4242
+ this.match_length = 0;
4243
+ this.prev_match = 0;
4244
+ this.match_available = 0;
4245
+ this.strstart = 0;
4246
+ this.match_start = 0;
4247
+ this.lookahead = 0;
4248
+ this.prev_length = 0;
4249
+ this.max_chain_length = 0;
4250
+ this.max_lazy_match = 0;
4251
+ this.level = 0;
4252
+ this.strategy = 0;
4253
+ this.good_match = 0;
4254
+ this.nice_match = 0;
4255
+ this.dyn_ltree = new Uint16Array(HEAP_SIZE * 2);
4256
+ this.dyn_dtree = new Uint16Array((2 * D_CODES + 1) * 2);
4257
+ this.bl_tree = new Uint16Array((2 * BL_CODES + 1) * 2);
4258
+ zero2(this.dyn_ltree);
4259
+ zero2(this.dyn_dtree);
4260
+ zero2(this.bl_tree);
4261
+ this.l_desc = null;
4262
+ this.d_desc = null;
4263
+ this.bl_desc = null;
4264
+ this.bl_count = new Uint16Array(MAX_BITS + 1);
4265
+ this.heap = new Uint16Array(2 * L_CODES + 1);
4266
+ zero2(this.heap);
4267
+ this.heap_len = 0;
4268
+ this.heap_max = 0;
4269
+ this.depth = new Uint16Array(2 * L_CODES + 1);
4270
+ zero2(this.depth);
4271
+ this.sym_buf = 0;
4272
+ this.lit_bufsize = 0;
4273
+ this.sym_next = 0;
4274
+ this.sym_end = 0;
4275
+ this.opt_len = 0;
4276
+ this.static_len = 0;
4277
+ this.matches = 0;
4278
+ this.insert = 0;
4279
+ this.bi_buf = 0;
4280
+ this.bi_valid = 0;
4281
+ }
4282
+ var deflateStateCheck = (strm) => {
4283
+ if (!strm) {
4284
+ return 1;
4285
+ }
4286
+ const s = strm.state;
4287
+ if (!s || s.strm !== strm || s.status !== INIT_STATE && //#ifdef GZIP
4288
+ s.status !== GZIP_STATE && //#endif
4289
+ s.status !== EXTRA_STATE && s.status !== NAME_STATE && s.status !== COMMENT_STATE && s.status !== HCRC_STATE && s.status !== BUSY_STATE && s.status !== FINISH_STATE) {
4290
+ return 1;
4291
+ }
4292
+ return 0;
4293
+ };
4294
+ var deflateResetKeep = (strm) => {
4295
+ if (deflateStateCheck(strm)) {
4296
+ return err(strm, Z_STREAM_ERROR$2);
4297
+ }
4298
+ strm.total_in = strm.total_out = 0;
4299
+ strm.data_type = Z_UNKNOWN;
4300
+ const s = strm.state;
4301
+ s.pending = 0;
4302
+ s.pending_out = 0;
4303
+ if (s.wrap < 0) {
4304
+ s.wrap = -s.wrap;
4305
+ }
4306
+ s.status = //#ifdef GZIP
4307
+ s.wrap === 2 ? GZIP_STATE : (
4308
+ //#endif
4309
+ s.wrap ? INIT_STATE : BUSY_STATE
4310
+ );
4311
+ strm.adler = s.wrap === 2 ? 0 : 1;
4312
+ s.last_flush = -2;
4313
+ _tr_init(s);
4314
+ return Z_OK$3;
4315
+ };
4316
+ var deflateReset = (strm) => {
4317
+ const ret = deflateResetKeep(strm);
4318
+ if (ret === Z_OK$3) {
4319
+ lm_init(strm.state);
4320
+ }
4321
+ return ret;
4322
+ };
4323
+ var deflateSetHeader = (strm, head) => {
4324
+ if (deflateStateCheck(strm) || strm.state.wrap !== 2) {
4325
+ return Z_STREAM_ERROR$2;
4326
+ }
4327
+ strm.state.gzhead = head;
4328
+ return Z_OK$3;
4329
+ };
4330
+ var deflateInit2 = (strm, level, method, windowBits, memLevel, strategy) => {
4331
+ if (!strm) {
4332
+ return Z_STREAM_ERROR$2;
4333
+ }
4334
+ let wrap = 1;
4335
+ if (level === Z_DEFAULT_COMPRESSION$1) {
4336
+ level = 6;
4337
+ }
4338
+ if (windowBits < 0) {
4339
+ wrap = 0;
4340
+ windowBits = -windowBits;
4341
+ } else if (windowBits > 15) {
4342
+ wrap = 2;
4343
+ windowBits -= 16;
4344
+ }
4345
+ if (memLevel < 1 || memLevel > MAX_MEM_LEVEL || method !== Z_DEFLATED$2 || windowBits < 8 || windowBits > 15 || level < 0 || level > 9 || strategy < 0 || strategy > Z_FIXED || windowBits === 8 && wrap !== 1) {
4346
+ return err(strm, Z_STREAM_ERROR$2);
4347
+ }
4348
+ if (windowBits === 8) {
4349
+ windowBits = 9;
4350
+ }
4351
+ const s = new DeflateState();
4352
+ strm.state = s;
4353
+ s.strm = strm;
4354
+ s.status = INIT_STATE;
4355
+ s.wrap = wrap;
4356
+ s.gzhead = null;
4357
+ s.w_bits = windowBits;
4358
+ s.w_size = 1 << s.w_bits;
4359
+ s.w_mask = s.w_size - 1;
4360
+ s.hash_bits = memLevel + 7;
4361
+ s.hash_size = 1 << s.hash_bits;
4362
+ s.hash_mask = s.hash_size - 1;
4363
+ s.hash_shift = ~~((s.hash_bits + MIN_MATCH - 1) / MIN_MATCH);
4364
+ s.window = new Uint8Array(s.w_size * 2);
4365
+ s.head = new Uint16Array(s.hash_size);
4366
+ s.prev = new Uint16Array(s.w_size);
4367
+ s.lit_bufsize = 1 << memLevel + 6;
4368
+ s.pending_buf_size = s.lit_bufsize * 4;
4369
+ s.pending_buf = new Uint8Array(s.pending_buf_size);
4370
+ s.sym_buf = s.lit_bufsize;
4371
+ s.sym_end = (s.lit_bufsize - 1) * 3;
4372
+ s.level = level;
4373
+ s.strategy = strategy;
4374
+ s.method = method;
4375
+ return deflateReset(strm);
4376
+ };
4377
+ var deflateInit = (strm, level) => {
4378
+ return deflateInit2(strm, level, Z_DEFLATED$2, MAX_WBITS$1, DEF_MEM_LEVEL, Z_DEFAULT_STRATEGY$1);
4379
+ };
4380
+ var deflate$2 = (strm, flush) => {
4381
+ if (deflateStateCheck(strm) || flush > Z_BLOCK$1 || flush < 0) {
4382
+ return strm ? err(strm, Z_STREAM_ERROR$2) : Z_STREAM_ERROR$2;
4383
+ }
4384
+ const s = strm.state;
4385
+ if (!strm.output || strm.avail_in !== 0 && !strm.input || s.status === FINISH_STATE && flush !== Z_FINISH$3) {
4386
+ return err(strm, strm.avail_out === 0 ? Z_BUF_ERROR$1 : Z_STREAM_ERROR$2);
4387
+ }
4388
+ const old_flush = s.last_flush;
4389
+ s.last_flush = flush;
4390
+ if (s.pending !== 0) {
4391
+ flush_pending(strm);
4392
+ if (strm.avail_out === 0) {
4393
+ s.last_flush = -1;
4394
+ return Z_OK$3;
4395
+ }
4396
+ } else if (strm.avail_in === 0 && rank(flush) <= rank(old_flush) && flush !== Z_FINISH$3) {
4397
+ return err(strm, Z_BUF_ERROR$1);
4398
+ }
4399
+ if (s.status === FINISH_STATE && strm.avail_in !== 0) {
4400
+ return err(strm, Z_BUF_ERROR$1);
4401
+ }
4402
+ if (s.status === INIT_STATE && s.wrap === 0) {
4403
+ s.status = BUSY_STATE;
4404
+ }
4405
+ if (s.status === INIT_STATE) {
4406
+ let header = Z_DEFLATED$2 + (s.w_bits - 8 << 4) << 8;
4407
+ let level_flags = -1;
4408
+ if (s.strategy >= Z_HUFFMAN_ONLY || s.level < 2) {
4409
+ level_flags = 0;
4410
+ } else if (s.level < 6) {
4411
+ level_flags = 1;
4412
+ } else if (s.level === 6) {
4413
+ level_flags = 2;
4414
+ } else {
4415
+ level_flags = 3;
4416
+ }
4417
+ header |= level_flags << 6;
4418
+ if (s.strstart !== 0) {
4419
+ header |= PRESET_DICT;
4420
+ }
4421
+ header += 31 - header % 31;
4422
+ putShortMSB(s, header);
4423
+ if (s.strstart !== 0) {
4424
+ putShortMSB(s, strm.adler >>> 16);
4425
+ putShortMSB(s, strm.adler & 65535);
4426
+ }
4427
+ strm.adler = 1;
4428
+ s.status = BUSY_STATE;
4429
+ flush_pending(strm);
4430
+ if (s.pending !== 0) {
4431
+ s.last_flush = -1;
4432
+ return Z_OK$3;
4433
+ }
4434
+ }
4435
+ if (s.status === GZIP_STATE) {
4436
+ strm.adler = 0;
4437
+ put_byte(s, 31);
4438
+ put_byte(s, 139);
4439
+ put_byte(s, 8);
4440
+ if (!s.gzhead) {
4441
+ put_byte(s, 0);
4442
+ put_byte(s, 0);
4443
+ put_byte(s, 0);
4444
+ put_byte(s, 0);
4445
+ put_byte(s, 0);
4446
+ put_byte(s, s.level === 9 ? 2 : s.strategy >= Z_HUFFMAN_ONLY || s.level < 2 ? 4 : 0);
4447
+ put_byte(s, OS_CODE);
4448
+ s.status = BUSY_STATE;
4449
+ flush_pending(strm);
4450
+ if (s.pending !== 0) {
4451
+ s.last_flush = -1;
4452
+ return Z_OK$3;
4453
+ }
4454
+ } else {
4455
+ put_byte(
4456
+ s,
4457
+ (s.gzhead.text ? 1 : 0) + (s.gzhead.hcrc ? 2 : 0) + (!s.gzhead.extra ? 0 : 4) + (!s.gzhead.name ? 0 : 8) + (!s.gzhead.comment ? 0 : 16)
4458
+ );
4459
+ put_byte(s, s.gzhead.time & 255);
4460
+ put_byte(s, s.gzhead.time >> 8 & 255);
4461
+ put_byte(s, s.gzhead.time >> 16 & 255);
4462
+ put_byte(s, s.gzhead.time >> 24 & 255);
4463
+ put_byte(s, s.level === 9 ? 2 : s.strategy >= Z_HUFFMAN_ONLY || s.level < 2 ? 4 : 0);
4464
+ put_byte(s, s.gzhead.os & 255);
4465
+ if (s.gzhead.extra && s.gzhead.extra.length) {
4466
+ put_byte(s, s.gzhead.extra.length & 255);
4467
+ put_byte(s, s.gzhead.extra.length >> 8 & 255);
4468
+ }
4469
+ if (s.gzhead.hcrc) {
4470
+ strm.adler = crc32_1(strm.adler, s.pending_buf, s.pending, 0);
4471
+ }
4472
+ s.gzindex = 0;
4473
+ s.status = EXTRA_STATE;
4474
+ }
4475
+ }
4476
+ if (s.status === EXTRA_STATE) {
4477
+ if (s.gzhead.extra) {
4478
+ let beg = s.pending;
4479
+ let left = (s.gzhead.extra.length & 65535) - s.gzindex;
4480
+ while (s.pending + left > s.pending_buf_size) {
4481
+ let copy3 = s.pending_buf_size - s.pending;
4482
+ s.pending_buf.set(s.gzhead.extra.subarray(s.gzindex, s.gzindex + copy3), s.pending);
4483
+ s.pending = s.pending_buf_size;
4484
+ if (s.gzhead.hcrc && s.pending > beg) {
4485
+ strm.adler = crc32_1(strm.adler, s.pending_buf, s.pending - beg, beg);
4486
+ }
4487
+ s.gzindex += copy3;
4488
+ flush_pending(strm);
4489
+ if (s.pending !== 0) {
4490
+ s.last_flush = -1;
4491
+ return Z_OK$3;
4492
+ }
4493
+ beg = 0;
4494
+ left -= copy3;
4495
+ }
4496
+ let gzhead_extra = new Uint8Array(s.gzhead.extra);
4497
+ s.pending_buf.set(gzhead_extra.subarray(s.gzindex, s.gzindex + left), s.pending);
4498
+ s.pending += left;
4499
+ if (s.gzhead.hcrc && s.pending > beg) {
4500
+ strm.adler = crc32_1(strm.adler, s.pending_buf, s.pending - beg, beg);
4501
+ }
4502
+ s.gzindex = 0;
4503
+ }
4504
+ s.status = NAME_STATE;
4505
+ }
4506
+ if (s.status === NAME_STATE) {
4507
+ if (s.gzhead.name) {
4508
+ let beg = s.pending;
4509
+ let val;
4510
+ do {
4511
+ if (s.pending === s.pending_buf_size) {
4512
+ if (s.gzhead.hcrc && s.pending > beg) {
4513
+ strm.adler = crc32_1(strm.adler, s.pending_buf, s.pending - beg, beg);
4514
+ }
4515
+ flush_pending(strm);
4516
+ if (s.pending !== 0) {
4517
+ s.last_flush = -1;
4518
+ return Z_OK$3;
4519
+ }
4520
+ beg = 0;
4521
+ }
4522
+ if (s.gzindex < s.gzhead.name.length) {
4523
+ val = s.gzhead.name.charCodeAt(s.gzindex++) & 255;
4524
+ } else {
4525
+ val = 0;
4526
+ }
4527
+ put_byte(s, val);
4528
+ } while (val !== 0);
4529
+ if (s.gzhead.hcrc && s.pending > beg) {
4530
+ strm.adler = crc32_1(strm.adler, s.pending_buf, s.pending - beg, beg);
4531
+ }
4532
+ s.gzindex = 0;
4533
+ }
4534
+ s.status = COMMENT_STATE;
4535
+ }
4536
+ if (s.status === COMMENT_STATE) {
4537
+ if (s.gzhead.comment) {
4538
+ let beg = s.pending;
4539
+ let val;
4540
+ do {
4541
+ if (s.pending === s.pending_buf_size) {
4542
+ if (s.gzhead.hcrc && s.pending > beg) {
4543
+ strm.adler = crc32_1(strm.adler, s.pending_buf, s.pending - beg, beg);
4544
+ }
4545
+ flush_pending(strm);
4546
+ if (s.pending !== 0) {
4547
+ s.last_flush = -1;
4548
+ return Z_OK$3;
4549
+ }
4550
+ beg = 0;
4551
+ }
4552
+ if (s.gzindex < s.gzhead.comment.length) {
4553
+ val = s.gzhead.comment.charCodeAt(s.gzindex++) & 255;
4554
+ } else {
4555
+ val = 0;
4556
+ }
4557
+ put_byte(s, val);
4558
+ } while (val !== 0);
4559
+ if (s.gzhead.hcrc && s.pending > beg) {
4560
+ strm.adler = crc32_1(strm.adler, s.pending_buf, s.pending - beg, beg);
4561
+ }
4562
+ }
4563
+ s.status = HCRC_STATE;
4564
+ }
4565
+ if (s.status === HCRC_STATE) {
4566
+ if (s.gzhead.hcrc) {
4567
+ if (s.pending + 2 > s.pending_buf_size) {
4568
+ flush_pending(strm);
4569
+ if (s.pending !== 0) {
4570
+ s.last_flush = -1;
4571
+ return Z_OK$3;
4572
+ }
4573
+ }
4574
+ put_byte(s, strm.adler & 255);
4575
+ put_byte(s, strm.adler >> 8 & 255);
4576
+ strm.adler = 0;
4577
+ }
4578
+ s.status = BUSY_STATE;
4579
+ flush_pending(strm);
4580
+ if (s.pending !== 0) {
4581
+ s.last_flush = -1;
4582
+ return Z_OK$3;
4583
+ }
4584
+ }
4585
+ if (strm.avail_in !== 0 || s.lookahead !== 0 || flush !== Z_NO_FLUSH$2 && s.status !== FINISH_STATE) {
4586
+ let bstate = s.level === 0 ? deflate_stored(s, flush) : s.strategy === Z_HUFFMAN_ONLY ? deflate_huff(s, flush) : s.strategy === Z_RLE ? deflate_rle(s, flush) : configuration_table[s.level].func(s, flush);
4587
+ if (bstate === BS_FINISH_STARTED || bstate === BS_FINISH_DONE) {
4588
+ s.status = FINISH_STATE;
4589
+ }
4590
+ if (bstate === BS_NEED_MORE || bstate === BS_FINISH_STARTED) {
4591
+ if (strm.avail_out === 0) {
4592
+ s.last_flush = -1;
4593
+ }
4594
+ return Z_OK$3;
4595
+ }
4596
+ if (bstate === BS_BLOCK_DONE) {
4597
+ if (flush === Z_PARTIAL_FLUSH) {
4598
+ _tr_align(s);
4599
+ } else if (flush !== Z_BLOCK$1) {
4600
+ _tr_stored_block(s, 0, 0, false);
4601
+ if (flush === Z_FULL_FLUSH$1) {
4602
+ zero2(s.head);
4603
+ if (s.lookahead === 0) {
4604
+ s.strstart = 0;
4605
+ s.block_start = 0;
4606
+ s.insert = 0;
4607
+ }
4608
+ }
4609
+ }
4610
+ flush_pending(strm);
4611
+ if (strm.avail_out === 0) {
4612
+ s.last_flush = -1;
4613
+ return Z_OK$3;
4614
+ }
4615
+ }
4616
+ }
4617
+ if (flush !== Z_FINISH$3) {
4618
+ return Z_OK$3;
4619
+ }
4620
+ if (s.wrap <= 0) {
4621
+ return Z_STREAM_END$3;
4622
+ }
4623
+ if (s.wrap === 2) {
4624
+ put_byte(s, strm.adler & 255);
4625
+ put_byte(s, strm.adler >> 8 & 255);
4626
+ put_byte(s, strm.adler >> 16 & 255);
4627
+ put_byte(s, strm.adler >> 24 & 255);
4628
+ put_byte(s, strm.total_in & 255);
4629
+ put_byte(s, strm.total_in >> 8 & 255);
4630
+ put_byte(s, strm.total_in >> 16 & 255);
4631
+ put_byte(s, strm.total_in >> 24 & 255);
4632
+ } else {
4633
+ putShortMSB(s, strm.adler >>> 16);
4634
+ putShortMSB(s, strm.adler & 65535);
4635
+ }
4636
+ flush_pending(strm);
4637
+ if (s.wrap > 0) {
4638
+ s.wrap = -s.wrap;
4639
+ }
4640
+ return s.pending !== 0 ? Z_OK$3 : Z_STREAM_END$3;
4641
+ };
4642
+ var deflateEnd = (strm) => {
4643
+ if (deflateStateCheck(strm)) {
4644
+ return Z_STREAM_ERROR$2;
4645
+ }
4646
+ const status = strm.state.status;
4647
+ strm.state = null;
4648
+ return status === BUSY_STATE ? err(strm, Z_DATA_ERROR$2) : Z_OK$3;
4649
+ };
4650
+ var deflateSetDictionary = (strm, dictionary) => {
4651
+ let dictLength = dictionary.length;
4652
+ if (deflateStateCheck(strm)) {
4653
+ return Z_STREAM_ERROR$2;
4654
+ }
4655
+ const s = strm.state;
4656
+ const wrap = s.wrap;
4657
+ if (wrap === 2 || wrap === 1 && s.status !== INIT_STATE || s.lookahead) {
4658
+ return Z_STREAM_ERROR$2;
4659
+ }
4660
+ if (wrap === 1) {
4661
+ strm.adler = adler32_1(strm.adler, dictionary, dictLength, 0);
4662
+ }
4663
+ s.wrap = 0;
4664
+ if (dictLength >= s.w_size) {
4665
+ if (wrap === 0) {
4666
+ zero2(s.head);
4667
+ s.strstart = 0;
4668
+ s.block_start = 0;
4669
+ s.insert = 0;
4670
+ }
4671
+ let tmpDict = new Uint8Array(s.w_size);
4672
+ tmpDict.set(dictionary.subarray(dictLength - s.w_size, dictLength), 0);
4673
+ dictionary = tmpDict;
4674
+ dictLength = s.w_size;
4675
+ }
4676
+ const avail = strm.avail_in;
4677
+ const next = strm.next_in;
4678
+ const input = strm.input;
4679
+ strm.avail_in = dictLength;
4680
+ strm.next_in = 0;
4681
+ strm.input = dictionary;
4682
+ fill_window(s);
4683
+ while (s.lookahead >= MIN_MATCH) {
4684
+ let str3 = s.strstart;
4685
+ let n = s.lookahead - (MIN_MATCH - 1);
4686
+ do {
4687
+ s.ins_h = HASH(s, s.ins_h, s.window[str3 + MIN_MATCH - 1]);
4688
+ s.prev[str3 & s.w_mask] = s.head[s.ins_h];
4689
+ s.head[s.ins_h] = str3;
4690
+ str3++;
4691
+ } while (--n);
4692
+ s.strstart = str3;
4693
+ s.lookahead = MIN_MATCH - 1;
4694
+ fill_window(s);
4695
+ }
4696
+ s.strstart += s.lookahead;
4697
+ s.block_start = s.strstart;
4698
+ s.insert = s.lookahead;
4699
+ s.lookahead = 0;
4700
+ s.match_length = s.prev_length = MIN_MATCH - 1;
4701
+ s.match_available = 0;
4702
+ strm.next_in = next;
4703
+ strm.input = input;
4704
+ strm.avail_in = avail;
4705
+ s.wrap = wrap;
4706
+ return Z_OK$3;
4707
+ };
4708
+ var deflateInit_1 = deflateInit;
4709
+ var deflateInit2_1 = deflateInit2;
4710
+ var deflateReset_1 = deflateReset;
4711
+ var deflateResetKeep_1 = deflateResetKeep;
4712
+ var deflateSetHeader_1 = deflateSetHeader;
4713
+ var deflate_2$1 = deflate$2;
4714
+ var deflateEnd_1 = deflateEnd;
4715
+ var deflateSetDictionary_1 = deflateSetDictionary;
4716
+ var deflateInfo = "pako deflate (from Nodeca project)";
4717
+ var deflate_1$2 = {
4718
+ deflateInit: deflateInit_1,
4719
+ deflateInit2: deflateInit2_1,
4720
+ deflateReset: deflateReset_1,
4721
+ deflateResetKeep: deflateResetKeep_1,
4722
+ deflateSetHeader: deflateSetHeader_1,
4723
+ deflate: deflate_2$1,
4724
+ deflateEnd: deflateEnd_1,
4725
+ deflateSetDictionary: deflateSetDictionary_1,
4726
+ deflateInfo
4727
+ };
4728
+ var _has = (obj, key) => {
4729
+ return Object.prototype.hasOwnProperty.call(obj, key);
4730
+ };
4731
+ var assign = function(obj) {
4732
+ const sources = Array.prototype.slice.call(arguments, 1);
4733
+ while (sources.length) {
4734
+ const source = sources.shift();
4735
+ if (!source) {
4736
+ continue;
4737
+ }
4738
+ if (typeof source !== "object") {
4739
+ throw new TypeError(source + "must be non-object");
4740
+ }
4741
+ for (const p in source) {
4742
+ if (_has(source, p)) {
4743
+ obj[p] = source[p];
4744
+ }
4745
+ }
4746
+ }
4747
+ return obj;
4748
+ };
4749
+ var flattenChunks = (chunks) => {
4750
+ let len2 = 0;
4751
+ for (let i = 0, l = chunks.length; i < l; i++) {
4752
+ len2 += chunks[i].length;
4753
+ }
4754
+ const result = new Uint8Array(len2);
4755
+ for (let i = 0, pos = 0, l = chunks.length; i < l; i++) {
4756
+ let chunk = chunks[i];
4757
+ result.set(chunk, pos);
4758
+ pos += chunk.length;
4759
+ }
4760
+ return result;
4761
+ };
4762
+ var common = {
4763
+ assign,
4764
+ flattenChunks
4765
+ };
4766
+ var STR_APPLY_UIA_OK = true;
4767
+ try {
4768
+ String.fromCharCode.apply(null, new Uint8Array(1));
4769
+ } catch (__) {
4770
+ STR_APPLY_UIA_OK = false;
4771
+ }
4772
+ var _utf8len = new Uint8Array(256);
4773
+ for (let q = 0; q < 256; q++) {
4774
+ _utf8len[q] = q >= 252 ? 6 : q >= 248 ? 5 : q >= 240 ? 4 : q >= 224 ? 3 : q >= 192 ? 2 : 1;
4775
+ }
4776
+ _utf8len[254] = _utf8len[254] = 1;
4777
+ var string2buf = (str3) => {
4778
+ if (typeof TextEncoder === "function" && TextEncoder.prototype.encode) {
4779
+ return new TextEncoder().encode(str3);
4780
+ }
4781
+ let buf, c, c2, m_pos, i, str_len = str3.length, buf_len = 0;
4782
+ for (m_pos = 0; m_pos < str_len; m_pos++) {
4783
+ c = str3.charCodeAt(m_pos);
4784
+ if ((c & 64512) === 55296 && m_pos + 1 < str_len) {
4785
+ c2 = str3.charCodeAt(m_pos + 1);
4786
+ if ((c2 & 64512) === 56320) {
4787
+ c = 65536 + (c - 55296 << 10) + (c2 - 56320);
4788
+ m_pos++;
4789
+ }
4790
+ }
4791
+ buf_len += c < 128 ? 1 : c < 2048 ? 2 : c < 65536 ? 3 : 4;
4792
+ }
4793
+ buf = new Uint8Array(buf_len);
4794
+ for (i = 0, m_pos = 0; i < buf_len; m_pos++) {
4795
+ c = str3.charCodeAt(m_pos);
4796
+ if ((c & 64512) === 55296 && m_pos + 1 < str_len) {
4797
+ c2 = str3.charCodeAt(m_pos + 1);
4798
+ if ((c2 & 64512) === 56320) {
4799
+ c = 65536 + (c - 55296 << 10) + (c2 - 56320);
4800
+ m_pos++;
4801
+ }
4802
+ }
4803
+ if (c < 128) {
4804
+ buf[i++] = c;
4805
+ } else if (c < 2048) {
4806
+ buf[i++] = 192 | c >>> 6;
4807
+ buf[i++] = 128 | c & 63;
4808
+ } else if (c < 65536) {
4809
+ buf[i++] = 224 | c >>> 12;
4810
+ buf[i++] = 128 | c >>> 6 & 63;
4811
+ buf[i++] = 128 | c & 63;
4812
+ } else {
4813
+ buf[i++] = 240 | c >>> 18;
4814
+ buf[i++] = 128 | c >>> 12 & 63;
4815
+ buf[i++] = 128 | c >>> 6 & 63;
4816
+ buf[i++] = 128 | c & 63;
4817
+ }
4818
+ }
4819
+ return buf;
4820
+ };
4821
+ var buf2binstring = (buf, len2) => {
4822
+ if (len2 < 65534) {
4823
+ if (buf.subarray && STR_APPLY_UIA_OK) {
4824
+ return String.fromCharCode.apply(null, buf.length === len2 ? buf : buf.subarray(0, len2));
4825
+ }
4826
+ }
4827
+ let result = "";
4828
+ for (let i = 0; i < len2; i++) {
4829
+ result += String.fromCharCode(buf[i]);
4830
+ }
4831
+ return result;
4832
+ };
4833
+ var buf2string = (buf, max2) => {
4834
+ const len2 = max2 || buf.length;
4835
+ if (typeof TextDecoder === "function" && TextDecoder.prototype.decode) {
4836
+ return new TextDecoder().decode(buf.subarray(0, max2));
4837
+ }
4838
+ let i, out;
4839
+ const utf16buf = new Array(len2 * 2);
4840
+ for (out = 0, i = 0; i < len2; ) {
4841
+ let c = buf[i++];
4842
+ if (c < 128) {
4843
+ utf16buf[out++] = c;
4844
+ continue;
4845
+ }
4846
+ let c_len = _utf8len[c];
4847
+ if (c_len > 4) {
4848
+ utf16buf[out++] = 65533;
4849
+ i += c_len - 1;
4850
+ continue;
4851
+ }
4852
+ c &= c_len === 2 ? 31 : c_len === 3 ? 15 : 7;
4853
+ while (c_len > 1 && i < len2) {
4854
+ c = c << 6 | buf[i++] & 63;
4855
+ c_len--;
4856
+ }
4857
+ if (c_len > 1) {
4858
+ utf16buf[out++] = 65533;
4859
+ continue;
4860
+ }
4861
+ if (c < 65536) {
4862
+ utf16buf[out++] = c;
4863
+ } else {
4864
+ c -= 65536;
4865
+ utf16buf[out++] = 55296 | c >> 10 & 1023;
4866
+ utf16buf[out++] = 56320 | c & 1023;
4867
+ }
4868
+ }
4869
+ return buf2binstring(utf16buf, out);
4870
+ };
4871
+ var utf8border = (buf, max2) => {
4872
+ max2 = max2 || buf.length;
4873
+ if (max2 > buf.length) {
4874
+ max2 = buf.length;
4875
+ }
4876
+ let pos = max2 - 1;
4877
+ while (pos >= 0 && (buf[pos] & 192) === 128) {
4878
+ pos--;
4879
+ }
4880
+ if (pos < 0) {
4881
+ return max2;
4882
+ }
4883
+ if (pos === 0) {
4884
+ return max2;
4885
+ }
4886
+ return pos + _utf8len[buf[pos]] > max2 ? pos : max2;
4887
+ };
4888
+ var strings = {
4889
+ string2buf,
4890
+ buf2string,
4891
+ utf8border
4892
+ };
4893
+ function ZStream() {
4894
+ this.input = null;
4895
+ this.next_in = 0;
4896
+ this.avail_in = 0;
4897
+ this.total_in = 0;
4898
+ this.output = null;
4899
+ this.next_out = 0;
4900
+ this.avail_out = 0;
4901
+ this.total_out = 0;
4902
+ this.msg = "";
4903
+ this.state = null;
4904
+ this.data_type = 2;
4905
+ this.adler = 0;
4906
+ }
4907
+ var zstream = ZStream;
4908
+ var toString$1 = Object.prototype.toString;
4909
+ var {
4910
+ Z_NO_FLUSH: Z_NO_FLUSH$1,
4911
+ Z_SYNC_FLUSH,
4912
+ Z_FULL_FLUSH,
4913
+ Z_FINISH: Z_FINISH$2,
4914
+ Z_OK: Z_OK$2,
4915
+ Z_STREAM_END: Z_STREAM_END$2,
4916
+ Z_DEFAULT_COMPRESSION,
4917
+ Z_DEFAULT_STRATEGY,
4918
+ Z_DEFLATED: Z_DEFLATED$1
4919
+ } = constants$2;
4920
+ function Deflate$1(options) {
4921
+ this.options = common.assign({
4922
+ level: Z_DEFAULT_COMPRESSION,
4923
+ method: Z_DEFLATED$1,
4924
+ chunkSize: 16384,
4925
+ windowBits: 15,
4926
+ memLevel: 8,
4927
+ strategy: Z_DEFAULT_STRATEGY
4928
+ }, options || {});
4929
+ let opt = this.options;
4930
+ if (opt.raw && opt.windowBits > 0) {
4931
+ opt.windowBits = -opt.windowBits;
4932
+ } else if (opt.gzip && opt.windowBits > 0 && opt.windowBits < 16) {
4933
+ opt.windowBits += 16;
4934
+ }
4935
+ this.err = 0;
4936
+ this.msg = "";
4937
+ this.ended = false;
4938
+ this.chunks = [];
4939
+ this.strm = new zstream();
4940
+ this.strm.avail_out = 0;
4941
+ let status = deflate_1$2.deflateInit2(
4942
+ this.strm,
4943
+ opt.level,
4944
+ opt.method,
4945
+ opt.windowBits,
4946
+ opt.memLevel,
4947
+ opt.strategy
4948
+ );
4949
+ if (status !== Z_OK$2) {
4950
+ throw new Error(messages[status]);
4951
+ }
4952
+ if (opt.header) {
4953
+ deflate_1$2.deflateSetHeader(this.strm, opt.header);
4954
+ }
4955
+ if (opt.dictionary) {
4956
+ let dict;
4957
+ if (typeof opt.dictionary === "string") {
4958
+ dict = strings.string2buf(opt.dictionary);
4959
+ } else if (toString$1.call(opt.dictionary) === "[object ArrayBuffer]") {
4960
+ dict = new Uint8Array(opt.dictionary);
4961
+ } else {
4962
+ dict = opt.dictionary;
4963
+ }
4964
+ status = deflate_1$2.deflateSetDictionary(this.strm, dict);
4965
+ if (status !== Z_OK$2) {
4966
+ throw new Error(messages[status]);
4967
+ }
4968
+ this._dict_set = true;
4969
+ }
4970
+ }
4971
+ Deflate$1.prototype.push = function(data, flush_mode) {
4972
+ const strm = this.strm;
4973
+ const chunkSize = this.options.chunkSize;
4974
+ let status, _flush_mode;
4975
+ if (this.ended) {
4976
+ return false;
4977
+ }
4978
+ if (flush_mode === ~~flush_mode) _flush_mode = flush_mode;
4979
+ else _flush_mode = flush_mode === true ? Z_FINISH$2 : Z_NO_FLUSH$1;
4980
+ if (typeof data === "string") {
4981
+ strm.input = strings.string2buf(data);
4982
+ } else if (toString$1.call(data) === "[object ArrayBuffer]") {
4983
+ strm.input = new Uint8Array(data);
4984
+ } else {
4985
+ strm.input = data;
4986
+ }
4987
+ strm.next_in = 0;
4988
+ strm.avail_in = strm.input.length;
4989
+ for (; ; ) {
4990
+ if (strm.avail_out === 0) {
4991
+ strm.output = new Uint8Array(chunkSize);
4992
+ strm.next_out = 0;
4993
+ strm.avail_out = chunkSize;
4994
+ }
4995
+ if ((_flush_mode === Z_SYNC_FLUSH || _flush_mode === Z_FULL_FLUSH) && strm.avail_out <= 6) {
4996
+ this.onData(strm.output.subarray(0, strm.next_out));
4997
+ strm.avail_out = 0;
4998
+ continue;
4999
+ }
5000
+ status = deflate_1$2.deflate(strm, _flush_mode);
5001
+ if (status === Z_STREAM_END$2) {
5002
+ if (strm.next_out > 0) {
5003
+ this.onData(strm.output.subarray(0, strm.next_out));
5004
+ }
5005
+ status = deflate_1$2.deflateEnd(this.strm);
5006
+ this.onEnd(status);
5007
+ this.ended = true;
5008
+ return status === Z_OK$2;
5009
+ }
5010
+ if (strm.avail_out === 0) {
5011
+ this.onData(strm.output);
5012
+ continue;
5013
+ }
5014
+ if (_flush_mode > 0 && strm.next_out > 0) {
5015
+ this.onData(strm.output.subarray(0, strm.next_out));
5016
+ strm.avail_out = 0;
5017
+ continue;
5018
+ }
5019
+ if (strm.avail_in === 0) break;
5020
+ }
5021
+ return true;
5022
+ };
5023
+ Deflate$1.prototype.onData = function(chunk) {
5024
+ this.chunks.push(chunk);
5025
+ };
5026
+ Deflate$1.prototype.onEnd = function(status) {
5027
+ if (status === Z_OK$2) {
5028
+ this.result = common.flattenChunks(this.chunks);
5029
+ }
5030
+ this.chunks = [];
5031
+ this.err = status;
5032
+ this.msg = this.strm.msg;
5033
+ };
5034
+ function deflate$1(input, options) {
5035
+ const deflator = new Deflate$1(options);
5036
+ deflator.push(input, true);
5037
+ if (deflator.err) {
5038
+ throw deflator.msg || messages[deflator.err];
5039
+ }
5040
+ return deflator.result;
5041
+ }
5042
+ function deflateRaw$1(input, options) {
5043
+ options = options || {};
5044
+ options.raw = true;
5045
+ return deflate$1(input, options);
5046
+ }
5047
+ function gzip$1(input, options) {
5048
+ options = options || {};
5049
+ options.gzip = true;
5050
+ return deflate$1(input, options);
5051
+ }
5052
+ var Deflate_1$1 = Deflate$1;
5053
+ var deflate_2 = deflate$1;
5054
+ var deflateRaw_1$1 = deflateRaw$1;
5055
+ var gzip_1$1 = gzip$1;
5056
+ var constants$1 = constants$2;
5057
+ var deflate_1$1 = {
5058
+ Deflate: Deflate_1$1,
5059
+ deflate: deflate_2,
5060
+ deflateRaw: deflateRaw_1$1,
5061
+ gzip: gzip_1$1,
5062
+ constants: constants$1
5063
+ };
5064
+ var BAD$1 = 16209;
5065
+ var TYPE$1 = 16191;
5066
+ var inffast = function inflate_fast(strm, start) {
5067
+ let _in;
5068
+ let last;
5069
+ let _out;
5070
+ let beg;
5071
+ let end;
5072
+ let dmax;
5073
+ let wsize;
5074
+ let whave;
5075
+ let wnext;
5076
+ let s_window;
5077
+ let hold;
5078
+ let bits;
5079
+ let lcode;
5080
+ let dcode;
5081
+ let lmask;
5082
+ let dmask;
5083
+ let here;
5084
+ let op;
5085
+ let len2;
5086
+ let dist2;
5087
+ let from;
5088
+ let from_source;
5089
+ let input, output;
5090
+ const state = strm.state;
5091
+ _in = strm.next_in;
5092
+ input = strm.input;
5093
+ last = _in + (strm.avail_in - 5);
5094
+ _out = strm.next_out;
5095
+ output = strm.output;
5096
+ beg = _out - (start - strm.avail_out);
5097
+ end = _out + (strm.avail_out - 257);
5098
+ dmax = state.dmax;
5099
+ wsize = state.wsize;
5100
+ whave = state.whave;
5101
+ wnext = state.wnext;
5102
+ s_window = state.window;
5103
+ hold = state.hold;
5104
+ bits = state.bits;
5105
+ lcode = state.lencode;
5106
+ dcode = state.distcode;
5107
+ lmask = (1 << state.lenbits) - 1;
5108
+ dmask = (1 << state.distbits) - 1;
5109
+ top:
5110
+ do {
5111
+ if (bits < 15) {
5112
+ hold += input[_in++] << bits;
5113
+ bits += 8;
5114
+ hold += input[_in++] << bits;
5115
+ bits += 8;
5116
+ }
5117
+ here = lcode[hold & lmask];
5118
+ dolen:
5119
+ for (; ; ) {
5120
+ op = here >>> 24;
5121
+ hold >>>= op;
5122
+ bits -= op;
5123
+ op = here >>> 16 & 255;
5124
+ if (op === 0) {
5125
+ output[_out++] = here & 65535;
5126
+ } else if (op & 16) {
5127
+ len2 = here & 65535;
5128
+ op &= 15;
5129
+ if (op) {
5130
+ if (bits < op) {
5131
+ hold += input[_in++] << bits;
5132
+ bits += 8;
5133
+ }
5134
+ len2 += hold & (1 << op) - 1;
5135
+ hold >>>= op;
5136
+ bits -= op;
5137
+ }
5138
+ if (bits < 15) {
5139
+ hold += input[_in++] << bits;
5140
+ bits += 8;
5141
+ hold += input[_in++] << bits;
5142
+ bits += 8;
5143
+ }
5144
+ here = dcode[hold & dmask];
5145
+ dodist:
5146
+ for (; ; ) {
5147
+ op = here >>> 24;
5148
+ hold >>>= op;
5149
+ bits -= op;
5150
+ op = here >>> 16 & 255;
5151
+ if (op & 16) {
5152
+ dist2 = here & 65535;
5153
+ op &= 15;
5154
+ if (bits < op) {
5155
+ hold += input[_in++] << bits;
5156
+ bits += 8;
5157
+ if (bits < op) {
5158
+ hold += input[_in++] << bits;
5159
+ bits += 8;
5160
+ }
5161
+ }
5162
+ dist2 += hold & (1 << op) - 1;
5163
+ if (dist2 > dmax) {
5164
+ strm.msg = "invalid distance too far back";
5165
+ state.mode = BAD$1;
5166
+ break top;
5167
+ }
5168
+ hold >>>= op;
5169
+ bits -= op;
5170
+ op = _out - beg;
5171
+ if (dist2 > op) {
5172
+ op = dist2 - op;
5173
+ if (op > whave) {
5174
+ if (state.sane) {
5175
+ strm.msg = "invalid distance too far back";
5176
+ state.mode = BAD$1;
5177
+ break top;
5178
+ }
5179
+ }
5180
+ from = 0;
5181
+ from_source = s_window;
5182
+ if (wnext === 0) {
5183
+ from += wsize - op;
5184
+ if (op < len2) {
5185
+ len2 -= op;
5186
+ do {
5187
+ output[_out++] = s_window[from++];
5188
+ } while (--op);
5189
+ from = _out - dist2;
5190
+ from_source = output;
5191
+ }
5192
+ } else if (wnext < op) {
5193
+ from += wsize + wnext - op;
5194
+ op -= wnext;
5195
+ if (op < len2) {
5196
+ len2 -= op;
5197
+ do {
5198
+ output[_out++] = s_window[from++];
5199
+ } while (--op);
5200
+ from = 0;
5201
+ if (wnext < len2) {
5202
+ op = wnext;
5203
+ len2 -= op;
5204
+ do {
5205
+ output[_out++] = s_window[from++];
5206
+ } while (--op);
5207
+ from = _out - dist2;
5208
+ from_source = output;
5209
+ }
5210
+ }
5211
+ } else {
5212
+ from += wnext - op;
5213
+ if (op < len2) {
5214
+ len2 -= op;
5215
+ do {
5216
+ output[_out++] = s_window[from++];
5217
+ } while (--op);
5218
+ from = _out - dist2;
5219
+ from_source = output;
5220
+ }
5221
+ }
5222
+ while (len2 > 2) {
5223
+ output[_out++] = from_source[from++];
5224
+ output[_out++] = from_source[from++];
5225
+ output[_out++] = from_source[from++];
5226
+ len2 -= 3;
5227
+ }
5228
+ if (len2) {
5229
+ output[_out++] = from_source[from++];
5230
+ if (len2 > 1) {
5231
+ output[_out++] = from_source[from++];
5232
+ }
5233
+ }
5234
+ } else {
5235
+ from = _out - dist2;
5236
+ do {
5237
+ output[_out++] = output[from++];
5238
+ output[_out++] = output[from++];
5239
+ output[_out++] = output[from++];
5240
+ len2 -= 3;
5241
+ } while (len2 > 2);
5242
+ if (len2) {
5243
+ output[_out++] = output[from++];
5244
+ if (len2 > 1) {
5245
+ output[_out++] = output[from++];
5246
+ }
5247
+ }
5248
+ }
5249
+ } else if ((op & 64) === 0) {
5250
+ here = dcode[(here & 65535) + (hold & (1 << op) - 1)];
5251
+ continue dodist;
5252
+ } else {
5253
+ strm.msg = "invalid distance code";
5254
+ state.mode = BAD$1;
5255
+ break top;
5256
+ }
5257
+ break;
5258
+ }
5259
+ } else if ((op & 64) === 0) {
5260
+ here = lcode[(here & 65535) + (hold & (1 << op) - 1)];
5261
+ continue dolen;
5262
+ } else if (op & 32) {
5263
+ state.mode = TYPE$1;
5264
+ break top;
5265
+ } else {
5266
+ strm.msg = "invalid literal/length code";
5267
+ state.mode = BAD$1;
5268
+ break top;
5269
+ }
5270
+ break;
5271
+ }
5272
+ } while (_in < last && _out < end);
5273
+ len2 = bits >> 3;
5274
+ _in -= len2;
5275
+ bits -= len2 << 3;
5276
+ hold &= (1 << bits) - 1;
5277
+ strm.next_in = _in;
5278
+ strm.next_out = _out;
5279
+ strm.avail_in = _in < last ? 5 + (last - _in) : 5 - (_in - last);
5280
+ strm.avail_out = _out < end ? 257 + (end - _out) : 257 - (_out - end);
5281
+ state.hold = hold;
5282
+ state.bits = bits;
5283
+ return;
5284
+ };
5285
+ var MAXBITS = 15;
5286
+ var ENOUGH_LENS$1 = 852;
5287
+ var ENOUGH_DISTS$1 = 592;
5288
+ var CODES$1 = 0;
5289
+ var LENS$1 = 1;
5290
+ var DISTS$1 = 2;
5291
+ var lbase = new Uint16Array([
5292
+ /* Length codes 257..285 base */
5293
+ 3,
5294
+ 4,
5295
+ 5,
5296
+ 6,
5297
+ 7,
5298
+ 8,
5299
+ 9,
5300
+ 10,
5301
+ 11,
5302
+ 13,
5303
+ 15,
5304
+ 17,
5305
+ 19,
5306
+ 23,
5307
+ 27,
5308
+ 31,
5309
+ 35,
5310
+ 43,
5311
+ 51,
5312
+ 59,
5313
+ 67,
5314
+ 83,
5315
+ 99,
5316
+ 115,
5317
+ 131,
5318
+ 163,
5319
+ 195,
5320
+ 227,
5321
+ 258,
5322
+ 0,
5323
+ 0
5324
+ ]);
5325
+ var lext = new Uint8Array([
5326
+ /* Length codes 257..285 extra */
5327
+ 16,
5328
+ 16,
5329
+ 16,
5330
+ 16,
5331
+ 16,
5332
+ 16,
5333
+ 16,
5334
+ 16,
5335
+ 17,
5336
+ 17,
5337
+ 17,
5338
+ 17,
5339
+ 18,
5340
+ 18,
5341
+ 18,
5342
+ 18,
5343
+ 19,
5344
+ 19,
5345
+ 19,
5346
+ 19,
5347
+ 20,
5348
+ 20,
5349
+ 20,
5350
+ 20,
5351
+ 21,
5352
+ 21,
5353
+ 21,
5354
+ 21,
5355
+ 16,
5356
+ 72,
5357
+ 78
5358
+ ]);
5359
+ var dbase = new Uint16Array([
5360
+ /* Distance codes 0..29 base */
5361
+ 1,
5362
+ 2,
5363
+ 3,
5364
+ 4,
5365
+ 5,
5366
+ 7,
5367
+ 9,
5368
+ 13,
5369
+ 17,
5370
+ 25,
5371
+ 33,
5372
+ 49,
5373
+ 65,
5374
+ 97,
5375
+ 129,
5376
+ 193,
5377
+ 257,
5378
+ 385,
5379
+ 513,
5380
+ 769,
5381
+ 1025,
5382
+ 1537,
5383
+ 2049,
5384
+ 3073,
5385
+ 4097,
5386
+ 6145,
5387
+ 8193,
5388
+ 12289,
5389
+ 16385,
5390
+ 24577,
5391
+ 0,
5392
+ 0
5393
+ ]);
5394
+ var dext = new Uint8Array([
5395
+ /* Distance codes 0..29 extra */
5396
+ 16,
5397
+ 16,
5398
+ 16,
5399
+ 16,
5400
+ 17,
5401
+ 17,
5402
+ 18,
5403
+ 18,
5404
+ 19,
5405
+ 19,
5406
+ 20,
5407
+ 20,
5408
+ 21,
5409
+ 21,
5410
+ 22,
5411
+ 22,
5412
+ 23,
5413
+ 23,
5414
+ 24,
5415
+ 24,
5416
+ 25,
5417
+ 25,
5418
+ 26,
5419
+ 26,
5420
+ 27,
5421
+ 27,
5422
+ 28,
5423
+ 28,
5424
+ 29,
5425
+ 29,
5426
+ 64,
5427
+ 64
5428
+ ]);
5429
+ var inflate_table = (type, lens, lens_index, codes, table, table_index, work, opts) => {
5430
+ const bits = opts.bits;
5431
+ let len2 = 0;
5432
+ let sym = 0;
5433
+ let min2 = 0, max2 = 0;
5434
+ let root = 0;
5435
+ let curr = 0;
5436
+ let drop = 0;
5437
+ let left = 0;
5438
+ let used = 0;
5439
+ let huff = 0;
5440
+ let incr;
5441
+ let fill;
5442
+ let low;
5443
+ let mask;
5444
+ let next;
5445
+ let base = null;
5446
+ let match;
5447
+ const count = new Uint16Array(MAXBITS + 1);
5448
+ const offs = new Uint16Array(MAXBITS + 1);
5449
+ let extra = null;
5450
+ let here_bits, here_op, here_val;
5451
+ for (len2 = 0; len2 <= MAXBITS; len2++) {
5452
+ count[len2] = 0;
5453
+ }
5454
+ for (sym = 0; sym < codes; sym++) {
5455
+ count[lens[lens_index + sym]]++;
5456
+ }
5457
+ root = bits;
5458
+ for (max2 = MAXBITS; max2 >= 1; max2--) {
5459
+ if (count[max2] !== 0) {
5460
+ break;
5461
+ }
5462
+ }
5463
+ if (root > max2) {
5464
+ root = max2;
5465
+ }
5466
+ if (max2 === 0) {
5467
+ table[table_index++] = 1 << 24 | 64 << 16 | 0;
5468
+ table[table_index++] = 1 << 24 | 64 << 16 | 0;
5469
+ opts.bits = 1;
5470
+ return 0;
5471
+ }
5472
+ for (min2 = 1; min2 < max2; min2++) {
5473
+ if (count[min2] !== 0) {
5474
+ break;
5475
+ }
5476
+ }
5477
+ if (root < min2) {
5478
+ root = min2;
5479
+ }
5480
+ left = 1;
5481
+ for (len2 = 1; len2 <= MAXBITS; len2++) {
5482
+ left <<= 1;
5483
+ left -= count[len2];
5484
+ if (left < 0) {
5485
+ return -1;
5486
+ }
5487
+ }
5488
+ if (left > 0 && (type === CODES$1 || max2 !== 1)) {
5489
+ return -1;
5490
+ }
5491
+ offs[1] = 0;
5492
+ for (len2 = 1; len2 < MAXBITS; len2++) {
5493
+ offs[len2 + 1] = offs[len2] + count[len2];
5494
+ }
5495
+ for (sym = 0; sym < codes; sym++) {
5496
+ if (lens[lens_index + sym] !== 0) {
5497
+ work[offs[lens[lens_index + sym]]++] = sym;
5498
+ }
5499
+ }
5500
+ if (type === CODES$1) {
5501
+ base = extra = work;
5502
+ match = 20;
5503
+ } else if (type === LENS$1) {
5504
+ base = lbase;
5505
+ extra = lext;
5506
+ match = 257;
5507
+ } else {
5508
+ base = dbase;
5509
+ extra = dext;
5510
+ match = 0;
5511
+ }
5512
+ huff = 0;
5513
+ sym = 0;
5514
+ len2 = min2;
5515
+ next = table_index;
5516
+ curr = root;
5517
+ drop = 0;
5518
+ low = -1;
5519
+ used = 1 << root;
5520
+ mask = used - 1;
5521
+ if (type === LENS$1 && used > ENOUGH_LENS$1 || type === DISTS$1 && used > ENOUGH_DISTS$1) {
5522
+ return 1;
5523
+ }
5524
+ for (; ; ) {
5525
+ here_bits = len2 - drop;
5526
+ if (work[sym] + 1 < match) {
5527
+ here_op = 0;
5528
+ here_val = work[sym];
5529
+ } else if (work[sym] >= match) {
5530
+ here_op = extra[work[sym] - match];
5531
+ here_val = base[work[sym] - match];
5532
+ } else {
5533
+ here_op = 32 + 64;
5534
+ here_val = 0;
5535
+ }
5536
+ incr = 1 << len2 - drop;
5537
+ fill = 1 << curr;
5538
+ min2 = fill;
5539
+ do {
5540
+ fill -= incr;
5541
+ table[next + (huff >> drop) + fill] = here_bits << 24 | here_op << 16 | here_val | 0;
5542
+ } while (fill !== 0);
5543
+ incr = 1 << len2 - 1;
5544
+ while (huff & incr) {
5545
+ incr >>= 1;
5546
+ }
5547
+ if (incr !== 0) {
5548
+ huff &= incr - 1;
5549
+ huff += incr;
5550
+ } else {
5551
+ huff = 0;
5552
+ }
5553
+ sym++;
5554
+ if (--count[len2] === 0) {
5555
+ if (len2 === max2) {
5556
+ break;
5557
+ }
5558
+ len2 = lens[lens_index + work[sym]];
5559
+ }
5560
+ if (len2 > root && (huff & mask) !== low) {
5561
+ if (drop === 0) {
5562
+ drop = root;
5563
+ }
5564
+ next += min2;
5565
+ curr = len2 - drop;
5566
+ left = 1 << curr;
5567
+ while (curr + drop < max2) {
5568
+ left -= count[curr + drop];
5569
+ if (left <= 0) {
5570
+ break;
5571
+ }
5572
+ curr++;
5573
+ left <<= 1;
5574
+ }
5575
+ used += 1 << curr;
5576
+ if (type === LENS$1 && used > ENOUGH_LENS$1 || type === DISTS$1 && used > ENOUGH_DISTS$1) {
5577
+ return 1;
5578
+ }
5579
+ low = huff & mask;
5580
+ table[low] = root << 24 | curr << 16 | next - table_index | 0;
5581
+ }
5582
+ }
5583
+ if (huff !== 0) {
5584
+ table[next + huff] = len2 - drop << 24 | 64 << 16 | 0;
5585
+ }
5586
+ opts.bits = root;
5587
+ return 0;
5588
+ };
5589
+ var inftrees = inflate_table;
5590
+ var CODES = 0;
5591
+ var LENS = 1;
5592
+ var DISTS = 2;
5593
+ var {
5594
+ Z_FINISH: Z_FINISH$1,
5595
+ Z_BLOCK,
5596
+ Z_TREES,
5597
+ Z_OK: Z_OK$1,
5598
+ Z_STREAM_END: Z_STREAM_END$1,
5599
+ Z_NEED_DICT: Z_NEED_DICT$1,
5600
+ Z_STREAM_ERROR: Z_STREAM_ERROR$1,
5601
+ Z_DATA_ERROR: Z_DATA_ERROR$1,
5602
+ Z_MEM_ERROR: Z_MEM_ERROR$1,
5603
+ Z_BUF_ERROR,
5604
+ Z_DEFLATED
5605
+ } = constants$2;
5606
+ var HEAD = 16180;
5607
+ var FLAGS = 16181;
5608
+ var TIME = 16182;
5609
+ var OS = 16183;
5610
+ var EXLEN = 16184;
5611
+ var EXTRA = 16185;
5612
+ var NAME = 16186;
5613
+ var COMMENT = 16187;
5614
+ var HCRC = 16188;
5615
+ var DICTID = 16189;
5616
+ var DICT = 16190;
5617
+ var TYPE = 16191;
5618
+ var TYPEDO = 16192;
5619
+ var STORED = 16193;
5620
+ var COPY_ = 16194;
5621
+ var COPY = 16195;
5622
+ var TABLE = 16196;
5623
+ var LENLENS = 16197;
5624
+ var CODELENS = 16198;
5625
+ var LEN_ = 16199;
5626
+ var LEN = 16200;
5627
+ var LENEXT = 16201;
5628
+ var DIST = 16202;
5629
+ var DISTEXT = 16203;
5630
+ var MATCH = 16204;
5631
+ var LIT = 16205;
5632
+ var CHECK = 16206;
5633
+ var LENGTH = 16207;
5634
+ var DONE = 16208;
5635
+ var BAD = 16209;
5636
+ var MEM = 16210;
5637
+ var SYNC = 16211;
5638
+ var ENOUGH_LENS = 852;
5639
+ var ENOUGH_DISTS = 592;
5640
+ var MAX_WBITS = 15;
5641
+ var DEF_WBITS = MAX_WBITS;
5642
+ var zswap32 = (q) => {
5643
+ return (q >>> 24 & 255) + (q >>> 8 & 65280) + ((q & 65280) << 8) + ((q & 255) << 24);
5644
+ };
5645
+ function InflateState() {
5646
+ this.strm = null;
5647
+ this.mode = 0;
5648
+ this.last = false;
5649
+ this.wrap = 0;
5650
+ this.havedict = false;
5651
+ this.flags = 0;
5652
+ this.dmax = 0;
5653
+ this.check = 0;
5654
+ this.total = 0;
5655
+ this.head = null;
5656
+ this.wbits = 0;
5657
+ this.wsize = 0;
5658
+ this.whave = 0;
5659
+ this.wnext = 0;
5660
+ this.window = null;
5661
+ this.hold = 0;
5662
+ this.bits = 0;
5663
+ this.length = 0;
5664
+ this.offset = 0;
5665
+ this.extra = 0;
5666
+ this.lencode = null;
5667
+ this.distcode = null;
5668
+ this.lenbits = 0;
5669
+ this.distbits = 0;
5670
+ this.ncode = 0;
5671
+ this.nlen = 0;
5672
+ this.ndist = 0;
5673
+ this.have = 0;
5674
+ this.next = null;
5675
+ this.lens = new Uint16Array(320);
5676
+ this.work = new Uint16Array(288);
5677
+ this.lendyn = null;
5678
+ this.distdyn = null;
5679
+ this.sane = 0;
5680
+ this.back = 0;
5681
+ this.was = 0;
5682
+ }
5683
+ var inflateStateCheck = (strm) => {
5684
+ if (!strm) {
5685
+ return 1;
5686
+ }
5687
+ const state = strm.state;
5688
+ if (!state || state.strm !== strm || state.mode < HEAD || state.mode > SYNC) {
5689
+ return 1;
5690
+ }
5691
+ return 0;
5692
+ };
5693
+ var inflateResetKeep = (strm) => {
5694
+ if (inflateStateCheck(strm)) {
5695
+ return Z_STREAM_ERROR$1;
5696
+ }
5697
+ const state = strm.state;
5698
+ strm.total_in = strm.total_out = state.total = 0;
5699
+ strm.msg = "";
5700
+ if (state.wrap) {
5701
+ strm.adler = state.wrap & 1;
5702
+ }
5703
+ state.mode = HEAD;
5704
+ state.last = 0;
5705
+ state.havedict = 0;
5706
+ state.flags = -1;
5707
+ state.dmax = 32768;
5708
+ state.head = null;
5709
+ state.hold = 0;
5710
+ state.bits = 0;
5711
+ state.lencode = state.lendyn = new Int32Array(ENOUGH_LENS);
5712
+ state.distcode = state.distdyn = new Int32Array(ENOUGH_DISTS);
5713
+ state.sane = 1;
5714
+ state.back = -1;
5715
+ return Z_OK$1;
5716
+ };
5717
+ var inflateReset = (strm) => {
5718
+ if (inflateStateCheck(strm)) {
5719
+ return Z_STREAM_ERROR$1;
5720
+ }
5721
+ const state = strm.state;
5722
+ state.wsize = 0;
5723
+ state.whave = 0;
5724
+ state.wnext = 0;
5725
+ return inflateResetKeep(strm);
5726
+ };
5727
+ var inflateReset2 = (strm, windowBits) => {
5728
+ let wrap;
5729
+ if (inflateStateCheck(strm)) {
5730
+ return Z_STREAM_ERROR$1;
5731
+ }
5732
+ const state = strm.state;
5733
+ if (windowBits < 0) {
5734
+ wrap = 0;
5735
+ windowBits = -windowBits;
5736
+ } else {
5737
+ wrap = (windowBits >> 4) + 5;
5738
+ if (windowBits < 48) {
5739
+ windowBits &= 15;
5740
+ }
5741
+ }
5742
+ if (windowBits && (windowBits < 8 || windowBits > 15)) {
5743
+ return Z_STREAM_ERROR$1;
5744
+ }
5745
+ if (state.window !== null && state.wbits !== windowBits) {
5746
+ state.window = null;
5747
+ }
5748
+ state.wrap = wrap;
5749
+ state.wbits = windowBits;
5750
+ return inflateReset(strm);
5751
+ };
5752
+ var inflateInit2 = (strm, windowBits) => {
5753
+ if (!strm) {
5754
+ return Z_STREAM_ERROR$1;
5755
+ }
5756
+ const state = new InflateState();
5757
+ strm.state = state;
5758
+ state.strm = strm;
5759
+ state.window = null;
5760
+ state.mode = HEAD;
5761
+ const ret = inflateReset2(strm, windowBits);
5762
+ if (ret !== Z_OK$1) {
5763
+ strm.state = null;
5764
+ }
5765
+ return ret;
5766
+ };
5767
+ var inflateInit = (strm) => {
5768
+ return inflateInit2(strm, DEF_WBITS);
5769
+ };
5770
+ var virgin = true;
5771
+ var lenfix;
5772
+ var distfix;
5773
+ var fixedtables = (state) => {
5774
+ if (virgin) {
5775
+ lenfix = new Int32Array(512);
5776
+ distfix = new Int32Array(32);
5777
+ let sym = 0;
5778
+ while (sym < 144) {
5779
+ state.lens[sym++] = 8;
5780
+ }
5781
+ while (sym < 256) {
5782
+ state.lens[sym++] = 9;
5783
+ }
5784
+ while (sym < 280) {
5785
+ state.lens[sym++] = 7;
5786
+ }
5787
+ while (sym < 288) {
5788
+ state.lens[sym++] = 8;
5789
+ }
5790
+ inftrees(LENS, state.lens, 0, 288, lenfix, 0, state.work, { bits: 9 });
5791
+ sym = 0;
5792
+ while (sym < 32) {
5793
+ state.lens[sym++] = 5;
5794
+ }
5795
+ inftrees(DISTS, state.lens, 0, 32, distfix, 0, state.work, { bits: 5 });
5796
+ virgin = false;
5797
+ }
5798
+ state.lencode = lenfix;
5799
+ state.lenbits = 9;
5800
+ state.distcode = distfix;
5801
+ state.distbits = 5;
5802
+ };
5803
+ var updatewindow = (strm, src, end, copy3) => {
5804
+ let dist2;
5805
+ const state = strm.state;
5806
+ if (state.window === null) {
5807
+ state.wsize = 1 << state.wbits;
5808
+ state.wnext = 0;
5809
+ state.whave = 0;
5810
+ state.window = new Uint8Array(state.wsize);
5811
+ }
5812
+ if (copy3 >= state.wsize) {
5813
+ state.window.set(src.subarray(end - state.wsize, end), 0);
5814
+ state.wnext = 0;
5815
+ state.whave = state.wsize;
5816
+ } else {
5817
+ dist2 = state.wsize - state.wnext;
5818
+ if (dist2 > copy3) {
5819
+ dist2 = copy3;
5820
+ }
5821
+ state.window.set(src.subarray(end - copy3, end - copy3 + dist2), state.wnext);
5822
+ copy3 -= dist2;
5823
+ if (copy3) {
5824
+ state.window.set(src.subarray(end - copy3, end), 0);
5825
+ state.wnext = copy3;
5826
+ state.whave = state.wsize;
5827
+ } else {
5828
+ state.wnext += dist2;
5829
+ if (state.wnext === state.wsize) {
5830
+ state.wnext = 0;
5831
+ }
5832
+ if (state.whave < state.wsize) {
5833
+ state.whave += dist2;
5834
+ }
5835
+ }
5836
+ }
5837
+ return 0;
5838
+ };
5839
+ var inflate$2 = (strm, flush) => {
5840
+ let state;
5841
+ let input, output;
5842
+ let next;
5843
+ let put;
5844
+ let have, left;
5845
+ let hold;
5846
+ let bits;
5847
+ let _in, _out;
5848
+ let copy3;
5849
+ let from;
5850
+ let from_source;
5851
+ let here = 0;
5852
+ let here_bits, here_op, here_val;
5853
+ let last_bits, last_op, last_val;
5854
+ let len2;
5855
+ let ret;
5856
+ const hbuf = new Uint8Array(4);
5857
+ let opts;
5858
+ let n;
5859
+ const order = (
5860
+ /* permutation of code lengths */
5861
+ new Uint8Array([16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15])
5862
+ );
5863
+ if (inflateStateCheck(strm) || !strm.output || !strm.input && strm.avail_in !== 0) {
5864
+ return Z_STREAM_ERROR$1;
5865
+ }
5866
+ state = strm.state;
5867
+ if (state.mode === TYPE) {
5868
+ state.mode = TYPEDO;
5869
+ }
5870
+ put = strm.next_out;
5871
+ output = strm.output;
5872
+ left = strm.avail_out;
5873
+ next = strm.next_in;
5874
+ input = strm.input;
5875
+ have = strm.avail_in;
5876
+ hold = state.hold;
5877
+ bits = state.bits;
5878
+ _in = have;
5879
+ _out = left;
5880
+ ret = Z_OK$1;
5881
+ inf_leave:
5882
+ for (; ; ) {
5883
+ switch (state.mode) {
5884
+ case HEAD:
5885
+ if (state.wrap === 0) {
5886
+ state.mode = TYPEDO;
5887
+ break;
5888
+ }
5889
+ while (bits < 16) {
5890
+ if (have === 0) {
5891
+ break inf_leave;
5892
+ }
5893
+ have--;
5894
+ hold += input[next++] << bits;
5895
+ bits += 8;
5896
+ }
5897
+ if (state.wrap & 2 && hold === 35615) {
5898
+ if (state.wbits === 0) {
5899
+ state.wbits = 15;
5900
+ }
5901
+ state.check = 0;
5902
+ hbuf[0] = hold & 255;
5903
+ hbuf[1] = hold >>> 8 & 255;
5904
+ state.check = crc32_1(state.check, hbuf, 2, 0);
5905
+ hold = 0;
5906
+ bits = 0;
5907
+ state.mode = FLAGS;
5908
+ break;
5909
+ }
5910
+ if (state.head) {
5911
+ state.head.done = false;
5912
+ }
5913
+ if (!(state.wrap & 1) || /* check if zlib header allowed */
5914
+ (((hold & 255) << 8) + (hold >> 8)) % 31) {
5915
+ strm.msg = "incorrect header check";
5916
+ state.mode = BAD;
5917
+ break;
5918
+ }
5919
+ if ((hold & 15) !== Z_DEFLATED) {
5920
+ strm.msg = "unknown compression method";
5921
+ state.mode = BAD;
5922
+ break;
5923
+ }
5924
+ hold >>>= 4;
5925
+ bits -= 4;
5926
+ len2 = (hold & 15) + 8;
5927
+ if (state.wbits === 0) {
5928
+ state.wbits = len2;
5929
+ }
5930
+ if (len2 > 15 || len2 > state.wbits) {
5931
+ strm.msg = "invalid window size";
5932
+ state.mode = BAD;
5933
+ break;
5934
+ }
5935
+ state.dmax = 1 << state.wbits;
5936
+ state.flags = 0;
5937
+ strm.adler = state.check = 1;
5938
+ state.mode = hold & 512 ? DICTID : TYPE;
5939
+ hold = 0;
5940
+ bits = 0;
5941
+ break;
5942
+ case FLAGS:
5943
+ while (bits < 16) {
5944
+ if (have === 0) {
5945
+ break inf_leave;
5946
+ }
5947
+ have--;
5948
+ hold += input[next++] << bits;
5949
+ bits += 8;
5950
+ }
5951
+ state.flags = hold;
5952
+ if ((state.flags & 255) !== Z_DEFLATED) {
5953
+ strm.msg = "unknown compression method";
5954
+ state.mode = BAD;
5955
+ break;
5956
+ }
5957
+ if (state.flags & 57344) {
5958
+ strm.msg = "unknown header flags set";
5959
+ state.mode = BAD;
5960
+ break;
5961
+ }
5962
+ if (state.head) {
5963
+ state.head.text = hold >> 8 & 1;
5964
+ }
5965
+ if (state.flags & 512 && state.wrap & 4) {
5966
+ hbuf[0] = hold & 255;
5967
+ hbuf[1] = hold >>> 8 & 255;
5968
+ state.check = crc32_1(state.check, hbuf, 2, 0);
5969
+ }
5970
+ hold = 0;
5971
+ bits = 0;
5972
+ state.mode = TIME;
5973
+ /* falls through */
5974
+ case TIME:
5975
+ while (bits < 32) {
5976
+ if (have === 0) {
5977
+ break inf_leave;
5978
+ }
5979
+ have--;
5980
+ hold += input[next++] << bits;
5981
+ bits += 8;
5982
+ }
5983
+ if (state.head) {
5984
+ state.head.time = hold;
5985
+ }
5986
+ if (state.flags & 512 && state.wrap & 4) {
5987
+ hbuf[0] = hold & 255;
5988
+ hbuf[1] = hold >>> 8 & 255;
5989
+ hbuf[2] = hold >>> 16 & 255;
5990
+ hbuf[3] = hold >>> 24 & 255;
5991
+ state.check = crc32_1(state.check, hbuf, 4, 0);
5992
+ }
5993
+ hold = 0;
5994
+ bits = 0;
5995
+ state.mode = OS;
5996
+ /* falls through */
5997
+ case OS:
5998
+ while (bits < 16) {
5999
+ if (have === 0) {
6000
+ break inf_leave;
6001
+ }
6002
+ have--;
6003
+ hold += input[next++] << bits;
6004
+ bits += 8;
6005
+ }
6006
+ if (state.head) {
6007
+ state.head.xflags = hold & 255;
6008
+ state.head.os = hold >> 8;
6009
+ }
6010
+ if (state.flags & 512 && state.wrap & 4) {
6011
+ hbuf[0] = hold & 255;
6012
+ hbuf[1] = hold >>> 8 & 255;
6013
+ state.check = crc32_1(state.check, hbuf, 2, 0);
6014
+ }
6015
+ hold = 0;
6016
+ bits = 0;
6017
+ state.mode = EXLEN;
6018
+ /* falls through */
6019
+ case EXLEN:
6020
+ if (state.flags & 1024) {
6021
+ while (bits < 16) {
6022
+ if (have === 0) {
6023
+ break inf_leave;
6024
+ }
6025
+ have--;
6026
+ hold += input[next++] << bits;
6027
+ bits += 8;
6028
+ }
6029
+ state.length = hold;
6030
+ if (state.head) {
6031
+ state.head.extra_len = hold;
6032
+ }
6033
+ if (state.flags & 512 && state.wrap & 4) {
6034
+ hbuf[0] = hold & 255;
6035
+ hbuf[1] = hold >>> 8 & 255;
6036
+ state.check = crc32_1(state.check, hbuf, 2, 0);
6037
+ }
6038
+ hold = 0;
6039
+ bits = 0;
6040
+ } else if (state.head) {
6041
+ state.head.extra = null;
6042
+ }
6043
+ state.mode = EXTRA;
6044
+ /* falls through */
6045
+ case EXTRA:
6046
+ if (state.flags & 1024) {
6047
+ copy3 = state.length;
6048
+ if (copy3 > have) {
6049
+ copy3 = have;
6050
+ }
6051
+ if (copy3) {
6052
+ if (state.head) {
6053
+ len2 = state.head.extra_len - state.length;
6054
+ if (!state.head.extra) {
6055
+ state.head.extra = new Uint8Array(state.head.extra_len);
6056
+ }
6057
+ state.head.extra.set(
6058
+ input.subarray(
6059
+ next,
6060
+ // extra field is limited to 65536 bytes
6061
+ // - no need for additional size check
6062
+ next + copy3
6063
+ ),
6064
+ /*len + copy > state.head.extra_max - len ? state.head.extra_max : copy,*/
6065
+ len2
6066
+ );
6067
+ }
6068
+ if (state.flags & 512 && state.wrap & 4) {
6069
+ state.check = crc32_1(state.check, input, copy3, next);
6070
+ }
6071
+ have -= copy3;
6072
+ next += copy3;
6073
+ state.length -= copy3;
6074
+ }
6075
+ if (state.length) {
6076
+ break inf_leave;
6077
+ }
6078
+ }
6079
+ state.length = 0;
6080
+ state.mode = NAME;
6081
+ /* falls through */
6082
+ case NAME:
6083
+ if (state.flags & 2048) {
6084
+ if (have === 0) {
6085
+ break inf_leave;
6086
+ }
6087
+ copy3 = 0;
6088
+ do {
6089
+ len2 = input[next + copy3++];
6090
+ if (state.head && len2 && state.length < 65536) {
6091
+ state.head.name += String.fromCharCode(len2);
6092
+ }
6093
+ } while (len2 && copy3 < have);
6094
+ if (state.flags & 512 && state.wrap & 4) {
6095
+ state.check = crc32_1(state.check, input, copy3, next);
6096
+ }
6097
+ have -= copy3;
6098
+ next += copy3;
6099
+ if (len2) {
6100
+ break inf_leave;
6101
+ }
6102
+ } else if (state.head) {
6103
+ state.head.name = null;
6104
+ }
6105
+ state.length = 0;
6106
+ state.mode = COMMENT;
6107
+ /* falls through */
6108
+ case COMMENT:
6109
+ if (state.flags & 4096) {
6110
+ if (have === 0) {
6111
+ break inf_leave;
6112
+ }
6113
+ copy3 = 0;
6114
+ do {
6115
+ len2 = input[next + copy3++];
6116
+ if (state.head && len2 && state.length < 65536) {
6117
+ state.head.comment += String.fromCharCode(len2);
6118
+ }
6119
+ } while (len2 && copy3 < have);
6120
+ if (state.flags & 512 && state.wrap & 4) {
6121
+ state.check = crc32_1(state.check, input, copy3, next);
6122
+ }
6123
+ have -= copy3;
6124
+ next += copy3;
6125
+ if (len2) {
6126
+ break inf_leave;
6127
+ }
6128
+ } else if (state.head) {
6129
+ state.head.comment = null;
6130
+ }
6131
+ state.mode = HCRC;
6132
+ /* falls through */
6133
+ case HCRC:
6134
+ if (state.flags & 512) {
6135
+ while (bits < 16) {
6136
+ if (have === 0) {
6137
+ break inf_leave;
6138
+ }
6139
+ have--;
6140
+ hold += input[next++] << bits;
6141
+ bits += 8;
6142
+ }
6143
+ if (state.wrap & 4 && hold !== (state.check & 65535)) {
6144
+ strm.msg = "header crc mismatch";
6145
+ state.mode = BAD;
6146
+ break;
6147
+ }
6148
+ hold = 0;
6149
+ bits = 0;
6150
+ }
6151
+ if (state.head) {
6152
+ state.head.hcrc = state.flags >> 9 & 1;
6153
+ state.head.done = true;
6154
+ }
6155
+ strm.adler = state.check = 0;
6156
+ state.mode = TYPE;
6157
+ break;
6158
+ case DICTID:
6159
+ while (bits < 32) {
6160
+ if (have === 0) {
6161
+ break inf_leave;
6162
+ }
6163
+ have--;
6164
+ hold += input[next++] << bits;
6165
+ bits += 8;
6166
+ }
6167
+ strm.adler = state.check = zswap32(hold);
6168
+ hold = 0;
6169
+ bits = 0;
6170
+ state.mode = DICT;
6171
+ /* falls through */
6172
+ case DICT:
6173
+ if (state.havedict === 0) {
6174
+ strm.next_out = put;
6175
+ strm.avail_out = left;
6176
+ strm.next_in = next;
6177
+ strm.avail_in = have;
6178
+ state.hold = hold;
6179
+ state.bits = bits;
6180
+ return Z_NEED_DICT$1;
6181
+ }
6182
+ strm.adler = state.check = 1;
6183
+ state.mode = TYPE;
6184
+ /* falls through */
6185
+ case TYPE:
6186
+ if (flush === Z_BLOCK || flush === Z_TREES) {
6187
+ break inf_leave;
6188
+ }
6189
+ /* falls through */
6190
+ case TYPEDO:
6191
+ if (state.last) {
6192
+ hold >>>= bits & 7;
6193
+ bits -= bits & 7;
6194
+ state.mode = CHECK;
6195
+ break;
6196
+ }
6197
+ while (bits < 3) {
6198
+ if (have === 0) {
6199
+ break inf_leave;
6200
+ }
6201
+ have--;
6202
+ hold += input[next++] << bits;
6203
+ bits += 8;
6204
+ }
6205
+ state.last = hold & 1;
6206
+ hold >>>= 1;
6207
+ bits -= 1;
6208
+ switch (hold & 3) {
6209
+ case 0:
6210
+ state.mode = STORED;
6211
+ break;
6212
+ case 1:
6213
+ fixedtables(state);
6214
+ state.mode = LEN_;
6215
+ if (flush === Z_TREES) {
6216
+ hold >>>= 2;
6217
+ bits -= 2;
6218
+ break inf_leave;
6219
+ }
6220
+ break;
6221
+ case 2:
6222
+ state.mode = TABLE;
6223
+ break;
6224
+ case 3:
6225
+ strm.msg = "invalid block type";
6226
+ state.mode = BAD;
6227
+ }
6228
+ hold >>>= 2;
6229
+ bits -= 2;
6230
+ break;
6231
+ case STORED:
6232
+ hold >>>= bits & 7;
6233
+ bits -= bits & 7;
6234
+ while (bits < 32) {
6235
+ if (have === 0) {
6236
+ break inf_leave;
6237
+ }
6238
+ have--;
6239
+ hold += input[next++] << bits;
6240
+ bits += 8;
6241
+ }
6242
+ if ((hold & 65535) !== (hold >>> 16 ^ 65535)) {
6243
+ strm.msg = "invalid stored block lengths";
6244
+ state.mode = BAD;
6245
+ break;
6246
+ }
6247
+ state.length = hold & 65535;
6248
+ hold = 0;
6249
+ bits = 0;
6250
+ state.mode = COPY_;
6251
+ if (flush === Z_TREES) {
6252
+ break inf_leave;
6253
+ }
6254
+ /* falls through */
6255
+ case COPY_:
6256
+ state.mode = COPY;
6257
+ /* falls through */
6258
+ case COPY:
6259
+ copy3 = state.length;
6260
+ if (copy3) {
6261
+ if (copy3 > have) {
6262
+ copy3 = have;
6263
+ }
6264
+ if (copy3 > left) {
6265
+ copy3 = left;
6266
+ }
6267
+ if (copy3 === 0) {
6268
+ break inf_leave;
6269
+ }
6270
+ output.set(input.subarray(next, next + copy3), put);
6271
+ have -= copy3;
6272
+ next += copy3;
6273
+ left -= copy3;
6274
+ put += copy3;
6275
+ state.length -= copy3;
6276
+ break;
6277
+ }
6278
+ state.mode = TYPE;
6279
+ break;
6280
+ case TABLE:
6281
+ while (bits < 14) {
6282
+ if (have === 0) {
6283
+ break inf_leave;
6284
+ }
6285
+ have--;
6286
+ hold += input[next++] << bits;
6287
+ bits += 8;
6288
+ }
6289
+ state.nlen = (hold & 31) + 257;
6290
+ hold >>>= 5;
6291
+ bits -= 5;
6292
+ state.ndist = (hold & 31) + 1;
6293
+ hold >>>= 5;
6294
+ bits -= 5;
6295
+ state.ncode = (hold & 15) + 4;
6296
+ hold >>>= 4;
6297
+ bits -= 4;
6298
+ if (state.nlen > 286 || state.ndist > 30) {
6299
+ strm.msg = "too many length or distance symbols";
6300
+ state.mode = BAD;
6301
+ break;
6302
+ }
6303
+ state.have = 0;
6304
+ state.mode = LENLENS;
6305
+ /* falls through */
6306
+ case LENLENS:
6307
+ while (state.have < state.ncode) {
6308
+ while (bits < 3) {
6309
+ if (have === 0) {
6310
+ break inf_leave;
6311
+ }
6312
+ have--;
6313
+ hold += input[next++] << bits;
6314
+ bits += 8;
6315
+ }
6316
+ state.lens[order[state.have++]] = hold & 7;
6317
+ hold >>>= 3;
6318
+ bits -= 3;
6319
+ }
6320
+ while (state.have < 19) {
6321
+ state.lens[order[state.have++]] = 0;
6322
+ }
6323
+ state.lencode = state.lendyn;
6324
+ state.lenbits = 7;
6325
+ opts = { bits: state.lenbits };
6326
+ ret = inftrees(CODES, state.lens, 0, 19, state.lencode, 0, state.work, opts);
6327
+ state.lenbits = opts.bits;
6328
+ if (ret) {
6329
+ strm.msg = "invalid code lengths set";
6330
+ state.mode = BAD;
6331
+ break;
6332
+ }
6333
+ state.have = 0;
6334
+ state.mode = CODELENS;
6335
+ /* falls through */
6336
+ case CODELENS:
6337
+ while (state.have < state.nlen + state.ndist) {
6338
+ for (; ; ) {
6339
+ here = state.lencode[hold & (1 << state.lenbits) - 1];
6340
+ here_bits = here >>> 24;
6341
+ here_op = here >>> 16 & 255;
6342
+ here_val = here & 65535;
6343
+ if (here_bits <= bits) {
6344
+ break;
6345
+ }
6346
+ if (have === 0) {
6347
+ break inf_leave;
6348
+ }
6349
+ have--;
6350
+ hold += input[next++] << bits;
6351
+ bits += 8;
6352
+ }
6353
+ if (here_val < 16) {
6354
+ hold >>>= here_bits;
6355
+ bits -= here_bits;
6356
+ state.lens[state.have++] = here_val;
6357
+ } else {
6358
+ if (here_val === 16) {
6359
+ n = here_bits + 2;
6360
+ while (bits < n) {
6361
+ if (have === 0) {
6362
+ break inf_leave;
6363
+ }
6364
+ have--;
6365
+ hold += input[next++] << bits;
6366
+ bits += 8;
6367
+ }
6368
+ hold >>>= here_bits;
6369
+ bits -= here_bits;
6370
+ if (state.have === 0) {
6371
+ strm.msg = "invalid bit length repeat";
6372
+ state.mode = BAD;
6373
+ break;
6374
+ }
6375
+ len2 = state.lens[state.have - 1];
6376
+ copy3 = 3 + (hold & 3);
6377
+ hold >>>= 2;
6378
+ bits -= 2;
6379
+ } else if (here_val === 17) {
6380
+ n = here_bits + 3;
6381
+ while (bits < n) {
6382
+ if (have === 0) {
6383
+ break inf_leave;
6384
+ }
6385
+ have--;
6386
+ hold += input[next++] << bits;
6387
+ bits += 8;
6388
+ }
6389
+ hold >>>= here_bits;
6390
+ bits -= here_bits;
6391
+ len2 = 0;
6392
+ copy3 = 3 + (hold & 7);
6393
+ hold >>>= 3;
6394
+ bits -= 3;
6395
+ } else {
6396
+ n = here_bits + 7;
6397
+ while (bits < n) {
6398
+ if (have === 0) {
6399
+ break inf_leave;
6400
+ }
6401
+ have--;
6402
+ hold += input[next++] << bits;
6403
+ bits += 8;
6404
+ }
6405
+ hold >>>= here_bits;
6406
+ bits -= here_bits;
6407
+ len2 = 0;
6408
+ copy3 = 11 + (hold & 127);
6409
+ hold >>>= 7;
6410
+ bits -= 7;
6411
+ }
6412
+ if (state.have + copy3 > state.nlen + state.ndist) {
6413
+ strm.msg = "invalid bit length repeat";
6414
+ state.mode = BAD;
6415
+ break;
6416
+ }
6417
+ while (copy3--) {
6418
+ state.lens[state.have++] = len2;
6419
+ }
6420
+ }
6421
+ }
6422
+ if (state.mode === BAD) {
6423
+ break;
6424
+ }
6425
+ if (state.lens[256] === 0) {
6426
+ strm.msg = "invalid code -- missing end-of-block";
6427
+ state.mode = BAD;
6428
+ break;
6429
+ }
6430
+ state.lenbits = 9;
6431
+ opts = { bits: state.lenbits };
6432
+ ret = inftrees(LENS, state.lens, 0, state.nlen, state.lencode, 0, state.work, opts);
6433
+ state.lenbits = opts.bits;
6434
+ if (ret) {
6435
+ strm.msg = "invalid literal/lengths set";
6436
+ state.mode = BAD;
6437
+ break;
6438
+ }
6439
+ state.distbits = 6;
6440
+ state.distcode = state.distdyn;
6441
+ opts = { bits: state.distbits };
6442
+ ret = inftrees(DISTS, state.lens, state.nlen, state.ndist, state.distcode, 0, state.work, opts);
6443
+ state.distbits = opts.bits;
6444
+ if (ret) {
6445
+ strm.msg = "invalid distances set";
6446
+ state.mode = BAD;
6447
+ break;
6448
+ }
6449
+ state.mode = LEN_;
6450
+ if (flush === Z_TREES) {
6451
+ break inf_leave;
6452
+ }
6453
+ /* falls through */
6454
+ case LEN_:
6455
+ state.mode = LEN;
6456
+ /* falls through */
6457
+ case LEN:
6458
+ if (have >= 6 && left >= 258) {
6459
+ strm.next_out = put;
6460
+ strm.avail_out = left;
6461
+ strm.next_in = next;
6462
+ strm.avail_in = have;
6463
+ state.hold = hold;
6464
+ state.bits = bits;
6465
+ inffast(strm, _out);
6466
+ put = strm.next_out;
6467
+ output = strm.output;
6468
+ left = strm.avail_out;
6469
+ next = strm.next_in;
6470
+ input = strm.input;
6471
+ have = strm.avail_in;
6472
+ hold = state.hold;
6473
+ bits = state.bits;
6474
+ if (state.mode === TYPE) {
6475
+ state.back = -1;
6476
+ }
6477
+ break;
6478
+ }
6479
+ state.back = 0;
6480
+ for (; ; ) {
6481
+ here = state.lencode[hold & (1 << state.lenbits) - 1];
6482
+ here_bits = here >>> 24;
6483
+ here_op = here >>> 16 & 255;
6484
+ here_val = here & 65535;
6485
+ if (here_bits <= bits) {
6486
+ break;
6487
+ }
6488
+ if (have === 0) {
6489
+ break inf_leave;
6490
+ }
6491
+ have--;
6492
+ hold += input[next++] << bits;
6493
+ bits += 8;
6494
+ }
6495
+ if (here_op && (here_op & 240) === 0) {
6496
+ last_bits = here_bits;
6497
+ last_op = here_op;
6498
+ last_val = here_val;
6499
+ for (; ; ) {
6500
+ here = state.lencode[last_val + ((hold & (1 << last_bits + last_op) - 1) >> last_bits)];
6501
+ here_bits = here >>> 24;
6502
+ here_op = here >>> 16 & 255;
6503
+ here_val = here & 65535;
6504
+ if (last_bits + here_bits <= bits) {
6505
+ break;
6506
+ }
6507
+ if (have === 0) {
6508
+ break inf_leave;
6509
+ }
6510
+ have--;
6511
+ hold += input[next++] << bits;
6512
+ bits += 8;
6513
+ }
6514
+ hold >>>= last_bits;
6515
+ bits -= last_bits;
6516
+ state.back += last_bits;
6517
+ }
6518
+ hold >>>= here_bits;
6519
+ bits -= here_bits;
6520
+ state.back += here_bits;
6521
+ state.length = here_val;
6522
+ if (here_op === 0) {
6523
+ state.mode = LIT;
6524
+ break;
6525
+ }
6526
+ if (here_op & 32) {
6527
+ state.back = -1;
6528
+ state.mode = TYPE;
6529
+ break;
6530
+ }
6531
+ if (here_op & 64) {
6532
+ strm.msg = "invalid literal/length code";
6533
+ state.mode = BAD;
6534
+ break;
6535
+ }
6536
+ state.extra = here_op & 15;
6537
+ state.mode = LENEXT;
6538
+ /* falls through */
6539
+ case LENEXT:
6540
+ if (state.extra) {
6541
+ n = state.extra;
6542
+ while (bits < n) {
6543
+ if (have === 0) {
6544
+ break inf_leave;
6545
+ }
6546
+ have--;
6547
+ hold += input[next++] << bits;
6548
+ bits += 8;
6549
+ }
6550
+ state.length += hold & (1 << state.extra) - 1;
6551
+ hold >>>= state.extra;
6552
+ bits -= state.extra;
6553
+ state.back += state.extra;
6554
+ }
6555
+ state.was = state.length;
6556
+ state.mode = DIST;
6557
+ /* falls through */
6558
+ case DIST:
6559
+ for (; ; ) {
6560
+ here = state.distcode[hold & (1 << state.distbits) - 1];
6561
+ here_bits = here >>> 24;
6562
+ here_op = here >>> 16 & 255;
6563
+ here_val = here & 65535;
6564
+ if (here_bits <= bits) {
6565
+ break;
6566
+ }
6567
+ if (have === 0) {
6568
+ break inf_leave;
6569
+ }
6570
+ have--;
6571
+ hold += input[next++] << bits;
6572
+ bits += 8;
6573
+ }
6574
+ if ((here_op & 240) === 0) {
6575
+ last_bits = here_bits;
6576
+ last_op = here_op;
6577
+ last_val = here_val;
6578
+ for (; ; ) {
6579
+ here = state.distcode[last_val + ((hold & (1 << last_bits + last_op) - 1) >> last_bits)];
6580
+ here_bits = here >>> 24;
6581
+ here_op = here >>> 16 & 255;
6582
+ here_val = here & 65535;
6583
+ if (last_bits + here_bits <= bits) {
6584
+ break;
6585
+ }
6586
+ if (have === 0) {
6587
+ break inf_leave;
6588
+ }
6589
+ have--;
6590
+ hold += input[next++] << bits;
6591
+ bits += 8;
6592
+ }
6593
+ hold >>>= last_bits;
6594
+ bits -= last_bits;
6595
+ state.back += last_bits;
6596
+ }
6597
+ hold >>>= here_bits;
6598
+ bits -= here_bits;
6599
+ state.back += here_bits;
6600
+ if (here_op & 64) {
6601
+ strm.msg = "invalid distance code";
6602
+ state.mode = BAD;
6603
+ break;
6604
+ }
6605
+ state.offset = here_val;
6606
+ state.extra = here_op & 15;
6607
+ state.mode = DISTEXT;
6608
+ /* falls through */
6609
+ case DISTEXT:
6610
+ if (state.extra) {
6611
+ n = state.extra;
6612
+ while (bits < n) {
6613
+ if (have === 0) {
6614
+ break inf_leave;
6615
+ }
6616
+ have--;
6617
+ hold += input[next++] << bits;
6618
+ bits += 8;
6619
+ }
6620
+ state.offset += hold & (1 << state.extra) - 1;
6621
+ hold >>>= state.extra;
6622
+ bits -= state.extra;
6623
+ state.back += state.extra;
6624
+ }
6625
+ if (state.offset > state.dmax) {
6626
+ strm.msg = "invalid distance too far back";
6627
+ state.mode = BAD;
6628
+ break;
6629
+ }
6630
+ state.mode = MATCH;
6631
+ /* falls through */
6632
+ case MATCH:
6633
+ if (left === 0) {
6634
+ break inf_leave;
6635
+ }
6636
+ copy3 = _out - left;
6637
+ if (state.offset > copy3) {
6638
+ copy3 = state.offset - copy3;
6639
+ if (copy3 > state.whave) {
6640
+ if (state.sane) {
6641
+ strm.msg = "invalid distance too far back";
6642
+ state.mode = BAD;
6643
+ break;
6644
+ }
6645
+ }
6646
+ if (copy3 > state.wnext) {
6647
+ copy3 -= state.wnext;
6648
+ from = state.wsize - copy3;
6649
+ } else {
6650
+ from = state.wnext - copy3;
6651
+ }
6652
+ if (copy3 > state.length) {
6653
+ copy3 = state.length;
6654
+ }
6655
+ from_source = state.window;
6656
+ } else {
6657
+ from_source = output;
6658
+ from = put - state.offset;
6659
+ copy3 = state.length;
6660
+ }
6661
+ if (copy3 > left) {
6662
+ copy3 = left;
6663
+ }
6664
+ left -= copy3;
6665
+ state.length -= copy3;
6666
+ do {
6667
+ output[put++] = from_source[from++];
6668
+ } while (--copy3);
6669
+ if (state.length === 0) {
6670
+ state.mode = LEN;
6671
+ }
6672
+ break;
6673
+ case LIT:
6674
+ if (left === 0) {
6675
+ break inf_leave;
6676
+ }
6677
+ output[put++] = state.length;
6678
+ left--;
6679
+ state.mode = LEN;
6680
+ break;
6681
+ case CHECK:
6682
+ if (state.wrap) {
6683
+ while (bits < 32) {
6684
+ if (have === 0) {
6685
+ break inf_leave;
6686
+ }
6687
+ have--;
6688
+ hold |= input[next++] << bits;
6689
+ bits += 8;
6690
+ }
6691
+ _out -= left;
6692
+ strm.total_out += _out;
6693
+ state.total += _out;
6694
+ if (state.wrap & 4 && _out) {
6695
+ strm.adler = state.check = /*UPDATE_CHECK(state.check, put - _out, _out);*/
6696
+ state.flags ? crc32_1(state.check, output, _out, put - _out) : adler32_1(state.check, output, _out, put - _out);
6697
+ }
6698
+ _out = left;
6699
+ if (state.wrap & 4 && (state.flags ? hold : zswap32(hold)) !== state.check) {
6700
+ strm.msg = "incorrect data check";
6701
+ state.mode = BAD;
6702
+ break;
6703
+ }
6704
+ hold = 0;
6705
+ bits = 0;
6706
+ }
6707
+ state.mode = LENGTH;
6708
+ /* falls through */
6709
+ case LENGTH:
6710
+ if (state.wrap && state.flags) {
6711
+ while (bits < 32) {
6712
+ if (have === 0) {
6713
+ break inf_leave;
6714
+ }
6715
+ have--;
6716
+ hold += input[next++] << bits;
6717
+ bits += 8;
6718
+ }
6719
+ if (state.wrap & 4 && hold !== (state.total & 4294967295)) {
6720
+ strm.msg = "incorrect length check";
6721
+ state.mode = BAD;
6722
+ break;
6723
+ }
6724
+ hold = 0;
6725
+ bits = 0;
6726
+ }
6727
+ state.mode = DONE;
6728
+ /* falls through */
6729
+ case DONE:
6730
+ ret = Z_STREAM_END$1;
6731
+ break inf_leave;
6732
+ case BAD:
6733
+ ret = Z_DATA_ERROR$1;
6734
+ break inf_leave;
6735
+ case MEM:
6736
+ return Z_MEM_ERROR$1;
6737
+ case SYNC:
6738
+ /* falls through */
6739
+ default:
6740
+ return Z_STREAM_ERROR$1;
6741
+ }
6742
+ }
6743
+ strm.next_out = put;
6744
+ strm.avail_out = left;
6745
+ strm.next_in = next;
6746
+ strm.avail_in = have;
6747
+ state.hold = hold;
6748
+ state.bits = bits;
6749
+ if (state.wsize || _out !== strm.avail_out && state.mode < BAD && (state.mode < CHECK || flush !== Z_FINISH$1)) {
6750
+ if (updatewindow(strm, strm.output, strm.next_out, _out - strm.avail_out)) ;
6751
+ }
6752
+ _in -= strm.avail_in;
6753
+ _out -= strm.avail_out;
6754
+ strm.total_in += _in;
6755
+ strm.total_out += _out;
6756
+ state.total += _out;
6757
+ if (state.wrap & 4 && _out) {
6758
+ strm.adler = state.check = /*UPDATE_CHECK(state.check, strm.next_out - _out, _out);*/
6759
+ state.flags ? crc32_1(state.check, output, _out, strm.next_out - _out) : adler32_1(state.check, output, _out, strm.next_out - _out);
6760
+ }
6761
+ strm.data_type = state.bits + (state.last ? 64 : 0) + (state.mode === TYPE ? 128 : 0) + (state.mode === LEN_ || state.mode === COPY_ ? 256 : 0);
6762
+ if ((_in === 0 && _out === 0 || flush === Z_FINISH$1) && ret === Z_OK$1) {
6763
+ ret = Z_BUF_ERROR;
6764
+ }
6765
+ return ret;
6766
+ };
6767
+ var inflateEnd = (strm) => {
6768
+ if (inflateStateCheck(strm)) {
6769
+ return Z_STREAM_ERROR$1;
6770
+ }
6771
+ let state = strm.state;
6772
+ if (state.window) {
6773
+ state.window = null;
2684
6774
  }
2685
- getViewmodelProjectionMatrix(fov) {
2686
- const projectionMatrix = mat4_exports.create();
2687
- mat4_exports.perspective(
2688
- projectionMatrix,
2689
- fov * DEG2RAD,
2690
- this._aspect,
2691
- this._near,
2692
- this._far
2693
- );
2694
- return projectionMatrix;
6775
+ strm.state = null;
6776
+ return Z_OK$1;
6777
+ };
6778
+ var inflateGetHeader = (strm, head) => {
6779
+ if (inflateStateCheck(strm)) {
6780
+ return Z_STREAM_ERROR$1;
2695
6781
  }
2696
- updateMatrices() {
2697
- if (!this._dirty) {
2698
- return;
2699
- }
2700
- mat4_exports.perspective(
2701
- this._projectionMatrix,
2702
- this._fov * DEG2RAD,
2703
- this._aspect,
2704
- this._near,
2705
- this._far
2706
- );
2707
- const quakeToGl = mat4_exports.fromValues(
2708
- 0,
2709
- -1,
2710
- 0,
2711
- 0,
2712
- // column 0: Quake X -> WebGL (0, -1, 0)
2713
- 0,
2714
- 0,
2715
- 1,
2716
- 0,
2717
- // column 1: Quake Y -> WebGL (0, 0, 1)
2718
- -1,
2719
- 0,
2720
- 0,
2721
- 0,
2722
- // column 2: Quake Z -> WebGL (-1, 0, 0)
2723
- 0,
2724
- 0,
2725
- 0,
2726
- 1
2727
- // column 3: no translation
2728
- );
2729
- const pitch = this._angles[0] + this._bobAngles[0] + this._kickAngles[0];
2730
- const yaw = this._angles[1] + this._bobAngles[1] + this._kickAngles[1];
2731
- const roll = this._angles[2] + this._bobAngles[2] + this._kickAngles[2] + this._rollAngle;
2732
- const pitchRad = pitch * DEG2RAD;
2733
- const yawRad = yaw * DEG2RAD;
2734
- const rollRad = roll * DEG2RAD;
2735
- const rotationQuake = mat4_exports.create();
2736
- mat4_exports.identity(rotationQuake);
2737
- mat4_exports.rotateZ(rotationQuake, rotationQuake, -yawRad);
2738
- mat4_exports.rotateY(rotationQuake, rotationQuake, -pitchRad);
2739
- mat4_exports.rotateX(rotationQuake, rotationQuake, -rollRad);
2740
- const rotationGl = mat4_exports.create();
2741
- mat4_exports.multiply(rotationGl, quakeToGl, rotationQuake);
2742
- const positionWithOffset = vec3_exports.add(vec3_exports.create(), this._position, this._bobOffset);
2743
- const negativePosition = vec3_exports.negate(vec3_exports.create(), positionWithOffset);
2744
- const rotatedPosQuake = vec3_exports.create();
2745
- vec3_exports.transformMat4(rotatedPosQuake, negativePosition, rotationQuake);
2746
- const translationGl = vec3_exports.fromValues(
2747
- rotatedPosQuake[1] || 0,
2748
- // Y in Quake -> X in WebGL (negation already applied above)
2749
- rotatedPosQuake[2] || 0,
2750
- // Z in Quake -> Y in WebGL
2751
- rotatedPosQuake[0] || 0
2752
- // X in Quake -> Z in WebGL (negation already applied above)
2753
- );
2754
- mat4_exports.copy(this._viewMatrix, rotationGl);
2755
- this._viewMatrix[12] = translationGl[0];
2756
- this._viewMatrix[13] = translationGl[1];
2757
- this._viewMatrix[14] = translationGl[2];
2758
- mat4_exports.multiply(
2759
- this._viewProjectionMatrix,
2760
- this._projectionMatrix,
2761
- this._viewMatrix
2762
- );
2763
- this._dirty = false;
6782
+ const state = strm.state;
6783
+ if ((state.wrap & 2) === 0) {
6784
+ return Z_STREAM_ERROR$1;
2764
6785
  }
6786
+ state.head = head;
6787
+ head.done = false;
6788
+ return Z_OK$1;
2765
6789
  };
2766
- var DemoReader = class {
2767
- constructor(buffer) {
2768
- this.buffer = buffer;
2769
- this.view = new DataView(buffer);
2770
- this.offset = 0;
2771
- }
2772
- /**
2773
- * Checks if there are more blocks to read.
2774
- */
2775
- hasMore() {
2776
- return this.offset < this.buffer.byteLength;
6790
+ var inflateSetDictionary = (strm, dictionary) => {
6791
+ const dictLength = dictionary.length;
6792
+ let state;
6793
+ let dictid;
6794
+ let ret;
6795
+ if (inflateStateCheck(strm)) {
6796
+ return Z_STREAM_ERROR$1;
6797
+ }
6798
+ state = strm.state;
6799
+ if (state.wrap !== 0 && state.mode !== DICT) {
6800
+ return Z_STREAM_ERROR$1;
6801
+ }
6802
+ if (state.mode === DICT) {
6803
+ dictid = 1;
6804
+ dictid = adler32_1(dictid, dictionary, dictLength, 0);
6805
+ if (dictid !== state.check) {
6806
+ return Z_DATA_ERROR$1;
6807
+ }
6808
+ }
6809
+ ret = updatewindow(strm, dictionary, dictLength, dictLength);
6810
+ if (ret) {
6811
+ state.mode = MEM;
6812
+ return Z_MEM_ERROR$1;
6813
+ }
6814
+ state.havedict = 1;
6815
+ return Z_OK$1;
6816
+ };
6817
+ var inflateReset_1 = inflateReset;
6818
+ var inflateReset2_1 = inflateReset2;
6819
+ var inflateResetKeep_1 = inflateResetKeep;
6820
+ var inflateInit_1 = inflateInit;
6821
+ var inflateInit2_1 = inflateInit2;
6822
+ var inflate_2$1 = inflate$2;
6823
+ var inflateEnd_1 = inflateEnd;
6824
+ var inflateGetHeader_1 = inflateGetHeader;
6825
+ var inflateSetDictionary_1 = inflateSetDictionary;
6826
+ var inflateInfo = "pako inflate (from Nodeca project)";
6827
+ var inflate_1$2 = {
6828
+ inflateReset: inflateReset_1,
6829
+ inflateReset2: inflateReset2_1,
6830
+ inflateResetKeep: inflateResetKeep_1,
6831
+ inflateInit: inflateInit_1,
6832
+ inflateInit2: inflateInit2_1,
6833
+ inflate: inflate_2$1,
6834
+ inflateEnd: inflateEnd_1,
6835
+ inflateGetHeader: inflateGetHeader_1,
6836
+ inflateSetDictionary: inflateSetDictionary_1,
6837
+ inflateInfo
6838
+ };
6839
+ function GZheader() {
6840
+ this.text = 0;
6841
+ this.time = 0;
6842
+ this.xflags = 0;
6843
+ this.os = 0;
6844
+ this.extra = null;
6845
+ this.extra_len = 0;
6846
+ this.name = "";
6847
+ this.comment = "";
6848
+ this.hcrc = 0;
6849
+ this.done = false;
6850
+ }
6851
+ var gzheader = GZheader;
6852
+ var toString = Object.prototype.toString;
6853
+ var {
6854
+ Z_NO_FLUSH,
6855
+ Z_FINISH,
6856
+ Z_OK,
6857
+ Z_STREAM_END,
6858
+ Z_NEED_DICT,
6859
+ Z_STREAM_ERROR,
6860
+ Z_DATA_ERROR,
6861
+ Z_MEM_ERROR
6862
+ } = constants$2;
6863
+ function Inflate$1(options) {
6864
+ this.options = common.assign({
6865
+ chunkSize: 1024 * 64,
6866
+ windowBits: 15,
6867
+ to: ""
6868
+ }, options || {});
6869
+ const opt = this.options;
6870
+ if (opt.raw && opt.windowBits >= 0 && opt.windowBits < 16) {
6871
+ opt.windowBits = -opt.windowBits;
6872
+ if (opt.windowBits === 0) {
6873
+ opt.windowBits = -15;
6874
+ }
6875
+ }
6876
+ if (opt.windowBits >= 0 && opt.windowBits < 16 && !(options && options.windowBits)) {
6877
+ opt.windowBits += 32;
6878
+ }
6879
+ if (opt.windowBits > 15 && opt.windowBits < 48) {
6880
+ if ((opt.windowBits & 15) === 0) {
6881
+ opt.windowBits |= 15;
6882
+ }
6883
+ }
6884
+ this.err = 0;
6885
+ this.msg = "";
6886
+ this.ended = false;
6887
+ this.chunks = [];
6888
+ this.strm = new zstream();
6889
+ this.strm.avail_out = 0;
6890
+ let status = inflate_1$2.inflateInit2(
6891
+ this.strm,
6892
+ opt.windowBits
6893
+ );
6894
+ if (status !== Z_OK) {
6895
+ throw new Error(messages[status]);
6896
+ }
6897
+ this.header = new gzheader();
6898
+ inflate_1$2.inflateGetHeader(this.strm, this.header);
6899
+ if (opt.dictionary) {
6900
+ if (typeof opt.dictionary === "string") {
6901
+ opt.dictionary = strings.string2buf(opt.dictionary);
6902
+ } else if (toString.call(opt.dictionary) === "[object ArrayBuffer]") {
6903
+ opt.dictionary = new Uint8Array(opt.dictionary);
6904
+ }
6905
+ if (opt.raw) {
6906
+ status = inflate_1$2.inflateSetDictionary(this.strm, opt.dictionary);
6907
+ if (status !== Z_OK) {
6908
+ throw new Error(messages[status]);
6909
+ }
6910
+ }
2777
6911
  }
2778
- /**
2779
- * Reads the next message block from the demo file.
2780
- * Format is [Length (4 bytes)] + [Message Block (Length bytes)].
2781
- * Returns null if end of file or incomplete block.
2782
- */
2783
- readNextBlock() {
2784
- if (this.offset + 4 > this.buffer.byteLength) {
2785
- return null;
6912
+ }
6913
+ Inflate$1.prototype.push = function(data, flush_mode) {
6914
+ const strm = this.strm;
6915
+ const chunkSize = this.options.chunkSize;
6916
+ const dictionary = this.options.dictionary;
6917
+ let status, _flush_mode, last_avail_out;
6918
+ if (this.ended) return false;
6919
+ if (flush_mode === ~~flush_mode) _flush_mode = flush_mode;
6920
+ else _flush_mode = flush_mode === true ? Z_FINISH : Z_NO_FLUSH;
6921
+ if (toString.call(data) === "[object ArrayBuffer]") {
6922
+ strm.input = new Uint8Array(data);
6923
+ } else {
6924
+ strm.input = data;
6925
+ }
6926
+ strm.next_in = 0;
6927
+ strm.avail_in = strm.input.length;
6928
+ for (; ; ) {
6929
+ if (strm.avail_out === 0) {
6930
+ strm.output = new Uint8Array(chunkSize);
6931
+ strm.next_out = 0;
6932
+ strm.avail_out = chunkSize;
6933
+ }
6934
+ status = inflate_1$2.inflate(strm, _flush_mode);
6935
+ if (status === Z_NEED_DICT && dictionary) {
6936
+ status = inflate_1$2.inflateSetDictionary(strm, dictionary);
6937
+ if (status === Z_OK) {
6938
+ status = inflate_1$2.inflate(strm, _flush_mode);
6939
+ } else if (status === Z_DATA_ERROR) {
6940
+ status = Z_NEED_DICT;
6941
+ }
2786
6942
  }
2787
- const length2 = this.view.getInt32(this.offset, true);
2788
- this.offset += 4;
2789
- if (length2 < 0 || length2 > 262144) {
2790
- console.warn(`DemoReader: Invalid block length ${length2} at offset ${this.offset - 4}`);
2791
- return null;
6943
+ while (strm.avail_in > 0 && status === Z_STREAM_END && strm.state.wrap > 0 && data[strm.next_in] !== 0) {
6944
+ inflate_1$2.inflateReset(strm);
6945
+ status = inflate_1$2.inflate(strm, _flush_mode);
6946
+ }
6947
+ switch (status) {
6948
+ case Z_STREAM_ERROR:
6949
+ case Z_DATA_ERROR:
6950
+ case Z_NEED_DICT:
6951
+ case Z_MEM_ERROR:
6952
+ this.onEnd(status);
6953
+ this.ended = true;
6954
+ return false;
2792
6955
  }
2793
- if (this.offset + length2 > this.buffer.byteLength) {
2794
- console.warn(`DemoReader: Incomplete block. Expected ${length2} bytes, but only ${this.buffer.byteLength - this.offset} remain.`);
2795
- return null;
6956
+ last_avail_out = strm.avail_out;
6957
+ if (strm.next_out) {
6958
+ if (strm.avail_out === 0 || status === Z_STREAM_END) {
6959
+ if (this.options.to === "string") {
6960
+ let next_out_utf8 = strings.utf8border(strm.output, strm.next_out);
6961
+ let tail = strm.next_out - next_out_utf8;
6962
+ let utf8str = strings.buf2string(strm.output, next_out_utf8);
6963
+ strm.next_out = tail;
6964
+ strm.avail_out = chunkSize - tail;
6965
+ if (tail) strm.output.set(strm.output.subarray(next_out_utf8, next_out_utf8 + tail), 0);
6966
+ this.onData(utf8str);
6967
+ } else {
6968
+ this.onData(strm.output.length === strm.next_out ? strm.output : strm.output.subarray(0, strm.next_out));
6969
+ }
6970
+ }
2796
6971
  }
2797
- const blockData = this.buffer.slice(this.offset, this.offset + length2);
2798
- this.offset += length2;
2799
- return {
2800
- length: length2,
2801
- data: new BinaryStream(blockData)
2802
- };
2803
- }
2804
- /**
2805
- * Resets the reader to the beginning.
2806
- */
2807
- reset() {
2808
- this.offset = 0;
6972
+ if (status === Z_OK && last_avail_out === 0) continue;
6973
+ if (status === Z_STREAM_END) {
6974
+ status = inflate_1$2.inflateEnd(this.strm);
6975
+ this.onEnd(status);
6976
+ this.ended = true;
6977
+ return true;
6978
+ }
6979
+ if (strm.avail_in === 0) break;
2809
6980
  }
2810
- getOffset() {
2811
- return this.offset;
6981
+ return true;
6982
+ };
6983
+ Inflate$1.prototype.onData = function(chunk) {
6984
+ this.chunks.push(chunk);
6985
+ };
6986
+ Inflate$1.prototype.onEnd = function(status) {
6987
+ if (status === Z_OK) {
6988
+ if (this.options.to === "string") {
6989
+ this.result = this.chunks.join("");
6990
+ } else {
6991
+ this.result = common.flattenChunks(this.chunks);
6992
+ }
2812
6993
  }
6994
+ this.chunks = [];
6995
+ this.err = status;
6996
+ this.msg = this.strm.msg;
6997
+ };
6998
+ function inflate$1(input, options) {
6999
+ const inflator = new Inflate$1(options);
7000
+ inflator.push(input);
7001
+ if (inflator.err) throw inflator.msg || messages[inflator.err];
7002
+ return inflator.result;
7003
+ }
7004
+ function inflateRaw$1(input, options) {
7005
+ options = options || {};
7006
+ options.raw = true;
7007
+ return inflate$1(input, options);
7008
+ }
7009
+ var Inflate_1$1 = Inflate$1;
7010
+ var inflate_2 = inflate$1;
7011
+ var inflateRaw_1$1 = inflateRaw$1;
7012
+ var ungzip$1 = inflate$1;
7013
+ var constants = constants$2;
7014
+ var inflate_1$1 = {
7015
+ Inflate: Inflate_1$1,
7016
+ inflate: inflate_2,
7017
+ inflateRaw: inflateRaw_1$1,
7018
+ ungzip: ungzip$1,
7019
+ constants
7020
+ };
7021
+ var { Deflate, deflate, deflateRaw, gzip } = deflate_1$1;
7022
+ var { Inflate, inflate, inflateRaw, ungzip } = inflate_1$1;
7023
+ var Deflate_1 = Deflate;
7024
+ var deflate_1 = deflate;
7025
+ var deflateRaw_1 = deflateRaw;
7026
+ var gzip_1 = gzip;
7027
+ var Inflate_1 = Inflate;
7028
+ var inflate_1 = inflate;
7029
+ var inflateRaw_1 = inflateRaw;
7030
+ var ungzip_1 = ungzip;
7031
+ var constants_1 = constants$2;
7032
+ var pako = {
7033
+ Deflate: Deflate_1,
7034
+ deflate: deflate_1,
7035
+ deflateRaw: deflateRaw_1,
7036
+ gzip: gzip_1,
7037
+ Inflate: Inflate_1,
7038
+ inflate: inflate_1,
7039
+ inflateRaw: inflateRaw_1,
7040
+ ungzip: ungzip_1,
7041
+ constants: constants_1
2813
7042
  };
2814
7043
  var PROTOCOL_VERSION_RERELEASE = 2023;
2815
7044
  var U_ORIGIN12 = 1 << 0;
@@ -2892,7 +7121,7 @@ var createEmptyProtocolPlayerState = () => ({
2892
7121
  damage_blend: [0, 0, 0, 0],
2893
7122
  team_id: 0
2894
7123
  });
2895
- var NetworkMessageParser = class {
7124
+ var NetworkMessageParser = class _NetworkMessageParser {
2896
7125
  constructor(stream, handler) {
2897
7126
  this.protocolVersion = 0;
2898
7127
  this.isDemo = RECORD_CLIENT;
@@ -2990,10 +7219,13 @@ var NetworkMessageParser = class {
2990
7219
  break;
2991
7220
  // New Rerelease Commands
2992
7221
  case ServerCommand.splitclient:
7222
+ this.parseSplitClient();
2993
7223
  break;
2994
7224
  case ServerCommand.configblast:
7225
+ this.parseConfigBlast();
2995
7226
  break;
2996
7227
  case ServerCommand.spawnbaselineblast:
7228
+ this.parseSpawnBaselineBlast();
2997
7229
  break;
2998
7230
  case ServerCommand.level_restart:
2999
7231
  if (this.handler && this.handler.onLevelRestart) this.handler.onLevelRestart();
@@ -3002,23 +7234,28 @@ var NetworkMessageParser = class {
3002
7234
  this.parseDamage();
3003
7235
  break;
3004
7236
  case ServerCommand.locprint:
7237
+ this.parseLocPrint();
3005
7238
  break;
3006
7239
  case ServerCommand.fog:
3007
7240
  this.parseFog();
3008
7241
  break;
3009
7242
  case ServerCommand.waitingforplayers:
3010
- if (this.handler && this.handler.onWaitingForPlayers) this.handler.onWaitingForPlayers();
7243
+ this.parseWaitingForPlayers();
3011
7244
  break;
3012
7245
  case ServerCommand.bot_chat:
7246
+ this.parseBotChat();
3013
7247
  break;
3014
7248
  case ServerCommand.poi:
7249
+ this.parsePoi();
3015
7250
  break;
3016
7251
  case ServerCommand.help_path:
7252
+ this.parseHelpPath();
3017
7253
  break;
3018
7254
  case ServerCommand.muzzleflash3:
3019
7255
  this.parseMuzzleFlash3();
3020
7256
  break;
3021
7257
  case ServerCommand.achievement:
7258
+ this.parseAchievement();
3022
7259
  break;
3023
7260
  default:
3024
7261
  console.warn(`Unknown server command: ${originalCmd} (translated: ${cmd}) at offset ${this.stream.getPosition() - 1}`);
@@ -3076,6 +7313,102 @@ var NetworkMessageParser = class {
3076
7313
  this.handler.onConfigString(index, str3);
3077
7314
  }
3078
7315
  }
7316
+ parseSplitClient() {
7317
+ const clientNum = this.stream.readByte();
7318
+ if (this.handler && this.handler.onSplitClient) {
7319
+ this.handler.onSplitClient(clientNum);
7320
+ }
7321
+ }
7322
+ parseConfigBlast() {
7323
+ const compressedSize = this.stream.readShort();
7324
+ const uncompressedSize = this.stream.readShort();
7325
+ const compressedData = this.stream.readData(compressedSize);
7326
+ try {
7327
+ const decompressed = pako.inflate(compressedData);
7328
+ if (decompressed.byteLength !== uncompressedSize) {
7329
+ console.warn(`svc_configblast: Decompressed size mismatch. Expected ${uncompressedSize}, got ${decompressed.byteLength}`);
7330
+ }
7331
+ const blastStream = new BinaryStream(decompressed.buffer);
7332
+ while (blastStream.hasMore()) {
7333
+ const index = blastStream.readUShort();
7334
+ const str3 = blastStream.readString();
7335
+ if (this.handler) {
7336
+ this.handler.onConfigString(index, str3);
7337
+ }
7338
+ }
7339
+ } catch (e) {
7340
+ console.error("svc_configblast: Failed to decompress data", e);
7341
+ }
7342
+ }
7343
+ parseSpawnBaselineBlast() {
7344
+ const compressedSize = this.stream.readShort();
7345
+ const uncompressedSize = this.stream.readShort();
7346
+ const compressedData = this.stream.readData(compressedSize);
7347
+ try {
7348
+ const decompressed = pako.inflate(compressedData);
7349
+ if (decompressed.byteLength !== uncompressedSize) {
7350
+ console.warn(`svc_spawnbaselineblast: Decompressed size mismatch. Expected ${uncompressedSize}, got ${decompressed.byteLength}`);
7351
+ }
7352
+ const blastStream = new BinaryStream(decompressed.buffer);
7353
+ const blastParser = new _NetworkMessageParser(blastStream, this.handler);
7354
+ while (blastStream.hasMore()) {
7355
+ blastParser.parseSpawnBaseline();
7356
+ }
7357
+ } catch (e) {
7358
+ console.error("svc_spawnbaselineblast: Failed to decompress data", e);
7359
+ }
7360
+ }
7361
+ parseLocPrint() {
7362
+ const flags = this.stream.readByte();
7363
+ const base = this.stream.readString();
7364
+ const numArgs = this.stream.readByte();
7365
+ const args = [];
7366
+ for (let i = 0; i < numArgs; i++) {
7367
+ args.push(this.stream.readString());
7368
+ }
7369
+ if (this.handler && this.handler.onLocPrint) {
7370
+ this.handler.onLocPrint(flags, base);
7371
+ }
7372
+ }
7373
+ parseWaitingForPlayers() {
7374
+ const count = this.stream.readByte();
7375
+ if (this.handler && this.handler.onWaitingForPlayers) {
7376
+ this.handler.onWaitingForPlayers();
7377
+ }
7378
+ }
7379
+ parseBotChat() {
7380
+ const botName = this.stream.readString();
7381
+ const clientIndex = this.stream.readShort();
7382
+ const locString = this.stream.readString();
7383
+ if (this.handler && this.handler.onBotChat) {
7384
+ this.handler.onBotChat(locString);
7385
+ }
7386
+ }
7387
+ parsePoi() {
7388
+ const key = this.stream.readUShort();
7389
+ const time = this.stream.readUShort();
7390
+ const pos = { x: 0, y: 0, z: 0 };
7391
+ this.stream.readPos(pos);
7392
+ const imageIndex = this.stream.readUShort();
7393
+ const paletteIndex = this.stream.readByte();
7394
+ const flags = this.stream.readByte();
7395
+ if (this.handler && this.handler.onPoi) {
7396
+ this.handler.onPoi(flags, pos);
7397
+ }
7398
+ }
7399
+ parseHelpPath() {
7400
+ const start = this.stream.readByte();
7401
+ const pos = { x: 0, y: 0, z: 0 };
7402
+ this.stream.readPos(pos);
7403
+ const dir = { x: 0, y: 0, z: 0 };
7404
+ this.stream.readDir(dir);
7405
+ if (this.handler && this.handler.onHelpPath) {
7406
+ this.handler.onHelpPath(pos);
7407
+ }
7408
+ }
7409
+ parseAchievement() {
7410
+ const idStr = this.stream.readString();
7411
+ }
3079
7412
  parseDownload() {
3080
7413
  const size = this.stream.readShort();
3081
7414
  const percent = this.stream.readByte();
@@ -4085,8 +8418,8 @@ function createCGameImport(imports, state) {
4085
8418
  picCache.set(name, pic);
4086
8419
  }
4087
8420
  pendingPics.delete(name);
4088
- }).catch((err) => {
4089
- console.warn(`[CGameImport] Failed to load pic: ${name}`, err);
8421
+ }).catch((err2) => {
8422
+ console.warn(`[CGameImport] Failed to load pic: ${name}`, err2);
4090
8423
  pendingPics.delete(name);
4091
8424
  });
4092
8425
  }
@@ -5232,8 +9565,8 @@ var OptionsMenuFactory = class {
5232
9565
  getValue: () => document.fullscreenElement ? "On" : "Off",
5233
9566
  onUpdate: () => {
5234
9567
  if (!document.fullscreenElement) {
5235
- document.documentElement.requestFullscreen().catch((err) => {
5236
- console.error(`Error attempting to enable fullscreen: ${err.message}`);
9568
+ document.documentElement.requestFullscreen().catch((err2) => {
9569
+ console.error(`Error attempting to enable fullscreen: ${err2.message}`);
5237
9570
  });
5238
9571
  } else {
5239
9572
  document.exitFullscreen();
@@ -6620,4 +10953,9 @@ export {
6620
10953
  normalizeCommand,
6621
10954
  normalizeInputCode
6622
10955
  };
10956
+ /*! Bundled license information:
10957
+
10958
+ pako/dist/pako.esm.mjs:
10959
+ (*! pako 2.1.0 https://github.com/nodeca/pako @license (MIT AND Zlib) *)
10960
+ */
6623
10961
  //# sourceMappingURL=index.js.map