@loaders.gl/zip 4.0.0-alpha.4 → 4.0.0-alpha.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (76) hide show
  1. package/dist/bundle.d.ts +2 -0
  2. package/dist/bundle.d.ts.map +1 -0
  3. package/dist/bundle.js +2 -2
  4. package/dist/dist.min.js +3065 -0
  5. package/dist/es5/bundle.js +6 -0
  6. package/dist/es5/bundle.js.map +1 -0
  7. package/dist/es5/index.js +28 -0
  8. package/dist/es5/index.js.map +1 -0
  9. package/dist/es5/lib/tar/header.js +52 -0
  10. package/dist/es5/lib/tar/header.js.map +1 -0
  11. package/dist/es5/lib/tar/tar.js +137 -0
  12. package/dist/es5/lib/tar/tar.js.map +1 -0
  13. package/dist/es5/lib/tar/types.js +2 -0
  14. package/dist/es5/lib/tar/types.js.map +1 -0
  15. package/dist/es5/lib/tar/utils.js +32 -0
  16. package/dist/es5/lib/tar/utils.js.map +1 -0
  17. package/dist/es5/tar-builder.js +69 -0
  18. package/dist/es5/tar-builder.js.map +1 -0
  19. package/dist/es5/zip-loader.js +105 -0
  20. package/dist/es5/zip-loader.js.map +1 -0
  21. package/dist/es5/zip-writer.js +57 -0
  22. package/dist/es5/zip-writer.js.map +1 -0
  23. package/dist/esm/bundle.js +4 -0
  24. package/dist/esm/bundle.js.map +1 -0
  25. package/dist/esm/index.js +4 -0
  26. package/dist/esm/index.js.map +1 -0
  27. package/dist/esm/lib/tar/header.js +39 -0
  28. package/dist/esm/lib/tar/header.js.map +1 -0
  29. package/dist/esm/lib/tar/tar.js +118 -0
  30. package/dist/esm/lib/tar/tar.js.map +1 -0
  31. package/dist/esm/lib/tar/types.js +2 -0
  32. package/dist/esm/lib/tar/types.js.map +1 -0
  33. package/dist/esm/lib/tar/utils.js +24 -0
  34. package/dist/esm/lib/tar/utils.js.map +1 -0
  35. package/dist/esm/tar-builder.js +35 -0
  36. package/dist/esm/tar-builder.js.map +1 -0
  37. package/dist/esm/zip-loader.js +47 -0
  38. package/dist/esm/zip-loader.js.map +1 -0
  39. package/dist/esm/zip-writer.js +27 -0
  40. package/dist/esm/zip-writer.js.map +1 -0
  41. package/dist/index.d.ts +4 -0
  42. package/dist/index.d.ts.map +1 -0
  43. package/dist/index.js +12 -4
  44. package/dist/lib/tar/header.d.ts +9 -0
  45. package/dist/lib/tar/header.d.ts.map +1 -0
  46. package/dist/lib/tar/header.js +95 -38
  47. package/dist/lib/tar/tar.d.ts +29 -0
  48. package/dist/lib/tar/tar.d.ts.map +1 -0
  49. package/dist/lib/tar/tar.js +123 -121
  50. package/dist/lib/tar/types.d.ts +48 -0
  51. package/dist/lib/tar/types.d.ts.map +1 -0
  52. package/dist/lib/tar/types.js +2 -2
  53. package/dist/lib/tar/utils.d.ts +23 -0
  54. package/dist/lib/tar/utils.d.ts.map +1 -0
  55. package/dist/lib/tar/utils.js +51 -25
  56. package/dist/tar-builder.d.ts +28 -0
  57. package/dist/tar-builder.d.ts.map +1 -0
  58. package/dist/tar-builder.js +35 -38
  59. package/dist/zip-loader.d.ts +6 -0
  60. package/dist/zip-loader.d.ts.map +1 -0
  61. package/dist/zip-loader.js +56 -44
  62. package/dist/zip-writer.d.ts +6 -0
  63. package/dist/zip-writer.d.ts.map +1 -0
  64. package/dist/zip-writer.js +34 -26
  65. package/package.json +6 -9
  66. package/src/lib/tar/header.ts +1 -1
  67. package/src/zip-loader.ts +4 -4
  68. package/dist/bundle.js.map +0 -1
  69. package/dist/index.js.map +0 -1
  70. package/dist/lib/tar/header.js.map +0 -1
  71. package/dist/lib/tar/tar.js.map +0 -1
  72. package/dist/lib/tar/types.js.map +0 -1
  73. package/dist/lib/tar/utils.js.map +0 -1
  74. package/dist/tar-builder.js.map +0 -1
  75. package/dist/zip-loader.js.map +0 -1
  76. package/dist/zip-writer.js.map +0 -1
@@ -0,0 +1,3065 @@
1
+ (() => {
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
9
+ var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, {
10
+ get: (a, b) => (typeof require !== "undefined" ? require : a)[b]
11
+ }) : x)(function(x) {
12
+ if (typeof require !== "undefined")
13
+ return require.apply(this, arguments);
14
+ throw new Error('Dynamic require of "' + x + '" is not supported');
15
+ });
16
+ var __esm = (fn, res) => function __init() {
17
+ return fn && (res = (0, fn[Object.keys(fn)[0]])(fn = 0)), res;
18
+ };
19
+ var __commonJS = (cb, mod) => function __require2() {
20
+ return mod || (0, cb[Object.keys(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
21
+ };
22
+ var __export = (target, all) => {
23
+ __markAsModule(target);
24
+ for (var name in all)
25
+ __defProp(target, name, { get: all[name], enumerable: true });
26
+ };
27
+ var __reExport = (target, module, desc) => {
28
+ if (module && typeof module === "object" || typeof module === "function") {
29
+ for (let key of __getOwnPropNames(module))
30
+ if (!__hasOwnProp.call(target, key) && key !== "default")
31
+ __defProp(target, key, { get: () => module[key], enumerable: !(desc = __getOwnPropDesc(module, key)) || desc.enumerable });
32
+ }
33
+ return target;
34
+ };
35
+ var __toModule = (module) => {
36
+ return __reExport(__markAsModule(__defProp(module != null ? __create(__getProtoOf(module)) : {}, "default", module && module.__esModule && "default" in module ? { get: () => module.default, enumerable: true } : { value: module, enumerable: true })), module);
37
+ };
38
+
39
+ // ../../node_modules/jszip/dist/jszip.min.js
40
+ var require_jszip_min = __commonJS({
41
+ "../../node_modules/jszip/dist/jszip.min.js"(exports, module) {
42
+ !function(e) {
43
+ if (typeof exports == "object" && typeof module != "undefined")
44
+ module.exports = e();
45
+ else if (typeof define == "function" && define.amd)
46
+ define([], e);
47
+ else {
48
+ (typeof window != "undefined" ? window : typeof global != "undefined" ? global : typeof self != "undefined" ? self : this).JSZip = e();
49
+ }
50
+ }(function() {
51
+ return function s(a, o, h) {
52
+ function u(r, e2) {
53
+ if (!o[r]) {
54
+ if (!a[r]) {
55
+ var t = typeof __require == "function" && __require;
56
+ if (!e2 && t)
57
+ return t(r, true);
58
+ if (l)
59
+ return l(r, true);
60
+ var n = new Error("Cannot find module '" + r + "'");
61
+ throw n.code = "MODULE_NOT_FOUND", n;
62
+ }
63
+ var i = o[r] = { exports: {} };
64
+ a[r][0].call(i.exports, function(e3) {
65
+ var t2 = a[r][1][e3];
66
+ return u(t2 || e3);
67
+ }, i, i.exports, s, a, o, h);
68
+ }
69
+ return o[r].exports;
70
+ }
71
+ for (var l = typeof __require == "function" && __require, e = 0; e < h.length; e++)
72
+ u(h[e]);
73
+ return u;
74
+ }({ 1: [function(e, t, r) {
75
+ "use strict";
76
+ var d = e("./utils"), c = e("./support"), p = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
77
+ r.encode = function(e2) {
78
+ for (var t2, r2, n, i, s, a, o, h = [], u = 0, l = e2.length, f = l, c2 = d.getTypeOf(e2) !== "string"; u < e2.length; )
79
+ f = l - u, n = c2 ? (t2 = e2[u++], r2 = u < l ? e2[u++] : 0, u < l ? e2[u++] : 0) : (t2 = e2.charCodeAt(u++), r2 = u < l ? e2.charCodeAt(u++) : 0, u < l ? e2.charCodeAt(u++) : 0), i = t2 >> 2, s = (3 & t2) << 4 | r2 >> 4, a = 1 < f ? (15 & r2) << 2 | n >> 6 : 64, o = 2 < f ? 63 & n : 64, h.push(p.charAt(i) + p.charAt(s) + p.charAt(a) + p.charAt(o));
80
+ return h.join("");
81
+ }, r.decode = function(e2) {
82
+ var t2, r2, n, i, s, a, o = 0, h = 0, u = "data:";
83
+ if (e2.substr(0, u.length) === u)
84
+ throw new Error("Invalid base64 input, it looks like a data url.");
85
+ var l, f = 3 * (e2 = e2.replace(/[^A-Za-z0-9+/=]/g, "")).length / 4;
86
+ if (e2.charAt(e2.length - 1) === p.charAt(64) && f--, e2.charAt(e2.length - 2) === p.charAt(64) && f--, f % 1 != 0)
87
+ throw new Error("Invalid base64 input, bad content length.");
88
+ for (l = c.uint8array ? new Uint8Array(0 | f) : new Array(0 | f); o < e2.length; )
89
+ t2 = p.indexOf(e2.charAt(o++)) << 2 | (i = p.indexOf(e2.charAt(o++))) >> 4, r2 = (15 & i) << 4 | (s = p.indexOf(e2.charAt(o++))) >> 2, n = (3 & s) << 6 | (a = p.indexOf(e2.charAt(o++))), l[h++] = t2, s !== 64 && (l[h++] = r2), a !== 64 && (l[h++] = n);
90
+ return l;
91
+ };
92
+ }, { "./support": 30, "./utils": 32 }], 2: [function(e, t, r) {
93
+ "use strict";
94
+ var n = e("./external"), i = e("./stream/DataWorker"), s = e("./stream/Crc32Probe"), a = e("./stream/DataLengthProbe");
95
+ function o(e2, t2, r2, n2, i2) {
96
+ this.compressedSize = e2, this.uncompressedSize = t2, this.crc32 = r2, this.compression = n2, this.compressedContent = i2;
97
+ }
98
+ o.prototype = { getContentWorker: function() {
99
+ var e2 = new i(n.Promise.resolve(this.compressedContent)).pipe(this.compression.uncompressWorker()).pipe(new a("data_length")), t2 = this;
100
+ return e2.on("end", function() {
101
+ if (this.streamInfo.data_length !== t2.uncompressedSize)
102
+ throw new Error("Bug : uncompressed data size mismatch");
103
+ }), e2;
104
+ }, getCompressedWorker: function() {
105
+ return new i(n.Promise.resolve(this.compressedContent)).withStreamInfo("compressedSize", this.compressedSize).withStreamInfo("uncompressedSize", this.uncompressedSize).withStreamInfo("crc32", this.crc32).withStreamInfo("compression", this.compression);
106
+ } }, o.createWorkerFrom = function(e2, t2, r2) {
107
+ return e2.pipe(new s()).pipe(new a("uncompressedSize")).pipe(t2.compressWorker(r2)).pipe(new a("compressedSize")).withStreamInfo("compression", t2);
108
+ }, t.exports = o;
109
+ }, { "./external": 6, "./stream/Crc32Probe": 25, "./stream/DataLengthProbe": 26, "./stream/DataWorker": 27 }], 3: [function(e, t, r) {
110
+ "use strict";
111
+ var n = e("./stream/GenericWorker");
112
+ r.STORE = { magic: "\0\0", compressWorker: function() {
113
+ return new n("STORE compression");
114
+ }, uncompressWorker: function() {
115
+ return new n("STORE decompression");
116
+ } }, r.DEFLATE = e("./flate");
117
+ }, { "./flate": 7, "./stream/GenericWorker": 28 }], 4: [function(e, t, r) {
118
+ "use strict";
119
+ var n = e("./utils");
120
+ var o = function() {
121
+ for (var e2, t2 = [], r2 = 0; r2 < 256; r2++) {
122
+ e2 = r2;
123
+ for (var n2 = 0; n2 < 8; n2++)
124
+ e2 = 1 & e2 ? 3988292384 ^ e2 >>> 1 : e2 >>> 1;
125
+ t2[r2] = e2;
126
+ }
127
+ return t2;
128
+ }();
129
+ t.exports = function(e2, t2) {
130
+ return e2 !== void 0 && e2.length ? n.getTypeOf(e2) !== "string" ? function(e3, t3, r2, n2) {
131
+ var i = o, s = n2 + r2;
132
+ e3 ^= -1;
133
+ for (var a = n2; a < s; a++)
134
+ e3 = e3 >>> 8 ^ i[255 & (e3 ^ t3[a])];
135
+ return -1 ^ e3;
136
+ }(0 | t2, e2, e2.length, 0) : function(e3, t3, r2, n2) {
137
+ var i = o, s = n2 + r2;
138
+ e3 ^= -1;
139
+ for (var a = n2; a < s; a++)
140
+ e3 = e3 >>> 8 ^ i[255 & (e3 ^ t3.charCodeAt(a))];
141
+ return -1 ^ e3;
142
+ }(0 | t2, e2, e2.length, 0) : 0;
143
+ };
144
+ }, { "./utils": 32 }], 5: [function(e, t, r) {
145
+ "use strict";
146
+ r.base64 = false, r.binary = false, r.dir = false, r.createFolders = true, r.date = null, r.compression = null, r.compressionOptions = null, r.comment = null, r.unixPermissions = null, r.dosPermissions = null;
147
+ }, {}], 6: [function(e, t, r) {
148
+ "use strict";
149
+ var n = null;
150
+ n = typeof Promise != "undefined" ? Promise : e("lie"), t.exports = { Promise: n };
151
+ }, { lie: 37 }], 7: [function(e, t, r) {
152
+ "use strict";
153
+ var n = typeof Uint8Array != "undefined" && typeof Uint16Array != "undefined" && typeof Uint32Array != "undefined", i = e("pako"), s = e("./utils"), a = e("./stream/GenericWorker"), o = n ? "uint8array" : "array";
154
+ function h(e2, t2) {
155
+ a.call(this, "FlateWorker/" + e2), this._pako = null, this._pakoAction = e2, this._pakoOptions = t2, this.meta = {};
156
+ }
157
+ r.magic = "\b\0", s.inherits(h, a), h.prototype.processChunk = function(e2) {
158
+ this.meta = e2.meta, this._pako === null && this._createPako(), this._pako.push(s.transformTo(o, e2.data), false);
159
+ }, h.prototype.flush = function() {
160
+ a.prototype.flush.call(this), this._pako === null && this._createPako(), this._pako.push([], true);
161
+ }, h.prototype.cleanUp = function() {
162
+ a.prototype.cleanUp.call(this), this._pako = null;
163
+ }, h.prototype._createPako = function() {
164
+ this._pako = new i[this._pakoAction]({ raw: true, level: this._pakoOptions.level || -1 });
165
+ var t2 = this;
166
+ this._pako.onData = function(e2) {
167
+ t2.push({ data: e2, meta: t2.meta });
168
+ };
169
+ }, r.compressWorker = function(e2) {
170
+ return new h("Deflate", e2);
171
+ }, r.uncompressWorker = function() {
172
+ return new h("Inflate", {});
173
+ };
174
+ }, { "./stream/GenericWorker": 28, "./utils": 32, pako: 38 }], 8: [function(e, t, r) {
175
+ "use strict";
176
+ function A(e2, t2) {
177
+ var r2, n2 = "";
178
+ for (r2 = 0; r2 < t2; r2++)
179
+ n2 += String.fromCharCode(255 & e2), e2 >>>= 8;
180
+ return n2;
181
+ }
182
+ function n(e2, t2, r2, n2, i2, s2) {
183
+ var a, o, h = e2.file, u = e2.compression, l = s2 !== O.utf8encode, f = I.transformTo("string", s2(h.name)), c = I.transformTo("string", O.utf8encode(h.name)), d = h.comment, p = I.transformTo("string", s2(d)), m = I.transformTo("string", O.utf8encode(d)), _ = c.length !== h.name.length, g = m.length !== d.length, b = "", v = "", y = "", w = h.dir, k = h.date, x = { crc32: 0, compressedSize: 0, uncompressedSize: 0 };
184
+ t2 && !r2 || (x.crc32 = e2.crc32, x.compressedSize = e2.compressedSize, x.uncompressedSize = e2.uncompressedSize);
185
+ var S = 0;
186
+ t2 && (S |= 8), l || !_ && !g || (S |= 2048);
187
+ var z = 0, C = 0;
188
+ w && (z |= 16), i2 === "UNIX" ? (C = 798, z |= function(e3, t3) {
189
+ var r3 = e3;
190
+ return e3 || (r3 = t3 ? 16893 : 33204), (65535 & r3) << 16;
191
+ }(h.unixPermissions, w)) : (C = 20, z |= function(e3) {
192
+ return 63 & (e3 || 0);
193
+ }(h.dosPermissions)), a = k.getUTCHours(), a <<= 6, a |= k.getUTCMinutes(), a <<= 5, a |= k.getUTCSeconds() / 2, o = k.getUTCFullYear() - 1980, o <<= 4, o |= k.getUTCMonth() + 1, o <<= 5, o |= k.getUTCDate(), _ && (v = A(1, 1) + A(B(f), 4) + c, b += "up" + A(v.length, 2) + v), g && (y = A(1, 1) + A(B(p), 4) + m, b += "uc" + A(y.length, 2) + y);
194
+ var E = "";
195
+ return E += "\n\0", E += A(S, 2), E += u.magic, E += A(a, 2), E += A(o, 2), E += A(x.crc32, 4), E += A(x.compressedSize, 4), E += A(x.uncompressedSize, 4), E += A(f.length, 2), E += A(b.length, 2), { fileRecord: R.LOCAL_FILE_HEADER + E + f + b, dirRecord: R.CENTRAL_FILE_HEADER + A(C, 2) + E + A(p.length, 2) + "\0\0\0\0" + A(z, 4) + A(n2, 4) + f + b + p };
196
+ }
197
+ var I = e("../utils"), i = e("../stream/GenericWorker"), O = e("../utf8"), B = e("../crc32"), R = e("../signature");
198
+ function s(e2, t2, r2, n2) {
199
+ i.call(this, "ZipFileWorker"), this.bytesWritten = 0, this.zipComment = t2, this.zipPlatform = r2, this.encodeFileName = n2, this.streamFiles = e2, this.accumulate = false, this.contentBuffer = [], this.dirRecords = [], this.currentSourceOffset = 0, this.entriesCount = 0, this.currentFile = null, this._sources = [];
200
+ }
201
+ I.inherits(s, i), s.prototype.push = function(e2) {
202
+ var t2 = e2.meta.percent || 0, r2 = this.entriesCount, n2 = this._sources.length;
203
+ this.accumulate ? this.contentBuffer.push(e2) : (this.bytesWritten += e2.data.length, i.prototype.push.call(this, { data: e2.data, meta: { currentFile: this.currentFile, percent: r2 ? (t2 + 100 * (r2 - n2 - 1)) / r2 : 100 } }));
204
+ }, s.prototype.openedSource = function(e2) {
205
+ this.currentSourceOffset = this.bytesWritten, this.currentFile = e2.file.name;
206
+ var t2 = this.streamFiles && !e2.file.dir;
207
+ if (t2) {
208
+ var r2 = n(e2, t2, false, this.currentSourceOffset, this.zipPlatform, this.encodeFileName);
209
+ this.push({ data: r2.fileRecord, meta: { percent: 0 } });
210
+ } else
211
+ this.accumulate = true;
212
+ }, s.prototype.closedSource = function(e2) {
213
+ this.accumulate = false;
214
+ var t2 = this.streamFiles && !e2.file.dir, r2 = n(e2, t2, true, this.currentSourceOffset, this.zipPlatform, this.encodeFileName);
215
+ if (this.dirRecords.push(r2.dirRecord), t2)
216
+ this.push({ data: function(e3) {
217
+ return R.DATA_DESCRIPTOR + A(e3.crc32, 4) + A(e3.compressedSize, 4) + A(e3.uncompressedSize, 4);
218
+ }(e2), meta: { percent: 100 } });
219
+ else
220
+ for (this.push({ data: r2.fileRecord, meta: { percent: 0 } }); this.contentBuffer.length; )
221
+ this.push(this.contentBuffer.shift());
222
+ this.currentFile = null;
223
+ }, s.prototype.flush = function() {
224
+ for (var e2 = this.bytesWritten, t2 = 0; t2 < this.dirRecords.length; t2++)
225
+ this.push({ data: this.dirRecords[t2], meta: { percent: 100 } });
226
+ var r2 = this.bytesWritten - e2, n2 = function(e3, t3, r3, n3, i2) {
227
+ var s2 = I.transformTo("string", i2(n3));
228
+ return R.CENTRAL_DIRECTORY_END + "\0\0\0\0" + A(e3, 2) + A(e3, 2) + A(t3, 4) + A(r3, 4) + A(s2.length, 2) + s2;
229
+ }(this.dirRecords.length, r2, e2, this.zipComment, this.encodeFileName);
230
+ this.push({ data: n2, meta: { percent: 100 } });
231
+ }, s.prototype.prepareNextSource = function() {
232
+ this.previous = this._sources.shift(), this.openedSource(this.previous.streamInfo), this.isPaused ? this.previous.pause() : this.previous.resume();
233
+ }, s.prototype.registerPrevious = function(e2) {
234
+ this._sources.push(e2);
235
+ var t2 = this;
236
+ return e2.on("data", function(e3) {
237
+ t2.processChunk(e3);
238
+ }), e2.on("end", function() {
239
+ t2.closedSource(t2.previous.streamInfo), t2._sources.length ? t2.prepareNextSource() : t2.end();
240
+ }), e2.on("error", function(e3) {
241
+ t2.error(e3);
242
+ }), this;
243
+ }, s.prototype.resume = function() {
244
+ return !!i.prototype.resume.call(this) && (!this.previous && this._sources.length ? (this.prepareNextSource(), true) : this.previous || this._sources.length || this.generatedError ? void 0 : (this.end(), true));
245
+ }, s.prototype.error = function(e2) {
246
+ var t2 = this._sources;
247
+ if (!i.prototype.error.call(this, e2))
248
+ return false;
249
+ for (var r2 = 0; r2 < t2.length; r2++)
250
+ try {
251
+ t2[r2].error(e2);
252
+ } catch (e3) {
253
+ }
254
+ return true;
255
+ }, s.prototype.lock = function() {
256
+ i.prototype.lock.call(this);
257
+ for (var e2 = this._sources, t2 = 0; t2 < e2.length; t2++)
258
+ e2[t2].lock();
259
+ }, t.exports = s;
260
+ }, { "../crc32": 4, "../signature": 23, "../stream/GenericWorker": 28, "../utf8": 31, "../utils": 32 }], 9: [function(e, t, r) {
261
+ "use strict";
262
+ var u = e("../compressions"), n = e("./ZipFileWorker");
263
+ r.generateWorker = function(e2, a, t2) {
264
+ var o = new n(a.streamFiles, t2, a.platform, a.encodeFileName), h = 0;
265
+ try {
266
+ e2.forEach(function(e3, t3) {
267
+ h++;
268
+ var r2 = function(e4, t4) {
269
+ var r3 = e4 || t4, n3 = u[r3];
270
+ if (!n3)
271
+ throw new Error(r3 + " is not a valid compression method !");
272
+ return n3;
273
+ }(t3.options.compression, a.compression), n2 = t3.options.compressionOptions || a.compressionOptions || {}, i = t3.dir, s = t3.date;
274
+ t3._compressWorker(r2, n2).withStreamInfo("file", { name: e3, dir: i, date: s, comment: t3.comment || "", unixPermissions: t3.unixPermissions, dosPermissions: t3.dosPermissions }).pipe(o);
275
+ }), o.entriesCount = h;
276
+ } catch (e3) {
277
+ o.error(e3);
278
+ }
279
+ return o;
280
+ };
281
+ }, { "../compressions": 3, "./ZipFileWorker": 8 }], 10: [function(e, t, r) {
282
+ "use strict";
283
+ function n() {
284
+ if (!(this instanceof n))
285
+ return new n();
286
+ if (arguments.length)
287
+ throw new Error("The constructor with parameters has been removed in JSZip 3.0, please check the upgrade guide.");
288
+ this.files = Object.create(null), this.comment = null, this.root = "", this.clone = function() {
289
+ var e2 = new n();
290
+ for (var t2 in this)
291
+ typeof this[t2] != "function" && (e2[t2] = this[t2]);
292
+ return e2;
293
+ };
294
+ }
295
+ (n.prototype = e("./object")).loadAsync = e("./load"), n.support = e("./support"), n.defaults = e("./defaults"), n.version = "3.10.1", n.loadAsync = function(e2, t2) {
296
+ return new n().loadAsync(e2, t2);
297
+ }, n.external = e("./external"), t.exports = n;
298
+ }, { "./defaults": 5, "./external": 6, "./load": 11, "./object": 15, "./support": 30 }], 11: [function(e, t, r) {
299
+ "use strict";
300
+ var u = e("./utils"), i = e("./external"), n = e("./utf8"), s = e("./zipEntries"), a = e("./stream/Crc32Probe"), l = e("./nodejsUtils");
301
+ function f(n2) {
302
+ return new i.Promise(function(e2, t2) {
303
+ var r2 = n2.decompressed.getContentWorker().pipe(new a());
304
+ r2.on("error", function(e3) {
305
+ t2(e3);
306
+ }).on("end", function() {
307
+ r2.streamInfo.crc32 !== n2.decompressed.crc32 ? t2(new Error("Corrupted zip : CRC32 mismatch")) : e2();
308
+ }).resume();
309
+ });
310
+ }
311
+ t.exports = function(e2, o) {
312
+ var h = this;
313
+ return o = u.extend(o || {}, { base64: false, checkCRC32: false, optimizedBinaryString: false, createFolders: false, decodeFileName: n.utf8decode }), l.isNode && l.isStream(e2) ? i.Promise.reject(new Error("JSZip can't accept a stream when loading a zip file.")) : u.prepareContent("the loaded zip file", e2, true, o.optimizedBinaryString, o.base64).then(function(e3) {
314
+ var t2 = new s(o);
315
+ return t2.load(e3), t2;
316
+ }).then(function(e3) {
317
+ var t2 = [i.Promise.resolve(e3)], r2 = e3.files;
318
+ if (o.checkCRC32)
319
+ for (var n2 = 0; n2 < r2.length; n2++)
320
+ t2.push(f(r2[n2]));
321
+ return i.Promise.all(t2);
322
+ }).then(function(e3) {
323
+ for (var t2 = e3.shift(), r2 = t2.files, n2 = 0; n2 < r2.length; n2++) {
324
+ var i2 = r2[n2], s2 = i2.fileNameStr, a2 = u.resolve(i2.fileNameStr);
325
+ h.file(a2, i2.decompressed, { binary: true, optimizedBinaryString: true, date: i2.date, dir: i2.dir, comment: i2.fileCommentStr.length ? i2.fileCommentStr : null, unixPermissions: i2.unixPermissions, dosPermissions: i2.dosPermissions, createFolders: o.createFolders }), i2.dir || (h.file(a2).unsafeOriginalName = s2);
326
+ }
327
+ return t2.zipComment.length && (h.comment = t2.zipComment), h;
328
+ });
329
+ };
330
+ }, { "./external": 6, "./nodejsUtils": 14, "./stream/Crc32Probe": 25, "./utf8": 31, "./utils": 32, "./zipEntries": 33 }], 12: [function(e, t, r) {
331
+ "use strict";
332
+ var n = e("../utils"), i = e("../stream/GenericWorker");
333
+ function s(e2, t2) {
334
+ i.call(this, "Nodejs stream input adapter for " + e2), this._upstreamEnded = false, this._bindStream(t2);
335
+ }
336
+ n.inherits(s, i), s.prototype._bindStream = function(e2) {
337
+ var t2 = this;
338
+ (this._stream = e2).pause(), e2.on("data", function(e3) {
339
+ t2.push({ data: e3, meta: { percent: 0 } });
340
+ }).on("error", function(e3) {
341
+ t2.isPaused ? this.generatedError = e3 : t2.error(e3);
342
+ }).on("end", function() {
343
+ t2.isPaused ? t2._upstreamEnded = true : t2.end();
344
+ });
345
+ }, s.prototype.pause = function() {
346
+ return !!i.prototype.pause.call(this) && (this._stream.pause(), true);
347
+ }, s.prototype.resume = function() {
348
+ return !!i.prototype.resume.call(this) && (this._upstreamEnded ? this.end() : this._stream.resume(), true);
349
+ }, t.exports = s;
350
+ }, { "../stream/GenericWorker": 28, "../utils": 32 }], 13: [function(e, t, r) {
351
+ "use strict";
352
+ var i = e("readable-stream").Readable;
353
+ function n(e2, t2, r2) {
354
+ i.call(this, t2), this._helper = e2;
355
+ var n2 = this;
356
+ e2.on("data", function(e3, t3) {
357
+ n2.push(e3) || n2._helper.pause(), r2 && r2(t3);
358
+ }).on("error", function(e3) {
359
+ n2.emit("error", e3);
360
+ }).on("end", function() {
361
+ n2.push(null);
362
+ });
363
+ }
364
+ e("../utils").inherits(n, i), n.prototype._read = function() {
365
+ this._helper.resume();
366
+ }, t.exports = n;
367
+ }, { "../utils": 32, "readable-stream": 16 }], 14: [function(e, t, r) {
368
+ "use strict";
369
+ t.exports = { isNode: typeof Buffer != "undefined", newBufferFrom: function(e2, t2) {
370
+ if (Buffer.from && Buffer.from !== Uint8Array.from)
371
+ return Buffer.from(e2, t2);
372
+ if (typeof e2 == "number")
373
+ throw new Error('The "data" argument must not be a number');
374
+ return new Buffer(e2, t2);
375
+ }, allocBuffer: function(e2) {
376
+ if (Buffer.alloc)
377
+ return Buffer.alloc(e2);
378
+ var t2 = new Buffer(e2);
379
+ return t2.fill(0), t2;
380
+ }, isBuffer: function(e2) {
381
+ return Buffer.isBuffer(e2);
382
+ }, isStream: function(e2) {
383
+ return e2 && typeof e2.on == "function" && typeof e2.pause == "function" && typeof e2.resume == "function";
384
+ } };
385
+ }, {}], 15: [function(e, t, r) {
386
+ "use strict";
387
+ function s(e2, t2, r2) {
388
+ var n2, i2 = u.getTypeOf(t2), s2 = u.extend(r2 || {}, f);
389
+ s2.date = s2.date || new Date(), s2.compression !== null && (s2.compression = s2.compression.toUpperCase()), typeof s2.unixPermissions == "string" && (s2.unixPermissions = parseInt(s2.unixPermissions, 8)), s2.unixPermissions && 16384 & s2.unixPermissions && (s2.dir = true), s2.dosPermissions && 16 & s2.dosPermissions && (s2.dir = true), s2.dir && (e2 = g(e2)), s2.createFolders && (n2 = _(e2)) && b.call(this, n2, true);
390
+ var a2 = i2 === "string" && s2.binary === false && s2.base64 === false;
391
+ r2 && r2.binary !== void 0 || (s2.binary = !a2), (t2 instanceof c && t2.uncompressedSize === 0 || s2.dir || !t2 || t2.length === 0) && (s2.base64 = false, s2.binary = true, t2 = "", s2.compression = "STORE", i2 = "string");
392
+ var o2 = null;
393
+ o2 = t2 instanceof c || t2 instanceof l ? t2 : p.isNode && p.isStream(t2) ? new m(e2, t2) : u.prepareContent(e2, t2, s2.binary, s2.optimizedBinaryString, s2.base64);
394
+ var h2 = new d(e2, o2, s2);
395
+ this.files[e2] = h2;
396
+ }
397
+ var i = e("./utf8"), u = e("./utils"), l = e("./stream/GenericWorker"), a = e("./stream/StreamHelper"), f = e("./defaults"), c = e("./compressedObject"), d = e("./zipObject"), o = e("./generate"), p = e("./nodejsUtils"), m = e("./nodejs/NodejsStreamInputAdapter"), _ = function(e2) {
398
+ e2.slice(-1) === "/" && (e2 = e2.substring(0, e2.length - 1));
399
+ var t2 = e2.lastIndexOf("/");
400
+ return 0 < t2 ? e2.substring(0, t2) : "";
401
+ }, g = function(e2) {
402
+ return e2.slice(-1) !== "/" && (e2 += "/"), e2;
403
+ }, b = function(e2, t2) {
404
+ return t2 = t2 !== void 0 ? t2 : f.createFolders, e2 = g(e2), this.files[e2] || s.call(this, e2, null, { dir: true, createFolders: t2 }), this.files[e2];
405
+ };
406
+ function h(e2) {
407
+ return Object.prototype.toString.call(e2) === "[object RegExp]";
408
+ }
409
+ var n = { load: function() {
410
+ throw new Error("This method has been removed in JSZip 3.0, please check the upgrade guide.");
411
+ }, forEach: function(e2) {
412
+ var t2, r2, n2;
413
+ for (t2 in this.files)
414
+ n2 = this.files[t2], (r2 = t2.slice(this.root.length, t2.length)) && t2.slice(0, this.root.length) === this.root && e2(r2, n2);
415
+ }, filter: function(r2) {
416
+ var n2 = [];
417
+ return this.forEach(function(e2, t2) {
418
+ r2(e2, t2) && n2.push(t2);
419
+ }), n2;
420
+ }, file: function(e2, t2, r2) {
421
+ if (arguments.length !== 1)
422
+ return e2 = this.root + e2, s.call(this, e2, t2, r2), this;
423
+ if (h(e2)) {
424
+ var n2 = e2;
425
+ return this.filter(function(e3, t3) {
426
+ return !t3.dir && n2.test(e3);
427
+ });
428
+ }
429
+ var i2 = this.files[this.root + e2];
430
+ return i2 && !i2.dir ? i2 : null;
431
+ }, folder: function(r2) {
432
+ if (!r2)
433
+ return this;
434
+ if (h(r2))
435
+ return this.filter(function(e3, t3) {
436
+ return t3.dir && r2.test(e3);
437
+ });
438
+ var e2 = this.root + r2, t2 = b.call(this, e2), n2 = this.clone();
439
+ return n2.root = t2.name, n2;
440
+ }, remove: function(r2) {
441
+ r2 = this.root + r2;
442
+ var e2 = this.files[r2];
443
+ if (e2 || (r2.slice(-1) !== "/" && (r2 += "/"), e2 = this.files[r2]), e2 && !e2.dir)
444
+ delete this.files[r2];
445
+ else
446
+ for (var t2 = this.filter(function(e3, t3) {
447
+ return t3.name.slice(0, r2.length) === r2;
448
+ }), n2 = 0; n2 < t2.length; n2++)
449
+ delete this.files[t2[n2].name];
450
+ return this;
451
+ }, generate: function() {
452
+ throw new Error("This method has been removed in JSZip 3.0, please check the upgrade guide.");
453
+ }, generateInternalStream: function(e2) {
454
+ var t2, r2 = {};
455
+ try {
456
+ if ((r2 = u.extend(e2 || {}, { streamFiles: false, compression: "STORE", compressionOptions: null, type: "", platform: "DOS", comment: null, mimeType: "application/zip", encodeFileName: i.utf8encode })).type = r2.type.toLowerCase(), r2.compression = r2.compression.toUpperCase(), r2.type === "binarystring" && (r2.type = "string"), !r2.type)
457
+ throw new Error("No output type specified.");
458
+ u.checkSupport(r2.type), r2.platform !== "darwin" && r2.platform !== "freebsd" && r2.platform !== "linux" && r2.platform !== "sunos" || (r2.platform = "UNIX"), r2.platform === "win32" && (r2.platform = "DOS");
459
+ var n2 = r2.comment || this.comment || "";
460
+ t2 = o.generateWorker(this, r2, n2);
461
+ } catch (e3) {
462
+ (t2 = new l("error")).error(e3);
463
+ }
464
+ return new a(t2, r2.type || "string", r2.mimeType);
465
+ }, generateAsync: function(e2, t2) {
466
+ return this.generateInternalStream(e2).accumulate(t2);
467
+ }, generateNodeStream: function(e2, t2) {
468
+ return (e2 = e2 || {}).type || (e2.type = "nodebuffer"), this.generateInternalStream(e2).toNodejsStream(t2);
469
+ } };
470
+ t.exports = n;
471
+ }, { "./compressedObject": 2, "./defaults": 5, "./generate": 9, "./nodejs/NodejsStreamInputAdapter": 12, "./nodejsUtils": 14, "./stream/GenericWorker": 28, "./stream/StreamHelper": 29, "./utf8": 31, "./utils": 32, "./zipObject": 35 }], 16: [function(e, t, r) {
472
+ "use strict";
473
+ t.exports = e("stream");
474
+ }, { stream: void 0 }], 17: [function(e, t, r) {
475
+ "use strict";
476
+ var n = e("./DataReader");
477
+ function i(e2) {
478
+ n.call(this, e2);
479
+ for (var t2 = 0; t2 < this.data.length; t2++)
480
+ e2[t2] = 255 & e2[t2];
481
+ }
482
+ e("../utils").inherits(i, n), i.prototype.byteAt = function(e2) {
483
+ return this.data[this.zero + e2];
484
+ }, i.prototype.lastIndexOfSignature = function(e2) {
485
+ for (var t2 = e2.charCodeAt(0), r2 = e2.charCodeAt(1), n2 = e2.charCodeAt(2), i2 = e2.charCodeAt(3), s = this.length - 4; 0 <= s; --s)
486
+ if (this.data[s] === t2 && this.data[s + 1] === r2 && this.data[s + 2] === n2 && this.data[s + 3] === i2)
487
+ return s - this.zero;
488
+ return -1;
489
+ }, i.prototype.readAndCheckSignature = function(e2) {
490
+ var t2 = e2.charCodeAt(0), r2 = e2.charCodeAt(1), n2 = e2.charCodeAt(2), i2 = e2.charCodeAt(3), s = this.readData(4);
491
+ return t2 === s[0] && r2 === s[1] && n2 === s[2] && i2 === s[3];
492
+ }, i.prototype.readData = function(e2) {
493
+ if (this.checkOffset(e2), e2 === 0)
494
+ return [];
495
+ var t2 = this.data.slice(this.zero + this.index, this.zero + this.index + e2);
496
+ return this.index += e2, t2;
497
+ }, t.exports = i;
498
+ }, { "../utils": 32, "./DataReader": 18 }], 18: [function(e, t, r) {
499
+ "use strict";
500
+ var n = e("../utils");
501
+ function i(e2) {
502
+ this.data = e2, this.length = e2.length, this.index = 0, this.zero = 0;
503
+ }
504
+ i.prototype = { checkOffset: function(e2) {
505
+ this.checkIndex(this.index + e2);
506
+ }, checkIndex: function(e2) {
507
+ if (this.length < this.zero + e2 || e2 < 0)
508
+ throw new Error("End of data reached (data length = " + this.length + ", asked index = " + e2 + "). Corrupted zip ?");
509
+ }, setIndex: function(e2) {
510
+ this.checkIndex(e2), this.index = e2;
511
+ }, skip: function(e2) {
512
+ this.setIndex(this.index + e2);
513
+ }, byteAt: function() {
514
+ }, readInt: function(e2) {
515
+ var t2, r2 = 0;
516
+ for (this.checkOffset(e2), t2 = this.index + e2 - 1; t2 >= this.index; t2--)
517
+ r2 = (r2 << 8) + this.byteAt(t2);
518
+ return this.index += e2, r2;
519
+ }, readString: function(e2) {
520
+ return n.transformTo("string", this.readData(e2));
521
+ }, readData: function() {
522
+ }, lastIndexOfSignature: function() {
523
+ }, readAndCheckSignature: function() {
524
+ }, readDate: function() {
525
+ var e2 = this.readInt(4);
526
+ return new Date(Date.UTC(1980 + (e2 >> 25 & 127), (e2 >> 21 & 15) - 1, e2 >> 16 & 31, e2 >> 11 & 31, e2 >> 5 & 63, (31 & e2) << 1));
527
+ } }, t.exports = i;
528
+ }, { "../utils": 32 }], 19: [function(e, t, r) {
529
+ "use strict";
530
+ var n = e("./Uint8ArrayReader");
531
+ function i(e2) {
532
+ n.call(this, e2);
533
+ }
534
+ e("../utils").inherits(i, n), i.prototype.readData = function(e2) {
535
+ this.checkOffset(e2);
536
+ var t2 = this.data.slice(this.zero + this.index, this.zero + this.index + e2);
537
+ return this.index += e2, t2;
538
+ }, t.exports = i;
539
+ }, { "../utils": 32, "./Uint8ArrayReader": 21 }], 20: [function(e, t, r) {
540
+ "use strict";
541
+ var n = e("./DataReader");
542
+ function i(e2) {
543
+ n.call(this, e2);
544
+ }
545
+ e("../utils").inherits(i, n), i.prototype.byteAt = function(e2) {
546
+ return this.data.charCodeAt(this.zero + e2);
547
+ }, i.prototype.lastIndexOfSignature = function(e2) {
548
+ return this.data.lastIndexOf(e2) - this.zero;
549
+ }, i.prototype.readAndCheckSignature = function(e2) {
550
+ return e2 === this.readData(4);
551
+ }, i.prototype.readData = function(e2) {
552
+ this.checkOffset(e2);
553
+ var t2 = this.data.slice(this.zero + this.index, this.zero + this.index + e2);
554
+ return this.index += e2, t2;
555
+ }, t.exports = i;
556
+ }, { "../utils": 32, "./DataReader": 18 }], 21: [function(e, t, r) {
557
+ "use strict";
558
+ var n = e("./ArrayReader");
559
+ function i(e2) {
560
+ n.call(this, e2);
561
+ }
562
+ e("../utils").inherits(i, n), i.prototype.readData = function(e2) {
563
+ if (this.checkOffset(e2), e2 === 0)
564
+ return new Uint8Array(0);
565
+ var t2 = this.data.subarray(this.zero + this.index, this.zero + this.index + e2);
566
+ return this.index += e2, t2;
567
+ }, t.exports = i;
568
+ }, { "../utils": 32, "./ArrayReader": 17 }], 22: [function(e, t, r) {
569
+ "use strict";
570
+ var n = e("../utils"), i = e("../support"), s = e("./ArrayReader"), a = e("./StringReader"), o = e("./NodeBufferReader"), h = e("./Uint8ArrayReader");
571
+ t.exports = function(e2) {
572
+ var t2 = n.getTypeOf(e2);
573
+ return n.checkSupport(t2), t2 !== "string" || i.uint8array ? t2 === "nodebuffer" ? new o(e2) : i.uint8array ? new h(n.transformTo("uint8array", e2)) : new s(n.transformTo("array", e2)) : new a(e2);
574
+ };
575
+ }, { "../support": 30, "../utils": 32, "./ArrayReader": 17, "./NodeBufferReader": 19, "./StringReader": 20, "./Uint8ArrayReader": 21 }], 23: [function(e, t, r) {
576
+ "use strict";
577
+ r.LOCAL_FILE_HEADER = "PK", r.CENTRAL_FILE_HEADER = "PK", r.CENTRAL_DIRECTORY_END = "PK", r.ZIP64_CENTRAL_DIRECTORY_LOCATOR = "PK\x07", r.ZIP64_CENTRAL_DIRECTORY_END = "PK", r.DATA_DESCRIPTOR = "PK\x07\b";
578
+ }, {}], 24: [function(e, t, r) {
579
+ "use strict";
580
+ var n = e("./GenericWorker"), i = e("../utils");
581
+ function s(e2) {
582
+ n.call(this, "ConvertWorker to " + e2), this.destType = e2;
583
+ }
584
+ i.inherits(s, n), s.prototype.processChunk = function(e2) {
585
+ this.push({ data: i.transformTo(this.destType, e2.data), meta: e2.meta });
586
+ }, t.exports = s;
587
+ }, { "../utils": 32, "./GenericWorker": 28 }], 25: [function(e, t, r) {
588
+ "use strict";
589
+ var n = e("./GenericWorker"), i = e("../crc32");
590
+ function s() {
591
+ n.call(this, "Crc32Probe"), this.withStreamInfo("crc32", 0);
592
+ }
593
+ e("../utils").inherits(s, n), s.prototype.processChunk = function(e2) {
594
+ this.streamInfo.crc32 = i(e2.data, this.streamInfo.crc32 || 0), this.push(e2);
595
+ }, t.exports = s;
596
+ }, { "../crc32": 4, "../utils": 32, "./GenericWorker": 28 }], 26: [function(e, t, r) {
597
+ "use strict";
598
+ var n = e("../utils"), i = e("./GenericWorker");
599
+ function s(e2) {
600
+ i.call(this, "DataLengthProbe for " + e2), this.propName = e2, this.withStreamInfo(e2, 0);
601
+ }
602
+ n.inherits(s, i), s.prototype.processChunk = function(e2) {
603
+ if (e2) {
604
+ var t2 = this.streamInfo[this.propName] || 0;
605
+ this.streamInfo[this.propName] = t2 + e2.data.length;
606
+ }
607
+ i.prototype.processChunk.call(this, e2);
608
+ }, t.exports = s;
609
+ }, { "../utils": 32, "./GenericWorker": 28 }], 27: [function(e, t, r) {
610
+ "use strict";
611
+ var n = e("../utils"), i = e("./GenericWorker");
612
+ function s(e2) {
613
+ i.call(this, "DataWorker");
614
+ var t2 = this;
615
+ this.dataIsReady = false, this.index = 0, this.max = 0, this.data = null, this.type = "", this._tickScheduled = false, e2.then(function(e3) {
616
+ t2.dataIsReady = true, t2.data = e3, t2.max = e3 && e3.length || 0, t2.type = n.getTypeOf(e3), t2.isPaused || t2._tickAndRepeat();
617
+ }, function(e3) {
618
+ t2.error(e3);
619
+ });
620
+ }
621
+ n.inherits(s, i), s.prototype.cleanUp = function() {
622
+ i.prototype.cleanUp.call(this), this.data = null;
623
+ }, s.prototype.resume = function() {
624
+ return !!i.prototype.resume.call(this) && (!this._tickScheduled && this.dataIsReady && (this._tickScheduled = true, n.delay(this._tickAndRepeat, [], this)), true);
625
+ }, s.prototype._tickAndRepeat = function() {
626
+ this._tickScheduled = false, this.isPaused || this.isFinished || (this._tick(), this.isFinished || (n.delay(this._tickAndRepeat, [], this), this._tickScheduled = true));
627
+ }, s.prototype._tick = function() {
628
+ if (this.isPaused || this.isFinished)
629
+ return false;
630
+ var e2 = null, t2 = Math.min(this.max, this.index + 16384);
631
+ if (this.index >= this.max)
632
+ return this.end();
633
+ switch (this.type) {
634
+ case "string":
635
+ e2 = this.data.substring(this.index, t2);
636
+ break;
637
+ case "uint8array":
638
+ e2 = this.data.subarray(this.index, t2);
639
+ break;
640
+ case "array":
641
+ case "nodebuffer":
642
+ e2 = this.data.slice(this.index, t2);
643
+ }
644
+ return this.index = t2, this.push({ data: e2, meta: { percent: this.max ? this.index / this.max * 100 : 0 } });
645
+ }, t.exports = s;
646
+ }, { "../utils": 32, "./GenericWorker": 28 }], 28: [function(e, t, r) {
647
+ "use strict";
648
+ function n(e2) {
649
+ this.name = e2 || "default", this.streamInfo = {}, this.generatedError = null, this.extraStreamInfo = {}, this.isPaused = true, this.isFinished = false, this.isLocked = false, this._listeners = { data: [], end: [], error: [] }, this.previous = null;
650
+ }
651
+ n.prototype = { push: function(e2) {
652
+ this.emit("data", e2);
653
+ }, end: function() {
654
+ if (this.isFinished)
655
+ return false;
656
+ this.flush();
657
+ try {
658
+ this.emit("end"), this.cleanUp(), this.isFinished = true;
659
+ } catch (e2) {
660
+ this.emit("error", e2);
661
+ }
662
+ return true;
663
+ }, error: function(e2) {
664
+ return !this.isFinished && (this.isPaused ? this.generatedError = e2 : (this.isFinished = true, this.emit("error", e2), this.previous && this.previous.error(e2), this.cleanUp()), true);
665
+ }, on: function(e2, t2) {
666
+ return this._listeners[e2].push(t2), this;
667
+ }, cleanUp: function() {
668
+ this.streamInfo = this.generatedError = this.extraStreamInfo = null, this._listeners = [];
669
+ }, emit: function(e2, t2) {
670
+ if (this._listeners[e2])
671
+ for (var r2 = 0; r2 < this._listeners[e2].length; r2++)
672
+ this._listeners[e2][r2].call(this, t2);
673
+ }, pipe: function(e2) {
674
+ return e2.registerPrevious(this);
675
+ }, registerPrevious: function(e2) {
676
+ if (this.isLocked)
677
+ throw new Error("The stream '" + this + "' has already been used.");
678
+ this.streamInfo = e2.streamInfo, this.mergeStreamInfo(), this.previous = e2;
679
+ var t2 = this;
680
+ return e2.on("data", function(e3) {
681
+ t2.processChunk(e3);
682
+ }), e2.on("end", function() {
683
+ t2.end();
684
+ }), e2.on("error", function(e3) {
685
+ t2.error(e3);
686
+ }), this;
687
+ }, pause: function() {
688
+ return !this.isPaused && !this.isFinished && (this.isPaused = true, this.previous && this.previous.pause(), true);
689
+ }, resume: function() {
690
+ if (!this.isPaused || this.isFinished)
691
+ return false;
692
+ var e2 = this.isPaused = false;
693
+ return this.generatedError && (this.error(this.generatedError), e2 = true), this.previous && this.previous.resume(), !e2;
694
+ }, flush: function() {
695
+ }, processChunk: function(e2) {
696
+ this.push(e2);
697
+ }, withStreamInfo: function(e2, t2) {
698
+ return this.extraStreamInfo[e2] = t2, this.mergeStreamInfo(), this;
699
+ }, mergeStreamInfo: function() {
700
+ for (var e2 in this.extraStreamInfo)
701
+ Object.prototype.hasOwnProperty.call(this.extraStreamInfo, e2) && (this.streamInfo[e2] = this.extraStreamInfo[e2]);
702
+ }, lock: function() {
703
+ if (this.isLocked)
704
+ throw new Error("The stream '" + this + "' has already been used.");
705
+ this.isLocked = true, this.previous && this.previous.lock();
706
+ }, toString: function() {
707
+ var e2 = "Worker " + this.name;
708
+ return this.previous ? this.previous + " -> " + e2 : e2;
709
+ } }, t.exports = n;
710
+ }, {}], 29: [function(e, t, r) {
711
+ "use strict";
712
+ var h = e("../utils"), i = e("./ConvertWorker"), s = e("./GenericWorker"), u = e("../base64"), n = e("../support"), a = e("../external"), o = null;
713
+ if (n.nodestream)
714
+ try {
715
+ o = e("../nodejs/NodejsStreamOutputAdapter");
716
+ } catch (e2) {
717
+ }
718
+ function l(e2, o2) {
719
+ return new a.Promise(function(t2, r2) {
720
+ var n2 = [], i2 = e2._internalType, s2 = e2._outputType, a2 = e2._mimeType;
721
+ e2.on("data", function(e3, t3) {
722
+ n2.push(e3), o2 && o2(t3);
723
+ }).on("error", function(e3) {
724
+ n2 = [], r2(e3);
725
+ }).on("end", function() {
726
+ try {
727
+ var e3 = function(e4, t3, r3) {
728
+ switch (e4) {
729
+ case "blob":
730
+ return h.newBlob(h.transformTo("arraybuffer", t3), r3);
731
+ case "base64":
732
+ return u.encode(t3);
733
+ default:
734
+ return h.transformTo(e4, t3);
735
+ }
736
+ }(s2, function(e4, t3) {
737
+ var r3, n3 = 0, i3 = null, s3 = 0;
738
+ for (r3 = 0; r3 < t3.length; r3++)
739
+ s3 += t3[r3].length;
740
+ switch (e4) {
741
+ case "string":
742
+ return t3.join("");
743
+ case "array":
744
+ return Array.prototype.concat.apply([], t3);
745
+ case "uint8array":
746
+ for (i3 = new Uint8Array(s3), r3 = 0; r3 < t3.length; r3++)
747
+ i3.set(t3[r3], n3), n3 += t3[r3].length;
748
+ return i3;
749
+ case "nodebuffer":
750
+ return Buffer.concat(t3);
751
+ default:
752
+ throw new Error("concat : unsupported type '" + e4 + "'");
753
+ }
754
+ }(i2, n2), a2);
755
+ t2(e3);
756
+ } catch (e4) {
757
+ r2(e4);
758
+ }
759
+ n2 = [];
760
+ }).resume();
761
+ });
762
+ }
763
+ function f(e2, t2, r2) {
764
+ var n2 = t2;
765
+ switch (t2) {
766
+ case "blob":
767
+ case "arraybuffer":
768
+ n2 = "uint8array";
769
+ break;
770
+ case "base64":
771
+ n2 = "string";
772
+ }
773
+ try {
774
+ this._internalType = n2, this._outputType = t2, this._mimeType = r2, h.checkSupport(n2), this._worker = e2.pipe(new i(n2)), e2.lock();
775
+ } catch (e3) {
776
+ this._worker = new s("error"), this._worker.error(e3);
777
+ }
778
+ }
779
+ f.prototype = { accumulate: function(e2) {
780
+ return l(this, e2);
781
+ }, on: function(e2, t2) {
782
+ var r2 = this;
783
+ return e2 === "data" ? this._worker.on(e2, function(e3) {
784
+ t2.call(r2, e3.data, e3.meta);
785
+ }) : this._worker.on(e2, function() {
786
+ h.delay(t2, arguments, r2);
787
+ }), this;
788
+ }, resume: function() {
789
+ return h.delay(this._worker.resume, [], this._worker), this;
790
+ }, pause: function() {
791
+ return this._worker.pause(), this;
792
+ }, toNodejsStream: function(e2) {
793
+ if (h.checkSupport("nodestream"), this._outputType !== "nodebuffer")
794
+ throw new Error(this._outputType + " is not supported by this method");
795
+ return new o(this, { objectMode: this._outputType !== "nodebuffer" }, e2);
796
+ } }, t.exports = f;
797
+ }, { "../base64": 1, "../external": 6, "../nodejs/NodejsStreamOutputAdapter": 13, "../support": 30, "../utils": 32, "./ConvertWorker": 24, "./GenericWorker": 28 }], 30: [function(e, t, r) {
798
+ "use strict";
799
+ if (r.base64 = true, r.array = true, r.string = true, r.arraybuffer = typeof ArrayBuffer != "undefined" && typeof Uint8Array != "undefined", r.nodebuffer = typeof Buffer != "undefined", r.uint8array = typeof Uint8Array != "undefined", typeof ArrayBuffer == "undefined")
800
+ r.blob = false;
801
+ else {
802
+ var n = new ArrayBuffer(0);
803
+ try {
804
+ r.blob = new Blob([n], { type: "application/zip" }).size === 0;
805
+ } catch (e2) {
806
+ try {
807
+ var i = new (self.BlobBuilder || self.WebKitBlobBuilder || self.MozBlobBuilder || self.MSBlobBuilder)();
808
+ i.append(n), r.blob = i.getBlob("application/zip").size === 0;
809
+ } catch (e3) {
810
+ r.blob = false;
811
+ }
812
+ }
813
+ }
814
+ try {
815
+ r.nodestream = !!e("readable-stream").Readable;
816
+ } catch (e2) {
817
+ r.nodestream = false;
818
+ }
819
+ }, { "readable-stream": 16 }], 31: [function(e, t, s) {
820
+ "use strict";
821
+ for (var o = e("./utils"), h = e("./support"), r = e("./nodejsUtils"), n = e("./stream/GenericWorker"), u = new Array(256), i = 0; i < 256; i++)
822
+ u[i] = 252 <= i ? 6 : 248 <= i ? 5 : 240 <= i ? 4 : 224 <= i ? 3 : 192 <= i ? 2 : 1;
823
+ u[254] = u[254] = 1;
824
+ function a() {
825
+ n.call(this, "utf-8 decode"), this.leftOver = null;
826
+ }
827
+ function l() {
828
+ n.call(this, "utf-8 encode");
829
+ }
830
+ s.utf8encode = function(e2) {
831
+ return h.nodebuffer ? r.newBufferFrom(e2, "utf-8") : function(e3) {
832
+ var t2, r2, n2, i2, s2, a2 = e3.length, o2 = 0;
833
+ for (i2 = 0; i2 < a2; i2++)
834
+ (64512 & (r2 = e3.charCodeAt(i2))) == 55296 && i2 + 1 < a2 && (64512 & (n2 = e3.charCodeAt(i2 + 1))) == 56320 && (r2 = 65536 + (r2 - 55296 << 10) + (n2 - 56320), i2++), o2 += r2 < 128 ? 1 : r2 < 2048 ? 2 : r2 < 65536 ? 3 : 4;
835
+ for (t2 = h.uint8array ? new Uint8Array(o2) : new Array(o2), i2 = s2 = 0; s2 < o2; i2++)
836
+ (64512 & (r2 = e3.charCodeAt(i2))) == 55296 && i2 + 1 < a2 && (64512 & (n2 = e3.charCodeAt(i2 + 1))) == 56320 && (r2 = 65536 + (r2 - 55296 << 10) + (n2 - 56320), i2++), r2 < 128 ? t2[s2++] = r2 : (r2 < 2048 ? t2[s2++] = 192 | r2 >>> 6 : (r2 < 65536 ? t2[s2++] = 224 | r2 >>> 12 : (t2[s2++] = 240 | r2 >>> 18, t2[s2++] = 128 | r2 >>> 12 & 63), t2[s2++] = 128 | r2 >>> 6 & 63), t2[s2++] = 128 | 63 & r2);
837
+ return t2;
838
+ }(e2);
839
+ }, s.utf8decode = function(e2) {
840
+ return h.nodebuffer ? o.transformTo("nodebuffer", e2).toString("utf-8") : function(e3) {
841
+ var t2, r2, n2, i2, s2 = e3.length, a2 = new Array(2 * s2);
842
+ for (t2 = r2 = 0; t2 < s2; )
843
+ if ((n2 = e3[t2++]) < 128)
844
+ a2[r2++] = n2;
845
+ else if (4 < (i2 = u[n2]))
846
+ a2[r2++] = 65533, t2 += i2 - 1;
847
+ else {
848
+ for (n2 &= i2 === 2 ? 31 : i2 === 3 ? 15 : 7; 1 < i2 && t2 < s2; )
849
+ n2 = n2 << 6 | 63 & e3[t2++], i2--;
850
+ 1 < i2 ? a2[r2++] = 65533 : n2 < 65536 ? a2[r2++] = n2 : (n2 -= 65536, a2[r2++] = 55296 | n2 >> 10 & 1023, a2[r2++] = 56320 | 1023 & n2);
851
+ }
852
+ return a2.length !== r2 && (a2.subarray ? a2 = a2.subarray(0, r2) : a2.length = r2), o.applyFromCharCode(a2);
853
+ }(e2 = o.transformTo(h.uint8array ? "uint8array" : "array", e2));
854
+ }, o.inherits(a, n), a.prototype.processChunk = function(e2) {
855
+ var t2 = o.transformTo(h.uint8array ? "uint8array" : "array", e2.data);
856
+ if (this.leftOver && this.leftOver.length) {
857
+ if (h.uint8array) {
858
+ var r2 = t2;
859
+ (t2 = new Uint8Array(r2.length + this.leftOver.length)).set(this.leftOver, 0), t2.set(r2, this.leftOver.length);
860
+ } else
861
+ t2 = this.leftOver.concat(t2);
862
+ this.leftOver = null;
863
+ }
864
+ var n2 = function(e3, t3) {
865
+ var r3;
866
+ for ((t3 = t3 || e3.length) > e3.length && (t3 = e3.length), r3 = t3 - 1; 0 <= r3 && (192 & e3[r3]) == 128; )
867
+ r3--;
868
+ return r3 < 0 ? t3 : r3 === 0 ? t3 : r3 + u[e3[r3]] > t3 ? r3 : t3;
869
+ }(t2), i2 = t2;
870
+ n2 !== t2.length && (h.uint8array ? (i2 = t2.subarray(0, n2), this.leftOver = t2.subarray(n2, t2.length)) : (i2 = t2.slice(0, n2), this.leftOver = t2.slice(n2, t2.length))), this.push({ data: s.utf8decode(i2), meta: e2.meta });
871
+ }, a.prototype.flush = function() {
872
+ this.leftOver && this.leftOver.length && (this.push({ data: s.utf8decode(this.leftOver), meta: {} }), this.leftOver = null);
873
+ }, s.Utf8DecodeWorker = a, o.inherits(l, n), l.prototype.processChunk = function(e2) {
874
+ this.push({ data: s.utf8encode(e2.data), meta: e2.meta });
875
+ }, s.Utf8EncodeWorker = l;
876
+ }, { "./nodejsUtils": 14, "./stream/GenericWorker": 28, "./support": 30, "./utils": 32 }], 32: [function(e, t, a) {
877
+ "use strict";
878
+ var o = e("./support"), h = e("./base64"), r = e("./nodejsUtils"), u = e("./external");
879
+ function n(e2) {
880
+ return e2;
881
+ }
882
+ function l(e2, t2) {
883
+ for (var r2 = 0; r2 < e2.length; ++r2)
884
+ t2[r2] = 255 & e2.charCodeAt(r2);
885
+ return t2;
886
+ }
887
+ e("setimmediate"), a.newBlob = function(t2, r2) {
888
+ a.checkSupport("blob");
889
+ try {
890
+ return new Blob([t2], { type: r2 });
891
+ } catch (e2) {
892
+ try {
893
+ var n2 = new (self.BlobBuilder || self.WebKitBlobBuilder || self.MozBlobBuilder || self.MSBlobBuilder)();
894
+ return n2.append(t2), n2.getBlob(r2);
895
+ } catch (e3) {
896
+ throw new Error("Bug : can't construct the Blob.");
897
+ }
898
+ }
899
+ };
900
+ var i = { stringifyByChunk: function(e2, t2, r2) {
901
+ var n2 = [], i2 = 0, s2 = e2.length;
902
+ if (s2 <= r2)
903
+ return String.fromCharCode.apply(null, e2);
904
+ for (; i2 < s2; )
905
+ t2 === "array" || t2 === "nodebuffer" ? n2.push(String.fromCharCode.apply(null, e2.slice(i2, Math.min(i2 + r2, s2)))) : n2.push(String.fromCharCode.apply(null, e2.subarray(i2, Math.min(i2 + r2, s2)))), i2 += r2;
906
+ return n2.join("");
907
+ }, stringifyByChar: function(e2) {
908
+ for (var t2 = "", r2 = 0; r2 < e2.length; r2++)
909
+ t2 += String.fromCharCode(e2[r2]);
910
+ return t2;
911
+ }, applyCanBeUsed: { uint8array: function() {
912
+ try {
913
+ return o.uint8array && String.fromCharCode.apply(null, new Uint8Array(1)).length === 1;
914
+ } catch (e2) {
915
+ return false;
916
+ }
917
+ }(), nodebuffer: function() {
918
+ try {
919
+ return o.nodebuffer && String.fromCharCode.apply(null, r.allocBuffer(1)).length === 1;
920
+ } catch (e2) {
921
+ return false;
922
+ }
923
+ }() } };
924
+ function s(e2) {
925
+ var t2 = 65536, r2 = a.getTypeOf(e2), n2 = true;
926
+ if (r2 === "uint8array" ? n2 = i.applyCanBeUsed.uint8array : r2 === "nodebuffer" && (n2 = i.applyCanBeUsed.nodebuffer), n2)
927
+ for (; 1 < t2; )
928
+ try {
929
+ return i.stringifyByChunk(e2, r2, t2);
930
+ } catch (e3) {
931
+ t2 = Math.floor(t2 / 2);
932
+ }
933
+ return i.stringifyByChar(e2);
934
+ }
935
+ function f(e2, t2) {
936
+ for (var r2 = 0; r2 < e2.length; r2++)
937
+ t2[r2] = e2[r2];
938
+ return t2;
939
+ }
940
+ a.applyFromCharCode = s;
941
+ var c = {};
942
+ c.string = { string: n, array: function(e2) {
943
+ return l(e2, new Array(e2.length));
944
+ }, arraybuffer: function(e2) {
945
+ return c.string.uint8array(e2).buffer;
946
+ }, uint8array: function(e2) {
947
+ return l(e2, new Uint8Array(e2.length));
948
+ }, nodebuffer: function(e2) {
949
+ return l(e2, r.allocBuffer(e2.length));
950
+ } }, c.array = { string: s, array: n, arraybuffer: function(e2) {
951
+ return new Uint8Array(e2).buffer;
952
+ }, uint8array: function(e2) {
953
+ return new Uint8Array(e2);
954
+ }, nodebuffer: function(e2) {
955
+ return r.newBufferFrom(e2);
956
+ } }, c.arraybuffer = { string: function(e2) {
957
+ return s(new Uint8Array(e2));
958
+ }, array: function(e2) {
959
+ return f(new Uint8Array(e2), new Array(e2.byteLength));
960
+ }, arraybuffer: n, uint8array: function(e2) {
961
+ return new Uint8Array(e2);
962
+ }, nodebuffer: function(e2) {
963
+ return r.newBufferFrom(new Uint8Array(e2));
964
+ } }, c.uint8array = { string: s, array: function(e2) {
965
+ return f(e2, new Array(e2.length));
966
+ }, arraybuffer: function(e2) {
967
+ return e2.buffer;
968
+ }, uint8array: n, nodebuffer: function(e2) {
969
+ return r.newBufferFrom(e2);
970
+ } }, c.nodebuffer = { string: s, array: function(e2) {
971
+ return f(e2, new Array(e2.length));
972
+ }, arraybuffer: function(e2) {
973
+ return c.nodebuffer.uint8array(e2).buffer;
974
+ }, uint8array: function(e2) {
975
+ return f(e2, new Uint8Array(e2.length));
976
+ }, nodebuffer: n }, a.transformTo = function(e2, t2) {
977
+ if (t2 = t2 || "", !e2)
978
+ return t2;
979
+ a.checkSupport(e2);
980
+ var r2 = a.getTypeOf(t2);
981
+ return c[r2][e2](t2);
982
+ }, a.resolve = function(e2) {
983
+ for (var t2 = e2.split("/"), r2 = [], n2 = 0; n2 < t2.length; n2++) {
984
+ var i2 = t2[n2];
985
+ i2 === "." || i2 === "" && n2 !== 0 && n2 !== t2.length - 1 || (i2 === ".." ? r2.pop() : r2.push(i2));
986
+ }
987
+ return r2.join("/");
988
+ }, a.getTypeOf = function(e2) {
989
+ return typeof e2 == "string" ? "string" : Object.prototype.toString.call(e2) === "[object Array]" ? "array" : o.nodebuffer && r.isBuffer(e2) ? "nodebuffer" : o.uint8array && e2 instanceof Uint8Array ? "uint8array" : o.arraybuffer && e2 instanceof ArrayBuffer ? "arraybuffer" : void 0;
990
+ }, a.checkSupport = function(e2) {
991
+ if (!o[e2.toLowerCase()])
992
+ throw new Error(e2 + " is not supported by this platform");
993
+ }, a.MAX_VALUE_16BITS = 65535, a.MAX_VALUE_32BITS = -1, a.pretty = function(e2) {
994
+ var t2, r2, n2 = "";
995
+ for (r2 = 0; r2 < (e2 || "").length; r2++)
996
+ n2 += "\\x" + ((t2 = e2.charCodeAt(r2)) < 16 ? "0" : "") + t2.toString(16).toUpperCase();
997
+ return n2;
998
+ }, a.delay = function(e2, t2, r2) {
999
+ setImmediate(function() {
1000
+ e2.apply(r2 || null, t2 || []);
1001
+ });
1002
+ }, a.inherits = function(e2, t2) {
1003
+ function r2() {
1004
+ }
1005
+ r2.prototype = t2.prototype, e2.prototype = new r2();
1006
+ }, a.extend = function() {
1007
+ var e2, t2, r2 = {};
1008
+ for (e2 = 0; e2 < arguments.length; e2++)
1009
+ for (t2 in arguments[e2])
1010
+ Object.prototype.hasOwnProperty.call(arguments[e2], t2) && r2[t2] === void 0 && (r2[t2] = arguments[e2][t2]);
1011
+ return r2;
1012
+ }, a.prepareContent = function(r2, e2, n2, i2, s2) {
1013
+ return u.Promise.resolve(e2).then(function(n3) {
1014
+ return o.blob && (n3 instanceof Blob || ["[object File]", "[object Blob]"].indexOf(Object.prototype.toString.call(n3)) !== -1) && typeof FileReader != "undefined" ? new u.Promise(function(t2, r3) {
1015
+ var e3 = new FileReader();
1016
+ e3.onload = function(e4) {
1017
+ t2(e4.target.result);
1018
+ }, e3.onerror = function(e4) {
1019
+ r3(e4.target.error);
1020
+ }, e3.readAsArrayBuffer(n3);
1021
+ }) : n3;
1022
+ }).then(function(e3) {
1023
+ var t2 = a.getTypeOf(e3);
1024
+ return t2 ? (t2 === "arraybuffer" ? e3 = a.transformTo("uint8array", e3) : t2 === "string" && (s2 ? e3 = h.decode(e3) : n2 && i2 !== true && (e3 = function(e4) {
1025
+ return l(e4, o.uint8array ? new Uint8Array(e4.length) : new Array(e4.length));
1026
+ }(e3))), e3) : u.Promise.reject(new Error("Can't read the data of '" + r2 + "'. Is it in a supported JavaScript type (String, Blob, ArrayBuffer, etc) ?"));
1027
+ });
1028
+ };
1029
+ }, { "./base64": 1, "./external": 6, "./nodejsUtils": 14, "./support": 30, setimmediate: 54 }], 33: [function(e, t, r) {
1030
+ "use strict";
1031
+ var n = e("./reader/readerFor"), i = e("./utils"), s = e("./signature"), a = e("./zipEntry"), o = e("./support");
1032
+ function h(e2) {
1033
+ this.files = [], this.loadOptions = e2;
1034
+ }
1035
+ h.prototype = { checkSignature: function(e2) {
1036
+ if (!this.reader.readAndCheckSignature(e2)) {
1037
+ this.reader.index -= 4;
1038
+ var t2 = this.reader.readString(4);
1039
+ throw new Error("Corrupted zip or bug: unexpected signature (" + i.pretty(t2) + ", expected " + i.pretty(e2) + ")");
1040
+ }
1041
+ }, isSignature: function(e2, t2) {
1042
+ var r2 = this.reader.index;
1043
+ this.reader.setIndex(e2);
1044
+ var n2 = this.reader.readString(4) === t2;
1045
+ return this.reader.setIndex(r2), n2;
1046
+ }, readBlockEndOfCentral: function() {
1047
+ this.diskNumber = this.reader.readInt(2), this.diskWithCentralDirStart = this.reader.readInt(2), this.centralDirRecordsOnThisDisk = this.reader.readInt(2), this.centralDirRecords = this.reader.readInt(2), this.centralDirSize = this.reader.readInt(4), this.centralDirOffset = this.reader.readInt(4), this.zipCommentLength = this.reader.readInt(2);
1048
+ var e2 = this.reader.readData(this.zipCommentLength), t2 = o.uint8array ? "uint8array" : "array", r2 = i.transformTo(t2, e2);
1049
+ this.zipComment = this.loadOptions.decodeFileName(r2);
1050
+ }, readBlockZip64EndOfCentral: function() {
1051
+ this.zip64EndOfCentralSize = this.reader.readInt(8), this.reader.skip(4), this.diskNumber = this.reader.readInt(4), this.diskWithCentralDirStart = this.reader.readInt(4), this.centralDirRecordsOnThisDisk = this.reader.readInt(8), this.centralDirRecords = this.reader.readInt(8), this.centralDirSize = this.reader.readInt(8), this.centralDirOffset = this.reader.readInt(8), this.zip64ExtensibleData = {};
1052
+ for (var e2, t2, r2, n2 = this.zip64EndOfCentralSize - 44; 0 < n2; )
1053
+ e2 = this.reader.readInt(2), t2 = this.reader.readInt(4), r2 = this.reader.readData(t2), this.zip64ExtensibleData[e2] = { id: e2, length: t2, value: r2 };
1054
+ }, readBlockZip64EndOfCentralLocator: function() {
1055
+ if (this.diskWithZip64CentralDirStart = this.reader.readInt(4), this.relativeOffsetEndOfZip64CentralDir = this.reader.readInt(8), this.disksCount = this.reader.readInt(4), 1 < this.disksCount)
1056
+ throw new Error("Multi-volumes zip are not supported");
1057
+ }, readLocalFiles: function() {
1058
+ var e2, t2;
1059
+ for (e2 = 0; e2 < this.files.length; e2++)
1060
+ t2 = this.files[e2], this.reader.setIndex(t2.localHeaderOffset), this.checkSignature(s.LOCAL_FILE_HEADER), t2.readLocalPart(this.reader), t2.handleUTF8(), t2.processAttributes();
1061
+ }, readCentralDir: function() {
1062
+ var e2;
1063
+ for (this.reader.setIndex(this.centralDirOffset); this.reader.readAndCheckSignature(s.CENTRAL_FILE_HEADER); )
1064
+ (e2 = new a({ zip64: this.zip64 }, this.loadOptions)).readCentralPart(this.reader), this.files.push(e2);
1065
+ if (this.centralDirRecords !== this.files.length && this.centralDirRecords !== 0 && this.files.length === 0)
1066
+ throw new Error("Corrupted zip or bug: expected " + this.centralDirRecords + " records in central dir, got " + this.files.length);
1067
+ }, readEndOfCentral: function() {
1068
+ var e2 = this.reader.lastIndexOfSignature(s.CENTRAL_DIRECTORY_END);
1069
+ if (e2 < 0)
1070
+ throw !this.isSignature(0, s.LOCAL_FILE_HEADER) ? new Error("Can't find end of central directory : is this a zip file ? If it is, see https://stuk.github.io/jszip/documentation/howto/read_zip.html") : new Error("Corrupted zip: can't find end of central directory");
1071
+ this.reader.setIndex(e2);
1072
+ var t2 = e2;
1073
+ if (this.checkSignature(s.CENTRAL_DIRECTORY_END), this.readBlockEndOfCentral(), this.diskNumber === i.MAX_VALUE_16BITS || this.diskWithCentralDirStart === i.MAX_VALUE_16BITS || this.centralDirRecordsOnThisDisk === i.MAX_VALUE_16BITS || this.centralDirRecords === i.MAX_VALUE_16BITS || this.centralDirSize === i.MAX_VALUE_32BITS || this.centralDirOffset === i.MAX_VALUE_32BITS) {
1074
+ if (this.zip64 = true, (e2 = this.reader.lastIndexOfSignature(s.ZIP64_CENTRAL_DIRECTORY_LOCATOR)) < 0)
1075
+ throw new Error("Corrupted zip: can't find the ZIP64 end of central directory locator");
1076
+ if (this.reader.setIndex(e2), this.checkSignature(s.ZIP64_CENTRAL_DIRECTORY_LOCATOR), this.readBlockZip64EndOfCentralLocator(), !this.isSignature(this.relativeOffsetEndOfZip64CentralDir, s.ZIP64_CENTRAL_DIRECTORY_END) && (this.relativeOffsetEndOfZip64CentralDir = this.reader.lastIndexOfSignature(s.ZIP64_CENTRAL_DIRECTORY_END), this.relativeOffsetEndOfZip64CentralDir < 0))
1077
+ throw new Error("Corrupted zip: can't find the ZIP64 end of central directory");
1078
+ this.reader.setIndex(this.relativeOffsetEndOfZip64CentralDir), this.checkSignature(s.ZIP64_CENTRAL_DIRECTORY_END), this.readBlockZip64EndOfCentral();
1079
+ }
1080
+ var r2 = this.centralDirOffset + this.centralDirSize;
1081
+ this.zip64 && (r2 += 20, r2 += 12 + this.zip64EndOfCentralSize);
1082
+ var n2 = t2 - r2;
1083
+ if (0 < n2)
1084
+ this.isSignature(t2, s.CENTRAL_FILE_HEADER) || (this.reader.zero = n2);
1085
+ else if (n2 < 0)
1086
+ throw new Error("Corrupted zip: missing " + Math.abs(n2) + " bytes.");
1087
+ }, prepareReader: function(e2) {
1088
+ this.reader = n(e2);
1089
+ }, load: function(e2) {
1090
+ this.prepareReader(e2), this.readEndOfCentral(), this.readCentralDir(), this.readLocalFiles();
1091
+ } }, t.exports = h;
1092
+ }, { "./reader/readerFor": 22, "./signature": 23, "./support": 30, "./utils": 32, "./zipEntry": 34 }], 34: [function(e, t, r) {
1093
+ "use strict";
1094
+ var n = e("./reader/readerFor"), s = e("./utils"), i = e("./compressedObject"), a = e("./crc32"), o = e("./utf8"), h = e("./compressions"), u = e("./support");
1095
+ function l(e2, t2) {
1096
+ this.options = e2, this.loadOptions = t2;
1097
+ }
1098
+ l.prototype = { isEncrypted: function() {
1099
+ return (1 & this.bitFlag) == 1;
1100
+ }, useUTF8: function() {
1101
+ return (2048 & this.bitFlag) == 2048;
1102
+ }, readLocalPart: function(e2) {
1103
+ var t2, r2;
1104
+ if (e2.skip(22), this.fileNameLength = e2.readInt(2), r2 = e2.readInt(2), this.fileName = e2.readData(this.fileNameLength), e2.skip(r2), this.compressedSize === -1 || this.uncompressedSize === -1)
1105
+ throw new Error("Bug or corrupted zip : didn't get enough information from the central directory (compressedSize === -1 || uncompressedSize === -1)");
1106
+ if ((t2 = function(e3) {
1107
+ for (var t3 in h)
1108
+ if (Object.prototype.hasOwnProperty.call(h, t3) && h[t3].magic === e3)
1109
+ return h[t3];
1110
+ return null;
1111
+ }(this.compressionMethod)) === null)
1112
+ throw new Error("Corrupted zip : compression " + s.pretty(this.compressionMethod) + " unknown (inner file : " + s.transformTo("string", this.fileName) + ")");
1113
+ this.decompressed = new i(this.compressedSize, this.uncompressedSize, this.crc32, t2, e2.readData(this.compressedSize));
1114
+ }, readCentralPart: function(e2) {
1115
+ this.versionMadeBy = e2.readInt(2), e2.skip(2), this.bitFlag = e2.readInt(2), this.compressionMethod = e2.readString(2), this.date = e2.readDate(), this.crc32 = e2.readInt(4), this.compressedSize = e2.readInt(4), this.uncompressedSize = e2.readInt(4);
1116
+ var t2 = e2.readInt(2);
1117
+ if (this.extraFieldsLength = e2.readInt(2), this.fileCommentLength = e2.readInt(2), this.diskNumberStart = e2.readInt(2), this.internalFileAttributes = e2.readInt(2), this.externalFileAttributes = e2.readInt(4), this.localHeaderOffset = e2.readInt(4), this.isEncrypted())
1118
+ throw new Error("Encrypted zip are not supported");
1119
+ e2.skip(t2), this.readExtraFields(e2), this.parseZIP64ExtraField(e2), this.fileComment = e2.readData(this.fileCommentLength);
1120
+ }, processAttributes: function() {
1121
+ this.unixPermissions = null, this.dosPermissions = null;
1122
+ var e2 = this.versionMadeBy >> 8;
1123
+ this.dir = !!(16 & this.externalFileAttributes), e2 == 0 && (this.dosPermissions = 63 & this.externalFileAttributes), e2 == 3 && (this.unixPermissions = this.externalFileAttributes >> 16 & 65535), this.dir || this.fileNameStr.slice(-1) !== "/" || (this.dir = true);
1124
+ }, parseZIP64ExtraField: function() {
1125
+ if (this.extraFields[1]) {
1126
+ var e2 = n(this.extraFields[1].value);
1127
+ this.uncompressedSize === s.MAX_VALUE_32BITS && (this.uncompressedSize = e2.readInt(8)), this.compressedSize === s.MAX_VALUE_32BITS && (this.compressedSize = e2.readInt(8)), this.localHeaderOffset === s.MAX_VALUE_32BITS && (this.localHeaderOffset = e2.readInt(8)), this.diskNumberStart === s.MAX_VALUE_32BITS && (this.diskNumberStart = e2.readInt(4));
1128
+ }
1129
+ }, readExtraFields: function(e2) {
1130
+ var t2, r2, n2, i2 = e2.index + this.extraFieldsLength;
1131
+ for (this.extraFields || (this.extraFields = {}); e2.index + 4 < i2; )
1132
+ t2 = e2.readInt(2), r2 = e2.readInt(2), n2 = e2.readData(r2), this.extraFields[t2] = { id: t2, length: r2, value: n2 };
1133
+ e2.setIndex(i2);
1134
+ }, handleUTF8: function() {
1135
+ var e2 = u.uint8array ? "uint8array" : "array";
1136
+ if (this.useUTF8())
1137
+ this.fileNameStr = o.utf8decode(this.fileName), this.fileCommentStr = o.utf8decode(this.fileComment);
1138
+ else {
1139
+ var t2 = this.findExtraFieldUnicodePath();
1140
+ if (t2 !== null)
1141
+ this.fileNameStr = t2;
1142
+ else {
1143
+ var r2 = s.transformTo(e2, this.fileName);
1144
+ this.fileNameStr = this.loadOptions.decodeFileName(r2);
1145
+ }
1146
+ var n2 = this.findExtraFieldUnicodeComment();
1147
+ if (n2 !== null)
1148
+ this.fileCommentStr = n2;
1149
+ else {
1150
+ var i2 = s.transformTo(e2, this.fileComment);
1151
+ this.fileCommentStr = this.loadOptions.decodeFileName(i2);
1152
+ }
1153
+ }
1154
+ }, findExtraFieldUnicodePath: function() {
1155
+ var e2 = this.extraFields[28789];
1156
+ if (e2) {
1157
+ var t2 = n(e2.value);
1158
+ return t2.readInt(1) !== 1 ? null : a(this.fileName) !== t2.readInt(4) ? null : o.utf8decode(t2.readData(e2.length - 5));
1159
+ }
1160
+ return null;
1161
+ }, findExtraFieldUnicodeComment: function() {
1162
+ var e2 = this.extraFields[25461];
1163
+ if (e2) {
1164
+ var t2 = n(e2.value);
1165
+ return t2.readInt(1) !== 1 ? null : a(this.fileComment) !== t2.readInt(4) ? null : o.utf8decode(t2.readData(e2.length - 5));
1166
+ }
1167
+ return null;
1168
+ } }, t.exports = l;
1169
+ }, { "./compressedObject": 2, "./compressions": 3, "./crc32": 4, "./reader/readerFor": 22, "./support": 30, "./utf8": 31, "./utils": 32 }], 35: [function(e, t, r) {
1170
+ "use strict";
1171
+ function n(e2, t2, r2) {
1172
+ this.name = e2, this.dir = r2.dir, this.date = r2.date, this.comment = r2.comment, this.unixPermissions = r2.unixPermissions, this.dosPermissions = r2.dosPermissions, this._data = t2, this._dataBinary = r2.binary, this.options = { compression: r2.compression, compressionOptions: r2.compressionOptions };
1173
+ }
1174
+ var s = e("./stream/StreamHelper"), i = e("./stream/DataWorker"), a = e("./utf8"), o = e("./compressedObject"), h = e("./stream/GenericWorker");
1175
+ n.prototype = { internalStream: function(e2) {
1176
+ var t2 = null, r2 = "string";
1177
+ try {
1178
+ if (!e2)
1179
+ throw new Error("No output type specified.");
1180
+ var n2 = (r2 = e2.toLowerCase()) === "string" || r2 === "text";
1181
+ r2 !== "binarystring" && r2 !== "text" || (r2 = "string"), t2 = this._decompressWorker();
1182
+ var i2 = !this._dataBinary;
1183
+ i2 && !n2 && (t2 = t2.pipe(new a.Utf8EncodeWorker())), !i2 && n2 && (t2 = t2.pipe(new a.Utf8DecodeWorker()));
1184
+ } catch (e3) {
1185
+ (t2 = new h("error")).error(e3);
1186
+ }
1187
+ return new s(t2, r2, "");
1188
+ }, async: function(e2, t2) {
1189
+ return this.internalStream(e2).accumulate(t2);
1190
+ }, nodeStream: function(e2, t2) {
1191
+ return this.internalStream(e2 || "nodebuffer").toNodejsStream(t2);
1192
+ }, _compressWorker: function(e2, t2) {
1193
+ if (this._data instanceof o && this._data.compression.magic === e2.magic)
1194
+ return this._data.getCompressedWorker();
1195
+ var r2 = this._decompressWorker();
1196
+ return this._dataBinary || (r2 = r2.pipe(new a.Utf8EncodeWorker())), o.createWorkerFrom(r2, e2, t2);
1197
+ }, _decompressWorker: function() {
1198
+ return this._data instanceof o ? this._data.getContentWorker() : this._data instanceof h ? this._data : new i(this._data);
1199
+ } };
1200
+ for (var u = ["asText", "asBinary", "asNodeBuffer", "asUint8Array", "asArrayBuffer"], l = function() {
1201
+ throw new Error("This method has been removed in JSZip 3.0, please check the upgrade guide.");
1202
+ }, f = 0; f < u.length; f++)
1203
+ n.prototype[u[f]] = l;
1204
+ t.exports = n;
1205
+ }, { "./compressedObject": 2, "./stream/DataWorker": 27, "./stream/GenericWorker": 28, "./stream/StreamHelper": 29, "./utf8": 31 }], 36: [function(e, l, t) {
1206
+ (function(t2) {
1207
+ "use strict";
1208
+ var r, n, e2 = t2.MutationObserver || t2.WebKitMutationObserver;
1209
+ if (e2) {
1210
+ var i = 0, s = new e2(u), a = t2.document.createTextNode("");
1211
+ s.observe(a, { characterData: true }), r = function() {
1212
+ a.data = i = ++i % 2;
1213
+ };
1214
+ } else if (t2.setImmediate || t2.MessageChannel === void 0)
1215
+ r = "document" in t2 && "onreadystatechange" in t2.document.createElement("script") ? function() {
1216
+ var e3 = t2.document.createElement("script");
1217
+ e3.onreadystatechange = function() {
1218
+ u(), e3.onreadystatechange = null, e3.parentNode.removeChild(e3), e3 = null;
1219
+ }, t2.document.documentElement.appendChild(e3);
1220
+ } : function() {
1221
+ setTimeout(u, 0);
1222
+ };
1223
+ else {
1224
+ var o = new t2.MessageChannel();
1225
+ o.port1.onmessage = u, r = function() {
1226
+ o.port2.postMessage(0);
1227
+ };
1228
+ }
1229
+ var h = [];
1230
+ function u() {
1231
+ var e3, t3;
1232
+ n = true;
1233
+ for (var r2 = h.length; r2; ) {
1234
+ for (t3 = h, h = [], e3 = -1; ++e3 < r2; )
1235
+ t3[e3]();
1236
+ r2 = h.length;
1237
+ }
1238
+ n = false;
1239
+ }
1240
+ l.exports = function(e3) {
1241
+ h.push(e3) !== 1 || n || r();
1242
+ };
1243
+ }).call(this, typeof global != "undefined" ? global : typeof self != "undefined" ? self : typeof window != "undefined" ? window : {});
1244
+ }, {}], 37: [function(e, t, r) {
1245
+ "use strict";
1246
+ var i = e("immediate");
1247
+ function u() {
1248
+ }
1249
+ var l = {}, s = ["REJECTED"], a = ["FULFILLED"], n = ["PENDING"];
1250
+ function o(e2) {
1251
+ if (typeof e2 != "function")
1252
+ throw new TypeError("resolver must be a function");
1253
+ this.state = n, this.queue = [], this.outcome = void 0, e2 !== u && d(this, e2);
1254
+ }
1255
+ function h(e2, t2, r2) {
1256
+ this.promise = e2, typeof t2 == "function" && (this.onFulfilled = t2, this.callFulfilled = this.otherCallFulfilled), typeof r2 == "function" && (this.onRejected = r2, this.callRejected = this.otherCallRejected);
1257
+ }
1258
+ function f(t2, r2, n2) {
1259
+ i(function() {
1260
+ var e2;
1261
+ try {
1262
+ e2 = r2(n2);
1263
+ } catch (e3) {
1264
+ return l.reject(t2, e3);
1265
+ }
1266
+ e2 === t2 ? l.reject(t2, new TypeError("Cannot resolve promise with itself")) : l.resolve(t2, e2);
1267
+ });
1268
+ }
1269
+ function c(e2) {
1270
+ var t2 = e2 && e2.then;
1271
+ if (e2 && (typeof e2 == "object" || typeof e2 == "function") && typeof t2 == "function")
1272
+ return function() {
1273
+ t2.apply(e2, arguments);
1274
+ };
1275
+ }
1276
+ function d(t2, e2) {
1277
+ var r2 = false;
1278
+ function n2(e3) {
1279
+ r2 || (r2 = true, l.reject(t2, e3));
1280
+ }
1281
+ function i2(e3) {
1282
+ r2 || (r2 = true, l.resolve(t2, e3));
1283
+ }
1284
+ var s2 = p(function() {
1285
+ e2(i2, n2);
1286
+ });
1287
+ s2.status === "error" && n2(s2.value);
1288
+ }
1289
+ function p(e2, t2) {
1290
+ var r2 = {};
1291
+ try {
1292
+ r2.value = e2(t2), r2.status = "success";
1293
+ } catch (e3) {
1294
+ r2.status = "error", r2.value = e3;
1295
+ }
1296
+ return r2;
1297
+ }
1298
+ (t.exports = o).prototype.finally = function(t2) {
1299
+ if (typeof t2 != "function")
1300
+ return this;
1301
+ var r2 = this.constructor;
1302
+ return this.then(function(e2) {
1303
+ return r2.resolve(t2()).then(function() {
1304
+ return e2;
1305
+ });
1306
+ }, function(e2) {
1307
+ return r2.resolve(t2()).then(function() {
1308
+ throw e2;
1309
+ });
1310
+ });
1311
+ }, o.prototype.catch = function(e2) {
1312
+ return this.then(null, e2);
1313
+ }, o.prototype.then = function(e2, t2) {
1314
+ if (typeof e2 != "function" && this.state === a || typeof t2 != "function" && this.state === s)
1315
+ return this;
1316
+ var r2 = new this.constructor(u);
1317
+ this.state !== n ? f(r2, this.state === a ? e2 : t2, this.outcome) : this.queue.push(new h(r2, e2, t2));
1318
+ return r2;
1319
+ }, h.prototype.callFulfilled = function(e2) {
1320
+ l.resolve(this.promise, e2);
1321
+ }, h.prototype.otherCallFulfilled = function(e2) {
1322
+ f(this.promise, this.onFulfilled, e2);
1323
+ }, h.prototype.callRejected = function(e2) {
1324
+ l.reject(this.promise, e2);
1325
+ }, h.prototype.otherCallRejected = function(e2) {
1326
+ f(this.promise, this.onRejected, e2);
1327
+ }, l.resolve = function(e2, t2) {
1328
+ var r2 = p(c, t2);
1329
+ if (r2.status === "error")
1330
+ return l.reject(e2, r2.value);
1331
+ var n2 = r2.value;
1332
+ if (n2)
1333
+ d(e2, n2);
1334
+ else {
1335
+ e2.state = a, e2.outcome = t2;
1336
+ for (var i2 = -1, s2 = e2.queue.length; ++i2 < s2; )
1337
+ e2.queue[i2].callFulfilled(t2);
1338
+ }
1339
+ return e2;
1340
+ }, l.reject = function(e2, t2) {
1341
+ e2.state = s, e2.outcome = t2;
1342
+ for (var r2 = -1, n2 = e2.queue.length; ++r2 < n2; )
1343
+ e2.queue[r2].callRejected(t2);
1344
+ return e2;
1345
+ }, o.resolve = function(e2) {
1346
+ if (e2 instanceof this)
1347
+ return e2;
1348
+ return l.resolve(new this(u), e2);
1349
+ }, o.reject = function(e2) {
1350
+ var t2 = new this(u);
1351
+ return l.reject(t2, e2);
1352
+ }, o.all = function(e2) {
1353
+ var r2 = this;
1354
+ if (Object.prototype.toString.call(e2) !== "[object Array]")
1355
+ return this.reject(new TypeError("must be an array"));
1356
+ var n2 = e2.length, i2 = false;
1357
+ if (!n2)
1358
+ return this.resolve([]);
1359
+ var s2 = new Array(n2), a2 = 0, t2 = -1, o2 = new this(u);
1360
+ for (; ++t2 < n2; )
1361
+ h2(e2[t2], t2);
1362
+ return o2;
1363
+ function h2(e3, t3) {
1364
+ r2.resolve(e3).then(function(e4) {
1365
+ s2[t3] = e4, ++a2 !== n2 || i2 || (i2 = true, l.resolve(o2, s2));
1366
+ }, function(e4) {
1367
+ i2 || (i2 = true, l.reject(o2, e4));
1368
+ });
1369
+ }
1370
+ }, o.race = function(e2) {
1371
+ var t2 = this;
1372
+ if (Object.prototype.toString.call(e2) !== "[object Array]")
1373
+ return this.reject(new TypeError("must be an array"));
1374
+ var r2 = e2.length, n2 = false;
1375
+ if (!r2)
1376
+ return this.resolve([]);
1377
+ var i2 = -1, s2 = new this(u);
1378
+ for (; ++i2 < r2; )
1379
+ a2 = e2[i2], t2.resolve(a2).then(function(e3) {
1380
+ n2 || (n2 = true, l.resolve(s2, e3));
1381
+ }, function(e3) {
1382
+ n2 || (n2 = true, l.reject(s2, e3));
1383
+ });
1384
+ var a2;
1385
+ return s2;
1386
+ };
1387
+ }, { immediate: 36 }], 38: [function(e, t, r) {
1388
+ "use strict";
1389
+ var n = {};
1390
+ (0, e("./lib/utils/common").assign)(n, e("./lib/deflate"), e("./lib/inflate"), e("./lib/zlib/constants")), t.exports = n;
1391
+ }, { "./lib/deflate": 39, "./lib/inflate": 40, "./lib/utils/common": 41, "./lib/zlib/constants": 44 }], 39: [function(e, t, r) {
1392
+ "use strict";
1393
+ var a = e("./zlib/deflate"), o = e("./utils/common"), h = e("./utils/strings"), i = e("./zlib/messages"), s = e("./zlib/zstream"), u = Object.prototype.toString, l = 0, f = -1, c = 0, d = 8;
1394
+ function p(e2) {
1395
+ if (!(this instanceof p))
1396
+ return new p(e2);
1397
+ this.options = o.assign({ level: f, method: d, chunkSize: 16384, windowBits: 15, memLevel: 8, strategy: c, to: "" }, e2 || {});
1398
+ var t2 = this.options;
1399
+ t2.raw && 0 < t2.windowBits ? t2.windowBits = -t2.windowBits : t2.gzip && 0 < t2.windowBits && t2.windowBits < 16 && (t2.windowBits += 16), this.err = 0, this.msg = "", this.ended = false, this.chunks = [], this.strm = new s(), this.strm.avail_out = 0;
1400
+ var r2 = a.deflateInit2(this.strm, t2.level, t2.method, t2.windowBits, t2.memLevel, t2.strategy);
1401
+ if (r2 !== l)
1402
+ throw new Error(i[r2]);
1403
+ if (t2.header && a.deflateSetHeader(this.strm, t2.header), t2.dictionary) {
1404
+ var n2;
1405
+ if (n2 = typeof t2.dictionary == "string" ? h.string2buf(t2.dictionary) : u.call(t2.dictionary) === "[object ArrayBuffer]" ? new Uint8Array(t2.dictionary) : t2.dictionary, (r2 = a.deflateSetDictionary(this.strm, n2)) !== l)
1406
+ throw new Error(i[r2]);
1407
+ this._dict_set = true;
1408
+ }
1409
+ }
1410
+ function n(e2, t2) {
1411
+ var r2 = new p(t2);
1412
+ if (r2.push(e2, true), r2.err)
1413
+ throw r2.msg || i[r2.err];
1414
+ return r2.result;
1415
+ }
1416
+ p.prototype.push = function(e2, t2) {
1417
+ var r2, n2, i2 = this.strm, s2 = this.options.chunkSize;
1418
+ if (this.ended)
1419
+ return false;
1420
+ n2 = t2 === ~~t2 ? t2 : t2 === true ? 4 : 0, typeof e2 == "string" ? i2.input = h.string2buf(e2) : u.call(e2) === "[object ArrayBuffer]" ? i2.input = new Uint8Array(e2) : i2.input = e2, i2.next_in = 0, i2.avail_in = i2.input.length;
1421
+ do {
1422
+ if (i2.avail_out === 0 && (i2.output = new o.Buf8(s2), i2.next_out = 0, i2.avail_out = s2), (r2 = a.deflate(i2, n2)) !== 1 && r2 !== l)
1423
+ return this.onEnd(r2), !(this.ended = true);
1424
+ i2.avail_out !== 0 && (i2.avail_in !== 0 || n2 !== 4 && n2 !== 2) || (this.options.to === "string" ? this.onData(h.buf2binstring(o.shrinkBuf(i2.output, i2.next_out))) : this.onData(o.shrinkBuf(i2.output, i2.next_out)));
1425
+ } while ((0 < i2.avail_in || i2.avail_out === 0) && r2 !== 1);
1426
+ return n2 === 4 ? (r2 = a.deflateEnd(this.strm), this.onEnd(r2), this.ended = true, r2 === l) : n2 !== 2 || (this.onEnd(l), !(i2.avail_out = 0));
1427
+ }, p.prototype.onData = function(e2) {
1428
+ this.chunks.push(e2);
1429
+ }, p.prototype.onEnd = function(e2) {
1430
+ e2 === l && (this.options.to === "string" ? this.result = this.chunks.join("") : this.result = o.flattenChunks(this.chunks)), this.chunks = [], this.err = e2, this.msg = this.strm.msg;
1431
+ }, r.Deflate = p, r.deflate = n, r.deflateRaw = function(e2, t2) {
1432
+ return (t2 = t2 || {}).raw = true, n(e2, t2);
1433
+ }, r.gzip = function(e2, t2) {
1434
+ return (t2 = t2 || {}).gzip = true, n(e2, t2);
1435
+ };
1436
+ }, { "./utils/common": 41, "./utils/strings": 42, "./zlib/deflate": 46, "./zlib/messages": 51, "./zlib/zstream": 53 }], 40: [function(e, t, r) {
1437
+ "use strict";
1438
+ var c = e("./zlib/inflate"), d = e("./utils/common"), p = e("./utils/strings"), m = e("./zlib/constants"), n = e("./zlib/messages"), i = e("./zlib/zstream"), s = e("./zlib/gzheader"), _ = Object.prototype.toString;
1439
+ function a(e2) {
1440
+ if (!(this instanceof a))
1441
+ return new a(e2);
1442
+ this.options = d.assign({ chunkSize: 16384, windowBits: 0, to: "" }, e2 || {});
1443
+ var t2 = this.options;
1444
+ t2.raw && 0 <= t2.windowBits && t2.windowBits < 16 && (t2.windowBits = -t2.windowBits, t2.windowBits === 0 && (t2.windowBits = -15)), !(0 <= t2.windowBits && t2.windowBits < 16) || e2 && e2.windowBits || (t2.windowBits += 32), 15 < t2.windowBits && t2.windowBits < 48 && (15 & t2.windowBits) == 0 && (t2.windowBits |= 15), this.err = 0, this.msg = "", this.ended = false, this.chunks = [], this.strm = new i(), this.strm.avail_out = 0;
1445
+ var r2 = c.inflateInit2(this.strm, t2.windowBits);
1446
+ if (r2 !== m.Z_OK)
1447
+ throw new Error(n[r2]);
1448
+ this.header = new s(), c.inflateGetHeader(this.strm, this.header);
1449
+ }
1450
+ function o(e2, t2) {
1451
+ var r2 = new a(t2);
1452
+ if (r2.push(e2, true), r2.err)
1453
+ throw r2.msg || n[r2.err];
1454
+ return r2.result;
1455
+ }
1456
+ a.prototype.push = function(e2, t2) {
1457
+ var r2, n2, i2, s2, a2, o2, h = this.strm, u = this.options.chunkSize, l = this.options.dictionary, f = false;
1458
+ if (this.ended)
1459
+ return false;
1460
+ n2 = t2 === ~~t2 ? t2 : t2 === true ? m.Z_FINISH : m.Z_NO_FLUSH, typeof e2 == "string" ? h.input = p.binstring2buf(e2) : _.call(e2) === "[object ArrayBuffer]" ? h.input = new Uint8Array(e2) : h.input = e2, h.next_in = 0, h.avail_in = h.input.length;
1461
+ do {
1462
+ if (h.avail_out === 0 && (h.output = new d.Buf8(u), h.next_out = 0, h.avail_out = u), (r2 = c.inflate(h, m.Z_NO_FLUSH)) === m.Z_NEED_DICT && l && (o2 = typeof l == "string" ? p.string2buf(l) : _.call(l) === "[object ArrayBuffer]" ? new Uint8Array(l) : l, r2 = c.inflateSetDictionary(this.strm, o2)), r2 === m.Z_BUF_ERROR && f === true && (r2 = m.Z_OK, f = false), r2 !== m.Z_STREAM_END && r2 !== m.Z_OK)
1463
+ return this.onEnd(r2), !(this.ended = true);
1464
+ h.next_out && (h.avail_out !== 0 && r2 !== m.Z_STREAM_END && (h.avail_in !== 0 || n2 !== m.Z_FINISH && n2 !== m.Z_SYNC_FLUSH) || (this.options.to === "string" ? (i2 = p.utf8border(h.output, h.next_out), s2 = h.next_out - i2, a2 = p.buf2string(h.output, i2), h.next_out = s2, h.avail_out = u - s2, s2 && d.arraySet(h.output, h.output, i2, s2, 0), this.onData(a2)) : this.onData(d.shrinkBuf(h.output, h.next_out)))), h.avail_in === 0 && h.avail_out === 0 && (f = true);
1465
+ } while ((0 < h.avail_in || h.avail_out === 0) && r2 !== m.Z_STREAM_END);
1466
+ return r2 === m.Z_STREAM_END && (n2 = m.Z_FINISH), n2 === m.Z_FINISH ? (r2 = c.inflateEnd(this.strm), this.onEnd(r2), this.ended = true, r2 === m.Z_OK) : n2 !== m.Z_SYNC_FLUSH || (this.onEnd(m.Z_OK), !(h.avail_out = 0));
1467
+ }, a.prototype.onData = function(e2) {
1468
+ this.chunks.push(e2);
1469
+ }, a.prototype.onEnd = function(e2) {
1470
+ e2 === m.Z_OK && (this.options.to === "string" ? this.result = this.chunks.join("") : this.result = d.flattenChunks(this.chunks)), this.chunks = [], this.err = e2, this.msg = this.strm.msg;
1471
+ }, r.Inflate = a, r.inflate = o, r.inflateRaw = function(e2, t2) {
1472
+ return (t2 = t2 || {}).raw = true, o(e2, t2);
1473
+ }, r.ungzip = o;
1474
+ }, { "./utils/common": 41, "./utils/strings": 42, "./zlib/constants": 44, "./zlib/gzheader": 47, "./zlib/inflate": 49, "./zlib/messages": 51, "./zlib/zstream": 53 }], 41: [function(e, t, r) {
1475
+ "use strict";
1476
+ var n = typeof Uint8Array != "undefined" && typeof Uint16Array != "undefined" && typeof Int32Array != "undefined";
1477
+ r.assign = function(e2) {
1478
+ for (var t2 = Array.prototype.slice.call(arguments, 1); t2.length; ) {
1479
+ var r2 = t2.shift();
1480
+ if (r2) {
1481
+ if (typeof r2 != "object")
1482
+ throw new TypeError(r2 + "must be non-object");
1483
+ for (var n2 in r2)
1484
+ r2.hasOwnProperty(n2) && (e2[n2] = r2[n2]);
1485
+ }
1486
+ }
1487
+ return e2;
1488
+ }, r.shrinkBuf = function(e2, t2) {
1489
+ return e2.length === t2 ? e2 : e2.subarray ? e2.subarray(0, t2) : (e2.length = t2, e2);
1490
+ };
1491
+ var i = { arraySet: function(e2, t2, r2, n2, i2) {
1492
+ if (t2.subarray && e2.subarray)
1493
+ e2.set(t2.subarray(r2, r2 + n2), i2);
1494
+ else
1495
+ for (var s2 = 0; s2 < n2; s2++)
1496
+ e2[i2 + s2] = t2[r2 + s2];
1497
+ }, flattenChunks: function(e2) {
1498
+ var t2, r2, n2, i2, s2, a;
1499
+ for (t2 = n2 = 0, r2 = e2.length; t2 < r2; t2++)
1500
+ n2 += e2[t2].length;
1501
+ for (a = new Uint8Array(n2), t2 = i2 = 0, r2 = e2.length; t2 < r2; t2++)
1502
+ s2 = e2[t2], a.set(s2, i2), i2 += s2.length;
1503
+ return a;
1504
+ } }, s = { arraySet: function(e2, t2, r2, n2, i2) {
1505
+ for (var s2 = 0; s2 < n2; s2++)
1506
+ e2[i2 + s2] = t2[r2 + s2];
1507
+ }, flattenChunks: function(e2) {
1508
+ return [].concat.apply([], e2);
1509
+ } };
1510
+ r.setTyped = function(e2) {
1511
+ e2 ? (r.Buf8 = Uint8Array, r.Buf16 = Uint16Array, r.Buf32 = Int32Array, r.assign(r, i)) : (r.Buf8 = Array, r.Buf16 = Array, r.Buf32 = Array, r.assign(r, s));
1512
+ }, r.setTyped(n);
1513
+ }, {}], 42: [function(e, t, r) {
1514
+ "use strict";
1515
+ var h = e("./common"), i = true, s = true;
1516
+ try {
1517
+ String.fromCharCode.apply(null, [0]);
1518
+ } catch (e2) {
1519
+ i = false;
1520
+ }
1521
+ try {
1522
+ String.fromCharCode.apply(null, new Uint8Array(1));
1523
+ } catch (e2) {
1524
+ s = false;
1525
+ }
1526
+ for (var u = new h.Buf8(256), n = 0; n < 256; n++)
1527
+ u[n] = 252 <= n ? 6 : 248 <= n ? 5 : 240 <= n ? 4 : 224 <= n ? 3 : 192 <= n ? 2 : 1;
1528
+ function l(e2, t2) {
1529
+ if (t2 < 65537 && (e2.subarray && s || !e2.subarray && i))
1530
+ return String.fromCharCode.apply(null, h.shrinkBuf(e2, t2));
1531
+ for (var r2 = "", n2 = 0; n2 < t2; n2++)
1532
+ r2 += String.fromCharCode(e2[n2]);
1533
+ return r2;
1534
+ }
1535
+ u[254] = u[254] = 1, r.string2buf = function(e2) {
1536
+ var t2, r2, n2, i2, s2, a = e2.length, o = 0;
1537
+ for (i2 = 0; i2 < a; i2++)
1538
+ (64512 & (r2 = e2.charCodeAt(i2))) == 55296 && i2 + 1 < a && (64512 & (n2 = e2.charCodeAt(i2 + 1))) == 56320 && (r2 = 65536 + (r2 - 55296 << 10) + (n2 - 56320), i2++), o += r2 < 128 ? 1 : r2 < 2048 ? 2 : r2 < 65536 ? 3 : 4;
1539
+ for (t2 = new h.Buf8(o), i2 = s2 = 0; s2 < o; i2++)
1540
+ (64512 & (r2 = e2.charCodeAt(i2))) == 55296 && i2 + 1 < a && (64512 & (n2 = e2.charCodeAt(i2 + 1))) == 56320 && (r2 = 65536 + (r2 - 55296 << 10) + (n2 - 56320), i2++), r2 < 128 ? t2[s2++] = r2 : (r2 < 2048 ? t2[s2++] = 192 | r2 >>> 6 : (r2 < 65536 ? t2[s2++] = 224 | r2 >>> 12 : (t2[s2++] = 240 | r2 >>> 18, t2[s2++] = 128 | r2 >>> 12 & 63), t2[s2++] = 128 | r2 >>> 6 & 63), t2[s2++] = 128 | 63 & r2);
1541
+ return t2;
1542
+ }, r.buf2binstring = function(e2) {
1543
+ return l(e2, e2.length);
1544
+ }, r.binstring2buf = function(e2) {
1545
+ for (var t2 = new h.Buf8(e2.length), r2 = 0, n2 = t2.length; r2 < n2; r2++)
1546
+ t2[r2] = e2.charCodeAt(r2);
1547
+ return t2;
1548
+ }, r.buf2string = function(e2, t2) {
1549
+ var r2, n2, i2, s2, a = t2 || e2.length, o = new Array(2 * a);
1550
+ for (r2 = n2 = 0; r2 < a; )
1551
+ if ((i2 = e2[r2++]) < 128)
1552
+ o[n2++] = i2;
1553
+ else if (4 < (s2 = u[i2]))
1554
+ o[n2++] = 65533, r2 += s2 - 1;
1555
+ else {
1556
+ for (i2 &= s2 === 2 ? 31 : s2 === 3 ? 15 : 7; 1 < s2 && r2 < a; )
1557
+ i2 = i2 << 6 | 63 & e2[r2++], s2--;
1558
+ 1 < s2 ? o[n2++] = 65533 : i2 < 65536 ? o[n2++] = i2 : (i2 -= 65536, o[n2++] = 55296 | i2 >> 10 & 1023, o[n2++] = 56320 | 1023 & i2);
1559
+ }
1560
+ return l(o, n2);
1561
+ }, r.utf8border = function(e2, t2) {
1562
+ var r2;
1563
+ for ((t2 = t2 || e2.length) > e2.length && (t2 = e2.length), r2 = t2 - 1; 0 <= r2 && (192 & e2[r2]) == 128; )
1564
+ r2--;
1565
+ return r2 < 0 ? t2 : r2 === 0 ? t2 : r2 + u[e2[r2]] > t2 ? r2 : t2;
1566
+ };
1567
+ }, { "./common": 41 }], 43: [function(e, t, r) {
1568
+ "use strict";
1569
+ t.exports = function(e2, t2, r2, n) {
1570
+ for (var i = 65535 & e2 | 0, s = e2 >>> 16 & 65535 | 0, a = 0; r2 !== 0; ) {
1571
+ for (r2 -= a = 2e3 < r2 ? 2e3 : r2; s = s + (i = i + t2[n++] | 0) | 0, --a; )
1572
+ ;
1573
+ i %= 65521, s %= 65521;
1574
+ }
1575
+ return i | s << 16 | 0;
1576
+ };
1577
+ }, {}], 44: [function(e, t, r) {
1578
+ "use strict";
1579
+ t.exports = { Z_NO_FLUSH: 0, Z_PARTIAL_FLUSH: 1, Z_SYNC_FLUSH: 2, Z_FULL_FLUSH: 3, Z_FINISH: 4, Z_BLOCK: 5, Z_TREES: 6, Z_OK: 0, Z_STREAM_END: 1, Z_NEED_DICT: 2, Z_ERRNO: -1, Z_STREAM_ERROR: -2, Z_DATA_ERROR: -3, Z_BUF_ERROR: -5, Z_NO_COMPRESSION: 0, Z_BEST_SPEED: 1, Z_BEST_COMPRESSION: 9, Z_DEFAULT_COMPRESSION: -1, Z_FILTERED: 1, Z_HUFFMAN_ONLY: 2, Z_RLE: 3, Z_FIXED: 4, Z_DEFAULT_STRATEGY: 0, Z_BINARY: 0, Z_TEXT: 1, Z_UNKNOWN: 2, Z_DEFLATED: 8 };
1580
+ }, {}], 45: [function(e, t, r) {
1581
+ "use strict";
1582
+ var o = function() {
1583
+ for (var e2, t2 = [], r2 = 0; r2 < 256; r2++) {
1584
+ e2 = r2;
1585
+ for (var n = 0; n < 8; n++)
1586
+ e2 = 1 & e2 ? 3988292384 ^ e2 >>> 1 : e2 >>> 1;
1587
+ t2[r2] = e2;
1588
+ }
1589
+ return t2;
1590
+ }();
1591
+ t.exports = function(e2, t2, r2, n) {
1592
+ var i = o, s = n + r2;
1593
+ e2 ^= -1;
1594
+ for (var a = n; a < s; a++)
1595
+ e2 = e2 >>> 8 ^ i[255 & (e2 ^ t2[a])];
1596
+ return -1 ^ e2;
1597
+ };
1598
+ }, {}], 46: [function(e, t, r) {
1599
+ "use strict";
1600
+ var h, c = e("../utils/common"), u = e("./trees"), d = e("./adler32"), p = e("./crc32"), n = e("./messages"), l = 0, f = 4, m = 0, _ = -2, g = -1, b = 4, i = 2, v = 8, y = 9, s = 286, a = 30, o = 19, w = 2 * s + 1, k = 15, x = 3, S = 258, z = S + x + 1, C = 42, E = 113, A = 1, I = 2, O = 3, B = 4;
1601
+ function R(e2, t2) {
1602
+ return e2.msg = n[t2], t2;
1603
+ }
1604
+ function T(e2) {
1605
+ return (e2 << 1) - (4 < e2 ? 9 : 0);
1606
+ }
1607
+ function D(e2) {
1608
+ for (var t2 = e2.length; 0 <= --t2; )
1609
+ e2[t2] = 0;
1610
+ }
1611
+ function F(e2) {
1612
+ var t2 = e2.state, r2 = t2.pending;
1613
+ r2 > e2.avail_out && (r2 = e2.avail_out), r2 !== 0 && (c.arraySet(e2.output, t2.pending_buf, t2.pending_out, r2, e2.next_out), e2.next_out += r2, t2.pending_out += r2, e2.total_out += r2, e2.avail_out -= r2, t2.pending -= r2, t2.pending === 0 && (t2.pending_out = 0));
1614
+ }
1615
+ function N(e2, t2) {
1616
+ u._tr_flush_block(e2, 0 <= e2.block_start ? e2.block_start : -1, e2.strstart - e2.block_start, t2), e2.block_start = e2.strstart, F(e2.strm);
1617
+ }
1618
+ function U(e2, t2) {
1619
+ e2.pending_buf[e2.pending++] = t2;
1620
+ }
1621
+ function P(e2, t2) {
1622
+ e2.pending_buf[e2.pending++] = t2 >>> 8 & 255, e2.pending_buf[e2.pending++] = 255 & t2;
1623
+ }
1624
+ function L(e2, t2) {
1625
+ var r2, n2, i2 = e2.max_chain_length, s2 = e2.strstart, a2 = e2.prev_length, o2 = e2.nice_match, h2 = e2.strstart > e2.w_size - z ? e2.strstart - (e2.w_size - z) : 0, u2 = e2.window, l2 = e2.w_mask, f2 = e2.prev, c2 = e2.strstart + S, d2 = u2[s2 + a2 - 1], p2 = u2[s2 + a2];
1626
+ e2.prev_length >= e2.good_match && (i2 >>= 2), o2 > e2.lookahead && (o2 = e2.lookahead);
1627
+ do {
1628
+ if (u2[(r2 = t2) + a2] === p2 && u2[r2 + a2 - 1] === d2 && u2[r2] === u2[s2] && u2[++r2] === u2[s2 + 1]) {
1629
+ s2 += 2, r2++;
1630
+ do {
1631
+ } while (u2[++s2] === u2[++r2] && u2[++s2] === u2[++r2] && u2[++s2] === u2[++r2] && u2[++s2] === u2[++r2] && u2[++s2] === u2[++r2] && u2[++s2] === u2[++r2] && u2[++s2] === u2[++r2] && u2[++s2] === u2[++r2] && s2 < c2);
1632
+ if (n2 = S - (c2 - s2), s2 = c2 - S, a2 < n2) {
1633
+ if (e2.match_start = t2, o2 <= (a2 = n2))
1634
+ break;
1635
+ d2 = u2[s2 + a2 - 1], p2 = u2[s2 + a2];
1636
+ }
1637
+ }
1638
+ } while ((t2 = f2[t2 & l2]) > h2 && --i2 != 0);
1639
+ return a2 <= e2.lookahead ? a2 : e2.lookahead;
1640
+ }
1641
+ function j(e2) {
1642
+ var t2, r2, n2, i2, s2, a2, o2, h2, u2, l2, f2 = e2.w_size;
1643
+ do {
1644
+ if (i2 = e2.window_size - e2.lookahead - e2.strstart, e2.strstart >= f2 + (f2 - z)) {
1645
+ for (c.arraySet(e2.window, e2.window, f2, f2, 0), e2.match_start -= f2, e2.strstart -= f2, e2.block_start -= f2, t2 = r2 = e2.hash_size; n2 = e2.head[--t2], e2.head[t2] = f2 <= n2 ? n2 - f2 : 0, --r2; )
1646
+ ;
1647
+ for (t2 = r2 = f2; n2 = e2.prev[--t2], e2.prev[t2] = f2 <= n2 ? n2 - f2 : 0, --r2; )
1648
+ ;
1649
+ i2 += f2;
1650
+ }
1651
+ if (e2.strm.avail_in === 0)
1652
+ break;
1653
+ if (a2 = e2.strm, o2 = e2.window, h2 = e2.strstart + e2.lookahead, u2 = i2, l2 = void 0, l2 = a2.avail_in, u2 < l2 && (l2 = u2), r2 = l2 === 0 ? 0 : (a2.avail_in -= l2, c.arraySet(o2, a2.input, a2.next_in, l2, h2), a2.state.wrap === 1 ? a2.adler = d(a2.adler, o2, l2, h2) : a2.state.wrap === 2 && (a2.adler = p(a2.adler, o2, l2, h2)), a2.next_in += l2, a2.total_in += l2, l2), e2.lookahead += r2, e2.lookahead + e2.insert >= x)
1654
+ for (s2 = e2.strstart - e2.insert, e2.ins_h = e2.window[s2], e2.ins_h = (e2.ins_h << e2.hash_shift ^ e2.window[s2 + 1]) & e2.hash_mask; e2.insert && (e2.ins_h = (e2.ins_h << e2.hash_shift ^ e2.window[s2 + x - 1]) & e2.hash_mask, e2.prev[s2 & e2.w_mask] = e2.head[e2.ins_h], e2.head[e2.ins_h] = s2, s2++, e2.insert--, !(e2.lookahead + e2.insert < x)); )
1655
+ ;
1656
+ } while (e2.lookahead < z && e2.strm.avail_in !== 0);
1657
+ }
1658
+ function Z(e2, t2) {
1659
+ for (var r2, n2; ; ) {
1660
+ if (e2.lookahead < z) {
1661
+ if (j(e2), e2.lookahead < z && t2 === l)
1662
+ return A;
1663
+ if (e2.lookahead === 0)
1664
+ break;
1665
+ }
1666
+ if (r2 = 0, e2.lookahead >= x && (e2.ins_h = (e2.ins_h << e2.hash_shift ^ e2.window[e2.strstart + x - 1]) & e2.hash_mask, r2 = e2.prev[e2.strstart & e2.w_mask] = e2.head[e2.ins_h], e2.head[e2.ins_h] = e2.strstart), r2 !== 0 && e2.strstart - r2 <= e2.w_size - z && (e2.match_length = L(e2, r2)), e2.match_length >= x)
1667
+ if (n2 = u._tr_tally(e2, e2.strstart - e2.match_start, e2.match_length - x), e2.lookahead -= e2.match_length, e2.match_length <= e2.max_lazy_match && e2.lookahead >= x) {
1668
+ for (e2.match_length--; e2.strstart++, e2.ins_h = (e2.ins_h << e2.hash_shift ^ e2.window[e2.strstart + x - 1]) & e2.hash_mask, r2 = e2.prev[e2.strstart & e2.w_mask] = e2.head[e2.ins_h], e2.head[e2.ins_h] = e2.strstart, --e2.match_length != 0; )
1669
+ ;
1670
+ e2.strstart++;
1671
+ } else
1672
+ e2.strstart += e2.match_length, e2.match_length = 0, e2.ins_h = e2.window[e2.strstart], e2.ins_h = (e2.ins_h << e2.hash_shift ^ e2.window[e2.strstart + 1]) & e2.hash_mask;
1673
+ else
1674
+ n2 = u._tr_tally(e2, 0, e2.window[e2.strstart]), e2.lookahead--, e2.strstart++;
1675
+ if (n2 && (N(e2, false), e2.strm.avail_out === 0))
1676
+ return A;
1677
+ }
1678
+ return e2.insert = e2.strstart < x - 1 ? e2.strstart : x - 1, t2 === f ? (N(e2, true), e2.strm.avail_out === 0 ? O : B) : e2.last_lit && (N(e2, false), e2.strm.avail_out === 0) ? A : I;
1679
+ }
1680
+ function W(e2, t2) {
1681
+ for (var r2, n2, i2; ; ) {
1682
+ if (e2.lookahead < z) {
1683
+ if (j(e2), e2.lookahead < z && t2 === l)
1684
+ return A;
1685
+ if (e2.lookahead === 0)
1686
+ break;
1687
+ }
1688
+ if (r2 = 0, e2.lookahead >= x && (e2.ins_h = (e2.ins_h << e2.hash_shift ^ e2.window[e2.strstart + x - 1]) & e2.hash_mask, r2 = e2.prev[e2.strstart & e2.w_mask] = e2.head[e2.ins_h], e2.head[e2.ins_h] = e2.strstart), e2.prev_length = e2.match_length, e2.prev_match = e2.match_start, e2.match_length = x - 1, r2 !== 0 && e2.prev_length < e2.max_lazy_match && e2.strstart - r2 <= e2.w_size - z && (e2.match_length = L(e2, r2), e2.match_length <= 5 && (e2.strategy === 1 || e2.match_length === x && 4096 < e2.strstart - e2.match_start) && (e2.match_length = x - 1)), e2.prev_length >= x && e2.match_length <= e2.prev_length) {
1689
+ for (i2 = e2.strstart + e2.lookahead - x, n2 = u._tr_tally(e2, e2.strstart - 1 - e2.prev_match, e2.prev_length - x), e2.lookahead -= e2.prev_length - 1, e2.prev_length -= 2; ++e2.strstart <= i2 && (e2.ins_h = (e2.ins_h << e2.hash_shift ^ e2.window[e2.strstart + x - 1]) & e2.hash_mask, r2 = e2.prev[e2.strstart & e2.w_mask] = e2.head[e2.ins_h], e2.head[e2.ins_h] = e2.strstart), --e2.prev_length != 0; )
1690
+ ;
1691
+ if (e2.match_available = 0, e2.match_length = x - 1, e2.strstart++, n2 && (N(e2, false), e2.strm.avail_out === 0))
1692
+ return A;
1693
+ } else if (e2.match_available) {
1694
+ if ((n2 = u._tr_tally(e2, 0, e2.window[e2.strstart - 1])) && N(e2, false), e2.strstart++, e2.lookahead--, e2.strm.avail_out === 0)
1695
+ return A;
1696
+ } else
1697
+ e2.match_available = 1, e2.strstart++, e2.lookahead--;
1698
+ }
1699
+ return e2.match_available && (n2 = u._tr_tally(e2, 0, e2.window[e2.strstart - 1]), e2.match_available = 0), e2.insert = e2.strstart < x - 1 ? e2.strstart : x - 1, t2 === f ? (N(e2, true), e2.strm.avail_out === 0 ? O : B) : e2.last_lit && (N(e2, false), e2.strm.avail_out === 0) ? A : I;
1700
+ }
1701
+ function M(e2, t2, r2, n2, i2) {
1702
+ this.good_length = e2, this.max_lazy = t2, this.nice_length = r2, this.max_chain = n2, this.func = i2;
1703
+ }
1704
+ function H() {
1705
+ this.strm = null, this.status = 0, this.pending_buf = null, this.pending_buf_size = 0, this.pending_out = 0, this.pending = 0, this.wrap = 0, this.gzhead = null, this.gzindex = 0, this.method = v, this.last_flush = -1, this.w_size = 0, this.w_bits = 0, this.w_mask = 0, this.window = null, this.window_size = 0, this.prev = null, this.head = null, this.ins_h = 0, this.hash_size = 0, this.hash_bits = 0, this.hash_mask = 0, this.hash_shift = 0, this.block_start = 0, this.match_length = 0, this.prev_match = 0, this.match_available = 0, this.strstart = 0, this.match_start = 0, this.lookahead = 0, this.prev_length = 0, this.max_chain_length = 0, this.max_lazy_match = 0, this.level = 0, this.strategy = 0, this.good_match = 0, this.nice_match = 0, this.dyn_ltree = new c.Buf16(2 * w), this.dyn_dtree = new c.Buf16(2 * (2 * a + 1)), this.bl_tree = new c.Buf16(2 * (2 * o + 1)), D(this.dyn_ltree), D(this.dyn_dtree), D(this.bl_tree), this.l_desc = null, this.d_desc = null, this.bl_desc = null, this.bl_count = new c.Buf16(k + 1), this.heap = new c.Buf16(2 * s + 1), D(this.heap), this.heap_len = 0, this.heap_max = 0, this.depth = new c.Buf16(2 * s + 1), D(this.depth), this.l_buf = 0, this.lit_bufsize = 0, this.last_lit = 0, this.d_buf = 0, this.opt_len = 0, this.static_len = 0, this.matches = 0, this.insert = 0, this.bi_buf = 0, this.bi_valid = 0;
1706
+ }
1707
+ function G(e2) {
1708
+ var t2;
1709
+ return e2 && e2.state ? (e2.total_in = e2.total_out = 0, e2.data_type = i, (t2 = e2.state).pending = 0, t2.pending_out = 0, t2.wrap < 0 && (t2.wrap = -t2.wrap), t2.status = t2.wrap ? C : E, e2.adler = t2.wrap === 2 ? 0 : 1, t2.last_flush = l, u._tr_init(t2), m) : R(e2, _);
1710
+ }
1711
+ function K(e2) {
1712
+ var t2 = G(e2);
1713
+ return t2 === m && function(e3) {
1714
+ e3.window_size = 2 * e3.w_size, D(e3.head), e3.max_lazy_match = h[e3.level].max_lazy, e3.good_match = h[e3.level].good_length, e3.nice_match = h[e3.level].nice_length, e3.max_chain_length = h[e3.level].max_chain, e3.strstart = 0, e3.block_start = 0, e3.lookahead = 0, e3.insert = 0, e3.match_length = e3.prev_length = x - 1, e3.match_available = 0, e3.ins_h = 0;
1715
+ }(e2.state), t2;
1716
+ }
1717
+ function Y(e2, t2, r2, n2, i2, s2) {
1718
+ if (!e2)
1719
+ return _;
1720
+ var a2 = 1;
1721
+ if (t2 === g && (t2 = 6), n2 < 0 ? (a2 = 0, n2 = -n2) : 15 < n2 && (a2 = 2, n2 -= 16), i2 < 1 || y < i2 || r2 !== v || n2 < 8 || 15 < n2 || t2 < 0 || 9 < t2 || s2 < 0 || b < s2)
1722
+ return R(e2, _);
1723
+ n2 === 8 && (n2 = 9);
1724
+ var o2 = new H();
1725
+ return (e2.state = o2).strm = e2, o2.wrap = a2, o2.gzhead = null, o2.w_bits = n2, o2.w_size = 1 << o2.w_bits, o2.w_mask = o2.w_size - 1, o2.hash_bits = i2 + 7, o2.hash_size = 1 << o2.hash_bits, o2.hash_mask = o2.hash_size - 1, o2.hash_shift = ~~((o2.hash_bits + x - 1) / x), o2.window = new c.Buf8(2 * o2.w_size), o2.head = new c.Buf16(o2.hash_size), o2.prev = new c.Buf16(o2.w_size), o2.lit_bufsize = 1 << i2 + 6, o2.pending_buf_size = 4 * o2.lit_bufsize, o2.pending_buf = new c.Buf8(o2.pending_buf_size), o2.d_buf = 1 * o2.lit_bufsize, o2.l_buf = 3 * o2.lit_bufsize, o2.level = t2, o2.strategy = s2, o2.method = r2, K(e2);
1726
+ }
1727
+ h = [new M(0, 0, 0, 0, function(e2, t2) {
1728
+ var r2 = 65535;
1729
+ for (r2 > e2.pending_buf_size - 5 && (r2 = e2.pending_buf_size - 5); ; ) {
1730
+ if (e2.lookahead <= 1) {
1731
+ if (j(e2), e2.lookahead === 0 && t2 === l)
1732
+ return A;
1733
+ if (e2.lookahead === 0)
1734
+ break;
1735
+ }
1736
+ e2.strstart += e2.lookahead, e2.lookahead = 0;
1737
+ var n2 = e2.block_start + r2;
1738
+ if ((e2.strstart === 0 || e2.strstart >= n2) && (e2.lookahead = e2.strstart - n2, e2.strstart = n2, N(e2, false), e2.strm.avail_out === 0))
1739
+ return A;
1740
+ if (e2.strstart - e2.block_start >= e2.w_size - z && (N(e2, false), e2.strm.avail_out === 0))
1741
+ return A;
1742
+ }
1743
+ return e2.insert = 0, t2 === f ? (N(e2, true), e2.strm.avail_out === 0 ? O : B) : (e2.strstart > e2.block_start && (N(e2, false), e2.strm.avail_out), A);
1744
+ }), new M(4, 4, 8, 4, Z), new M(4, 5, 16, 8, Z), new M(4, 6, 32, 32, Z), new M(4, 4, 16, 16, W), new M(8, 16, 32, 32, W), new M(8, 16, 128, 128, W), new M(8, 32, 128, 256, W), new M(32, 128, 258, 1024, W), new M(32, 258, 258, 4096, W)], r.deflateInit = function(e2, t2) {
1745
+ return Y(e2, t2, v, 15, 8, 0);
1746
+ }, r.deflateInit2 = Y, r.deflateReset = K, r.deflateResetKeep = G, r.deflateSetHeader = function(e2, t2) {
1747
+ return e2 && e2.state ? e2.state.wrap !== 2 ? _ : (e2.state.gzhead = t2, m) : _;
1748
+ }, r.deflate = function(e2, t2) {
1749
+ var r2, n2, i2, s2;
1750
+ if (!e2 || !e2.state || 5 < t2 || t2 < 0)
1751
+ return e2 ? R(e2, _) : _;
1752
+ if (n2 = e2.state, !e2.output || !e2.input && e2.avail_in !== 0 || n2.status === 666 && t2 !== f)
1753
+ return R(e2, e2.avail_out === 0 ? -5 : _);
1754
+ if (n2.strm = e2, r2 = n2.last_flush, n2.last_flush = t2, n2.status === C)
1755
+ if (n2.wrap === 2)
1756
+ e2.adler = 0, U(n2, 31), U(n2, 139), U(n2, 8), n2.gzhead ? (U(n2, (n2.gzhead.text ? 1 : 0) + (n2.gzhead.hcrc ? 2 : 0) + (n2.gzhead.extra ? 4 : 0) + (n2.gzhead.name ? 8 : 0) + (n2.gzhead.comment ? 16 : 0)), U(n2, 255 & n2.gzhead.time), U(n2, n2.gzhead.time >> 8 & 255), U(n2, n2.gzhead.time >> 16 & 255), U(n2, n2.gzhead.time >> 24 & 255), U(n2, n2.level === 9 ? 2 : 2 <= n2.strategy || n2.level < 2 ? 4 : 0), U(n2, 255 & n2.gzhead.os), n2.gzhead.extra && n2.gzhead.extra.length && (U(n2, 255 & n2.gzhead.extra.length), U(n2, n2.gzhead.extra.length >> 8 & 255)), n2.gzhead.hcrc && (e2.adler = p(e2.adler, n2.pending_buf, n2.pending, 0)), n2.gzindex = 0, n2.status = 69) : (U(n2, 0), U(n2, 0), U(n2, 0), U(n2, 0), U(n2, 0), U(n2, n2.level === 9 ? 2 : 2 <= n2.strategy || n2.level < 2 ? 4 : 0), U(n2, 3), n2.status = E);
1757
+ else {
1758
+ var a2 = v + (n2.w_bits - 8 << 4) << 8;
1759
+ a2 |= (2 <= n2.strategy || n2.level < 2 ? 0 : n2.level < 6 ? 1 : n2.level === 6 ? 2 : 3) << 6, n2.strstart !== 0 && (a2 |= 32), a2 += 31 - a2 % 31, n2.status = E, P(n2, a2), n2.strstart !== 0 && (P(n2, e2.adler >>> 16), P(n2, 65535 & e2.adler)), e2.adler = 1;
1760
+ }
1761
+ if (n2.status === 69)
1762
+ if (n2.gzhead.extra) {
1763
+ for (i2 = n2.pending; n2.gzindex < (65535 & n2.gzhead.extra.length) && (n2.pending !== n2.pending_buf_size || (n2.gzhead.hcrc && n2.pending > i2 && (e2.adler = p(e2.adler, n2.pending_buf, n2.pending - i2, i2)), F(e2), i2 = n2.pending, n2.pending !== n2.pending_buf_size)); )
1764
+ U(n2, 255 & n2.gzhead.extra[n2.gzindex]), n2.gzindex++;
1765
+ n2.gzhead.hcrc && n2.pending > i2 && (e2.adler = p(e2.adler, n2.pending_buf, n2.pending - i2, i2)), n2.gzindex === n2.gzhead.extra.length && (n2.gzindex = 0, n2.status = 73);
1766
+ } else
1767
+ n2.status = 73;
1768
+ if (n2.status === 73)
1769
+ if (n2.gzhead.name) {
1770
+ i2 = n2.pending;
1771
+ do {
1772
+ if (n2.pending === n2.pending_buf_size && (n2.gzhead.hcrc && n2.pending > i2 && (e2.adler = p(e2.adler, n2.pending_buf, n2.pending - i2, i2)), F(e2), i2 = n2.pending, n2.pending === n2.pending_buf_size)) {
1773
+ s2 = 1;
1774
+ break;
1775
+ }
1776
+ s2 = n2.gzindex < n2.gzhead.name.length ? 255 & n2.gzhead.name.charCodeAt(n2.gzindex++) : 0, U(n2, s2);
1777
+ } while (s2 !== 0);
1778
+ n2.gzhead.hcrc && n2.pending > i2 && (e2.adler = p(e2.adler, n2.pending_buf, n2.pending - i2, i2)), s2 === 0 && (n2.gzindex = 0, n2.status = 91);
1779
+ } else
1780
+ n2.status = 91;
1781
+ if (n2.status === 91)
1782
+ if (n2.gzhead.comment) {
1783
+ i2 = n2.pending;
1784
+ do {
1785
+ if (n2.pending === n2.pending_buf_size && (n2.gzhead.hcrc && n2.pending > i2 && (e2.adler = p(e2.adler, n2.pending_buf, n2.pending - i2, i2)), F(e2), i2 = n2.pending, n2.pending === n2.pending_buf_size)) {
1786
+ s2 = 1;
1787
+ break;
1788
+ }
1789
+ s2 = n2.gzindex < n2.gzhead.comment.length ? 255 & n2.gzhead.comment.charCodeAt(n2.gzindex++) : 0, U(n2, s2);
1790
+ } while (s2 !== 0);
1791
+ n2.gzhead.hcrc && n2.pending > i2 && (e2.adler = p(e2.adler, n2.pending_buf, n2.pending - i2, i2)), s2 === 0 && (n2.status = 103);
1792
+ } else
1793
+ n2.status = 103;
1794
+ if (n2.status === 103 && (n2.gzhead.hcrc ? (n2.pending + 2 > n2.pending_buf_size && F(e2), n2.pending + 2 <= n2.pending_buf_size && (U(n2, 255 & e2.adler), U(n2, e2.adler >> 8 & 255), e2.adler = 0, n2.status = E)) : n2.status = E), n2.pending !== 0) {
1795
+ if (F(e2), e2.avail_out === 0)
1796
+ return n2.last_flush = -1, m;
1797
+ } else if (e2.avail_in === 0 && T(t2) <= T(r2) && t2 !== f)
1798
+ return R(e2, -5);
1799
+ if (n2.status === 666 && e2.avail_in !== 0)
1800
+ return R(e2, -5);
1801
+ if (e2.avail_in !== 0 || n2.lookahead !== 0 || t2 !== l && n2.status !== 666) {
1802
+ var o2 = n2.strategy === 2 ? function(e3, t3) {
1803
+ for (var r3; ; ) {
1804
+ if (e3.lookahead === 0 && (j(e3), e3.lookahead === 0)) {
1805
+ if (t3 === l)
1806
+ return A;
1807
+ break;
1808
+ }
1809
+ if (e3.match_length = 0, r3 = u._tr_tally(e3, 0, e3.window[e3.strstart]), e3.lookahead--, e3.strstart++, r3 && (N(e3, false), e3.strm.avail_out === 0))
1810
+ return A;
1811
+ }
1812
+ return e3.insert = 0, t3 === f ? (N(e3, true), e3.strm.avail_out === 0 ? O : B) : e3.last_lit && (N(e3, false), e3.strm.avail_out === 0) ? A : I;
1813
+ }(n2, t2) : n2.strategy === 3 ? function(e3, t3) {
1814
+ for (var r3, n3, i3, s3, a3 = e3.window; ; ) {
1815
+ if (e3.lookahead <= S) {
1816
+ if (j(e3), e3.lookahead <= S && t3 === l)
1817
+ return A;
1818
+ if (e3.lookahead === 0)
1819
+ break;
1820
+ }
1821
+ if (e3.match_length = 0, e3.lookahead >= x && 0 < e3.strstart && (n3 = a3[i3 = e3.strstart - 1]) === a3[++i3] && n3 === a3[++i3] && n3 === a3[++i3]) {
1822
+ s3 = e3.strstart + S;
1823
+ do {
1824
+ } while (n3 === a3[++i3] && n3 === a3[++i3] && n3 === a3[++i3] && n3 === a3[++i3] && n3 === a3[++i3] && n3 === a3[++i3] && n3 === a3[++i3] && n3 === a3[++i3] && i3 < s3);
1825
+ e3.match_length = S - (s3 - i3), e3.match_length > e3.lookahead && (e3.match_length = e3.lookahead);
1826
+ }
1827
+ if (e3.match_length >= x ? (r3 = u._tr_tally(e3, 1, e3.match_length - x), e3.lookahead -= e3.match_length, e3.strstart += e3.match_length, e3.match_length = 0) : (r3 = u._tr_tally(e3, 0, e3.window[e3.strstart]), e3.lookahead--, e3.strstart++), r3 && (N(e3, false), e3.strm.avail_out === 0))
1828
+ return A;
1829
+ }
1830
+ return e3.insert = 0, t3 === f ? (N(e3, true), e3.strm.avail_out === 0 ? O : B) : e3.last_lit && (N(e3, false), e3.strm.avail_out === 0) ? A : I;
1831
+ }(n2, t2) : h[n2.level].func(n2, t2);
1832
+ if (o2 !== O && o2 !== B || (n2.status = 666), o2 === A || o2 === O)
1833
+ return e2.avail_out === 0 && (n2.last_flush = -1), m;
1834
+ if (o2 === I && (t2 === 1 ? u._tr_align(n2) : t2 !== 5 && (u._tr_stored_block(n2, 0, 0, false), t2 === 3 && (D(n2.head), n2.lookahead === 0 && (n2.strstart = 0, n2.block_start = 0, n2.insert = 0))), F(e2), e2.avail_out === 0))
1835
+ return n2.last_flush = -1, m;
1836
+ }
1837
+ return t2 !== f ? m : n2.wrap <= 0 ? 1 : (n2.wrap === 2 ? (U(n2, 255 & e2.adler), U(n2, e2.adler >> 8 & 255), U(n2, e2.adler >> 16 & 255), U(n2, e2.adler >> 24 & 255), U(n2, 255 & e2.total_in), U(n2, e2.total_in >> 8 & 255), U(n2, e2.total_in >> 16 & 255), U(n2, e2.total_in >> 24 & 255)) : (P(n2, e2.adler >>> 16), P(n2, 65535 & e2.adler)), F(e2), 0 < n2.wrap && (n2.wrap = -n2.wrap), n2.pending !== 0 ? m : 1);
1838
+ }, r.deflateEnd = function(e2) {
1839
+ var t2;
1840
+ return e2 && e2.state ? (t2 = e2.state.status) !== C && t2 !== 69 && t2 !== 73 && t2 !== 91 && t2 !== 103 && t2 !== E && t2 !== 666 ? R(e2, _) : (e2.state = null, t2 === E ? R(e2, -3) : m) : _;
1841
+ }, r.deflateSetDictionary = function(e2, t2) {
1842
+ var r2, n2, i2, s2, a2, o2, h2, u2, l2 = t2.length;
1843
+ if (!e2 || !e2.state)
1844
+ return _;
1845
+ if ((s2 = (r2 = e2.state).wrap) === 2 || s2 === 1 && r2.status !== C || r2.lookahead)
1846
+ return _;
1847
+ for (s2 === 1 && (e2.adler = d(e2.adler, t2, l2, 0)), r2.wrap = 0, l2 >= r2.w_size && (s2 === 0 && (D(r2.head), r2.strstart = 0, r2.block_start = 0, r2.insert = 0), u2 = new c.Buf8(r2.w_size), c.arraySet(u2, t2, l2 - r2.w_size, r2.w_size, 0), t2 = u2, l2 = r2.w_size), a2 = e2.avail_in, o2 = e2.next_in, h2 = e2.input, e2.avail_in = l2, e2.next_in = 0, e2.input = t2, j(r2); r2.lookahead >= x; ) {
1848
+ for (n2 = r2.strstart, i2 = r2.lookahead - (x - 1); r2.ins_h = (r2.ins_h << r2.hash_shift ^ r2.window[n2 + x - 1]) & r2.hash_mask, r2.prev[n2 & r2.w_mask] = r2.head[r2.ins_h], r2.head[r2.ins_h] = n2, n2++, --i2; )
1849
+ ;
1850
+ r2.strstart = n2, r2.lookahead = x - 1, j(r2);
1851
+ }
1852
+ return r2.strstart += r2.lookahead, r2.block_start = r2.strstart, r2.insert = r2.lookahead, r2.lookahead = 0, r2.match_length = r2.prev_length = x - 1, r2.match_available = 0, e2.next_in = o2, e2.input = h2, e2.avail_in = a2, r2.wrap = s2, m;
1853
+ }, r.deflateInfo = "pako deflate (from Nodeca project)";
1854
+ }, { "../utils/common": 41, "./adler32": 43, "./crc32": 45, "./messages": 51, "./trees": 52 }], 47: [function(e, t, r) {
1855
+ "use strict";
1856
+ t.exports = function() {
1857
+ this.text = 0, this.time = 0, this.xflags = 0, this.os = 0, this.extra = null, this.extra_len = 0, this.name = "", this.comment = "", this.hcrc = 0, this.done = false;
1858
+ };
1859
+ }, {}], 48: [function(e, t, r) {
1860
+ "use strict";
1861
+ t.exports = function(e2, t2) {
1862
+ var r2, n, i, s, a, o, h, u, l, f, c, d, p, m, _, g, b, v, y, w, k, x, S, z, C;
1863
+ r2 = e2.state, n = e2.next_in, z = e2.input, i = n + (e2.avail_in - 5), s = e2.next_out, C = e2.output, a = s - (t2 - e2.avail_out), o = s + (e2.avail_out - 257), h = r2.dmax, u = r2.wsize, l = r2.whave, f = r2.wnext, c = r2.window, d = r2.hold, p = r2.bits, m = r2.lencode, _ = r2.distcode, g = (1 << r2.lenbits) - 1, b = (1 << r2.distbits) - 1;
1864
+ e:
1865
+ do {
1866
+ p < 15 && (d += z[n++] << p, p += 8, d += z[n++] << p, p += 8), v = m[d & g];
1867
+ t:
1868
+ for (; ; ) {
1869
+ if (d >>>= y = v >>> 24, p -= y, (y = v >>> 16 & 255) === 0)
1870
+ C[s++] = 65535 & v;
1871
+ else {
1872
+ if (!(16 & y)) {
1873
+ if ((64 & y) == 0) {
1874
+ v = m[(65535 & v) + (d & (1 << y) - 1)];
1875
+ continue t;
1876
+ }
1877
+ if (32 & y) {
1878
+ r2.mode = 12;
1879
+ break e;
1880
+ }
1881
+ e2.msg = "invalid literal/length code", r2.mode = 30;
1882
+ break e;
1883
+ }
1884
+ w = 65535 & v, (y &= 15) && (p < y && (d += z[n++] << p, p += 8), w += d & (1 << y) - 1, d >>>= y, p -= y), p < 15 && (d += z[n++] << p, p += 8, d += z[n++] << p, p += 8), v = _[d & b];
1885
+ r:
1886
+ for (; ; ) {
1887
+ if (d >>>= y = v >>> 24, p -= y, !(16 & (y = v >>> 16 & 255))) {
1888
+ if ((64 & y) == 0) {
1889
+ v = _[(65535 & v) + (d & (1 << y) - 1)];
1890
+ continue r;
1891
+ }
1892
+ e2.msg = "invalid distance code", r2.mode = 30;
1893
+ break e;
1894
+ }
1895
+ if (k = 65535 & v, p < (y &= 15) && (d += z[n++] << p, (p += 8) < y && (d += z[n++] << p, p += 8)), h < (k += d & (1 << y) - 1)) {
1896
+ e2.msg = "invalid distance too far back", r2.mode = 30;
1897
+ break e;
1898
+ }
1899
+ if (d >>>= y, p -= y, (y = s - a) < k) {
1900
+ if (l < (y = k - y) && r2.sane) {
1901
+ e2.msg = "invalid distance too far back", r2.mode = 30;
1902
+ break e;
1903
+ }
1904
+ if (S = c, (x = 0) === f) {
1905
+ if (x += u - y, y < w) {
1906
+ for (w -= y; C[s++] = c[x++], --y; )
1907
+ ;
1908
+ x = s - k, S = C;
1909
+ }
1910
+ } else if (f < y) {
1911
+ if (x += u + f - y, (y -= f) < w) {
1912
+ for (w -= y; C[s++] = c[x++], --y; )
1913
+ ;
1914
+ if (x = 0, f < w) {
1915
+ for (w -= y = f; C[s++] = c[x++], --y; )
1916
+ ;
1917
+ x = s - k, S = C;
1918
+ }
1919
+ }
1920
+ } else if (x += f - y, y < w) {
1921
+ for (w -= y; C[s++] = c[x++], --y; )
1922
+ ;
1923
+ x = s - k, S = C;
1924
+ }
1925
+ for (; 2 < w; )
1926
+ C[s++] = S[x++], C[s++] = S[x++], C[s++] = S[x++], w -= 3;
1927
+ w && (C[s++] = S[x++], 1 < w && (C[s++] = S[x++]));
1928
+ } else {
1929
+ for (x = s - k; C[s++] = C[x++], C[s++] = C[x++], C[s++] = C[x++], 2 < (w -= 3); )
1930
+ ;
1931
+ w && (C[s++] = C[x++], 1 < w && (C[s++] = C[x++]));
1932
+ }
1933
+ break;
1934
+ }
1935
+ }
1936
+ break;
1937
+ }
1938
+ } while (n < i && s < o);
1939
+ n -= w = p >> 3, d &= (1 << (p -= w << 3)) - 1, e2.next_in = n, e2.next_out = s, e2.avail_in = n < i ? i - n + 5 : 5 - (n - i), e2.avail_out = s < o ? o - s + 257 : 257 - (s - o), r2.hold = d, r2.bits = p;
1940
+ };
1941
+ }, {}], 49: [function(e, t, r) {
1942
+ "use strict";
1943
+ var I = e("../utils/common"), O = e("./adler32"), B = e("./crc32"), R = e("./inffast"), T = e("./inftrees"), D = 1, F = 2, N = 0, U = -2, P = 1, n = 852, i = 592;
1944
+ function L(e2) {
1945
+ return (e2 >>> 24 & 255) + (e2 >>> 8 & 65280) + ((65280 & e2) << 8) + ((255 & e2) << 24);
1946
+ }
1947
+ function s() {
1948
+ this.mode = 0, this.last = false, this.wrap = 0, this.havedict = false, this.flags = 0, this.dmax = 0, this.check = 0, this.total = 0, this.head = null, this.wbits = 0, this.wsize = 0, this.whave = 0, this.wnext = 0, this.window = null, this.hold = 0, this.bits = 0, this.length = 0, this.offset = 0, this.extra = 0, this.lencode = null, this.distcode = null, this.lenbits = 0, this.distbits = 0, this.ncode = 0, this.nlen = 0, this.ndist = 0, this.have = 0, this.next = null, this.lens = new I.Buf16(320), this.work = new I.Buf16(288), this.lendyn = null, this.distdyn = null, this.sane = 0, this.back = 0, this.was = 0;
1949
+ }
1950
+ function a(e2) {
1951
+ var t2;
1952
+ return e2 && e2.state ? (t2 = e2.state, e2.total_in = e2.total_out = t2.total = 0, e2.msg = "", t2.wrap && (e2.adler = 1 & t2.wrap), t2.mode = P, t2.last = 0, t2.havedict = 0, t2.dmax = 32768, t2.head = null, t2.hold = 0, t2.bits = 0, t2.lencode = t2.lendyn = new I.Buf32(n), t2.distcode = t2.distdyn = new I.Buf32(i), t2.sane = 1, t2.back = -1, N) : U;
1953
+ }
1954
+ function o(e2) {
1955
+ var t2;
1956
+ return e2 && e2.state ? ((t2 = e2.state).wsize = 0, t2.whave = 0, t2.wnext = 0, a(e2)) : U;
1957
+ }
1958
+ function h(e2, t2) {
1959
+ var r2, n2;
1960
+ return e2 && e2.state ? (n2 = e2.state, t2 < 0 ? (r2 = 0, t2 = -t2) : (r2 = 1 + (t2 >> 4), t2 < 48 && (t2 &= 15)), t2 && (t2 < 8 || 15 < t2) ? U : (n2.window !== null && n2.wbits !== t2 && (n2.window = null), n2.wrap = r2, n2.wbits = t2, o(e2))) : U;
1961
+ }
1962
+ function u(e2, t2) {
1963
+ var r2, n2;
1964
+ return e2 ? (n2 = new s(), (e2.state = n2).window = null, (r2 = h(e2, t2)) !== N && (e2.state = null), r2) : U;
1965
+ }
1966
+ var l, f, c = true;
1967
+ function j(e2) {
1968
+ if (c) {
1969
+ var t2;
1970
+ for (l = new I.Buf32(512), f = new I.Buf32(32), t2 = 0; t2 < 144; )
1971
+ e2.lens[t2++] = 8;
1972
+ for (; t2 < 256; )
1973
+ e2.lens[t2++] = 9;
1974
+ for (; t2 < 280; )
1975
+ e2.lens[t2++] = 7;
1976
+ for (; t2 < 288; )
1977
+ e2.lens[t2++] = 8;
1978
+ for (T(D, e2.lens, 0, 288, l, 0, e2.work, { bits: 9 }), t2 = 0; t2 < 32; )
1979
+ e2.lens[t2++] = 5;
1980
+ T(F, e2.lens, 0, 32, f, 0, e2.work, { bits: 5 }), c = false;
1981
+ }
1982
+ e2.lencode = l, e2.lenbits = 9, e2.distcode = f, e2.distbits = 5;
1983
+ }
1984
+ function Z(e2, t2, r2, n2) {
1985
+ var i2, s2 = e2.state;
1986
+ return s2.window === null && (s2.wsize = 1 << s2.wbits, s2.wnext = 0, s2.whave = 0, s2.window = new I.Buf8(s2.wsize)), n2 >= s2.wsize ? (I.arraySet(s2.window, t2, r2 - s2.wsize, s2.wsize, 0), s2.wnext = 0, s2.whave = s2.wsize) : (n2 < (i2 = s2.wsize - s2.wnext) && (i2 = n2), I.arraySet(s2.window, t2, r2 - n2, i2, s2.wnext), (n2 -= i2) ? (I.arraySet(s2.window, t2, r2 - n2, n2, 0), s2.wnext = n2, s2.whave = s2.wsize) : (s2.wnext += i2, s2.wnext === s2.wsize && (s2.wnext = 0), s2.whave < s2.wsize && (s2.whave += i2))), 0;
1987
+ }
1988
+ r.inflateReset = o, r.inflateReset2 = h, r.inflateResetKeep = a, r.inflateInit = function(e2) {
1989
+ return u(e2, 15);
1990
+ }, r.inflateInit2 = u, r.inflate = function(e2, t2) {
1991
+ var r2, n2, i2, s2, a2, o2, h2, u2, l2, f2, c2, d, p, m, _, g, b, v, y, w, k, x, S, z, C = 0, E = new I.Buf8(4), A = [16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15];
1992
+ if (!e2 || !e2.state || !e2.output || !e2.input && e2.avail_in !== 0)
1993
+ return U;
1994
+ (r2 = e2.state).mode === 12 && (r2.mode = 13), a2 = e2.next_out, i2 = e2.output, h2 = e2.avail_out, s2 = e2.next_in, n2 = e2.input, o2 = e2.avail_in, u2 = r2.hold, l2 = r2.bits, f2 = o2, c2 = h2, x = N;
1995
+ e:
1996
+ for (; ; )
1997
+ switch (r2.mode) {
1998
+ case P:
1999
+ if (r2.wrap === 0) {
2000
+ r2.mode = 13;
2001
+ break;
2002
+ }
2003
+ for (; l2 < 16; ) {
2004
+ if (o2 === 0)
2005
+ break e;
2006
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2007
+ }
2008
+ if (2 & r2.wrap && u2 === 35615) {
2009
+ E[r2.check = 0] = 255 & u2, E[1] = u2 >>> 8 & 255, r2.check = B(r2.check, E, 2, 0), l2 = u2 = 0, r2.mode = 2;
2010
+ break;
2011
+ }
2012
+ if (r2.flags = 0, r2.head && (r2.head.done = false), !(1 & r2.wrap) || (((255 & u2) << 8) + (u2 >> 8)) % 31) {
2013
+ e2.msg = "incorrect header check", r2.mode = 30;
2014
+ break;
2015
+ }
2016
+ if ((15 & u2) != 8) {
2017
+ e2.msg = "unknown compression method", r2.mode = 30;
2018
+ break;
2019
+ }
2020
+ if (l2 -= 4, k = 8 + (15 & (u2 >>>= 4)), r2.wbits === 0)
2021
+ r2.wbits = k;
2022
+ else if (k > r2.wbits) {
2023
+ e2.msg = "invalid window size", r2.mode = 30;
2024
+ break;
2025
+ }
2026
+ r2.dmax = 1 << k, e2.adler = r2.check = 1, r2.mode = 512 & u2 ? 10 : 12, l2 = u2 = 0;
2027
+ break;
2028
+ case 2:
2029
+ for (; l2 < 16; ) {
2030
+ if (o2 === 0)
2031
+ break e;
2032
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2033
+ }
2034
+ if (r2.flags = u2, (255 & r2.flags) != 8) {
2035
+ e2.msg = "unknown compression method", r2.mode = 30;
2036
+ break;
2037
+ }
2038
+ if (57344 & r2.flags) {
2039
+ e2.msg = "unknown header flags set", r2.mode = 30;
2040
+ break;
2041
+ }
2042
+ r2.head && (r2.head.text = u2 >> 8 & 1), 512 & r2.flags && (E[0] = 255 & u2, E[1] = u2 >>> 8 & 255, r2.check = B(r2.check, E, 2, 0)), l2 = u2 = 0, r2.mode = 3;
2043
+ case 3:
2044
+ for (; l2 < 32; ) {
2045
+ if (o2 === 0)
2046
+ break e;
2047
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2048
+ }
2049
+ r2.head && (r2.head.time = u2), 512 & r2.flags && (E[0] = 255 & u2, E[1] = u2 >>> 8 & 255, E[2] = u2 >>> 16 & 255, E[3] = u2 >>> 24 & 255, r2.check = B(r2.check, E, 4, 0)), l2 = u2 = 0, r2.mode = 4;
2050
+ case 4:
2051
+ for (; l2 < 16; ) {
2052
+ if (o2 === 0)
2053
+ break e;
2054
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2055
+ }
2056
+ r2.head && (r2.head.xflags = 255 & u2, r2.head.os = u2 >> 8), 512 & r2.flags && (E[0] = 255 & u2, E[1] = u2 >>> 8 & 255, r2.check = B(r2.check, E, 2, 0)), l2 = u2 = 0, r2.mode = 5;
2057
+ case 5:
2058
+ if (1024 & r2.flags) {
2059
+ for (; l2 < 16; ) {
2060
+ if (o2 === 0)
2061
+ break e;
2062
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2063
+ }
2064
+ r2.length = u2, r2.head && (r2.head.extra_len = u2), 512 & r2.flags && (E[0] = 255 & u2, E[1] = u2 >>> 8 & 255, r2.check = B(r2.check, E, 2, 0)), l2 = u2 = 0;
2065
+ } else
2066
+ r2.head && (r2.head.extra = null);
2067
+ r2.mode = 6;
2068
+ case 6:
2069
+ if (1024 & r2.flags && (o2 < (d = r2.length) && (d = o2), d && (r2.head && (k = r2.head.extra_len - r2.length, r2.head.extra || (r2.head.extra = new Array(r2.head.extra_len)), I.arraySet(r2.head.extra, n2, s2, d, k)), 512 & r2.flags && (r2.check = B(r2.check, n2, d, s2)), o2 -= d, s2 += d, r2.length -= d), r2.length))
2070
+ break e;
2071
+ r2.length = 0, r2.mode = 7;
2072
+ case 7:
2073
+ if (2048 & r2.flags) {
2074
+ if (o2 === 0)
2075
+ break e;
2076
+ for (d = 0; k = n2[s2 + d++], r2.head && k && r2.length < 65536 && (r2.head.name += String.fromCharCode(k)), k && d < o2; )
2077
+ ;
2078
+ if (512 & r2.flags && (r2.check = B(r2.check, n2, d, s2)), o2 -= d, s2 += d, k)
2079
+ break e;
2080
+ } else
2081
+ r2.head && (r2.head.name = null);
2082
+ r2.length = 0, r2.mode = 8;
2083
+ case 8:
2084
+ if (4096 & r2.flags) {
2085
+ if (o2 === 0)
2086
+ break e;
2087
+ for (d = 0; k = n2[s2 + d++], r2.head && k && r2.length < 65536 && (r2.head.comment += String.fromCharCode(k)), k && d < o2; )
2088
+ ;
2089
+ if (512 & r2.flags && (r2.check = B(r2.check, n2, d, s2)), o2 -= d, s2 += d, k)
2090
+ break e;
2091
+ } else
2092
+ r2.head && (r2.head.comment = null);
2093
+ r2.mode = 9;
2094
+ case 9:
2095
+ if (512 & r2.flags) {
2096
+ for (; l2 < 16; ) {
2097
+ if (o2 === 0)
2098
+ break e;
2099
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2100
+ }
2101
+ if (u2 !== (65535 & r2.check)) {
2102
+ e2.msg = "header crc mismatch", r2.mode = 30;
2103
+ break;
2104
+ }
2105
+ l2 = u2 = 0;
2106
+ }
2107
+ r2.head && (r2.head.hcrc = r2.flags >> 9 & 1, r2.head.done = true), e2.adler = r2.check = 0, r2.mode = 12;
2108
+ break;
2109
+ case 10:
2110
+ for (; l2 < 32; ) {
2111
+ if (o2 === 0)
2112
+ break e;
2113
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2114
+ }
2115
+ e2.adler = r2.check = L(u2), l2 = u2 = 0, r2.mode = 11;
2116
+ case 11:
2117
+ if (r2.havedict === 0)
2118
+ return e2.next_out = a2, e2.avail_out = h2, e2.next_in = s2, e2.avail_in = o2, r2.hold = u2, r2.bits = l2, 2;
2119
+ e2.adler = r2.check = 1, r2.mode = 12;
2120
+ case 12:
2121
+ if (t2 === 5 || t2 === 6)
2122
+ break e;
2123
+ case 13:
2124
+ if (r2.last) {
2125
+ u2 >>>= 7 & l2, l2 -= 7 & l2, r2.mode = 27;
2126
+ break;
2127
+ }
2128
+ for (; l2 < 3; ) {
2129
+ if (o2 === 0)
2130
+ break e;
2131
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2132
+ }
2133
+ switch (r2.last = 1 & u2, l2 -= 1, 3 & (u2 >>>= 1)) {
2134
+ case 0:
2135
+ r2.mode = 14;
2136
+ break;
2137
+ case 1:
2138
+ if (j(r2), r2.mode = 20, t2 !== 6)
2139
+ break;
2140
+ u2 >>>= 2, l2 -= 2;
2141
+ break e;
2142
+ case 2:
2143
+ r2.mode = 17;
2144
+ break;
2145
+ case 3:
2146
+ e2.msg = "invalid block type", r2.mode = 30;
2147
+ }
2148
+ u2 >>>= 2, l2 -= 2;
2149
+ break;
2150
+ case 14:
2151
+ for (u2 >>>= 7 & l2, l2 -= 7 & l2; l2 < 32; ) {
2152
+ if (o2 === 0)
2153
+ break e;
2154
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2155
+ }
2156
+ if ((65535 & u2) != (u2 >>> 16 ^ 65535)) {
2157
+ e2.msg = "invalid stored block lengths", r2.mode = 30;
2158
+ break;
2159
+ }
2160
+ if (r2.length = 65535 & u2, l2 = u2 = 0, r2.mode = 15, t2 === 6)
2161
+ break e;
2162
+ case 15:
2163
+ r2.mode = 16;
2164
+ case 16:
2165
+ if (d = r2.length) {
2166
+ if (o2 < d && (d = o2), h2 < d && (d = h2), d === 0)
2167
+ break e;
2168
+ I.arraySet(i2, n2, s2, d, a2), o2 -= d, s2 += d, h2 -= d, a2 += d, r2.length -= d;
2169
+ break;
2170
+ }
2171
+ r2.mode = 12;
2172
+ break;
2173
+ case 17:
2174
+ for (; l2 < 14; ) {
2175
+ if (o2 === 0)
2176
+ break e;
2177
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2178
+ }
2179
+ if (r2.nlen = 257 + (31 & u2), u2 >>>= 5, l2 -= 5, r2.ndist = 1 + (31 & u2), u2 >>>= 5, l2 -= 5, r2.ncode = 4 + (15 & u2), u2 >>>= 4, l2 -= 4, 286 < r2.nlen || 30 < r2.ndist) {
2180
+ e2.msg = "too many length or distance symbols", r2.mode = 30;
2181
+ break;
2182
+ }
2183
+ r2.have = 0, r2.mode = 18;
2184
+ case 18:
2185
+ for (; r2.have < r2.ncode; ) {
2186
+ for (; l2 < 3; ) {
2187
+ if (o2 === 0)
2188
+ break e;
2189
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2190
+ }
2191
+ r2.lens[A[r2.have++]] = 7 & u2, u2 >>>= 3, l2 -= 3;
2192
+ }
2193
+ for (; r2.have < 19; )
2194
+ r2.lens[A[r2.have++]] = 0;
2195
+ if (r2.lencode = r2.lendyn, r2.lenbits = 7, S = { bits: r2.lenbits }, x = T(0, r2.lens, 0, 19, r2.lencode, 0, r2.work, S), r2.lenbits = S.bits, x) {
2196
+ e2.msg = "invalid code lengths set", r2.mode = 30;
2197
+ break;
2198
+ }
2199
+ r2.have = 0, r2.mode = 19;
2200
+ case 19:
2201
+ for (; r2.have < r2.nlen + r2.ndist; ) {
2202
+ for (; g = (C = r2.lencode[u2 & (1 << r2.lenbits) - 1]) >>> 16 & 255, b = 65535 & C, !((_ = C >>> 24) <= l2); ) {
2203
+ if (o2 === 0)
2204
+ break e;
2205
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2206
+ }
2207
+ if (b < 16)
2208
+ u2 >>>= _, l2 -= _, r2.lens[r2.have++] = b;
2209
+ else {
2210
+ if (b === 16) {
2211
+ for (z = _ + 2; l2 < z; ) {
2212
+ if (o2 === 0)
2213
+ break e;
2214
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2215
+ }
2216
+ if (u2 >>>= _, l2 -= _, r2.have === 0) {
2217
+ e2.msg = "invalid bit length repeat", r2.mode = 30;
2218
+ break;
2219
+ }
2220
+ k = r2.lens[r2.have - 1], d = 3 + (3 & u2), u2 >>>= 2, l2 -= 2;
2221
+ } else if (b === 17) {
2222
+ for (z = _ + 3; l2 < z; ) {
2223
+ if (o2 === 0)
2224
+ break e;
2225
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2226
+ }
2227
+ l2 -= _, k = 0, d = 3 + (7 & (u2 >>>= _)), u2 >>>= 3, l2 -= 3;
2228
+ } else {
2229
+ for (z = _ + 7; l2 < z; ) {
2230
+ if (o2 === 0)
2231
+ break e;
2232
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2233
+ }
2234
+ l2 -= _, k = 0, d = 11 + (127 & (u2 >>>= _)), u2 >>>= 7, l2 -= 7;
2235
+ }
2236
+ if (r2.have + d > r2.nlen + r2.ndist) {
2237
+ e2.msg = "invalid bit length repeat", r2.mode = 30;
2238
+ break;
2239
+ }
2240
+ for (; d--; )
2241
+ r2.lens[r2.have++] = k;
2242
+ }
2243
+ }
2244
+ if (r2.mode === 30)
2245
+ break;
2246
+ if (r2.lens[256] === 0) {
2247
+ e2.msg = "invalid code -- missing end-of-block", r2.mode = 30;
2248
+ break;
2249
+ }
2250
+ if (r2.lenbits = 9, S = { bits: r2.lenbits }, x = T(D, r2.lens, 0, r2.nlen, r2.lencode, 0, r2.work, S), r2.lenbits = S.bits, x) {
2251
+ e2.msg = "invalid literal/lengths set", r2.mode = 30;
2252
+ break;
2253
+ }
2254
+ if (r2.distbits = 6, r2.distcode = r2.distdyn, S = { bits: r2.distbits }, x = T(F, r2.lens, r2.nlen, r2.ndist, r2.distcode, 0, r2.work, S), r2.distbits = S.bits, x) {
2255
+ e2.msg = "invalid distances set", r2.mode = 30;
2256
+ break;
2257
+ }
2258
+ if (r2.mode = 20, t2 === 6)
2259
+ break e;
2260
+ case 20:
2261
+ r2.mode = 21;
2262
+ case 21:
2263
+ if (6 <= o2 && 258 <= h2) {
2264
+ e2.next_out = a2, e2.avail_out = h2, e2.next_in = s2, e2.avail_in = o2, r2.hold = u2, r2.bits = l2, R(e2, c2), a2 = e2.next_out, i2 = e2.output, h2 = e2.avail_out, s2 = e2.next_in, n2 = e2.input, o2 = e2.avail_in, u2 = r2.hold, l2 = r2.bits, r2.mode === 12 && (r2.back = -1);
2265
+ break;
2266
+ }
2267
+ for (r2.back = 0; g = (C = r2.lencode[u2 & (1 << r2.lenbits) - 1]) >>> 16 & 255, b = 65535 & C, !((_ = C >>> 24) <= l2); ) {
2268
+ if (o2 === 0)
2269
+ break e;
2270
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2271
+ }
2272
+ if (g && (240 & g) == 0) {
2273
+ for (v = _, y = g, w = b; g = (C = r2.lencode[w + ((u2 & (1 << v + y) - 1) >> v)]) >>> 16 & 255, b = 65535 & C, !(v + (_ = C >>> 24) <= l2); ) {
2274
+ if (o2 === 0)
2275
+ break e;
2276
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2277
+ }
2278
+ u2 >>>= v, l2 -= v, r2.back += v;
2279
+ }
2280
+ if (u2 >>>= _, l2 -= _, r2.back += _, r2.length = b, g === 0) {
2281
+ r2.mode = 26;
2282
+ break;
2283
+ }
2284
+ if (32 & g) {
2285
+ r2.back = -1, r2.mode = 12;
2286
+ break;
2287
+ }
2288
+ if (64 & g) {
2289
+ e2.msg = "invalid literal/length code", r2.mode = 30;
2290
+ break;
2291
+ }
2292
+ r2.extra = 15 & g, r2.mode = 22;
2293
+ case 22:
2294
+ if (r2.extra) {
2295
+ for (z = r2.extra; l2 < z; ) {
2296
+ if (o2 === 0)
2297
+ break e;
2298
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2299
+ }
2300
+ r2.length += u2 & (1 << r2.extra) - 1, u2 >>>= r2.extra, l2 -= r2.extra, r2.back += r2.extra;
2301
+ }
2302
+ r2.was = r2.length, r2.mode = 23;
2303
+ case 23:
2304
+ for (; g = (C = r2.distcode[u2 & (1 << r2.distbits) - 1]) >>> 16 & 255, b = 65535 & C, !((_ = C >>> 24) <= l2); ) {
2305
+ if (o2 === 0)
2306
+ break e;
2307
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2308
+ }
2309
+ if ((240 & g) == 0) {
2310
+ for (v = _, y = g, w = b; g = (C = r2.distcode[w + ((u2 & (1 << v + y) - 1) >> v)]) >>> 16 & 255, b = 65535 & C, !(v + (_ = C >>> 24) <= l2); ) {
2311
+ if (o2 === 0)
2312
+ break e;
2313
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2314
+ }
2315
+ u2 >>>= v, l2 -= v, r2.back += v;
2316
+ }
2317
+ if (u2 >>>= _, l2 -= _, r2.back += _, 64 & g) {
2318
+ e2.msg = "invalid distance code", r2.mode = 30;
2319
+ break;
2320
+ }
2321
+ r2.offset = b, r2.extra = 15 & g, r2.mode = 24;
2322
+ case 24:
2323
+ if (r2.extra) {
2324
+ for (z = r2.extra; l2 < z; ) {
2325
+ if (o2 === 0)
2326
+ break e;
2327
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2328
+ }
2329
+ r2.offset += u2 & (1 << r2.extra) - 1, u2 >>>= r2.extra, l2 -= r2.extra, r2.back += r2.extra;
2330
+ }
2331
+ if (r2.offset > r2.dmax) {
2332
+ e2.msg = "invalid distance too far back", r2.mode = 30;
2333
+ break;
2334
+ }
2335
+ r2.mode = 25;
2336
+ case 25:
2337
+ if (h2 === 0)
2338
+ break e;
2339
+ if (d = c2 - h2, r2.offset > d) {
2340
+ if ((d = r2.offset - d) > r2.whave && r2.sane) {
2341
+ e2.msg = "invalid distance too far back", r2.mode = 30;
2342
+ break;
2343
+ }
2344
+ p = d > r2.wnext ? (d -= r2.wnext, r2.wsize - d) : r2.wnext - d, d > r2.length && (d = r2.length), m = r2.window;
2345
+ } else
2346
+ m = i2, p = a2 - r2.offset, d = r2.length;
2347
+ for (h2 < d && (d = h2), h2 -= d, r2.length -= d; i2[a2++] = m[p++], --d; )
2348
+ ;
2349
+ r2.length === 0 && (r2.mode = 21);
2350
+ break;
2351
+ case 26:
2352
+ if (h2 === 0)
2353
+ break e;
2354
+ i2[a2++] = r2.length, h2--, r2.mode = 21;
2355
+ break;
2356
+ case 27:
2357
+ if (r2.wrap) {
2358
+ for (; l2 < 32; ) {
2359
+ if (o2 === 0)
2360
+ break e;
2361
+ o2--, u2 |= n2[s2++] << l2, l2 += 8;
2362
+ }
2363
+ if (c2 -= h2, e2.total_out += c2, r2.total += c2, c2 && (e2.adler = r2.check = r2.flags ? B(r2.check, i2, c2, a2 - c2) : O(r2.check, i2, c2, a2 - c2)), c2 = h2, (r2.flags ? u2 : L(u2)) !== r2.check) {
2364
+ e2.msg = "incorrect data check", r2.mode = 30;
2365
+ break;
2366
+ }
2367
+ l2 = u2 = 0;
2368
+ }
2369
+ r2.mode = 28;
2370
+ case 28:
2371
+ if (r2.wrap && r2.flags) {
2372
+ for (; l2 < 32; ) {
2373
+ if (o2 === 0)
2374
+ break e;
2375
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2376
+ }
2377
+ if (u2 !== (4294967295 & r2.total)) {
2378
+ e2.msg = "incorrect length check", r2.mode = 30;
2379
+ break;
2380
+ }
2381
+ l2 = u2 = 0;
2382
+ }
2383
+ r2.mode = 29;
2384
+ case 29:
2385
+ x = 1;
2386
+ break e;
2387
+ case 30:
2388
+ x = -3;
2389
+ break e;
2390
+ case 31:
2391
+ return -4;
2392
+ case 32:
2393
+ default:
2394
+ return U;
2395
+ }
2396
+ return e2.next_out = a2, e2.avail_out = h2, e2.next_in = s2, e2.avail_in = o2, r2.hold = u2, r2.bits = l2, (r2.wsize || c2 !== e2.avail_out && r2.mode < 30 && (r2.mode < 27 || t2 !== 4)) && Z(e2, e2.output, e2.next_out, c2 - e2.avail_out) ? (r2.mode = 31, -4) : (f2 -= e2.avail_in, c2 -= e2.avail_out, e2.total_in += f2, e2.total_out += c2, r2.total += c2, r2.wrap && c2 && (e2.adler = r2.check = r2.flags ? B(r2.check, i2, c2, e2.next_out - c2) : O(r2.check, i2, c2, e2.next_out - c2)), e2.data_type = r2.bits + (r2.last ? 64 : 0) + (r2.mode === 12 ? 128 : 0) + (r2.mode === 20 || r2.mode === 15 ? 256 : 0), (f2 == 0 && c2 === 0 || t2 === 4) && x === N && (x = -5), x);
2397
+ }, r.inflateEnd = function(e2) {
2398
+ if (!e2 || !e2.state)
2399
+ return U;
2400
+ var t2 = e2.state;
2401
+ return t2.window && (t2.window = null), e2.state = null, N;
2402
+ }, r.inflateGetHeader = function(e2, t2) {
2403
+ var r2;
2404
+ return e2 && e2.state ? (2 & (r2 = e2.state).wrap) == 0 ? U : ((r2.head = t2).done = false, N) : U;
2405
+ }, r.inflateSetDictionary = function(e2, t2) {
2406
+ var r2, n2 = t2.length;
2407
+ return e2 && e2.state ? (r2 = e2.state).wrap !== 0 && r2.mode !== 11 ? U : r2.mode === 11 && O(1, t2, n2, 0) !== r2.check ? -3 : Z(e2, t2, n2, n2) ? (r2.mode = 31, -4) : (r2.havedict = 1, N) : U;
2408
+ }, r.inflateInfo = "pako inflate (from Nodeca project)";
2409
+ }, { "../utils/common": 41, "./adler32": 43, "./crc32": 45, "./inffast": 48, "./inftrees": 50 }], 50: [function(e, t, r) {
2410
+ "use strict";
2411
+ var D = e("../utils/common"), F = [3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31, 35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0], N = [16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 18, 18, 18, 18, 19, 19, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 16, 72, 78], U = [1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193, 257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145, 8193, 12289, 16385, 24577, 0, 0], P = [16, 16, 16, 16, 17, 17, 18, 18, 19, 19, 20, 20, 21, 21, 22, 22, 23, 23, 24, 24, 25, 25, 26, 26, 27, 27, 28, 28, 29, 29, 64, 64];
2412
+ t.exports = function(e2, t2, r2, n, i, s, a, o) {
2413
+ var h, u, l, f, c, d, p, m, _, g = o.bits, b = 0, v = 0, y = 0, w = 0, k = 0, x = 0, S = 0, z = 0, C = 0, E = 0, A = null, I = 0, O = new D.Buf16(16), B = new D.Buf16(16), R = null, T = 0;
2414
+ for (b = 0; b <= 15; b++)
2415
+ O[b] = 0;
2416
+ for (v = 0; v < n; v++)
2417
+ O[t2[r2 + v]]++;
2418
+ for (k = g, w = 15; 1 <= w && O[w] === 0; w--)
2419
+ ;
2420
+ if (w < k && (k = w), w === 0)
2421
+ return i[s++] = 20971520, i[s++] = 20971520, o.bits = 1, 0;
2422
+ for (y = 1; y < w && O[y] === 0; y++)
2423
+ ;
2424
+ for (k < y && (k = y), b = z = 1; b <= 15; b++)
2425
+ if (z <<= 1, (z -= O[b]) < 0)
2426
+ return -1;
2427
+ if (0 < z && (e2 === 0 || w !== 1))
2428
+ return -1;
2429
+ for (B[1] = 0, b = 1; b < 15; b++)
2430
+ B[b + 1] = B[b] + O[b];
2431
+ for (v = 0; v < n; v++)
2432
+ t2[r2 + v] !== 0 && (a[B[t2[r2 + v]]++] = v);
2433
+ if (d = e2 === 0 ? (A = R = a, 19) : e2 === 1 ? (A = F, I -= 257, R = N, T -= 257, 256) : (A = U, R = P, -1), b = y, c = s, S = v = E = 0, l = -1, f = (C = 1 << (x = k)) - 1, e2 === 1 && 852 < C || e2 === 2 && 592 < C)
2434
+ return 1;
2435
+ for (; ; ) {
2436
+ for (p = b - S, _ = a[v] < d ? (m = 0, a[v]) : a[v] > d ? (m = R[T + a[v]], A[I + a[v]]) : (m = 96, 0), h = 1 << b - S, y = u = 1 << x; i[c + (E >> S) + (u -= h)] = p << 24 | m << 16 | _ | 0, u !== 0; )
2437
+ ;
2438
+ for (h = 1 << b - 1; E & h; )
2439
+ h >>= 1;
2440
+ if (h !== 0 ? (E &= h - 1, E += h) : E = 0, v++, --O[b] == 0) {
2441
+ if (b === w)
2442
+ break;
2443
+ b = t2[r2 + a[v]];
2444
+ }
2445
+ if (k < b && (E & f) !== l) {
2446
+ for (S === 0 && (S = k), c += y, z = 1 << (x = b - S); x + S < w && !((z -= O[x + S]) <= 0); )
2447
+ x++, z <<= 1;
2448
+ if (C += 1 << x, e2 === 1 && 852 < C || e2 === 2 && 592 < C)
2449
+ return 1;
2450
+ i[l = E & f] = k << 24 | x << 16 | c - s | 0;
2451
+ }
2452
+ }
2453
+ return E !== 0 && (i[c + E] = b - S << 24 | 64 << 16 | 0), o.bits = k, 0;
2454
+ };
2455
+ }, { "../utils/common": 41 }], 51: [function(e, t, r) {
2456
+ "use strict";
2457
+ t.exports = { 2: "need dictionary", 1: "stream end", 0: "", "-1": "file error", "-2": "stream error", "-3": "data error", "-4": "insufficient memory", "-5": "buffer error", "-6": "incompatible version" };
2458
+ }, {}], 52: [function(e, t, r) {
2459
+ "use strict";
2460
+ var i = e("../utils/common"), o = 0, h = 1;
2461
+ function n(e2) {
2462
+ for (var t2 = e2.length; 0 <= --t2; )
2463
+ e2[t2] = 0;
2464
+ }
2465
+ var s = 0, a = 29, u = 256, l = u + 1 + a, f = 30, c = 19, _ = 2 * l + 1, g = 15, d = 16, p = 7, m = 256, b = 16, v = 17, y = 18, w = [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], k = [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], x = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 3, 7], S = [16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15], z = new Array(2 * (l + 2));
2466
+ n(z);
2467
+ var C = new Array(2 * f);
2468
+ n(C);
2469
+ var E = new Array(512);
2470
+ n(E);
2471
+ var A = new Array(256);
2472
+ n(A);
2473
+ var I = new Array(a);
2474
+ n(I);
2475
+ var O, B, R, T = new Array(f);
2476
+ function D(e2, t2, r2, n2, i2) {
2477
+ this.static_tree = e2, this.extra_bits = t2, this.extra_base = r2, this.elems = n2, this.max_length = i2, this.has_stree = e2 && e2.length;
2478
+ }
2479
+ function F(e2, t2) {
2480
+ this.dyn_tree = e2, this.max_code = 0, this.stat_desc = t2;
2481
+ }
2482
+ function N(e2) {
2483
+ return e2 < 256 ? E[e2] : E[256 + (e2 >>> 7)];
2484
+ }
2485
+ function U(e2, t2) {
2486
+ e2.pending_buf[e2.pending++] = 255 & t2, e2.pending_buf[e2.pending++] = t2 >>> 8 & 255;
2487
+ }
2488
+ function P(e2, t2, r2) {
2489
+ e2.bi_valid > d - r2 ? (e2.bi_buf |= t2 << e2.bi_valid & 65535, U(e2, e2.bi_buf), e2.bi_buf = t2 >> d - e2.bi_valid, e2.bi_valid += r2 - d) : (e2.bi_buf |= t2 << e2.bi_valid & 65535, e2.bi_valid += r2);
2490
+ }
2491
+ function L(e2, t2, r2) {
2492
+ P(e2, r2[2 * t2], r2[2 * t2 + 1]);
2493
+ }
2494
+ function j(e2, t2) {
2495
+ for (var r2 = 0; r2 |= 1 & e2, e2 >>>= 1, r2 <<= 1, 0 < --t2; )
2496
+ ;
2497
+ return r2 >>> 1;
2498
+ }
2499
+ function Z(e2, t2, r2) {
2500
+ var n2, i2, s2 = new Array(g + 1), a2 = 0;
2501
+ for (n2 = 1; n2 <= g; n2++)
2502
+ s2[n2] = a2 = a2 + r2[n2 - 1] << 1;
2503
+ for (i2 = 0; i2 <= t2; i2++) {
2504
+ var o2 = e2[2 * i2 + 1];
2505
+ o2 !== 0 && (e2[2 * i2] = j(s2[o2]++, o2));
2506
+ }
2507
+ }
2508
+ function W(e2) {
2509
+ var t2;
2510
+ for (t2 = 0; t2 < l; t2++)
2511
+ e2.dyn_ltree[2 * t2] = 0;
2512
+ for (t2 = 0; t2 < f; t2++)
2513
+ e2.dyn_dtree[2 * t2] = 0;
2514
+ for (t2 = 0; t2 < c; t2++)
2515
+ e2.bl_tree[2 * t2] = 0;
2516
+ e2.dyn_ltree[2 * m] = 1, e2.opt_len = e2.static_len = 0, e2.last_lit = e2.matches = 0;
2517
+ }
2518
+ function M(e2) {
2519
+ 8 < e2.bi_valid ? U(e2, e2.bi_buf) : 0 < e2.bi_valid && (e2.pending_buf[e2.pending++] = e2.bi_buf), e2.bi_buf = 0, e2.bi_valid = 0;
2520
+ }
2521
+ function H(e2, t2, r2, n2) {
2522
+ var i2 = 2 * t2, s2 = 2 * r2;
2523
+ return e2[i2] < e2[s2] || e2[i2] === e2[s2] && n2[t2] <= n2[r2];
2524
+ }
2525
+ function G(e2, t2, r2) {
2526
+ for (var n2 = e2.heap[r2], i2 = r2 << 1; i2 <= e2.heap_len && (i2 < e2.heap_len && H(t2, e2.heap[i2 + 1], e2.heap[i2], e2.depth) && i2++, !H(t2, n2, e2.heap[i2], e2.depth)); )
2527
+ e2.heap[r2] = e2.heap[i2], r2 = i2, i2 <<= 1;
2528
+ e2.heap[r2] = n2;
2529
+ }
2530
+ function K(e2, t2, r2) {
2531
+ var n2, i2, s2, a2, o2 = 0;
2532
+ if (e2.last_lit !== 0)
2533
+ for (; n2 = e2.pending_buf[e2.d_buf + 2 * o2] << 8 | e2.pending_buf[e2.d_buf + 2 * o2 + 1], i2 = e2.pending_buf[e2.l_buf + o2], o2++, n2 === 0 ? L(e2, i2, t2) : (L(e2, (s2 = A[i2]) + u + 1, t2), (a2 = w[s2]) !== 0 && P(e2, i2 -= I[s2], a2), L(e2, s2 = N(--n2), r2), (a2 = k[s2]) !== 0 && P(e2, n2 -= T[s2], a2)), o2 < e2.last_lit; )
2534
+ ;
2535
+ L(e2, m, t2);
2536
+ }
2537
+ function Y(e2, t2) {
2538
+ var r2, n2, i2, s2 = t2.dyn_tree, a2 = t2.stat_desc.static_tree, o2 = t2.stat_desc.has_stree, h2 = t2.stat_desc.elems, u2 = -1;
2539
+ for (e2.heap_len = 0, e2.heap_max = _, r2 = 0; r2 < h2; r2++)
2540
+ s2[2 * r2] !== 0 ? (e2.heap[++e2.heap_len] = u2 = r2, e2.depth[r2] = 0) : s2[2 * r2 + 1] = 0;
2541
+ for (; e2.heap_len < 2; )
2542
+ s2[2 * (i2 = e2.heap[++e2.heap_len] = u2 < 2 ? ++u2 : 0)] = 1, e2.depth[i2] = 0, e2.opt_len--, o2 && (e2.static_len -= a2[2 * i2 + 1]);
2543
+ for (t2.max_code = u2, r2 = e2.heap_len >> 1; 1 <= r2; r2--)
2544
+ G(e2, s2, r2);
2545
+ for (i2 = h2; r2 = e2.heap[1], e2.heap[1] = e2.heap[e2.heap_len--], G(e2, s2, 1), n2 = e2.heap[1], e2.heap[--e2.heap_max] = r2, e2.heap[--e2.heap_max] = n2, s2[2 * i2] = s2[2 * r2] + s2[2 * n2], e2.depth[i2] = (e2.depth[r2] >= e2.depth[n2] ? e2.depth[r2] : e2.depth[n2]) + 1, s2[2 * r2 + 1] = s2[2 * n2 + 1] = i2, e2.heap[1] = i2++, G(e2, s2, 1), 2 <= e2.heap_len; )
2546
+ ;
2547
+ e2.heap[--e2.heap_max] = e2.heap[1], function(e3, t3) {
2548
+ var r3, n3, i3, s3, a3, o3, h3 = t3.dyn_tree, u3 = t3.max_code, l2 = t3.stat_desc.static_tree, f2 = t3.stat_desc.has_stree, c2 = t3.stat_desc.extra_bits, d2 = t3.stat_desc.extra_base, p2 = t3.stat_desc.max_length, m2 = 0;
2549
+ for (s3 = 0; s3 <= g; s3++)
2550
+ e3.bl_count[s3] = 0;
2551
+ for (h3[2 * e3.heap[e3.heap_max] + 1] = 0, r3 = e3.heap_max + 1; r3 < _; r3++)
2552
+ p2 < (s3 = h3[2 * h3[2 * (n3 = e3.heap[r3]) + 1] + 1] + 1) && (s3 = p2, m2++), h3[2 * n3 + 1] = s3, u3 < n3 || (e3.bl_count[s3]++, a3 = 0, d2 <= n3 && (a3 = c2[n3 - d2]), o3 = h3[2 * n3], e3.opt_len += o3 * (s3 + a3), f2 && (e3.static_len += o3 * (l2[2 * n3 + 1] + a3)));
2553
+ if (m2 !== 0) {
2554
+ do {
2555
+ for (s3 = p2 - 1; e3.bl_count[s3] === 0; )
2556
+ s3--;
2557
+ e3.bl_count[s3]--, e3.bl_count[s3 + 1] += 2, e3.bl_count[p2]--, m2 -= 2;
2558
+ } while (0 < m2);
2559
+ for (s3 = p2; s3 !== 0; s3--)
2560
+ for (n3 = e3.bl_count[s3]; n3 !== 0; )
2561
+ u3 < (i3 = e3.heap[--r3]) || (h3[2 * i3 + 1] !== s3 && (e3.opt_len += (s3 - h3[2 * i3 + 1]) * h3[2 * i3], h3[2 * i3 + 1] = s3), n3--);
2562
+ }
2563
+ }(e2, t2), Z(s2, u2, e2.bl_count);
2564
+ }
2565
+ function X(e2, t2, r2) {
2566
+ var n2, i2, s2 = -1, a2 = t2[1], o2 = 0, h2 = 7, u2 = 4;
2567
+ for (a2 === 0 && (h2 = 138, u2 = 3), t2[2 * (r2 + 1) + 1] = 65535, n2 = 0; n2 <= r2; n2++)
2568
+ i2 = a2, a2 = t2[2 * (n2 + 1) + 1], ++o2 < h2 && i2 === a2 || (o2 < u2 ? e2.bl_tree[2 * i2] += o2 : i2 !== 0 ? (i2 !== s2 && e2.bl_tree[2 * i2]++, e2.bl_tree[2 * b]++) : o2 <= 10 ? e2.bl_tree[2 * v]++ : e2.bl_tree[2 * y]++, s2 = i2, u2 = (o2 = 0) === a2 ? (h2 = 138, 3) : i2 === a2 ? (h2 = 6, 3) : (h2 = 7, 4));
2569
+ }
2570
+ function V(e2, t2, r2) {
2571
+ var n2, i2, s2 = -1, a2 = t2[1], o2 = 0, h2 = 7, u2 = 4;
2572
+ for (a2 === 0 && (h2 = 138, u2 = 3), n2 = 0; n2 <= r2; n2++)
2573
+ if (i2 = a2, a2 = t2[2 * (n2 + 1) + 1], !(++o2 < h2 && i2 === a2)) {
2574
+ if (o2 < u2)
2575
+ for (; L(e2, i2, e2.bl_tree), --o2 != 0; )
2576
+ ;
2577
+ else
2578
+ i2 !== 0 ? (i2 !== s2 && (L(e2, i2, e2.bl_tree), o2--), L(e2, b, e2.bl_tree), P(e2, o2 - 3, 2)) : o2 <= 10 ? (L(e2, v, e2.bl_tree), P(e2, o2 - 3, 3)) : (L(e2, y, e2.bl_tree), P(e2, o2 - 11, 7));
2579
+ s2 = i2, u2 = (o2 = 0) === a2 ? (h2 = 138, 3) : i2 === a2 ? (h2 = 6, 3) : (h2 = 7, 4);
2580
+ }
2581
+ }
2582
+ n(T);
2583
+ var q = false;
2584
+ function J(e2, t2, r2, n2) {
2585
+ P(e2, (s << 1) + (n2 ? 1 : 0), 3), function(e3, t3, r3, n3) {
2586
+ M(e3), n3 && (U(e3, r3), U(e3, ~r3)), i.arraySet(e3.pending_buf, e3.window, t3, r3, e3.pending), e3.pending += r3;
2587
+ }(e2, t2, r2, true);
2588
+ }
2589
+ r._tr_init = function(e2) {
2590
+ q || (function() {
2591
+ var e3, t2, r2, n2, i2, s2 = new Array(g + 1);
2592
+ for (n2 = r2 = 0; n2 < a - 1; n2++)
2593
+ for (I[n2] = r2, e3 = 0; e3 < 1 << w[n2]; e3++)
2594
+ A[r2++] = n2;
2595
+ for (A[r2 - 1] = n2, n2 = i2 = 0; n2 < 16; n2++)
2596
+ for (T[n2] = i2, e3 = 0; e3 < 1 << k[n2]; e3++)
2597
+ E[i2++] = n2;
2598
+ for (i2 >>= 7; n2 < f; n2++)
2599
+ for (T[n2] = i2 << 7, e3 = 0; e3 < 1 << k[n2] - 7; e3++)
2600
+ E[256 + i2++] = n2;
2601
+ for (t2 = 0; t2 <= g; t2++)
2602
+ s2[t2] = 0;
2603
+ for (e3 = 0; e3 <= 143; )
2604
+ z[2 * e3 + 1] = 8, e3++, s2[8]++;
2605
+ for (; e3 <= 255; )
2606
+ z[2 * e3 + 1] = 9, e3++, s2[9]++;
2607
+ for (; e3 <= 279; )
2608
+ z[2 * e3 + 1] = 7, e3++, s2[7]++;
2609
+ for (; e3 <= 287; )
2610
+ z[2 * e3 + 1] = 8, e3++, s2[8]++;
2611
+ for (Z(z, l + 1, s2), e3 = 0; e3 < f; e3++)
2612
+ C[2 * e3 + 1] = 5, C[2 * e3] = j(e3, 5);
2613
+ O = new D(z, w, u + 1, l, g), B = new D(C, k, 0, f, g), R = new D(new Array(0), x, 0, c, p);
2614
+ }(), q = true), e2.l_desc = new F(e2.dyn_ltree, O), e2.d_desc = new F(e2.dyn_dtree, B), e2.bl_desc = new F(e2.bl_tree, R), e2.bi_buf = 0, e2.bi_valid = 0, W(e2);
2615
+ }, r._tr_stored_block = J, r._tr_flush_block = function(e2, t2, r2, n2) {
2616
+ var i2, s2, a2 = 0;
2617
+ 0 < e2.level ? (e2.strm.data_type === 2 && (e2.strm.data_type = function(e3) {
2618
+ var t3, r3 = 4093624447;
2619
+ for (t3 = 0; t3 <= 31; t3++, r3 >>>= 1)
2620
+ if (1 & r3 && e3.dyn_ltree[2 * t3] !== 0)
2621
+ return o;
2622
+ if (e3.dyn_ltree[18] !== 0 || e3.dyn_ltree[20] !== 0 || e3.dyn_ltree[26] !== 0)
2623
+ return h;
2624
+ for (t3 = 32; t3 < u; t3++)
2625
+ if (e3.dyn_ltree[2 * t3] !== 0)
2626
+ return h;
2627
+ return o;
2628
+ }(e2)), Y(e2, e2.l_desc), Y(e2, e2.d_desc), a2 = function(e3) {
2629
+ var t3;
2630
+ for (X(e3, e3.dyn_ltree, e3.l_desc.max_code), X(e3, e3.dyn_dtree, e3.d_desc.max_code), Y(e3, e3.bl_desc), t3 = c - 1; 3 <= t3 && e3.bl_tree[2 * S[t3] + 1] === 0; t3--)
2631
+ ;
2632
+ return e3.opt_len += 3 * (t3 + 1) + 5 + 5 + 4, t3;
2633
+ }(e2), i2 = e2.opt_len + 3 + 7 >>> 3, (s2 = e2.static_len + 3 + 7 >>> 3) <= i2 && (i2 = s2)) : i2 = s2 = r2 + 5, r2 + 4 <= i2 && t2 !== -1 ? J(e2, t2, r2, n2) : e2.strategy === 4 || s2 === i2 ? (P(e2, 2 + (n2 ? 1 : 0), 3), K(e2, z, C)) : (P(e2, 4 + (n2 ? 1 : 0), 3), function(e3, t3, r3, n3) {
2634
+ var i3;
2635
+ for (P(e3, t3 - 257, 5), P(e3, r3 - 1, 5), P(e3, n3 - 4, 4), i3 = 0; i3 < n3; i3++)
2636
+ P(e3, e3.bl_tree[2 * S[i3] + 1], 3);
2637
+ V(e3, e3.dyn_ltree, t3 - 1), V(e3, e3.dyn_dtree, r3 - 1);
2638
+ }(e2, e2.l_desc.max_code + 1, e2.d_desc.max_code + 1, a2 + 1), K(e2, e2.dyn_ltree, e2.dyn_dtree)), W(e2), n2 && M(e2);
2639
+ }, r._tr_tally = function(e2, t2, r2) {
2640
+ return e2.pending_buf[e2.d_buf + 2 * e2.last_lit] = t2 >>> 8 & 255, e2.pending_buf[e2.d_buf + 2 * e2.last_lit + 1] = 255 & t2, e2.pending_buf[e2.l_buf + e2.last_lit] = 255 & r2, e2.last_lit++, t2 === 0 ? e2.dyn_ltree[2 * r2]++ : (e2.matches++, t2--, e2.dyn_ltree[2 * (A[r2] + u + 1)]++, e2.dyn_dtree[2 * N(t2)]++), e2.last_lit === e2.lit_bufsize - 1;
2641
+ }, r._tr_align = function(e2) {
2642
+ P(e2, 2, 3), L(e2, m, z), function(e3) {
2643
+ e3.bi_valid === 16 ? (U(e3, e3.bi_buf), e3.bi_buf = 0, e3.bi_valid = 0) : 8 <= e3.bi_valid && (e3.pending_buf[e3.pending++] = 255 & e3.bi_buf, e3.bi_buf >>= 8, e3.bi_valid -= 8);
2644
+ }(e2);
2645
+ };
2646
+ }, { "../utils/common": 41 }], 53: [function(e, t, r) {
2647
+ "use strict";
2648
+ t.exports = function() {
2649
+ this.input = null, this.next_in = 0, this.avail_in = 0, this.total_in = 0, this.output = null, this.next_out = 0, this.avail_out = 0, this.total_out = 0, this.msg = "", this.state = null, this.data_type = 2, this.adler = 0;
2650
+ };
2651
+ }, {}], 54: [function(e, t, r) {
2652
+ (function(e2) {
2653
+ !function(r2, n) {
2654
+ "use strict";
2655
+ if (!r2.setImmediate) {
2656
+ var i, s, t2, a, o = 1, h = {}, u = false, l = r2.document, e3 = Object.getPrototypeOf && Object.getPrototypeOf(r2);
2657
+ e3 = e3 && e3.setTimeout ? e3 : r2, i = {}.toString.call(r2.process) === "[object process]" ? function(e4) {
2658
+ process.nextTick(function() {
2659
+ c(e4);
2660
+ });
2661
+ } : function() {
2662
+ if (r2.postMessage && !r2.importScripts) {
2663
+ var e4 = true, t3 = r2.onmessage;
2664
+ return r2.onmessage = function() {
2665
+ e4 = false;
2666
+ }, r2.postMessage("", "*"), r2.onmessage = t3, e4;
2667
+ }
2668
+ }() ? (a = "setImmediate$" + Math.random() + "$", r2.addEventListener ? r2.addEventListener("message", d, false) : r2.attachEvent("onmessage", d), function(e4) {
2669
+ r2.postMessage(a + e4, "*");
2670
+ }) : r2.MessageChannel ? ((t2 = new MessageChannel()).port1.onmessage = function(e4) {
2671
+ c(e4.data);
2672
+ }, function(e4) {
2673
+ t2.port2.postMessage(e4);
2674
+ }) : l && "onreadystatechange" in l.createElement("script") ? (s = l.documentElement, function(e4) {
2675
+ var t3 = l.createElement("script");
2676
+ t3.onreadystatechange = function() {
2677
+ c(e4), t3.onreadystatechange = null, s.removeChild(t3), t3 = null;
2678
+ }, s.appendChild(t3);
2679
+ }) : function(e4) {
2680
+ setTimeout(c, 0, e4);
2681
+ }, e3.setImmediate = function(e4) {
2682
+ typeof e4 != "function" && (e4 = new Function("" + e4));
2683
+ for (var t3 = new Array(arguments.length - 1), r3 = 0; r3 < t3.length; r3++)
2684
+ t3[r3] = arguments[r3 + 1];
2685
+ var n2 = { callback: e4, args: t3 };
2686
+ return h[o] = n2, i(o), o++;
2687
+ }, e3.clearImmediate = f;
2688
+ }
2689
+ function f(e4) {
2690
+ delete h[e4];
2691
+ }
2692
+ function c(e4) {
2693
+ if (u)
2694
+ setTimeout(c, 0, e4);
2695
+ else {
2696
+ var t3 = h[e4];
2697
+ if (t3) {
2698
+ u = true;
2699
+ try {
2700
+ !function(e5) {
2701
+ var t4 = e5.callback, r3 = e5.args;
2702
+ switch (r3.length) {
2703
+ case 0:
2704
+ t4();
2705
+ break;
2706
+ case 1:
2707
+ t4(r3[0]);
2708
+ break;
2709
+ case 2:
2710
+ t4(r3[0], r3[1]);
2711
+ break;
2712
+ case 3:
2713
+ t4(r3[0], r3[1], r3[2]);
2714
+ break;
2715
+ default:
2716
+ t4.apply(n, r3);
2717
+ }
2718
+ }(t3);
2719
+ } finally {
2720
+ f(e4), u = false;
2721
+ }
2722
+ }
2723
+ }
2724
+ }
2725
+ function d(e4) {
2726
+ e4.source === r2 && typeof e4.data == "string" && e4.data.indexOf(a) === 0 && c(+e4.data.slice(a.length));
2727
+ }
2728
+ }(typeof self == "undefined" ? e2 === void 0 ? this : e2 : self);
2729
+ }).call(this, typeof global != "undefined" ? global : typeof self != "undefined" ? self : typeof window != "undefined" ? window : {});
2730
+ }, {}] }, {}, [10])(10);
2731
+ });
2732
+ }
2733
+ });
2734
+
2735
+ // src/zip-loader.ts
2736
+ async function parseZipAsync(data, options = {}) {
2737
+ const promises = [];
2738
+ const fileMap = {};
2739
+ try {
2740
+ const jsZip = new import_jszip.default();
2741
+ const zip = await jsZip.loadAsync(data, options);
2742
+ zip.forEach((relativePath, zipEntry) => {
2743
+ const subFilename = zipEntry.name;
2744
+ const promise = loadZipEntry(jsZip, subFilename, options).then((arrayBufferOrError) => {
2745
+ fileMap[relativePath] = arrayBufferOrError;
2746
+ });
2747
+ promises.push(promise);
2748
+ });
2749
+ await Promise.all(promises);
2750
+ return fileMap;
2751
+ } catch (error) {
2752
+ options.log.error(`Unable to read zip archive: ${error}`);
2753
+ throw error;
2754
+ }
2755
+ }
2756
+ async function loadZipEntry(jsZip, subFilename, options = {}) {
2757
+ try {
2758
+ const arrayBuffer = await jsZip.file(subFilename).async(options.dataType || "arraybuffer");
2759
+ return arrayBuffer;
2760
+ } catch (error) {
2761
+ options.log.error(`Unable to read ${subFilename} from zip archive: ${error}`);
2762
+ return error;
2763
+ }
2764
+ }
2765
+ var import_jszip, VERSION, ZipLoader;
2766
+ var init_zip_loader = __esm({
2767
+ "src/zip-loader.ts"() {
2768
+ import_jszip = __toModule(require_jszip_min());
2769
+ VERSION = typeof __VERSION__ !== "undefined" ? __VERSION__ : "latest";
2770
+ ZipLoader = {
2771
+ id: "zip",
2772
+ module: "zip",
2773
+ name: "Zip Archive",
2774
+ version: VERSION,
2775
+ extensions: ["zip"],
2776
+ mimeTypes: ["application/zip"],
2777
+ category: "archive",
2778
+ tests: ["PK"],
2779
+ options: {},
2780
+ parse: parseZipAsync
2781
+ };
2782
+ }
2783
+ });
2784
+
2785
+ // src/zip-writer.ts
2786
+ async function encodeZipAsync(fileMap, options = {}) {
2787
+ const jsZip = new import_jszip2.default();
2788
+ for (const subFileName in fileMap) {
2789
+ const subFileData = fileMap[subFileName];
2790
+ jsZip.file(subFileName, subFileData, options);
2791
+ }
2792
+ options = Object.assign({}, options, {
2793
+ type: "arraybuffer"
2794
+ });
2795
+ const { onUpdate = () => {
2796
+ } } = options;
2797
+ return jsZip.generateAsync(options, onUpdate).catch((error) => {
2798
+ options.log.error(`Unable to write zip archive: ${error}`);
2799
+ throw error;
2800
+ });
2801
+ }
2802
+ var import_jszip2, ZipWriter;
2803
+ var init_zip_writer = __esm({
2804
+ "src/zip-writer.ts"() {
2805
+ import_jszip2 = __toModule(require_jszip_min());
2806
+ ZipWriter = {
2807
+ name: "Zip Archive",
2808
+ extensions: ["zip"],
2809
+ category: "archive",
2810
+ mimeTypes: ["application/zip"],
2811
+ encode: encodeZipAsync
2812
+ };
2813
+ }
2814
+ });
2815
+
2816
+ // src/lib/tar/utils.ts
2817
+ function clean(length) {
2818
+ let i;
2819
+ const buffer = new Uint8Array(length);
2820
+ for (i = 0; i < length; i += 1) {
2821
+ buffer[i] = 0;
2822
+ }
2823
+ return buffer;
2824
+ }
2825
+ function pad(num, bytes, base) {
2826
+ const numStr = num.toString(base || 8);
2827
+ return "000000000000".substr(numStr.length + 12 - bytes) + numStr;
2828
+ }
2829
+ function stringToUint8(input, out, offset) {
2830
+ let i;
2831
+ let length;
2832
+ out = out || clean(input.length);
2833
+ offset = offset || 0;
2834
+ for (i = 0, length = input.length; i < length; i += 1) {
2835
+ out[offset] = input.charCodeAt(i);
2836
+ offset += 1;
2837
+ }
2838
+ return out;
2839
+ }
2840
+ var init_utils = __esm({
2841
+ "src/lib/tar/utils.ts"() {
2842
+ }
2843
+ });
2844
+
2845
+ // src/lib/tar/header.ts
2846
+ function format(data, cb) {
2847
+ const buffer = clean(512);
2848
+ let offset = 0;
2849
+ Object.entries(structure).forEach(([field, length]) => {
2850
+ const str = data[field] || "";
2851
+ let i;
2852
+ let fieldLength;
2853
+ for (i = 0, fieldLength = str.length; i < fieldLength; i += 1) {
2854
+ buffer[offset] = str.charCodeAt(i);
2855
+ offset += 1;
2856
+ }
2857
+ offset += length - i;
2858
+ });
2859
+ if (typeof cb === "function") {
2860
+ return cb(buffer, offset);
2861
+ }
2862
+ return buffer;
2863
+ }
2864
+ var structure;
2865
+ var init_header = __esm({
2866
+ "src/lib/tar/header.ts"() {
2867
+ init_utils();
2868
+ structure = {
2869
+ fileName: 100,
2870
+ fileMode: 8,
2871
+ uid: 8,
2872
+ gid: 8,
2873
+ fileSize: 12,
2874
+ mtime: 12,
2875
+ checksum: 8,
2876
+ type: 1,
2877
+ linkName: 100,
2878
+ ustar: 8,
2879
+ owner: 32,
2880
+ group: 32,
2881
+ majorNumber: 8,
2882
+ minorNumber: 8,
2883
+ filenamePrefix: 155,
2884
+ padding: 12
2885
+ };
2886
+ }
2887
+ });
2888
+
2889
+ // src/lib/tar/tar.ts
2890
+ var blockSize, headerLength, inputLength, recordSize, Tar, tar_default;
2891
+ var init_tar = __esm({
2892
+ "src/lib/tar/tar.ts"() {
2893
+ init_utils();
2894
+ init_header();
2895
+ recordSize = 512;
2896
+ Tar = class {
2897
+ constructor(recordsPerBlock) {
2898
+ this.blocks = [];
2899
+ this.written = 0;
2900
+ blockSize = (recordsPerBlock || 20) * recordSize;
2901
+ this.out = clean(blockSize);
2902
+ this.blocks = [];
2903
+ this.length = 0;
2904
+ this.save = this.save.bind(this);
2905
+ this.clear = this.clear.bind(this);
2906
+ this.append = this.append.bind(this);
2907
+ }
2908
+ append(filepath, input, opts) {
2909
+ let checksum;
2910
+ if (typeof input === "string") {
2911
+ input = stringToUint8(input);
2912
+ } else if (input.constructor && input.constructor !== Uint8Array.prototype.constructor) {
2913
+ const errorInputMatch = /function\s*([$A-Za-z_][0-9A-Za-z_]*)\s*\(/.exec(input.constructor.toString());
2914
+ const errorInput = errorInputMatch && errorInputMatch[1];
2915
+ const errorMessage = `Invalid input type. You gave me: ${errorInput}`;
2916
+ throw errorMessage;
2917
+ }
2918
+ opts = opts || {};
2919
+ const mode = opts.mode || parseInt("777", 8) & 4095;
2920
+ const mtime = opts.mtime || Math.floor(Number(new Date()) / 1e3);
2921
+ const uid = opts.uid || 0;
2922
+ const gid = opts.gid || 0;
2923
+ const data = {
2924
+ fileName: filepath,
2925
+ fileMode: pad(mode, 7),
2926
+ uid: pad(uid, 7),
2927
+ gid: pad(gid, 7),
2928
+ fileSize: pad(input.length, 11),
2929
+ mtime: pad(mtime, 11),
2930
+ checksum: " ",
2931
+ type: "0",
2932
+ ustar: "ustar ",
2933
+ owner: opts.owner || "",
2934
+ group: opts.group || ""
2935
+ };
2936
+ checksum = 0;
2937
+ Object.keys(data).forEach((key) => {
2938
+ let i;
2939
+ const value = data[key];
2940
+ let length;
2941
+ for (i = 0, length = value.length; i < length; i += 1) {
2942
+ checksum += value.charCodeAt(i);
2943
+ }
2944
+ });
2945
+ data.checksum = `${pad(checksum, 6)}\0 `;
2946
+ const headerArr = format(data);
2947
+ headerLength = Math.ceil(headerArr.length / recordSize) * recordSize;
2948
+ inputLength = Math.ceil(input.length / recordSize) * recordSize;
2949
+ this.blocks.push({
2950
+ header: headerArr,
2951
+ input,
2952
+ headerLength,
2953
+ inputLength
2954
+ });
2955
+ }
2956
+ save() {
2957
+ const buffers = [];
2958
+ const chunks = new Array();
2959
+ let length = 0;
2960
+ const max = Math.pow(2, 20);
2961
+ let chunk = new Array();
2962
+ this.blocks.forEach((b = []) => {
2963
+ if (length + b.headerLength + b.inputLength > max) {
2964
+ chunks.push({ blocks: chunk, length });
2965
+ chunk = [];
2966
+ length = 0;
2967
+ }
2968
+ chunk.push(b);
2969
+ length += b.headerLength + b.inputLength;
2970
+ });
2971
+ chunks.push({ blocks: chunk, length });
2972
+ chunks.forEach((c = []) => {
2973
+ const buffer = new Uint8Array(c.length);
2974
+ let written = 0;
2975
+ c.blocks.forEach((b = []) => {
2976
+ buffer.set(b.header, written);
2977
+ written += b.headerLength;
2978
+ buffer.set(b.input, written);
2979
+ written += b.inputLength;
2980
+ });
2981
+ buffers.push(buffer);
2982
+ });
2983
+ buffers.push(new Uint8Array(2 * recordSize));
2984
+ return new Blob(buffers, { type: "octet/stream" });
2985
+ }
2986
+ clear() {
2987
+ this.written = 0;
2988
+ this.out = clean(blockSize);
2989
+ }
2990
+ };
2991
+ tar_default = Tar;
2992
+ }
2993
+ });
2994
+
2995
+ // src/tar-builder.ts
2996
+ var TAR_BUILDER_OPTIONS, TARBuilder;
2997
+ var init_tar_builder = __esm({
2998
+ "src/tar-builder.ts"() {
2999
+ init_tar();
3000
+ TAR_BUILDER_OPTIONS = {
3001
+ recordsPerBlock: 20
3002
+ };
3003
+ TARBuilder = class {
3004
+ constructor(options) {
3005
+ this.count = 0;
3006
+ this.options = { ...TAR_BUILDER_OPTIONS, ...options };
3007
+ this.tape = new tar_default(this.options.recordsPerBlock);
3008
+ }
3009
+ static get properties() {
3010
+ return {
3011
+ id: "tar",
3012
+ name: "TAR",
3013
+ extensions: ["tar"],
3014
+ mimeTypes: ["application/x-tar"],
3015
+ builder: TARBuilder,
3016
+ options: TAR_BUILDER_OPTIONS
3017
+ };
3018
+ }
3019
+ addFile(filename, buffer) {
3020
+ this.tape.append(filename, new Uint8Array(buffer));
3021
+ this.count++;
3022
+ }
3023
+ async build() {
3024
+ return new Response(this.tape.save()).arrayBuffer();
3025
+ }
3026
+ };
3027
+ }
3028
+ });
3029
+
3030
+ // src/index.ts
3031
+ var src_exports = {};
3032
+ __export(src_exports, {
3033
+ TarBuilder: () => TARBuilder,
3034
+ ZipLoader: () => ZipLoader,
3035
+ ZipWriter: () => ZipWriter
3036
+ });
3037
+ var init_src = __esm({
3038
+ "src/index.ts"() {
3039
+ init_zip_loader();
3040
+ init_zip_writer();
3041
+ init_tar_builder();
3042
+ }
3043
+ });
3044
+
3045
+ // src/bundle.ts
3046
+ var require_bundle = __commonJS({
3047
+ "src/bundle.ts"(exports, module) {
3048
+ var moduleExports = (init_src(), src_exports);
3049
+ globalThis.loaders = globalThis.loaders || {};
3050
+ module.exports = Object.assign(globalThis.loaders, moduleExports);
3051
+ }
3052
+ });
3053
+ require_bundle();
3054
+ })();
3055
+ /*!
3056
+
3057
+ JSZip v3.10.1 - A JavaScript class for generating and reading zip files
3058
+ <http://stuartk.com/jszip>
3059
+
3060
+ (c) 2009-2016 Stuart Knightley <stuart [at] stuartk.com>
3061
+ Dual licenced under the MIT license or GPLv3. See https://raw.github.com/Stuk/jszip/main/LICENSE.markdown.
3062
+
3063
+ JSZip uses the library pako released under the MIT license :
3064
+ https://github.com/nodeca/pako/blob/main/LICENSE
3065
+ */