quake2ts 0.0.233 → 0.0.234

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