@secrecy/lib 1.0.0-dev.39 → 1.0.0-dev.42
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/BaseClient.d.ts +33 -53
- package/dist/BaseClient.js +886 -2093
- package/dist/PopupTools.js +20 -21
- package/dist/ZeusThunder.js +50 -84
- package/dist/cache.d.ts +2 -3
- package/dist/cache.js +4 -5
- package/dist/client/admin/index.js +77 -165
- package/dist/client/convert/file.d.ts +3 -3
- package/dist/client/convert/file.js +18 -23
- package/dist/client/convert/mail.js +13 -13
- package/dist/client/convert/node.d.ts +9 -0
- package/dist/client/convert/node.js +101 -0
- package/dist/client/helpers.js +41 -41
- package/dist/client/index.d.ts +63 -74
- package/dist/client/index.js +2727 -5759
- package/dist/client/storage.js +7 -7
- package/dist/client/types/File.d.ts +6 -13
- package/dist/client/types/File.js +1 -1
- package/dist/client/types/Inputs.d.ts +2 -7
- package/dist/client/types/Inputs.js +1 -1
- package/dist/client/types/Node.d.ts +49 -0
- package/dist/client/types/Node.js +3 -0
- package/dist/client/types/UserAppNotifications.d.ts +1 -1
- package/dist/client/types/UserAppNotifications.js +1 -1
- package/dist/client/types/UserAppSettings.js +1 -1
- package/dist/client/types/index.d.ts +7 -13
- package/dist/client/types/index.js +2 -4
- package/dist/client/types/selectors.d.ts +476 -0
- package/dist/client/types/selectors.js +125 -0
- package/dist/crypto/file.js +122 -203
- package/dist/crypto/index.js +14 -12
- package/dist/error.js +1 -1
- package/dist/index.d.ts +1 -2
- package/dist/index.js +2 -34
- package/dist/minify/index.js +7 -7
- package/dist/minify/lz4.js +87 -93
- package/dist/sodium.js +3 -25
- package/dist/utils/store-buddy.js +11 -15
- package/dist/utils/time.js +4 -12
- package/dist/{utils.d.ts → utils/utils.d.ts} +0 -0
- package/dist/utils/utils.js +57 -0
- package/dist/worker/__mock__/sodium.worker.js +35 -32
- package/dist/worker/md5.js +21 -39
- package/dist/worker/sodium.js +95 -130
- package/dist/worker/workerCodes.js +3 -3
- package/dist/zeus/const.d.ts +5 -0
- package/dist/zeus/const.js +303 -1360
- package/dist/zeus/index.d.ts +1805 -1817
- package/dist/zeus/index.js +542 -434
- package/package.json +40 -39
- package/dist/client/convert/folder.d.ts +0 -8
- package/dist/client/convert/folder.js +0 -264
- package/dist/client/convert/vFile.d.ts +0 -5
- package/dist/client/convert/vFile.js +0 -164
- package/dist/client/types/FilesOnUsersOnApplications.d.ts +0 -9
- package/dist/client/types/FilesOnUsersOnApplications.js +0 -3
- package/dist/client/types/Folder.d.ts +0 -68
- package/dist/client/types/Folder.js +0 -7
- package/dist/client/types/VFile.d.ts +0 -62
- package/dist/client/types/VFile.js +0 -4
- package/dist/client/types/queries.d.ts +0 -535
- package/dist/client/types/queries.js +0 -192
- package/dist/utils.js +0 -188
package/dist/minify/index.js
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { calcUncompressedLen, compressBlockBound, compressBlockHC, uncompressBlock } from "./lz4.js";
|
|
2
|
-
import { concatenate } from "../utils.js";
|
|
2
|
+
import { concatenate } from "../utils/utils.js";
|
|
3
3
|
export function compress(data) {
|
|
4
4
|
if (data.byteLength > 15000000) {
|
|
5
5
|
return concatenate(new Uint8Array([0]), data);
|
|
6
6
|
}
|
|
7
7
|
|
|
8
|
-
|
|
9
|
-
|
|
8
|
+
const compressed = new Uint8Array(compressBlockBound(data.byteLength));
|
|
9
|
+
const compressedSize = compressBlockHC(data, compressed, 0);
|
|
10
10
|
|
|
11
11
|
if (compressedSize === 0) {
|
|
12
12
|
return concatenate(new Uint8Array([0]), data);
|
|
@@ -15,14 +15,14 @@ export function compress(data) {
|
|
|
15
15
|
return concatenate(new Uint8Array([1]), compressed.slice(0, compressedSize));
|
|
16
16
|
}
|
|
17
17
|
export function uncompress(data) {
|
|
18
|
-
|
|
18
|
+
const realData = data.slice(1);
|
|
19
19
|
|
|
20
20
|
if (data[0] === 0) {
|
|
21
21
|
return realData;
|
|
22
22
|
}
|
|
23
23
|
|
|
24
|
-
|
|
25
|
-
|
|
24
|
+
const dst = new Uint8Array(calcUncompressedLen(realData));
|
|
25
|
+
const uncompressedSize = uncompressBlock(realData, dst);
|
|
26
26
|
return dst.slice(0, uncompressedSize);
|
|
27
27
|
}
|
|
28
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
28
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjYWxjVW5jb21wcmVzc2VkTGVuIiwiY29tcHJlc3NCbG9ja0JvdW5kIiwiY29tcHJlc3NCbG9ja0hDIiwidW5jb21wcmVzc0Jsb2NrIiwiY29uY2F0ZW5hdGUiLCJjb21wcmVzcyIsImRhdGEiLCJieXRlTGVuZ3RoIiwiVWludDhBcnJheSIsImNvbXByZXNzZWQiLCJjb21wcmVzc2VkU2l6ZSIsInNsaWNlIiwidW5jb21wcmVzcyIsInJlYWxEYXRhIiwiZHN0IiwidW5jb21wcmVzc2VkU2l6ZSJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9taW5pZnkvaW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgY2FsY1VuY29tcHJlc3NlZExlbixcbiAgY29tcHJlc3NCbG9ja0JvdW5kLFxuICBjb21wcmVzc0Jsb2NrSEMsXG4gIHVuY29tcHJlc3NCbG9ja1xufSBmcm9tIFwiLi9sejQuanNcIjtcbmltcG9ydCB7IGNvbmNhdGVuYXRlIH0gZnJvbSBcIi4uL3V0aWxzL3V0aWxzLmpzXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBjb21wcmVzcyhkYXRhOiBVaW50OEFycmF5KTogVWludDhBcnJheSB7XG4gIGlmIChkYXRhLmJ5dGVMZW5ndGggPiAxNV8wMDBfMDAwKSB7XG4gICAgcmV0dXJuIGNvbmNhdGVuYXRlKG5ldyBVaW50OEFycmF5KFswXSksIGRhdGEpO1xuICB9XG4gIGNvbnN0IGNvbXByZXNzZWQgPSBuZXcgVWludDhBcnJheShjb21wcmVzc0Jsb2NrQm91bmQoZGF0YS5ieXRlTGVuZ3RoKSk7XG4gIGNvbnN0IGNvbXByZXNzZWRTaXplID0gY29tcHJlc3NCbG9ja0hDKGRhdGEsIGNvbXByZXNzZWQsIDApO1xuICBpZiAoY29tcHJlc3NlZFNpemUgPT09IDApIHtcbiAgICByZXR1cm4gY29uY2F0ZW5hdGUobmV3IFVpbnQ4QXJyYXkoWzBdKSwgZGF0YSk7XG4gIH1cbiAgcmV0dXJuIGNvbmNhdGVuYXRlKG5ldyBVaW50OEFycmF5KFsxXSksIGNvbXByZXNzZWQuc2xpY2UoMCwgY29tcHJlc3NlZFNpemUpKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHVuY29tcHJlc3MoZGF0YTogVWludDhBcnJheSk6IFVpbnQ4QXJyYXkge1xuICBjb25zdCByZWFsRGF0YSA9IGRhdGEuc2xpY2UoMSk7XG4gIGlmIChkYXRhWzBdID09PSAwKSB7XG4gICAgcmV0dXJuIHJlYWxEYXRhO1xuICB9XG4gIGNvbnN0IGRzdCA9IG5ldyBVaW50OEFycmF5KGNhbGNVbmNvbXByZXNzZWRMZW4ocmVhbERhdGEpKTtcbiAgY29uc3QgdW5jb21wcmVzc2VkU2l6ZSA9IHVuY29tcHJlc3NCbG9jayhyZWFsRGF0YSwgZHN0KTtcbiAgcmV0dXJuIGRzdC5zbGljZSgwLCB1bmNvbXByZXNzZWRTaXplKTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsU0FDRUEsbUJBREYsRUFFRUMsa0JBRkYsRUFHRUMsZUFIRixFQUlFQyxlQUpGLFFBS08sVUFMUDtBQU1BLFNBQVNDLFdBQVQsUUFBNEIsbUJBQTVCO0FBRUEsT0FBTyxTQUFTQyxRQUFULENBQWtCQyxJQUFsQixFQUFnRDtFQUNyRCxJQUFJQSxJQUFJLENBQUNDLFVBQUwsR0FBa0IsUUFBdEIsRUFBa0M7SUFDaEMsT0FBT0gsV0FBVyxDQUFDLElBQUlJLFVBQUosQ0FBZSxDQUFDLENBQUQsQ0FBZixDQUFELEVBQXNCRixJQUF0QixDQUFsQjtFQUNEOztFQUNELE1BQU1HLFVBQVUsR0FBRyxJQUFJRCxVQUFKLENBQWVQLGtCQUFrQixDQUFDSyxJQUFJLENBQUNDLFVBQU4sQ0FBakMsQ0FBbkI7RUFDQSxNQUFNRyxjQUFjLEdBQUdSLGVBQWUsQ0FBQ0ksSUFBRCxFQUFPRyxVQUFQLEVBQW1CLENBQW5CLENBQXRDOztFQUNBLElBQUlDLGNBQWMsS0FBSyxDQUF2QixFQUEwQjtJQUN4QixPQUFPTixXQUFXLENBQUMsSUFBSUksVUFBSixDQUFlLENBQUMsQ0FBRCxDQUFmLENBQUQsRUFBc0JGLElBQXRCLENBQWxCO0VBQ0Q7O0VBQ0QsT0FBT0YsV0FBVyxDQUFDLElBQUlJLFVBQUosQ0FBZSxDQUFDLENBQUQsQ0FBZixDQUFELEVBQXNCQyxVQUFVLENBQUNFLEtBQVgsQ0FBaUIsQ0FBakIsRUFBb0JELGNBQXBCLENBQXRCLENBQWxCO0FBQ0Q7QUFFRCxPQUFPLFNBQVNFLFVBQVQsQ0FBb0JOLElBQXBCLEVBQWtEO0VBQ3ZELE1BQU1PLFFBQVEsR0FBR1AsSUFBSSxDQUFDSyxLQUFMLENBQVcsQ0FBWCxDQUFqQjs7RUFDQSxJQUFJTCxJQUFJLENBQUMsQ0FBRCxDQUFKLEtBQVksQ0FBaEIsRUFBbUI7SUFDakIsT0FBT08sUUFBUDtFQUNEOztFQUNELE1BQU1DLEdBQUcsR0FBRyxJQUFJTixVQUFKLENBQWVSLG1CQUFtQixDQUFDYSxRQUFELENBQWxDLENBQVo7RUFDQSxNQUFNRSxnQkFBZ0IsR0FBR1osZUFBZSxDQUFDVSxRQUFELEVBQVdDLEdBQVgsQ0FBeEM7RUFDQSxPQUFPQSxHQUFHLENBQUNILEtBQUosQ0FBVSxDQUFWLEVBQWFJLGdCQUFiLENBQVA7QUFDRCJ9
|
package/dist/minify/lz4.js
CHANGED
|
@@ -30,66 +30,66 @@
|
|
|
30
30
|
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
31
31
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
32
32
|
*/
|
|
33
|
-
|
|
34
|
-
|
|
33
|
+
const errInvalidSource = new Error("invalid source");
|
|
34
|
+
const errShortBuffer = new Error("short buffer"); // The following constants are used to setup the compression algorithm.
|
|
35
35
|
|
|
36
|
-
|
|
36
|
+
const minMatch = 4; // the minimum size of the match sequence size (4 bytes)
|
|
37
37
|
|
|
38
|
-
|
|
38
|
+
const winSizeLog = 16; // LZ4 64Kb window size limit
|
|
39
39
|
|
|
40
|
-
|
|
41
|
-
|
|
40
|
+
const winSize = 1 << winSizeLog;
|
|
41
|
+
const winMask = winSize - 1; // 64Kb window of previous data for dependent blocks
|
|
42
42
|
// hashSizeLog determines the size of the hash table used to quickly find a previous match position.
|
|
43
43
|
// Its value influences the compression speed and memory usage, the lower the faster,
|
|
44
44
|
// but at the expense of the compression ratio.
|
|
45
45
|
// 16 seems to be the best compromise.
|
|
46
46
|
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
47
|
+
const hashSizeLog = 16;
|
|
48
|
+
const hashSize = 1 << hashSizeLog;
|
|
49
|
+
const hashShift = minMatch * 8 - hashSizeLog;
|
|
50
|
+
const mfLimit = 8 + minMatch; // The last match cannot start within the last 12 bytes.
|
|
51
51
|
|
|
52
|
-
|
|
52
|
+
const skipStrength = 6; // variable step for fast scan
|
|
53
53
|
|
|
54
|
-
|
|
54
|
+
const hasher = 2654435761 | 0; // prime number used to hash minMatch
|
|
55
55
|
// https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Math/imul#Polyfill
|
|
56
56
|
|
|
57
57
|
function imulPolyfill(a, b) {
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
58
|
+
const ah = a >>> 16 & 0xffff;
|
|
59
|
+
const al = a & 0xffff;
|
|
60
|
+
const bh = b >>> 16 & 0xffff;
|
|
61
|
+
const bl = b & 0xffff; // the shift by 0 fixes the sign on the high part
|
|
62
62
|
// the final |0 converts the unsigned value into a signed value
|
|
63
63
|
|
|
64
64
|
return al * bl + (ah * bl + al * bh << 16 >>> 0) | 0;
|
|
65
65
|
}
|
|
66
66
|
|
|
67
|
-
|
|
67
|
+
const imul = Math.imul ? Math.imul : imulPolyfill;
|
|
68
68
|
|
|
69
69
|
function getUint32(a, i) {
|
|
70
70
|
return a[i + 3] | a[i + 2] << 8 | a[i + 1] << 16 | a[i] << 24;
|
|
71
71
|
}
|
|
72
72
|
|
|
73
73
|
function copy(dest, src, di, si, len) {
|
|
74
|
-
for (
|
|
74
|
+
for (let i = 0; i < len; ++i) {
|
|
75
75
|
dest[di++] = src[si++];
|
|
76
76
|
}
|
|
77
77
|
}
|
|
78
78
|
|
|
79
79
|
export function calcUncompressedLen(src) {
|
|
80
|
-
|
|
80
|
+
const sn = src.length;
|
|
81
81
|
|
|
82
82
|
if (sn === 0) {
|
|
83
83
|
return 0;
|
|
84
84
|
}
|
|
85
85
|
|
|
86
|
-
|
|
87
|
-
|
|
86
|
+
let si = 0;
|
|
87
|
+
let di = 0;
|
|
88
88
|
|
|
89
89
|
while (true) {
|
|
90
90
|
// literals and match lengths (token)
|
|
91
|
-
|
|
92
|
-
|
|
91
|
+
let lLen = src[si] >> 4;
|
|
92
|
+
let mLen = src[si] & 0xf;
|
|
93
93
|
|
|
94
94
|
if (++si === sn) {
|
|
95
95
|
throw errInvalidSource;
|
|
@@ -127,7 +127,7 @@ export function calcUncompressedLen(src) {
|
|
|
127
127
|
throw errInvalidSource;
|
|
128
128
|
}
|
|
129
129
|
|
|
130
|
-
|
|
130
|
+
const offset = src[si - 2] | src[si - 1] << 8;
|
|
131
131
|
|
|
132
132
|
if (di - offset < 0 || offset === 0) {
|
|
133
133
|
throw errInvalidSource;
|
|
@@ -161,20 +161,20 @@ export function calcUncompressedLen(src) {
|
|
|
161
161
|
}
|
|
162
162
|
}
|
|
163
163
|
export function uncompressBlock(src, dest) {
|
|
164
|
-
|
|
165
|
-
|
|
164
|
+
const sn = src.length;
|
|
165
|
+
const dn = dest.length;
|
|
166
166
|
|
|
167
167
|
if (sn === 0) {
|
|
168
168
|
return 0;
|
|
169
169
|
}
|
|
170
170
|
|
|
171
|
-
|
|
172
|
-
|
|
171
|
+
let si = 0;
|
|
172
|
+
let di = 0;
|
|
173
173
|
|
|
174
174
|
while (true) {
|
|
175
175
|
// literals and match lengths (token)
|
|
176
|
-
|
|
177
|
-
|
|
176
|
+
let lLen = src[si] >> 4;
|
|
177
|
+
let mLen = src[si] & 0xf;
|
|
178
178
|
|
|
179
179
|
if (++si === sn) {
|
|
180
180
|
throw errInvalidSource;
|
|
@@ -217,7 +217,7 @@ export function uncompressBlock(src, dest) {
|
|
|
217
217
|
throw errInvalidSource;
|
|
218
218
|
}
|
|
219
219
|
|
|
220
|
-
|
|
220
|
+
const offset = src[si - 2] | src[si - 1] << 8;
|
|
221
221
|
|
|
222
222
|
if (di - offset < 0 || offset === 0) {
|
|
223
223
|
throw errInvalidSource;
|
|
@@ -261,36 +261,35 @@ export function compressBlockBound(n) {
|
|
|
261
261
|
return n + (n / 255 | 0) + 16;
|
|
262
262
|
}
|
|
263
263
|
export function compressBlock(src, dest, soffset) {
|
|
264
|
-
|
|
265
|
-
|
|
264
|
+
const sn = src.length - mfLimit;
|
|
265
|
+
const dn = dest.length;
|
|
266
266
|
|
|
267
267
|
if (sn <= 0 || dn === 0 || soffset >= sn) {
|
|
268
268
|
return 0;
|
|
269
269
|
}
|
|
270
270
|
|
|
271
|
-
|
|
271
|
+
let si = 0,
|
|
272
272
|
di = 0; // fast scan strategy:
|
|
273
273
|
// we only need a hash table to store the last sequences (4 bytes)
|
|
274
274
|
|
|
275
|
-
|
|
275
|
+
const hashTable = new Uint32Array(hashSize); // Initialise the hash table with the first 64Kb of the input buffer
|
|
276
276
|
// (used when compressing dependent blocks)
|
|
277
277
|
|
|
278
278
|
while (si < soffset) {
|
|
279
|
-
|
|
279
|
+
const h = imul(getUint32(src, si), hasher) >>> hashShift;
|
|
280
280
|
hashTable[h] = ++si;
|
|
281
281
|
}
|
|
282
282
|
|
|
283
|
-
|
|
284
|
-
|
|
283
|
+
let anchor = si;
|
|
284
|
+
let fma = 1 << skipStrength;
|
|
285
285
|
|
|
286
286
|
while (si < sn - minMatch) {
|
|
287
287
|
// hash the next 4 bytes (sequence)...
|
|
288
|
-
|
|
288
|
+
const h = imul(getUint32(src, si), hasher) >>> hashShift; // -1 to separate existing entries from new ones
|
|
289
289
|
|
|
290
|
+
const ref = hashTable[h] - 1; // ...and store the position of the hash in the hash table (+1 to compensate the -1 upon saving)
|
|
290
291
|
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
hashTable[_h] = si + 1; // no need to check the last 3 bytes in the first literal 4 bytes as
|
|
292
|
+
hashTable[h] = si + 1; // no need to check the last 3 bytes in the first literal 4 bytes as
|
|
294
293
|
// this guarantees that the next match, if any, is compressed with
|
|
295
294
|
// a lower size, since to have some compression we must have:
|
|
296
295
|
// ll+ml-overlap > 1 + (ll-15)/255 + (ml-4-15)/255 + 2 (uncompressed size>compressed size)
|
|
@@ -311,13 +310,11 @@ export function compressBlock(src, dest, soffset) {
|
|
|
311
310
|
|
|
312
311
|
|
|
313
312
|
fma = 1 << skipStrength;
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
var offset = si - ref; // encode match length part 1
|
|
313
|
+
const lLen = si - anchor;
|
|
314
|
+
const offset = si - ref; // encode match length part 1
|
|
318
315
|
|
|
319
316
|
si += minMatch;
|
|
320
|
-
|
|
317
|
+
let mLen = si; // match length has minMatch already
|
|
321
318
|
|
|
322
319
|
while (si <= sn && src[si] === src[si - offset]) {
|
|
323
320
|
si++;
|
|
@@ -332,8 +329,8 @@ export function compressBlock(src, dest, soffset) {
|
|
|
332
329
|
} // encode literals length
|
|
333
330
|
|
|
334
331
|
|
|
335
|
-
if (
|
|
336
|
-
dest[di] |=
|
|
332
|
+
if (lLen < 0xf) {
|
|
333
|
+
dest[di] |= lLen << 4;
|
|
337
334
|
} else {
|
|
338
335
|
dest[di] |= 0xf0;
|
|
339
336
|
|
|
@@ -341,7 +338,7 @@ export function compressBlock(src, dest, soffset) {
|
|
|
341
338
|
throw errShortBuffer;
|
|
342
339
|
}
|
|
343
340
|
|
|
344
|
-
|
|
341
|
+
let l = lLen - 0xf;
|
|
345
342
|
|
|
346
343
|
for (; l >= 0xff; l -= 0xff) {
|
|
347
344
|
dest[di] = 0xff;
|
|
@@ -359,12 +356,12 @@ export function compressBlock(src, dest, soffset) {
|
|
|
359
356
|
} // literals
|
|
360
357
|
|
|
361
358
|
|
|
362
|
-
if (di +
|
|
359
|
+
if (di + lLen >= dn) {
|
|
363
360
|
throw errShortBuffer;
|
|
364
361
|
}
|
|
365
362
|
|
|
366
|
-
copy(dest, src, di, anchor,
|
|
367
|
-
di +=
|
|
363
|
+
copy(dest, src, di, anchor, lLen);
|
|
364
|
+
di += lLen;
|
|
368
365
|
anchor = si; // encode offset
|
|
369
366
|
|
|
370
367
|
di += 2;
|
|
@@ -399,7 +396,7 @@ export function compressBlock(src, dest, soffset) {
|
|
|
399
396
|
} // last literals
|
|
400
397
|
|
|
401
398
|
|
|
402
|
-
|
|
399
|
+
let lLen = src.length - anchor;
|
|
403
400
|
|
|
404
401
|
if (lLen < 0xf) {
|
|
405
402
|
dest[di] = lLen << 4;
|
|
@@ -426,8 +423,8 @@ export function compressBlock(src, dest, soffset) {
|
|
|
426
423
|
} // write literals
|
|
427
424
|
|
|
428
425
|
|
|
429
|
-
|
|
430
|
-
|
|
426
|
+
const lastLen = src.length - anchor;
|
|
427
|
+
const n = di + lastLen;
|
|
431
428
|
|
|
432
429
|
if (n > dn) {
|
|
433
430
|
throw errShortBuffer;
|
|
@@ -441,46 +438,45 @@ export function compressBlock(src, dest, soffset) {
|
|
|
441
438
|
return di;
|
|
442
439
|
}
|
|
443
440
|
export function compressBlockHC(src, dest, soffset) {
|
|
444
|
-
|
|
445
|
-
|
|
441
|
+
const sn = src.length - mfLimit;
|
|
442
|
+
const dn = dest.length;
|
|
446
443
|
|
|
447
444
|
if (sn <= 0 || dn === 0 || soffset >= sn) {
|
|
448
445
|
return 0;
|
|
449
446
|
}
|
|
450
447
|
|
|
451
|
-
|
|
452
|
-
|
|
448
|
+
let si = 0;
|
|
449
|
+
let di = 0; // Hash Chain strategy:
|
|
453
450
|
// we need a hash table and a chain table
|
|
454
451
|
// the chain table cannot contain more entries than the window size (64Kb entries)
|
|
455
452
|
|
|
456
|
-
|
|
457
|
-
|
|
453
|
+
const hashTable = new Uint32Array(hashSize);
|
|
454
|
+
const chainTable = new Uint32Array(winSize); // Initialise the hash table with the first 64Kb of the input buffer
|
|
458
455
|
// (used when compressing dependent blocks)
|
|
459
456
|
|
|
460
457
|
while (si < soffset) {
|
|
461
|
-
|
|
458
|
+
const h = imul(getUint32(src, si), hasher) >>> hashShift;
|
|
462
459
|
chainTable[si & winMask] = hashTable[h];
|
|
463
460
|
hashTable[h] = ++si;
|
|
464
461
|
}
|
|
465
462
|
|
|
466
|
-
|
|
463
|
+
let anchor = si;
|
|
467
464
|
|
|
468
465
|
while (si < sn - minMatch) {
|
|
469
466
|
// hash the next 4 bytes (sequence)...
|
|
470
|
-
|
|
471
|
-
|
|
467
|
+
const h = imul(getUint32(src, si), hasher) >>> hashShift; // follow the chain until out of window and give the longest match
|
|
472
468
|
|
|
473
|
-
|
|
474
|
-
|
|
469
|
+
let mLen = 0;
|
|
470
|
+
let offset = 0;
|
|
475
471
|
|
|
476
|
-
for (
|
|
472
|
+
for (let next = hashTable[h] - 1; next > 0 && next > si - winSize; next = chainTable[next & winMask] - 1) {
|
|
477
473
|
// the first (mLen==0) or next byte (mLen>=minMatch) at current match length must match to improve on the match length
|
|
478
474
|
if (src[next + mLen] === src[si + mLen]) {
|
|
479
|
-
for (
|
|
480
|
-
if (src[next +
|
|
475
|
+
for (let ml = 0;; ++ml) {
|
|
476
|
+
if (src[next + ml] !== src[si + ml] || si + ml > sn) {
|
|
481
477
|
// found a longer match, keep its position and length
|
|
482
|
-
if (mLen <
|
|
483
|
-
mLen =
|
|
478
|
+
if (mLen < ml && ml >= minMatch) {
|
|
479
|
+
mLen = ml;
|
|
484
480
|
offset = si - next;
|
|
485
481
|
}
|
|
486
482
|
|
|
@@ -490,28 +486,26 @@ export function compressBlockHC(src, dest, soffset) {
|
|
|
490
486
|
}
|
|
491
487
|
}
|
|
492
488
|
|
|
493
|
-
chainTable[si & winMask] = hashTable[
|
|
494
|
-
hashTable[
|
|
489
|
+
chainTable[si & winMask] = hashTable[h];
|
|
490
|
+
hashTable[h] = si + 1; // no match found
|
|
495
491
|
|
|
496
492
|
if (mLen === 0) {
|
|
497
493
|
++si;
|
|
498
494
|
continue;
|
|
499
495
|
}
|
|
500
496
|
|
|
501
|
-
|
|
502
|
-
|
|
497
|
+
let si2 = si + 1;
|
|
498
|
+
const ml = si + mLen; // match found
|
|
503
499
|
// update hash/chain tables with overlaping bytes:
|
|
504
500
|
// si already hashed, add everything from si+1 up to the match length
|
|
505
501
|
|
|
506
502
|
while (si2 < ml) {
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
hashTable[_h3] = ++si2;
|
|
503
|
+
const h = imul(getUint32(src, si2), hasher) >>> hashShift;
|
|
504
|
+
chainTable[si2 & winMask] = hashTable[h];
|
|
505
|
+
hashTable[h] = ++si2;
|
|
511
506
|
}
|
|
512
507
|
|
|
513
|
-
|
|
514
|
-
|
|
508
|
+
const lLen = si - anchor;
|
|
515
509
|
si += mLen;
|
|
516
510
|
mLen -= minMatch; // match length does not include minMatch
|
|
517
511
|
|
|
@@ -522,8 +516,8 @@ export function compressBlockHC(src, dest, soffset) {
|
|
|
522
516
|
} // encode literals length
|
|
523
517
|
|
|
524
518
|
|
|
525
|
-
if (
|
|
526
|
-
dest[di] |=
|
|
519
|
+
if (lLen < 0xf) {
|
|
520
|
+
dest[di] |= lLen << 4;
|
|
527
521
|
} else {
|
|
528
522
|
dest[di] |= 0xf0;
|
|
529
523
|
|
|
@@ -531,7 +525,7 @@ export function compressBlockHC(src, dest, soffset) {
|
|
|
531
525
|
throw errShortBuffer;
|
|
532
526
|
}
|
|
533
527
|
|
|
534
|
-
|
|
528
|
+
let l = lLen - 0xf;
|
|
535
529
|
|
|
536
530
|
for (; l >= 0xff; l -= 0xff) {
|
|
537
531
|
dest[di] = 0xff;
|
|
@@ -549,12 +543,12 @@ export function compressBlockHC(src, dest, soffset) {
|
|
|
549
543
|
} // literals
|
|
550
544
|
|
|
551
545
|
|
|
552
|
-
if (di +
|
|
546
|
+
if (di + lLen >= dn) {
|
|
553
547
|
throw errShortBuffer;
|
|
554
548
|
}
|
|
555
549
|
|
|
556
|
-
copy(dest, src, di, anchor,
|
|
557
|
-
di +=
|
|
550
|
+
copy(dest, src, di, anchor, lLen);
|
|
551
|
+
di += lLen;
|
|
558
552
|
anchor = si; // encode offset
|
|
559
553
|
|
|
560
554
|
di += 2;
|
|
@@ -589,7 +583,7 @@ export function compressBlockHC(src, dest, soffset) {
|
|
|
589
583
|
} // last literals
|
|
590
584
|
|
|
591
585
|
|
|
592
|
-
|
|
586
|
+
let lLen = src.length - anchor;
|
|
593
587
|
|
|
594
588
|
if (lLen < 0xf) {
|
|
595
589
|
dest[di] = lLen << 4;
|
|
@@ -616,8 +610,8 @@ export function compressBlockHC(src, dest, soffset) {
|
|
|
616
610
|
} // write literals
|
|
617
611
|
|
|
618
612
|
|
|
619
|
-
|
|
620
|
-
|
|
613
|
+
const lastLen = src.length - anchor;
|
|
614
|
+
const n = di + lastLen;
|
|
621
615
|
|
|
622
616
|
if (n > dn) {
|
|
623
617
|
throw errShortBuffer;
|
|
@@ -630,4 +624,4 @@ export function compressBlockHC(src, dest, soffset) {
|
|
|
630
624
|
di += lastLen;
|
|
631
625
|
return di;
|
|
632
626
|
}
|
|
633
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/minify/lz4.ts"],"names":["errInvalidSource","Error","errShortBuffer","minMatch","winSizeLog","winSize","winMask","hashSizeLog","hashSize","hashShift","mfLimit","skipStrength","hasher","imulPolyfill","a","b","ah","al","bh","bl","imul","Math","getUint32","i","copy","dest","src","di","si","len","calcUncompressedLen","sn","length","lLen","mLen","offset","uncompressBlock","dn","compressBlockBound","n","compressBlock","soffset","hashTable","Uint32Array","h","anchor","fma","ref","l","lastLen","compressBlockHC","chainTable","next","ml","si2"],"mappings":"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","sourcesContent":["// lz4-ts @license BSD-3-Clause / Copyright (c) 2015, Pierre Curto / 2016, oov. All rights reserved.\n/**\n * Copyright (c) 2015, Pierre Curto\n * Copyright (c) 2016, oov\n * All rights reserved.\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * * Redistributions of source code must retain the above copyright notice, this\n *   list of conditions and the following disclaimer.\n *\n * * Redistributions in binary form must reproduce the above copyright notice,\n *   this list of conditions and the following disclaimer in the documentation\n *   and/or other materials provided with the distribution.\n *\n * * Neither the name of xxHash nor the names of its\n *   contributors may be used to endorse or promote products derived from\n *   this software without specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\"\n * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nconst errInvalidSource = new Error(\"invalid source\");\nconst errShortBuffer = new Error(\"short buffer\");\n\n// The following constants are used to setup the compression algorithm.\nconst minMatch = 4; // the minimum size of the match sequence size (4 bytes)\nconst winSizeLog = 16; // LZ4 64Kb window size limit\nconst winSize = 1 << winSizeLog;\nconst winMask = winSize - 1; // 64Kb window of previous data for dependent blocks\n\n// hashSizeLog determines the size of the hash table used to quickly find a previous match position.\n// Its value influences the compression speed and memory usage, the lower the faster,\n// but at the expense of the compression ratio.\n// 16 seems to be the best compromise.\nconst hashSizeLog = 16;\nconst hashSize = 1 << hashSizeLog;\nconst hashShift = minMatch * 8 - hashSizeLog;\n\nconst mfLimit = 8 + minMatch; // The last match cannot start within the last 12 bytes.\nconst skipStrength = 6; // variable step for fast scan\n\nconst hasher = 2654435761 | 0; // prime number used to hash minMatch\n\n// https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Math/imul#Polyfill\nfunction imulPolyfill(a: number, b: number): number {\n  const ah = (a >>> 16) & 0xffff;\n  const al = a & 0xffff;\n  const bh = (b >>> 16) & 0xffff;\n  const bl = b & 0xffff;\n  // the shift by 0 fixes the sign on the high part\n  // the final |0 converts the unsigned value into a signed value\n  return (al * bl + (((ah * bl + al * bh) << 16) >>> 0)) | 0;\n}\nconst imul = Math.imul ? Math.imul : imulPolyfill;\n\nfunction getUint32(a: Uint8Array, i: number): number {\n  return a[i + 3] | (a[i + 2] << 8) | (a[i + 1] << 16) | (a[i] << 24);\n}\n\nfunction copy(\n  dest: Uint8Array,\n  src: Uint8Array,\n  di: number,\n  si: number,\n  len: number\n): void {\n  for (let i = 0; i < len; ++i) {\n    dest[di++] = src[si++];\n  }\n}\n\nexport function calcUncompressedLen(src: Uint8Array): number {\n  const sn = src.length;\n  if (sn === 0) {\n    return 0;\n  }\n\n  let si = 0;\n  let di = 0;\n\n  while (true) {\n    // literals and match lengths (token)\n    let lLen = src[si] >> 4;\n    let mLen = src[si] & 0xf;\n    if (++si === sn) {\n      throw errInvalidSource;\n    }\n\n    // literals\n    if (lLen > 0) {\n      if (lLen === 0xf) {\n        while (src[si] === 0xff) {\n          lLen += 0xff;\n          if (++si === sn) {\n            throw errInvalidSource;\n          }\n        }\n        lLen += src[si];\n        if (++si === sn) {\n          throw errInvalidSource;\n        }\n      }\n      di += lLen;\n      si += lLen;\n      if (si >= sn) {\n        return di;\n      }\n    }\n\n    si += 2;\n    if (si >= sn) {\n      throw errInvalidSource;\n    }\n    const offset = src[si - 2] | (src[si - 1] << 8);\n    if (di - offset < 0 || offset === 0) {\n      throw errInvalidSource;\n    }\n\n    // match\n    if (mLen === 0xf) {\n      while (src[si] === 0xff) {\n        mLen += 0xff;\n        if (++si === sn) {\n          throw errInvalidSource;\n        }\n      }\n      mLen += src[si];\n      if (++si === sn) {\n        throw errInvalidSource;\n      }\n    }\n    // minimum match length is 4\n    mLen += 4;\n\n    // copy the match (NB. match is at least 4 bytes long)\n    for (; mLen >= offset; mLen -= offset) {\n      di += offset;\n    }\n    di += mLen;\n  }\n}\n\nexport function uncompressBlock(src: Uint8Array, dest: Uint8Array): number {\n  const sn = src.length;\n  const dn = dest.length;\n  if (sn === 0) {\n    return 0;\n  }\n\n  let si = 0;\n  let di = 0;\n\n  while (true) {\n    // literals and match lengths (token)\n    let lLen = src[si] >> 4;\n    let mLen = src[si] & 0xf;\n    if (++si === sn) {\n      throw errInvalidSource;\n    }\n\n    // literals\n    if (lLen > 0) {\n      if (lLen === 0xf) {\n        while (src[si] === 0xff) {\n          lLen += 0xff;\n          if (++si === sn) {\n            throw errInvalidSource;\n          }\n        }\n        lLen += src[si];\n        if (++si === sn) {\n          throw errInvalidSource;\n        }\n      }\n      if (dn - di < lLen || si + lLen > sn) {\n        throw errShortBuffer;\n      }\n      copy(dest, src, di, si, lLen);\n      di += lLen;\n      si += lLen;\n      if (si >= sn) {\n        return di;\n      }\n    }\n\n    si += 2;\n    if (si >= sn) {\n      throw errInvalidSource;\n    }\n    const offset = src[si - 2] | (src[si - 1] << 8);\n    if (di - offset < 0 || offset === 0) {\n      throw errInvalidSource;\n    }\n\n    // match\n    if (mLen === 0xf) {\n      while (src[si] === 0xff) {\n        mLen += 0xff;\n        if (++si === sn) {\n          throw errInvalidSource;\n        }\n      }\n      mLen += src[si];\n      if (++si === sn) {\n        throw errInvalidSource;\n      }\n    }\n    // minimum match length is 4\n    mLen += 4;\n    if (dn - di <= mLen) {\n      throw errShortBuffer;\n    }\n\n    // copy the match (NB. match is at least 4 bytes long)\n    for (; mLen >= offset; mLen -= offset) {\n      copy(dest, dest, di, di - offset, offset);\n      di += offset;\n    }\n    copy(dest, dest, di, di - offset, mLen);\n    di += mLen;\n  }\n}\n\nexport function compressBlockBound(n: number): number {\n  return n + ((n / 255) | 0) + 16;\n}\n\nexport function compressBlock(\n  src: Uint8Array,\n  dest: Uint8Array,\n  soffset: number\n): number {\n  const sn = src.length - mfLimit;\n  const dn = dest.length;\n  if (sn <= 0 || dn === 0 || soffset >= sn) {\n    return 0;\n  }\n  let si = 0,\n    di = 0;\n\n  // fast scan strategy:\n  // we only need a hash table to store the last sequences (4 bytes)\n  const hashTable = new Uint32Array(hashSize);\n\n  // Initialise the hash table with the first 64Kb of the input buffer\n  // (used when compressing dependent blocks)\n  while (si < soffset) {\n    const h = imul(getUint32(src, si), hasher) >>> hashShift;\n    hashTable[h] = ++si;\n  }\n\n  let anchor = si;\n  let fma = 1 << skipStrength;\n  while (si < sn - minMatch) {\n    // hash the next 4 bytes (sequence)...\n    const h = imul(getUint32(src, si), hasher) >>> hashShift;\n    // -1 to separate existing entries from new ones\n    const ref = hashTable[h] - 1;\n    // ...and store the position of the hash in the hash table (+1 to compensate the -1 upon saving)\n    hashTable[h] = si + 1;\n    // no need to check the last 3 bytes in the first literal 4 bytes as\n    // this guarantees that the next match, if any, is compressed with\n    // a lower size, since to have some compression we must have:\n    // ll+ml-overlap > 1 + (ll-15)/255 + (ml-4-15)/255 + 2 (uncompressed size>compressed size)\n    // => ll+ml>3+2*overlap => ll+ml>= 4+2*overlap\n    // and by definition we do have:\n    // ll >= 1, ml >= 4\n    // => ll+ml >= 5\n    // => so overlap must be 0\n\n    // the sequence is new, out of bound (64kb) or not valid: try next sequence\n    if (\n      ref < 0 || //(fma & ((1 << skipStrength) - 1)) < 4 || // this code seems has a big penalty for size...\n      (si - ref) >> winSizeLog > 0 ||\n      src[ref] !== src[si] ||\n      src[ref + 1] !== src[si + 1] ||\n      src[ref + 2] !== src[si + 2] ||\n      src[ref + 3] !== src[si + 3]\n    ) {\n      // variable step: improves performance on non-compressible data\n      si += fma >> skipStrength;\n      ++fma;\n      continue;\n    }\n    // match found\n    fma = 1 << skipStrength;\n    const lLen = si - anchor;\n    const offset = si - ref;\n\n    // encode match length part 1\n    si += minMatch;\n    let mLen = si; // match length has minMatch already\n    while (si <= sn && src[si] === src[si - offset]) {\n      si++;\n    }\n    mLen = si - mLen;\n    if (mLen < 0xf) {\n      dest[di] = mLen;\n    } else {\n      dest[di] = 0xf;\n    }\n\n    // encode literals length\n    if (lLen < 0xf) {\n      dest[di] |= lLen << 4;\n    } else {\n      dest[di] |= 0xf0;\n      if (++di === dn) {\n        throw errShortBuffer;\n      }\n      let l = lLen - 0xf;\n      for (; l >= 0xff; l -= 0xff) {\n        dest[di] = 0xff;\n        if (++di === dn) {\n          throw errShortBuffer;\n        }\n      }\n      dest[di] = l & 0xff;\n    }\n    if (++di === dn) {\n      throw errShortBuffer;\n    }\n\n    // literals\n    if (di + lLen >= dn) {\n      throw errShortBuffer;\n    }\n    copy(dest, src, di, anchor, lLen);\n    di += lLen;\n    anchor = si;\n\n    // encode offset\n    di += 2;\n    if (di >= dn) {\n      throw errShortBuffer;\n    }\n    dest[di - 2] = offset;\n    dest[di - 1] = offset >> 8;\n\n    // encode match length part 2\n    if (mLen >= 0xf) {\n      for (mLen -= 0xf; mLen >= 0xff; mLen -= 0xff) {\n        dest[di] = 0xff;\n        if (++di === dn) {\n          throw errShortBuffer;\n        }\n      }\n      dest[di] = mLen;\n      if (++di === dn) {\n        throw errShortBuffer;\n      }\n    }\n  }\n\n  if (anchor === 0) {\n    // incompressible\n    return 0;\n  }\n\n  // last literals\n  let lLen = src.length - anchor;\n  if (lLen < 0xf) {\n    dest[di] = lLen << 4;\n  } else {\n    dest[di] = 0xf0;\n    if (++di === dn) {\n      throw errShortBuffer;\n    }\n    for (lLen -= 0xf; lLen >= 0xff; lLen -= 0xff) {\n      dest[di] = 0xff;\n      if (++di === dn) {\n        throw errShortBuffer;\n      }\n    }\n    dest[di] = lLen;\n  }\n  if (++di === dn) {\n    throw errShortBuffer;\n  }\n\n  // write literals\n  const lastLen = src.length - anchor;\n  const n = di + lastLen;\n  if (n > dn) {\n    throw errShortBuffer;\n  } else if (n >= sn) {\n    // incompressible\n    return 0;\n  }\n  copy(dest, src, di, anchor, lastLen);\n  di += lastLen;\n  return di;\n}\n\nexport function compressBlockHC(\n  src: Uint8Array,\n  dest: Uint8Array,\n  soffset: number\n): number {\n  const sn = src.length - mfLimit;\n  const dn = dest.length;\n  if (sn <= 0 || dn === 0 || soffset >= sn) {\n    return 0;\n  }\n  let si = 0;\n  let di = 0;\n\n  // Hash Chain strategy:\n  // we need a hash table and a chain table\n  // the chain table cannot contain more entries than the window size (64Kb entries)\n  const hashTable = new Uint32Array(hashSize);\n  const chainTable = new Uint32Array(winSize);\n\n  // Initialise the hash table with the first 64Kb of the input buffer\n  // (used when compressing dependent blocks)\n  while (si < soffset) {\n    const h = imul(getUint32(src, si), hasher) >>> hashShift;\n    chainTable[si & winMask] = hashTable[h];\n    hashTable[h] = ++si;\n  }\n\n  let anchor = si;\n  while (si < sn - minMatch) {\n    // hash the next 4 bytes (sequence)...\n    const h = imul(getUint32(src, si), hasher) >>> hashShift;\n\n    // follow the chain until out of window and give the longest match\n    let mLen = 0;\n    let offset = 0;\n    for (\n      let next = hashTable[h] - 1;\n      next > 0 && next > si - winSize;\n      next = chainTable[next & winMask] - 1\n    ) {\n      // the first (mLen==0) or next byte (mLen>=minMatch) at current match length must match to improve on the match length\n      if (src[next + mLen] === src[si + mLen]) {\n        for (let ml = 0; ; ++ml) {\n          if (src[next + ml] !== src[si + ml] || si + ml > sn) {\n            // found a longer match, keep its position and length\n            if (mLen < ml && ml >= minMatch) {\n              mLen = ml;\n              offset = si - next;\n            }\n            break;\n          }\n        }\n      }\n    }\n    chainTable[si & winMask] = hashTable[h];\n    hashTable[h] = si + 1;\n\n    // no match found\n    if (mLen === 0) {\n      ++si;\n      continue;\n    }\n\n    let si2 = si + 1;\n    const ml = si + mLen;\n\n    // match found\n    // update hash/chain tables with overlaping bytes:\n    // si already hashed, add everything from si+1 up to the match length\n    while (si2 < ml) {\n      const h = imul(getUint32(src, si2), hasher) >>> hashShift;\n      chainTable[si2 & winMask] = hashTable[h];\n      hashTable[h] = ++si2;\n    }\n\n    const lLen = si - anchor;\n    si += mLen;\n    mLen -= minMatch; // match length does not include minMatch\n\n    if (mLen < 0xf) {\n      dest[di] = mLen;\n    } else {\n      dest[di] = 0xf;\n    }\n\n    // encode literals length\n    if (lLen < 0xf) {\n      dest[di] |= lLen << 4;\n    } else {\n      dest[di] |= 0xf0;\n      if (++di === dn) {\n        throw errShortBuffer;\n      }\n      let l = lLen - 0xf;\n      for (; l >= 0xff; l -= 0xff) {\n        dest[di] = 0xff;\n        if (++di === dn) {\n          throw errShortBuffer;\n        }\n      }\n      dest[di] = l & 0xff;\n    }\n    if (++di === dn) {\n      throw errShortBuffer;\n    }\n\n    // literals\n    if (di + lLen >= dn) {\n      throw errShortBuffer;\n    }\n    copy(dest, src, di, anchor, lLen);\n    di += lLen;\n    anchor = si;\n\n    // encode offset\n    di += 2;\n    if (di >= dn) {\n      throw errShortBuffer;\n    }\n    dest[di - 2] = offset;\n    dest[di - 1] = offset >> 8;\n\n    // encode match length part 2\n    if (mLen >= 0xf) {\n      for (mLen -= 0xf; mLen >= 0xff; mLen -= 0xff) {\n        dest[di] = 0xff;\n        if (++di === dn) {\n          throw errShortBuffer;\n        }\n      }\n      dest[di] = mLen;\n      if (++di === dn) {\n        throw errShortBuffer;\n      }\n    }\n  }\n\n  if (anchor === 0) {\n    // incompressible\n    return 0;\n  }\n\n  // last literals\n  let lLen = src.length - anchor;\n  if (lLen < 0xf) {\n    dest[di] = lLen << 4;\n  } else {\n    dest[di] = 0xf0;\n    if (++di === dn) {\n      throw errShortBuffer;\n    }\n    for (lLen -= 0xf; lLen >= 0xff; lLen -= 0xff) {\n      dest[di] = 0xff;\n      if (++di === dn) {\n        throw errShortBuffer;\n      }\n    }\n    dest[di] = lLen;\n  }\n  if (++di === dn) {\n    throw errShortBuffer;\n  }\n\n  // write literals\n  const lastLen = src.length - anchor;\n  const n = di + lastLen;\n  if (n > dn) {\n    throw errShortBuffer;\n  } else if (n >= sn) {\n    // incompressible\n    return 0;\n  }\n  copy(dest, src, di, anchor, lastLen);\n  di += lastLen;\n  return di;\n}\n"]}
|
|
627
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["errInvalidSource","Error","errShortBuffer","minMatch","winSizeLog","winSize","winMask","hashSizeLog","hashSize","hashShift","mfLimit","skipStrength","hasher","imulPolyfill","a","b","ah","al","bh","bl","imul","Math","getUint32","i","copy","dest","src","di","si","len","calcUncompressedLen","sn","length","lLen","mLen","offset","uncompressBlock","dn","compressBlockBound","n","compressBlock","soffset","hashTable","Uint32Array","h","anchor","fma","ref","l","lastLen","compressBlockHC","chainTable","next","ml","si2"],"sources":["../../src/minify/lz4.ts"],"sourcesContent":["// lz4-ts @license BSD-3-Clause / Copyright (c) 2015, Pierre Curto / 2016, oov. All rights reserved.\n/**\n * Copyright (c) 2015, Pierre Curto\n * Copyright (c) 2016, oov\n * All rights reserved.\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * * Redistributions of source code must retain the above copyright notice, this\n *   list of conditions and the following disclaimer.\n *\n * * Redistributions in binary form must reproduce the above copyright notice,\n *   this list of conditions and the following disclaimer in the documentation\n *   and/or other materials provided with the distribution.\n *\n * * Neither the name of xxHash nor the names of its\n *   contributors may be used to endorse or promote products derived from\n *   this software without specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\"\n * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nconst errInvalidSource = new Error(\"invalid source\");\nconst errShortBuffer = new Error(\"short buffer\");\n\n// The following constants are used to setup the compression algorithm.\nconst minMatch = 4; // the minimum size of the match sequence size (4 bytes)\nconst winSizeLog = 16; // LZ4 64Kb window size limit\nconst winSize = 1 << winSizeLog;\nconst winMask = winSize - 1; // 64Kb window of previous data for dependent blocks\n\n// hashSizeLog determines the size of the hash table used to quickly find a previous match position.\n// Its value influences the compression speed and memory usage, the lower the faster,\n// but at the expense of the compression ratio.\n// 16 seems to be the best compromise.\nconst hashSizeLog = 16;\nconst hashSize = 1 << hashSizeLog;\nconst hashShift = minMatch * 8 - hashSizeLog;\n\nconst mfLimit = 8 + minMatch; // The last match cannot start within the last 12 bytes.\nconst skipStrength = 6; // variable step for fast scan\n\nconst hasher = 2654435761 | 0; // prime number used to hash minMatch\n\n// https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Math/imul#Polyfill\nfunction imulPolyfill(a: number, b: number): number {\n  const ah = (a >>> 16) & 0xffff;\n  const al = a & 0xffff;\n  const bh = (b >>> 16) & 0xffff;\n  const bl = b & 0xffff;\n  // the shift by 0 fixes the sign on the high part\n  // the final |0 converts the unsigned value into a signed value\n  return (al * bl + (((ah * bl + al * bh) << 16) >>> 0)) | 0;\n}\nconst imul = Math.imul ? Math.imul : imulPolyfill;\n\nfunction getUint32(a: Uint8Array, i: number): number {\n  return a[i + 3] | (a[i + 2] << 8) | (a[i + 1] << 16) | (a[i] << 24);\n}\n\nfunction copy(\n  dest: Uint8Array,\n  src: Uint8Array,\n  di: number,\n  si: number,\n  len: number\n): void {\n  for (let i = 0; i < len; ++i) {\n    dest[di++] = src[si++];\n  }\n}\n\nexport function calcUncompressedLen(src: Uint8Array): number {\n  const sn = src.length;\n  if (sn === 0) {\n    return 0;\n  }\n\n  let si = 0;\n  let di = 0;\n\n  while (true) {\n    // literals and match lengths (token)\n    let lLen = src[si] >> 4;\n    let mLen = src[si] & 0xf;\n    if (++si === sn) {\n      throw errInvalidSource;\n    }\n\n    // literals\n    if (lLen > 0) {\n      if (lLen === 0xf) {\n        while (src[si] === 0xff) {\n          lLen += 0xff;\n          if (++si === sn) {\n            throw errInvalidSource;\n          }\n        }\n        lLen += src[si];\n        if (++si === sn) {\n          throw errInvalidSource;\n        }\n      }\n      di += lLen;\n      si += lLen;\n      if (si >= sn) {\n        return di;\n      }\n    }\n\n    si += 2;\n    if (si >= sn) {\n      throw errInvalidSource;\n    }\n    const offset = src[si - 2] | (src[si - 1] << 8);\n    if (di - offset < 0 || offset === 0) {\n      throw errInvalidSource;\n    }\n\n    // match\n    if (mLen === 0xf) {\n      while (src[si] === 0xff) {\n        mLen += 0xff;\n        if (++si === sn) {\n          throw errInvalidSource;\n        }\n      }\n      mLen += src[si];\n      if (++si === sn) {\n        throw errInvalidSource;\n      }\n    }\n    // minimum match length is 4\n    mLen += 4;\n\n    // copy the match (NB. match is at least 4 bytes long)\n    for (; mLen >= offset; mLen -= offset) {\n      di += offset;\n    }\n    di += mLen;\n  }\n}\n\nexport function uncompressBlock(src: Uint8Array, dest: Uint8Array): number {\n  const sn = src.length;\n  const dn = dest.length;\n  if (sn === 0) {\n    return 0;\n  }\n\n  let si = 0;\n  let di = 0;\n\n  while (true) {\n    // literals and match lengths (token)\n    let lLen = src[si] >> 4;\n    let mLen = src[si] & 0xf;\n    if (++si === sn) {\n      throw errInvalidSource;\n    }\n\n    // literals\n    if (lLen > 0) {\n      if (lLen === 0xf) {\n        while (src[si] === 0xff) {\n          lLen += 0xff;\n          if (++si === sn) {\n            throw errInvalidSource;\n          }\n        }\n        lLen += src[si];\n        if (++si === sn) {\n          throw errInvalidSource;\n        }\n      }\n      if (dn - di < lLen || si + lLen > sn) {\n        throw errShortBuffer;\n      }\n      copy(dest, src, di, si, lLen);\n      di += lLen;\n      si += lLen;\n      if (si >= sn) {\n        return di;\n      }\n    }\n\n    si += 2;\n    if (si >= sn) {\n      throw errInvalidSource;\n    }\n    const offset = src[si - 2] | (src[si - 1] << 8);\n    if (di - offset < 0 || offset === 0) {\n      throw errInvalidSource;\n    }\n\n    // match\n    if (mLen === 0xf) {\n      while (src[si] === 0xff) {\n        mLen += 0xff;\n        if (++si === sn) {\n          throw errInvalidSource;\n        }\n      }\n      mLen += src[si];\n      if (++si === sn) {\n        throw errInvalidSource;\n      }\n    }\n    // minimum match length is 4\n    mLen += 4;\n    if (dn - di <= mLen) {\n      throw errShortBuffer;\n    }\n\n    // copy the match (NB. match is at least 4 bytes long)\n    for (; mLen >= offset; mLen -= offset) {\n      copy(dest, dest, di, di - offset, offset);\n      di += offset;\n    }\n    copy(dest, dest, di, di - offset, mLen);\n    di += mLen;\n  }\n}\n\nexport function compressBlockBound(n: number): number {\n  return n + ((n / 255) | 0) + 16;\n}\n\nexport function compressBlock(\n  src: Uint8Array,\n  dest: Uint8Array,\n  soffset: number\n): number {\n  const sn = src.length - mfLimit;\n  const dn = dest.length;\n  if (sn <= 0 || dn === 0 || soffset >= sn) {\n    return 0;\n  }\n  let si = 0,\n    di = 0;\n\n  // fast scan strategy:\n  // we only need a hash table to store the last sequences (4 bytes)\n  const hashTable = new Uint32Array(hashSize);\n\n  // Initialise the hash table with the first 64Kb of the input buffer\n  // (used when compressing dependent blocks)\n  while (si < soffset) {\n    const h = imul(getUint32(src, si), hasher) >>> hashShift;\n    hashTable[h] = ++si;\n  }\n\n  let anchor = si;\n  let fma = 1 << skipStrength;\n  while (si < sn - minMatch) {\n    // hash the next 4 bytes (sequence)...\n    const h = imul(getUint32(src, si), hasher) >>> hashShift;\n    // -1 to separate existing entries from new ones\n    const ref = hashTable[h] - 1;\n    // ...and store the position of the hash in the hash table (+1 to compensate the -1 upon saving)\n    hashTable[h] = si + 1;\n    // no need to check the last 3 bytes in the first literal 4 bytes as\n    // this guarantees that the next match, if any, is compressed with\n    // a lower size, since to have some compression we must have:\n    // ll+ml-overlap > 1 + (ll-15)/255 + (ml-4-15)/255 + 2 (uncompressed size>compressed size)\n    // => ll+ml>3+2*overlap => ll+ml>= 4+2*overlap\n    // and by definition we do have:\n    // ll >= 1, ml >= 4\n    // => ll+ml >= 5\n    // => so overlap must be 0\n\n    // the sequence is new, out of bound (64kb) or not valid: try next sequence\n    if (\n      ref < 0 || //(fma & ((1 << skipStrength) - 1)) < 4 || // this code seems has a big penalty for size...\n      (si - ref) >> winSizeLog > 0 ||\n      src[ref] !== src[si] ||\n      src[ref + 1] !== src[si + 1] ||\n      src[ref + 2] !== src[si + 2] ||\n      src[ref + 3] !== src[si + 3]\n    ) {\n      // variable step: improves performance on non-compressible data\n      si += fma >> skipStrength;\n      ++fma;\n      continue;\n    }\n    // match found\n    fma = 1 << skipStrength;\n    const lLen = si - anchor;\n    const offset = si - ref;\n\n    // encode match length part 1\n    si += minMatch;\n    let mLen = si; // match length has minMatch already\n    while (si <= sn && src[si] === src[si - offset]) {\n      si++;\n    }\n    mLen = si - mLen;\n    if (mLen < 0xf) {\n      dest[di] = mLen;\n    } else {\n      dest[di] = 0xf;\n    }\n\n    // encode literals length\n    if (lLen < 0xf) {\n      dest[di] |= lLen << 4;\n    } else {\n      dest[di] |= 0xf0;\n      if (++di === dn) {\n        throw errShortBuffer;\n      }\n      let l = lLen - 0xf;\n      for (; l >= 0xff; l -= 0xff) {\n        dest[di] = 0xff;\n        if (++di === dn) {\n          throw errShortBuffer;\n        }\n      }\n      dest[di] = l & 0xff;\n    }\n    if (++di === dn) {\n      throw errShortBuffer;\n    }\n\n    // literals\n    if (di + lLen >= dn) {\n      throw errShortBuffer;\n    }\n    copy(dest, src, di, anchor, lLen);\n    di += lLen;\n    anchor = si;\n\n    // encode offset\n    di += 2;\n    if (di >= dn) {\n      throw errShortBuffer;\n    }\n    dest[di - 2] = offset;\n    dest[di - 1] = offset >> 8;\n\n    // encode match length part 2\n    if (mLen >= 0xf) {\n      for (mLen -= 0xf; mLen >= 0xff; mLen -= 0xff) {\n        dest[di] = 0xff;\n        if (++di === dn) {\n          throw errShortBuffer;\n        }\n      }\n      dest[di] = mLen;\n      if (++di === dn) {\n        throw errShortBuffer;\n      }\n    }\n  }\n\n  if (anchor === 0) {\n    // incompressible\n    return 0;\n  }\n\n  // last literals\n  let lLen = src.length - anchor;\n  if (lLen < 0xf) {\n    dest[di] = lLen << 4;\n  } else {\n    dest[di] = 0xf0;\n    if (++di === dn) {\n      throw errShortBuffer;\n    }\n    for (lLen -= 0xf; lLen >= 0xff; lLen -= 0xff) {\n      dest[di] = 0xff;\n      if (++di === dn) {\n        throw errShortBuffer;\n      }\n    }\n    dest[di] = lLen;\n  }\n  if (++di === dn) {\n    throw errShortBuffer;\n  }\n\n  // write literals\n  const lastLen = src.length - anchor;\n  const n = di + lastLen;\n  if (n > dn) {\n    throw errShortBuffer;\n  } else if (n >= sn) {\n    // incompressible\n    return 0;\n  }\n  copy(dest, src, di, anchor, lastLen);\n  di += lastLen;\n  return di;\n}\n\nexport function compressBlockHC(\n  src: Uint8Array,\n  dest: Uint8Array,\n  soffset: number\n): number {\n  const sn = src.length - mfLimit;\n  const dn = dest.length;\n  if (sn <= 0 || dn === 0 || soffset >= sn) {\n    return 0;\n  }\n  let si = 0;\n  let di = 0;\n\n  // Hash Chain strategy:\n  // we need a hash table and a chain table\n  // the chain table cannot contain more entries than the window size (64Kb entries)\n  const hashTable = new Uint32Array(hashSize);\n  const chainTable = new Uint32Array(winSize);\n\n  // Initialise the hash table with the first 64Kb of the input buffer\n  // (used when compressing dependent blocks)\n  while (si < soffset) {\n    const h = imul(getUint32(src, si), hasher) >>> hashShift;\n    chainTable[si & winMask] = hashTable[h];\n    hashTable[h] = ++si;\n  }\n\n  let anchor = si;\n  while (si < sn - minMatch) {\n    // hash the next 4 bytes (sequence)...\n    const h = imul(getUint32(src, si), hasher) >>> hashShift;\n\n    // follow the chain until out of window and give the longest match\n    let mLen = 0;\n    let offset = 0;\n    for (\n      let next = hashTable[h] - 1;\n      next > 0 && next > si - winSize;\n      next = chainTable[next & winMask] - 1\n    ) {\n      // the first (mLen==0) or next byte (mLen>=minMatch) at current match length must match to improve on the match length\n      if (src[next + mLen] === src[si + mLen]) {\n        for (let ml = 0; ; ++ml) {\n          if (src[next + ml] !== src[si + ml] || si + ml > sn) {\n            // found a longer match, keep its position and length\n            if (mLen < ml && ml >= minMatch) {\n              mLen = ml;\n              offset = si - next;\n            }\n            break;\n          }\n        }\n      }\n    }\n    chainTable[si & winMask] = hashTable[h];\n    hashTable[h] = si + 1;\n\n    // no match found\n    if (mLen === 0) {\n      ++si;\n      continue;\n    }\n\n    let si2 = si + 1;\n    const ml = si + mLen;\n\n    // match found\n    // update hash/chain tables with overlaping bytes:\n    // si already hashed, add everything from si+1 up to the match length\n    while (si2 < ml) {\n      const h = imul(getUint32(src, si2), hasher) >>> hashShift;\n      chainTable[si2 & winMask] = hashTable[h];\n      hashTable[h] = ++si2;\n    }\n\n    const lLen = si - anchor;\n    si += mLen;\n    mLen -= minMatch; // match length does not include minMatch\n\n    if (mLen < 0xf) {\n      dest[di] = mLen;\n    } else {\n      dest[di] = 0xf;\n    }\n\n    // encode literals length\n    if (lLen < 0xf) {\n      dest[di] |= lLen << 4;\n    } else {\n      dest[di] |= 0xf0;\n      if (++di === dn) {\n        throw errShortBuffer;\n      }\n      let l = lLen - 0xf;\n      for (; l >= 0xff; l -= 0xff) {\n        dest[di] = 0xff;\n        if (++di === dn) {\n          throw errShortBuffer;\n        }\n      }\n      dest[di] = l & 0xff;\n    }\n    if (++di === dn) {\n      throw errShortBuffer;\n    }\n\n    // literals\n    if (di + lLen >= dn) {\n      throw errShortBuffer;\n    }\n    copy(dest, src, di, anchor, lLen);\n    di += lLen;\n    anchor = si;\n\n    // encode offset\n    di += 2;\n    if (di >= dn) {\n      throw errShortBuffer;\n    }\n    dest[di - 2] = offset;\n    dest[di - 1] = offset >> 8;\n\n    // encode match length part 2\n    if (mLen >= 0xf) {\n      for (mLen -= 0xf; mLen >= 0xff; mLen -= 0xff) {\n        dest[di] = 0xff;\n        if (++di === dn) {\n          throw errShortBuffer;\n        }\n      }\n      dest[di] = mLen;\n      if (++di === dn) {\n        throw errShortBuffer;\n      }\n    }\n  }\n\n  if (anchor === 0) {\n    // incompressible\n    return 0;\n  }\n\n  // last literals\n  let lLen = src.length - anchor;\n  if (lLen < 0xf) {\n    dest[di] = lLen << 4;\n  } else {\n    dest[di] = 0xf0;\n    if (++di === dn) {\n      throw errShortBuffer;\n    }\n    for (lLen -= 0xf; lLen >= 0xff; lLen -= 0xff) {\n      dest[di] = 0xff;\n      if (++di === dn) {\n        throw errShortBuffer;\n      }\n    }\n    dest[di] = lLen;\n  }\n  if (++di === dn) {\n    throw errShortBuffer;\n  }\n\n  // write literals\n  const lastLen = src.length - anchor;\n  const n = di + lastLen;\n  if (n > dn) {\n    throw errShortBuffer;\n  } else if (n >= sn) {\n    // incompressible\n    return 0;\n  }\n  copy(dest, src, di, anchor, lastLen);\n  di += lastLen;\n  return di;\n}\n"],"mappings":"AAAA;;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA,MAAMA,gBAAgB,GAAG,IAAIC,KAAJ,CAAU,gBAAV,CAAzB;AACA,MAAMC,cAAc,GAAG,IAAID,KAAJ,CAAU,cAAV,CAAvB,C,CAEA;;AACA,MAAME,QAAQ,GAAG,CAAjB,C,CAAoB;;AACpB,MAAMC,UAAU,GAAG,EAAnB,C,CAAuB;;AACvB,MAAMC,OAAO,GAAG,KAAKD,UAArB;AACA,MAAME,OAAO,GAAGD,OAAO,GAAG,CAA1B,C,CAA6B;AAE7B;AACA;AACA;AACA;;AACA,MAAME,WAAW,GAAG,EAApB;AACA,MAAMC,QAAQ,GAAG,KAAKD,WAAtB;AACA,MAAME,SAAS,GAAGN,QAAQ,GAAG,CAAX,GAAeI,WAAjC;AAEA,MAAMG,OAAO,GAAG,IAAIP,QAApB,C,CAA8B;;AAC9B,MAAMQ,YAAY,GAAG,CAArB,C,CAAwB;;AAExB,MAAMC,MAAM,GAAG,aAAa,CAA5B,C,CAA+B;AAE/B;;AACA,SAASC,YAAT,CAAsBC,CAAtB,EAAiCC,CAAjC,EAAoD;EAClD,MAAMC,EAAE,GAAIF,CAAC,KAAK,EAAP,GAAa,MAAxB;EACA,MAAMG,EAAE,GAAGH,CAAC,GAAG,MAAf;EACA,MAAMI,EAAE,GAAIH,CAAC,KAAK,EAAP,GAAa,MAAxB;EACA,MAAMI,EAAE,GAAGJ,CAAC,GAAG,MAAf,CAJkD,CAKlD;EACA;;EACA,OAAQE,EAAE,GAAGE,EAAL,IAAaH,EAAE,GAAGG,EAAL,GAAUF,EAAE,GAAGC,EAAhB,IAAuB,EAAxB,KAAgC,CAA3C,CAAD,GAAkD,CAAzD;AACD;;AACD,MAAME,IAAI,GAAGC,IAAI,CAACD,IAAL,GAAYC,IAAI,CAACD,IAAjB,GAAwBP,YAArC;;AAEA,SAASS,SAAT,CAAmBR,CAAnB,EAAkCS,CAAlC,EAAqD;EACnD,OAAOT,CAAC,CAACS,CAAC,GAAG,CAAL,CAAD,GAAYT,CAAC,CAACS,CAAC,GAAG,CAAL,CAAD,IAAY,CAAxB,GAA8BT,CAAC,CAACS,CAAC,GAAG,CAAL,CAAD,IAAY,EAA1C,GAAiDT,CAAC,CAACS,CAAD,CAAD,IAAQ,EAAhE;AACD;;AAED,SAASC,IAAT,CACEC,IADF,EAEEC,GAFF,EAGEC,EAHF,EAIEC,EAJF,EAKEC,GALF,EAMQ;EACN,KAAK,IAAIN,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGM,GAApB,EAAyB,EAAEN,CAA3B,EAA8B;IAC5BE,IAAI,CAACE,EAAE,EAAH,CAAJ,GAAaD,GAAG,CAACE,EAAE,EAAH,CAAhB;EACD;AACF;;AAED,OAAO,SAASE,mBAAT,CAA6BJ,GAA7B,EAAsD;EAC3D,MAAMK,EAAE,GAAGL,GAAG,CAACM,MAAf;;EACA,IAAID,EAAE,KAAK,CAAX,EAAc;IACZ,OAAO,CAAP;EACD;;EAED,IAAIH,EAAE,GAAG,CAAT;EACA,IAAID,EAAE,GAAG,CAAT;;EAEA,OAAO,IAAP,EAAa;IACX;IACA,IAAIM,IAAI,GAAGP,GAAG,CAACE,EAAD,CAAH,IAAW,CAAtB;IACA,IAAIM,IAAI,GAAGR,GAAG,CAACE,EAAD,CAAH,GAAU,GAArB;;IACA,IAAI,EAAEA,EAAF,KAASG,EAAb,EAAiB;MACf,MAAM/B,gBAAN;IACD,CANU,CAQX;;;IACA,IAAIiC,IAAI,GAAG,CAAX,EAAc;MACZ,IAAIA,IAAI,KAAK,GAAb,EAAkB;QAChB,OAAOP,GAAG,CAACE,EAAD,CAAH,KAAY,IAAnB,EAAyB;UACvBK,IAAI,IAAI,IAAR;;UACA,IAAI,EAAEL,EAAF,KAASG,EAAb,EAAiB;YACf,MAAM/B,gBAAN;UACD;QACF;;QACDiC,IAAI,IAAIP,GAAG,CAACE,EAAD,CAAX;;QACA,IAAI,EAAEA,EAAF,KAASG,EAAb,EAAiB;UACf,MAAM/B,gBAAN;QACD;MACF;;MACD2B,EAAE,IAAIM,IAAN;MACAL,EAAE,IAAIK,IAAN;;MACA,IAAIL,EAAE,IAAIG,EAAV,EAAc;QACZ,OAAOJ,EAAP;MACD;IACF;;IAEDC,EAAE,IAAI,CAAN;;IACA,IAAIA,EAAE,IAAIG,EAAV,EAAc;MACZ,MAAM/B,gBAAN;IACD;;IACD,MAAMmC,MAAM,GAAGT,GAAG,CAACE,EAAE,GAAG,CAAN,CAAH,GAAeF,GAAG,CAACE,EAAE,GAAG,CAAN,CAAH,IAAe,CAA7C;;IACA,IAAID,EAAE,GAAGQ,MAAL,GAAc,CAAd,IAAmBA,MAAM,KAAK,CAAlC,EAAqC;MACnC,MAAMnC,gBAAN;IACD,CApCU,CAsCX;;;IACA,IAAIkC,IAAI,KAAK,GAAb,EAAkB;MAChB,OAAOR,GAAG,CAACE,EAAD,CAAH,KAAY,IAAnB,EAAyB;QACvBM,IAAI,IAAI,IAAR;;QACA,IAAI,EAAEN,EAAF,KAASG,EAAb,EAAiB;UACf,MAAM/B,gBAAN;QACD;MACF;;MACDkC,IAAI,IAAIR,GAAG,CAACE,EAAD,CAAX;;MACA,IAAI,EAAEA,EAAF,KAASG,EAAb,EAAiB;QACf,MAAM/B,gBAAN;MACD;IACF,CAlDU,CAmDX;;;IACAkC,IAAI,IAAI,CAAR,CApDW,CAsDX;;IACA,OAAOA,IAAI,IAAIC,MAAf,EAAuBD,IAAI,IAAIC,MAA/B,EAAuC;MACrCR,EAAE,IAAIQ,MAAN;IACD;;IACDR,EAAE,IAAIO,IAAN;EACD;AACF;AAED,OAAO,SAASE,eAAT,CAAyBV,GAAzB,EAA0CD,IAA1C,EAAoE;EACzE,MAAMM,EAAE,GAAGL,GAAG,CAACM,MAAf;EACA,MAAMK,EAAE,GAAGZ,IAAI,CAACO,MAAhB;;EACA,IAAID,EAAE,KAAK,CAAX,EAAc;IACZ,OAAO,CAAP;EACD;;EAED,IAAIH,EAAE,GAAG,CAAT;EACA,IAAID,EAAE,GAAG,CAAT;;EAEA,OAAO,IAAP,EAAa;IACX;IACA,IAAIM,IAAI,GAAGP,GAAG,CAACE,EAAD,CAAH,IAAW,CAAtB;IACA,IAAIM,IAAI,GAAGR,GAAG,CAACE,EAAD,CAAH,GAAU,GAArB;;IACA,IAAI,EAAEA,EAAF,KAASG,EAAb,EAAiB;MACf,MAAM/B,gBAAN;IACD,CANU,CAQX;;;IACA,IAAIiC,IAAI,GAAG,CAAX,EAAc;MACZ,IAAIA,IAAI,KAAK,GAAb,EAAkB;QAChB,OAAOP,GAAG,CAACE,EAAD,CAAH,KAAY,IAAnB,EAAyB;UACvBK,IAAI,IAAI,IAAR;;UACA,IAAI,EAAEL,EAAF,KAASG,EAAb,EAAiB;YACf,MAAM/B,gBAAN;UACD;QACF;;QACDiC,IAAI,IAAIP,GAAG,CAACE,EAAD,CAAX;;QACA,IAAI,EAAEA,EAAF,KAASG,EAAb,EAAiB;UACf,MAAM/B,gBAAN;QACD;MACF;;MACD,IAAIqC,EAAE,GAAGV,EAAL,GAAUM,IAAV,IAAkBL,EAAE,GAAGK,IAAL,GAAYF,EAAlC,EAAsC;QACpC,MAAM7B,cAAN;MACD;;MACDsB,IAAI,CAACC,IAAD,EAAOC,GAAP,EAAYC,EAAZ,EAAgBC,EAAhB,EAAoBK,IAApB,CAAJ;MACAN,EAAE,IAAIM,IAAN;MACAL,EAAE,IAAIK,IAAN;;MACA,IAAIL,EAAE,IAAIG,EAAV,EAAc;QACZ,OAAOJ,EAAP;MACD;IACF;;IAEDC,EAAE,IAAI,CAAN;;IACA,IAAIA,EAAE,IAAIG,EAAV,EAAc;MACZ,MAAM/B,gBAAN;IACD;;IACD,MAAMmC,MAAM,GAAGT,GAAG,CAACE,EAAE,GAAG,CAAN,CAAH,GAAeF,GAAG,CAACE,EAAE,GAAG,CAAN,CAAH,IAAe,CAA7C;;IACA,IAAID,EAAE,GAAGQ,MAAL,GAAc,CAAd,IAAmBA,MAAM,KAAK,CAAlC,EAAqC;MACnC,MAAMnC,gBAAN;IACD,CAxCU,CA0CX;;;IACA,IAAIkC,IAAI,KAAK,GAAb,EAAkB;MAChB,OAAOR,GAAG,CAACE,EAAD,CAAH,KAAY,IAAnB,EAAyB;QACvBM,IAAI,IAAI,IAAR;;QACA,IAAI,EAAEN,EAAF,KAASG,EAAb,EAAiB;UACf,MAAM/B,gBAAN;QACD;MACF;;MACDkC,IAAI,IAAIR,GAAG,CAACE,EAAD,CAAX;;MACA,IAAI,EAAEA,EAAF,KAASG,EAAb,EAAiB;QACf,MAAM/B,gBAAN;MACD;IACF,CAtDU,CAuDX;;;IACAkC,IAAI,IAAI,CAAR;;IACA,IAAIG,EAAE,GAAGV,EAAL,IAAWO,IAAf,EAAqB;MACnB,MAAMhC,cAAN;IACD,CA3DU,CA6DX;;;IACA,OAAOgC,IAAI,IAAIC,MAAf,EAAuBD,IAAI,IAAIC,MAA/B,EAAuC;MACrCX,IAAI,CAACC,IAAD,EAAOA,IAAP,EAAaE,EAAb,EAAiBA,EAAE,GAAGQ,MAAtB,EAA8BA,MAA9B,CAAJ;MACAR,EAAE,IAAIQ,MAAN;IACD;;IACDX,IAAI,CAACC,IAAD,EAAOA,IAAP,EAAaE,EAAb,EAAiBA,EAAE,GAAGQ,MAAtB,EAA8BD,IAA9B,CAAJ;IACAP,EAAE,IAAIO,IAAN;EACD;AACF;AAED,OAAO,SAASI,kBAAT,CAA4BC,CAA5B,EAA+C;EACpD,OAAOA,CAAC,IAAKA,CAAC,GAAG,GAAL,GAAY,CAAhB,CAAD,GAAsB,EAA7B;AACD;AAED,OAAO,SAASC,aAAT,CACLd,GADK,EAELD,IAFK,EAGLgB,OAHK,EAIG;EACR,MAAMV,EAAE,GAAGL,GAAG,CAACM,MAAJ,GAAatB,OAAxB;EACA,MAAM2B,EAAE,GAAGZ,IAAI,CAACO,MAAhB;;EACA,IAAID,EAAE,IAAI,CAAN,IAAWM,EAAE,KAAK,CAAlB,IAAuBI,OAAO,IAAIV,EAAtC,EAA0C;IACxC,OAAO,CAAP;EACD;;EACD,IAAIH,EAAE,GAAG,CAAT;EAAA,IACED,EAAE,GAAG,CADP,CANQ,CASR;EACA;;EACA,MAAMe,SAAS,GAAG,IAAIC,WAAJ,CAAgBnC,QAAhB,CAAlB,CAXQ,CAaR;EACA;;EACA,OAAOoB,EAAE,GAAGa,OAAZ,EAAqB;IACnB,MAAMG,CAAC,GAAGxB,IAAI,CAACE,SAAS,CAACI,GAAD,EAAME,EAAN,CAAV,EAAqBhB,MAArB,CAAJ,KAAqCH,SAA/C;IACAiC,SAAS,CAACE,CAAD,CAAT,GAAe,EAAEhB,EAAjB;EACD;;EAED,IAAIiB,MAAM,GAAGjB,EAAb;EACA,IAAIkB,GAAG,GAAG,KAAKnC,YAAf;;EACA,OAAOiB,EAAE,GAAGG,EAAE,GAAG5B,QAAjB,EAA2B;IACzB;IACA,MAAMyC,CAAC,GAAGxB,IAAI,CAACE,SAAS,CAACI,GAAD,EAAME,EAAN,CAAV,EAAqBhB,MAArB,CAAJ,KAAqCH,SAA/C,CAFyB,CAGzB;;IACA,MAAMsC,GAAG,GAAGL,SAAS,CAACE,CAAD,CAAT,GAAe,CAA3B,CAJyB,CAKzB;;IACAF,SAAS,CAACE,CAAD,CAAT,GAAehB,EAAE,GAAG,CAApB,CANyB,CAOzB;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IAEA;;IACA,IACEmB,GAAG,GAAG,CAAN,IAAW;IACVnB,EAAE,GAAGmB,GAAN,IAAc3C,UAAd,GAA2B,CAD3B,IAEAsB,GAAG,CAACqB,GAAD,CAAH,KAAarB,GAAG,CAACE,EAAD,CAFhB,IAGAF,GAAG,CAACqB,GAAG,GAAG,CAAP,CAAH,KAAiBrB,GAAG,CAACE,EAAE,GAAG,CAAN,CAHpB,IAIAF,GAAG,CAACqB,GAAG,GAAG,CAAP,CAAH,KAAiBrB,GAAG,CAACE,EAAE,GAAG,CAAN,CAJpB,IAKAF,GAAG,CAACqB,GAAG,GAAG,CAAP,CAAH,KAAiBrB,GAAG,CAACE,EAAE,GAAG,CAAN,CANtB,EAOE;MACA;MACAA,EAAE,IAAIkB,GAAG,IAAInC,YAAb;MACA,EAAEmC,GAAF;MACA;IACD,CA9BwB,CA+BzB;;;IACAA,GAAG,GAAG,KAAKnC,YAAX;IACA,MAAMsB,IAAI,GAAGL,EAAE,GAAGiB,MAAlB;IACA,MAAMV,MAAM,GAAGP,EAAE,GAAGmB,GAApB,CAlCyB,CAoCzB;;IACAnB,EAAE,IAAIzB,QAAN;IACA,IAAI+B,IAAI,GAAGN,EAAX,CAtCyB,CAsCV;;IACf,OAAOA,EAAE,IAAIG,EAAN,IAAYL,GAAG,CAACE,EAAD,CAAH,KAAYF,GAAG,CAACE,EAAE,GAAGO,MAAN,CAAlC,EAAiD;MAC/CP,EAAE;IACH;;IACDM,IAAI,GAAGN,EAAE,GAAGM,IAAZ;;IACA,IAAIA,IAAI,GAAG,GAAX,EAAgB;MACdT,IAAI,CAACE,EAAD,CAAJ,GAAWO,IAAX;IACD,CAFD,MAEO;MACLT,IAAI,CAACE,EAAD,CAAJ,GAAW,GAAX;IACD,CA/CwB,CAiDzB;;;IACA,IAAIM,IAAI,GAAG,GAAX,EAAgB;MACdR,IAAI,CAACE,EAAD,CAAJ,IAAYM,IAAI,IAAI,CAApB;IACD,CAFD,MAEO;MACLR,IAAI,CAACE,EAAD,CAAJ,IAAY,IAAZ;;MACA,IAAI,EAAEA,EAAF,KAASU,EAAb,EAAiB;QACf,MAAMnC,cAAN;MACD;;MACD,IAAI8C,CAAC,GAAGf,IAAI,GAAG,GAAf;;MACA,OAAOe,CAAC,IAAI,IAAZ,EAAkBA,CAAC,IAAI,IAAvB,EAA6B;QAC3BvB,IAAI,CAACE,EAAD,CAAJ,GAAW,IAAX;;QACA,IAAI,EAAEA,EAAF,KAASU,EAAb,EAAiB;UACf,MAAMnC,cAAN;QACD;MACF;;MACDuB,IAAI,CAACE,EAAD,CAAJ,GAAWqB,CAAC,GAAG,IAAf;IACD;;IACD,IAAI,EAAErB,EAAF,KAASU,EAAb,EAAiB;MACf,MAAMnC,cAAN;IACD,CApEwB,CAsEzB;;;IACA,IAAIyB,EAAE,GAAGM,IAAL,IAAaI,EAAjB,EAAqB;MACnB,MAAMnC,cAAN;IACD;;IACDsB,IAAI,CAACC,IAAD,EAAOC,GAAP,EAAYC,EAAZ,EAAgBkB,MAAhB,EAAwBZ,IAAxB,CAAJ;IACAN,EAAE,IAAIM,IAAN;IACAY,MAAM,GAAGjB,EAAT,CA5EyB,CA8EzB;;IACAD,EAAE,IAAI,CAAN;;IACA,IAAIA,EAAE,IAAIU,EAAV,EAAc;MACZ,MAAMnC,cAAN;IACD;;IACDuB,IAAI,CAACE,EAAE,GAAG,CAAN,CAAJ,GAAeQ,MAAf;IACAV,IAAI,CAACE,EAAE,GAAG,CAAN,CAAJ,GAAeQ,MAAM,IAAI,CAAzB,CApFyB,CAsFzB;;IACA,IAAID,IAAI,IAAI,GAAZ,EAAiB;MACf,KAAKA,IAAI,IAAI,GAAb,EAAkBA,IAAI,IAAI,IAA1B,EAAgCA,IAAI,IAAI,IAAxC,EAA8C;QAC5CT,IAAI,CAACE,EAAD,CAAJ,GAAW,IAAX;;QACA,IAAI,EAAEA,EAAF,KAASU,EAAb,EAAiB;UACf,MAAMnC,cAAN;QACD;MACF;;MACDuB,IAAI,CAACE,EAAD,CAAJ,GAAWO,IAAX;;MACA,IAAI,EAAEP,EAAF,KAASU,EAAb,EAAiB;QACf,MAAMnC,cAAN;MACD;IACF;EACF;;EAED,IAAI2C,MAAM,KAAK,CAAf,EAAkB;IAChB;IACA,OAAO,CAAP;EACD,CA9HO,CAgIR;;;EACA,IAAIZ,IAAI,GAAGP,GAAG,CAACM,MAAJ,GAAaa,MAAxB;;EACA,IAAIZ,IAAI,GAAG,GAAX,EAAgB;IACdR,IAAI,CAACE,EAAD,CAAJ,GAAWM,IAAI,IAAI,CAAnB;EACD,CAFD,MAEO;IACLR,IAAI,CAACE,EAAD,CAAJ,GAAW,IAAX;;IACA,IAAI,EAAEA,EAAF,KAASU,EAAb,EAAiB;MACf,MAAMnC,cAAN;IACD;;IACD,KAAK+B,IAAI,IAAI,GAAb,EAAkBA,IAAI,IAAI,IAA1B,EAAgCA,IAAI,IAAI,IAAxC,EAA8C;MAC5CR,IAAI,CAACE,EAAD,CAAJ,GAAW,IAAX;;MACA,IAAI,EAAEA,EAAF,KAASU,EAAb,EAAiB;QACf,MAAMnC,cAAN;MACD;IACF;;IACDuB,IAAI,CAACE,EAAD,CAAJ,GAAWM,IAAX;EACD;;EACD,IAAI,EAAEN,EAAF,KAASU,EAAb,EAAiB;IACf,MAAMnC,cAAN;EACD,CAnJO,CAqJR;;;EACA,MAAM+C,OAAO,GAAGvB,GAAG,CAACM,MAAJ,GAAaa,MAA7B;EACA,MAAMN,CAAC,GAAGZ,EAAE,GAAGsB,OAAf;;EACA,IAAIV,CAAC,GAAGF,EAAR,EAAY;IACV,MAAMnC,cAAN;EACD,CAFD,MAEO,IAAIqC,CAAC,IAAIR,EAAT,EAAa;IAClB;IACA,OAAO,CAAP;EACD;;EACDP,IAAI,CAACC,IAAD,EAAOC,GAAP,EAAYC,EAAZ,EAAgBkB,MAAhB,EAAwBI,OAAxB,CAAJ;EACAtB,EAAE,IAAIsB,OAAN;EACA,OAAOtB,EAAP;AACD;AAED,OAAO,SAASuB,eAAT,CACLxB,GADK,EAELD,IAFK,EAGLgB,OAHK,EAIG;EACR,MAAMV,EAAE,GAAGL,GAAG,CAACM,MAAJ,GAAatB,OAAxB;EACA,MAAM2B,EAAE,GAAGZ,IAAI,CAACO,MAAhB;;EACA,IAAID,EAAE,IAAI,CAAN,IAAWM,EAAE,KAAK,CAAlB,IAAuBI,OAAO,IAAIV,EAAtC,EAA0C;IACxC,OAAO,CAAP;EACD;;EACD,IAAIH,EAAE,GAAG,CAAT;EACA,IAAID,EAAE,GAAG,CAAT,CAPQ,CASR;EACA;EACA;;EACA,MAAMe,SAAS,GAAG,IAAIC,WAAJ,CAAgBnC,QAAhB,CAAlB;EACA,MAAM2C,UAAU,GAAG,IAAIR,WAAJ,CAAgBtC,OAAhB,CAAnB,CAbQ,CAeR;EACA;;EACA,OAAOuB,EAAE,GAAGa,OAAZ,EAAqB;IACnB,MAAMG,CAAC,GAAGxB,IAAI,CAACE,SAAS,CAACI,GAAD,EAAME,EAAN,CAAV,EAAqBhB,MAArB,CAAJ,KAAqCH,SAA/C;IACA0C,UAAU,CAACvB,EAAE,GAAGtB,OAAN,CAAV,GAA2BoC,SAAS,CAACE,CAAD,CAApC;IACAF,SAAS,CAACE,CAAD,CAAT,GAAe,EAAEhB,EAAjB;EACD;;EAED,IAAIiB,MAAM,GAAGjB,EAAb;;EACA,OAAOA,EAAE,GAAGG,EAAE,GAAG5B,QAAjB,EAA2B;IACzB;IACA,MAAMyC,CAAC,GAAGxB,IAAI,CAACE,SAAS,CAACI,GAAD,EAAME,EAAN,CAAV,EAAqBhB,MAArB,CAAJ,KAAqCH,SAA/C,CAFyB,CAIzB;;IACA,IAAIyB,IAAI,GAAG,CAAX;IACA,IAAIC,MAAM,GAAG,CAAb;;IACA,KACE,IAAIiB,IAAI,GAAGV,SAAS,CAACE,CAAD,CAAT,GAAe,CAD5B,EAEEQ,IAAI,GAAG,CAAP,IAAYA,IAAI,GAAGxB,EAAE,GAAGvB,OAF1B,EAGE+C,IAAI,GAAGD,UAAU,CAACC,IAAI,GAAG9C,OAAR,CAAV,GAA6B,CAHtC,EAIE;MACA;MACA,IAAIoB,GAAG,CAAC0B,IAAI,GAAGlB,IAAR,CAAH,KAAqBR,GAAG,CAACE,EAAE,GAAGM,IAAN,CAA5B,EAAyC;QACvC,KAAK,IAAImB,EAAE,GAAG,CAAd,GAAmB,EAAEA,EAArB,EAAyB;UACvB,IAAI3B,GAAG,CAAC0B,IAAI,GAAGC,EAAR,CAAH,KAAmB3B,GAAG,CAACE,EAAE,GAAGyB,EAAN,CAAtB,IAAmCzB,EAAE,GAAGyB,EAAL,GAAUtB,EAAjD,EAAqD;YACnD;YACA,IAAIG,IAAI,GAAGmB,EAAP,IAAaA,EAAE,IAAIlD,QAAvB,EAAiC;cAC/B+B,IAAI,GAAGmB,EAAP;cACAlB,MAAM,GAAGP,EAAE,GAAGwB,IAAd;YACD;;YACD;UACD;QACF;MACF;IACF;;IACDD,UAAU,CAACvB,EAAE,GAAGtB,OAAN,CAAV,GAA2BoC,SAAS,CAACE,CAAD,CAApC;IACAF,SAAS,CAACE,CAAD,CAAT,GAAehB,EAAE,GAAG,CAApB,CA3ByB,CA6BzB;;IACA,IAAIM,IAAI,KAAK,CAAb,EAAgB;MACd,EAAEN,EAAF;MACA;IACD;;IAED,IAAI0B,GAAG,GAAG1B,EAAE,GAAG,CAAf;IACA,MAAMyB,EAAE,GAAGzB,EAAE,GAAGM,IAAhB,CApCyB,CAsCzB;IACA;IACA;;IACA,OAAOoB,GAAG,GAAGD,EAAb,EAAiB;MACf,MAAMT,CAAC,GAAGxB,IAAI,CAACE,SAAS,CAACI,GAAD,EAAM4B,GAAN,CAAV,EAAsB1C,MAAtB,CAAJ,KAAsCH,SAAhD;MACA0C,UAAU,CAACG,GAAG,GAAGhD,OAAP,CAAV,GAA4BoC,SAAS,CAACE,CAAD,CAArC;MACAF,SAAS,CAACE,CAAD,CAAT,GAAe,EAAEU,GAAjB;IACD;;IAED,MAAMrB,IAAI,GAAGL,EAAE,GAAGiB,MAAlB;IACAjB,EAAE,IAAIM,IAAN;IACAA,IAAI,IAAI/B,QAAR,CAjDyB,CAiDP;;IAElB,IAAI+B,IAAI,GAAG,GAAX,EAAgB;MACdT,IAAI,CAACE,EAAD,CAAJ,GAAWO,IAAX;IACD,CAFD,MAEO;MACLT,IAAI,CAACE,EAAD,CAAJ,GAAW,GAAX;IACD,CAvDwB,CAyDzB;;;IACA,IAAIM,IAAI,GAAG,GAAX,EAAgB;MACdR,IAAI,CAACE,EAAD,CAAJ,IAAYM,IAAI,IAAI,CAApB;IACD,CAFD,MAEO;MACLR,IAAI,CAACE,EAAD,CAAJ,IAAY,IAAZ;;MACA,IAAI,EAAEA,EAAF,KAASU,EAAb,EAAiB;QACf,MAAMnC,cAAN;MACD;;MACD,IAAI8C,CAAC,GAAGf,IAAI,GAAG,GAAf;;MACA,OAAOe,CAAC,IAAI,IAAZ,EAAkBA,CAAC,IAAI,IAAvB,EAA6B;QAC3BvB,IAAI,CAACE,EAAD,CAAJ,GAAW,IAAX;;QACA,IAAI,EAAEA,EAAF,KAASU,EAAb,EAAiB;UACf,MAAMnC,cAAN;QACD;MACF;;MACDuB,IAAI,CAACE,EAAD,CAAJ,GAAWqB,CAAC,GAAG,IAAf;IACD;;IACD,IAAI,EAAErB,EAAF,KAASU,EAAb,EAAiB;MACf,MAAMnC,cAAN;IACD,CA5EwB,CA8EzB;;;IACA,IAAIyB,EAAE,GAAGM,IAAL,IAAaI,EAAjB,EAAqB;MACnB,MAAMnC,cAAN;IACD;;IACDsB,IAAI,CAACC,IAAD,EAAOC,GAAP,EAAYC,EAAZ,EAAgBkB,MAAhB,EAAwBZ,IAAxB,CAAJ;IACAN,EAAE,IAAIM,IAAN;IACAY,MAAM,GAAGjB,EAAT,CApFyB,CAsFzB;;IACAD,EAAE,IAAI,CAAN;;IACA,IAAIA,EAAE,IAAIU,EAAV,EAAc;MACZ,MAAMnC,cAAN;IACD;;IACDuB,IAAI,CAACE,EAAE,GAAG,CAAN,CAAJ,GAAeQ,MAAf;IACAV,IAAI,CAACE,EAAE,GAAG,CAAN,CAAJ,GAAeQ,MAAM,IAAI,CAAzB,CA5FyB,CA8FzB;;IACA,IAAID,IAAI,IAAI,GAAZ,EAAiB;MACf,KAAKA,IAAI,IAAI,GAAb,EAAkBA,IAAI,IAAI,IAA1B,EAAgCA,IAAI,IAAI,IAAxC,EAA8C;QAC5CT,IAAI,CAACE,EAAD,CAAJ,GAAW,IAAX;;QACA,IAAI,EAAEA,EAAF,KAASU,EAAb,EAAiB;UACf,MAAMnC,cAAN;QACD;MACF;;MACDuB,IAAI,CAACE,EAAD,CAAJ,GAAWO,IAAX;;MACA,IAAI,EAAEP,EAAF,KAASU,EAAb,EAAiB;QACf,MAAMnC,cAAN;MACD;IACF;EACF;;EAED,IAAI2C,MAAM,KAAK,CAAf,EAAkB;IAChB;IACA,OAAO,CAAP;EACD,CAxIO,CA0IR;;;EACA,IAAIZ,IAAI,GAAGP,GAAG,CAACM,MAAJ,GAAaa,MAAxB;;EACA,IAAIZ,IAAI,GAAG,GAAX,EAAgB;IACdR,IAAI,CAACE,EAAD,CAAJ,GAAWM,IAAI,IAAI,CAAnB;EACD,CAFD,MAEO;IACLR,IAAI,CAACE,EAAD,CAAJ,GAAW,IAAX;;IACA,IAAI,EAAEA,EAAF,KAASU,EAAb,EAAiB;MACf,MAAMnC,cAAN;IACD;;IACD,KAAK+B,IAAI,IAAI,GAAb,EAAkBA,IAAI,IAAI,IAA1B,EAAgCA,IAAI,IAAI,IAAxC,EAA8C;MAC5CR,IAAI,CAACE,EAAD,CAAJ,GAAW,IAAX;;MACA,IAAI,EAAEA,EAAF,KAASU,EAAb,EAAiB;QACf,MAAMnC,cAAN;MACD;IACF;;IACDuB,IAAI,CAACE,EAAD,CAAJ,GAAWM,IAAX;EACD;;EACD,IAAI,EAAEN,EAAF,KAASU,EAAb,EAAiB;IACf,MAAMnC,cAAN;EACD,CA7JO,CA+JR;;;EACA,MAAM+C,OAAO,GAAGvB,GAAG,CAACM,MAAJ,GAAaa,MAA7B;EACA,MAAMN,CAAC,GAAGZ,EAAE,GAAGsB,OAAf;;EACA,IAAIV,CAAC,GAAGF,EAAR,EAAY;IACV,MAAMnC,cAAN;EACD,CAFD,MAEO,IAAIqC,CAAC,IAAIR,EAAT,EAAa;IAClB;IACA,OAAO,CAAP;EACD;;EACDP,IAAI,CAACC,IAAD,EAAOC,GAAP,EAAYC,EAAZ,EAAgBkB,MAAhB,EAAwBI,OAAxB,CAAJ;EACAtB,EAAE,IAAIsB,OAAN;EACA,OAAOtB,EAAP;AACD"}
|