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.
- package/package.json +4 -2
- package/packages/client/dist/browser/index.global.js +18 -13
- package/packages/client/dist/browser/index.global.js.map +1 -1
- package/packages/client/dist/cjs/index.cjs +4438 -128
- package/packages/client/dist/cjs/index.cjs.map +1 -1
- package/packages/client/dist/esm/index.js +4438 -128
- package/packages/client/dist/esm/index.js.map +1 -1
- package/packages/client/dist/tsconfig.tsbuildinfo +1 -1
- package/packages/engine/dist/browser/index.global.js +22 -17
- package/packages/engine/dist/browser/index.global.js.map +1 -1
- package/packages/engine/dist/cjs/index.cjs +4546 -234
- package/packages/engine/dist/cjs/index.cjs.map +1 -1
- package/packages/engine/dist/esm/index.js +4546 -234
- package/packages/engine/dist/esm/index.js.map +1 -1
- package/packages/engine/dist/tsconfig.tsbuildinfo +1 -1
- package/packages/engine/dist/types/demo/parser.d.ts +12 -3
- package/packages/engine/dist/types/demo/parser.d.ts.map +1 -1
- package/packages/game/dist/browser/index.global.js.map +1 -1
- package/packages/game/dist/cjs/index.cjs.map +1 -1
- package/packages/game/dist/esm/index.js.map +1 -1
- package/packages/game/dist/tsconfig.tsbuildinfo +1 -1
- package/packages/shared/dist/browser/index.global.js +1 -1
- package/packages/shared/dist/browser/index.global.js.map +1 -1
- package/packages/shared/dist/cjs/index.cjs +10 -0
- package/packages/shared/dist/cjs/index.cjs.map +1 -1
- package/packages/shared/dist/esm/index.js +10 -0
- package/packages/shared/dist/esm/index.js.map +1 -1
- package/packages/shared/dist/tsconfig.tsbuildinfo +1 -1
- package/packages/shared/dist/types/io/binaryStream.d.ts +2 -0
- package/packages/shared/dist/types/io/binaryStream.d.ts.map +1 -1
- 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
|
-
|
|
2717
|
-
|
|
2718
|
-
|
|
2719
|
-
|
|
2720
|
-
|
|
2721
|
-
|
|
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
|
-
|
|
2728
|
-
|
|
2729
|
-
|
|
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
|
|
2798
|
-
|
|
2799
|
-
|
|
2800
|
-
|
|
2801
|
-
|
|
2802
|
-
|
|
2803
|
-
|
|
2804
|
-
|
|
2805
|
-
|
|
2806
|
-
|
|
2807
|
-
return
|
|
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
|
-
|
|
2811
|
-
|
|
2812
|
-
|
|
2813
|
-
|
|
2814
|
-
|
|
2815
|
-
|
|
2816
|
-
|
|
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
|
-
|
|
2819
|
-
|
|
2820
|
-
|
|
2821
|
-
|
|
2822
|
-
|
|
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
|
-
|
|
2825
|
-
|
|
2826
|
-
|
|
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
|
-
|
|
2829
|
-
|
|
2830
|
-
|
|
2831
|
-
|
|
2832
|
-
|
|
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
|
-
|
|
2842
|
-
|
|
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
|
-
|
|
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((
|
|
4120
|
-
console.warn(`[CGameImport] Failed to load pic: ${name}`,
|
|
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((
|
|
5267
|
-
console.error(`Error attempting to enable fullscreen: ${
|
|
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
|