@secrecy/lib 1.0.0-dev.63 → 1.0.0-dev.65

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 (196) hide show
  1. package/dist/BaseClient-15fdf493.d.ts +351 -0
  2. package/dist/BaseClient.cjs +2 -0
  3. package/dist/BaseClient.cjs.map +1 -0
  4. package/dist/BaseClient.d.ts +16 -104
  5. package/dist/BaseClient.js +2 -482
  6. package/dist/BaseClient.js.map +1 -0
  7. package/dist/PopupTools.cjs +2 -0
  8. package/dist/PopupTools.cjs.map +1 -0
  9. package/dist/PopupTools.d.ts +5 -4
  10. package/dist/PopupTools.js +2 -216
  11. package/dist/PopupTools.js.map +1 -0
  12. package/dist/ZeusThunder.cjs +2 -0
  13. package/dist/ZeusThunder.cjs.map +1 -0
  14. package/dist/ZeusThunder.d.ts +6 -2
  15. package/dist/ZeusThunder.js +2 -79
  16. package/dist/ZeusThunder.js.map +1 -0
  17. package/dist/cache.cjs +2 -0
  18. package/dist/cache.cjs.map +1 -0
  19. package/dist/cache.d.ts +22 -4
  20. package/dist/cache.js +2 -4
  21. package/dist/cache.js.map +1 -0
  22. package/dist/chunk-5WPCTUWH.cjs +2 -0
  23. package/dist/chunk-5WPCTUWH.cjs.map +1 -0
  24. package/dist/chunk-KMTF2BZE.js +2 -0
  25. package/dist/chunk-KMTF2BZE.js.map +1 -0
  26. package/dist/client/SecrecyAppClient.cjs +2 -0
  27. package/dist/client/SecrecyAppClient.cjs.map +1 -0
  28. package/dist/client/SecrecyAppClient.d.ts +16 -17
  29. package/dist/client/SecrecyAppClient.js +2 -256
  30. package/dist/client/SecrecyAppClient.js.map +1 -0
  31. package/dist/client/SecrecyCloudClient.cjs +2 -0
  32. package/dist/client/SecrecyCloudClient.cjs.map +1 -0
  33. package/dist/client/SecrecyCloudClient.d.ts +16 -89
  34. package/dist/client/SecrecyCloudClient.js +2 -1627
  35. package/dist/client/SecrecyCloudClient.js.map +1 -0
  36. package/dist/client/SecrecyDbClient.cjs +2 -0
  37. package/dist/client/SecrecyDbClient.cjs.map +1 -0
  38. package/dist/client/SecrecyDbClient.d.ts +16 -21
  39. package/dist/client/SecrecyDbClient.js +2 -198
  40. package/dist/client/SecrecyDbClient.js.map +1 -0
  41. package/dist/client/SecrecyMailClient.cjs +2 -0
  42. package/dist/client/SecrecyMailClient.cjs.map +1 -0
  43. package/dist/client/SecrecyMailClient.d.ts +16 -42
  44. package/dist/client/SecrecyMailClient.js +2 -1187
  45. package/dist/client/SecrecyMailClient.js.map +1 -0
  46. package/dist/client/SecrecyPayClient.cjs +2 -0
  47. package/dist/client/SecrecyPayClient.cjs.map +1 -0
  48. package/dist/client/SecrecyPayClient.d.ts +16 -7
  49. package/dist/client/SecrecyPayClient.js +2 -37
  50. package/dist/client/SecrecyPayClient.js.map +1 -0
  51. package/dist/client/SecrecyWalletClient.cjs +2 -0
  52. package/dist/client/SecrecyWalletClient.cjs.map +1 -0
  53. package/dist/client/SecrecyWalletClient.d.ts +16 -30
  54. package/dist/client/SecrecyWalletClient.js +2 -76
  55. package/dist/client/SecrecyWalletClient.js.map +1 -0
  56. package/dist/client/convert/file.cjs +2 -0
  57. package/dist/client/convert/file.cjs.map +1 -0
  58. package/dist/client/convert/file.d.ts +11 -5
  59. package/dist/client/convert/file.js +2 -34
  60. package/dist/client/convert/file.js.map +1 -0
  61. package/dist/client/convert/mail.cjs +2 -0
  62. package/dist/client/convert/mail.cjs.map +1 -0
  63. package/dist/client/convert/mail.d.ts +13 -3
  64. package/dist/client/convert/mail.js +2 -48
  65. package/dist/client/convert/mail.js.map +1 -0
  66. package/dist/client/convert/node.cjs +2 -0
  67. package/dist/client/convert/node.cjs.map +1 -0
  68. package/dist/client/convert/node.d.ts +18 -9
  69. package/dist/client/convert/node.js +2 -100
  70. package/dist/client/convert/node.js.map +1 -0
  71. package/dist/client/helpers.cjs +2 -0
  72. package/dist/client/helpers.cjs.map +1 -0
  73. package/dist/client/helpers.d.ts +16 -28
  74. package/dist/client/helpers.js +2 -126
  75. package/dist/client/helpers.js.map +1 -0
  76. package/dist/client/index.cjs +2 -0
  77. package/dist/client/index.cjs.map +1 -0
  78. package/dist/client/index.d.ts +16 -34
  79. package/dist/client/index.js +2 -52
  80. package/dist/client/index.js.map +1 -0
  81. package/dist/client/storage.cjs +2 -0
  82. package/dist/client/storage.cjs.map +1 -0
  83. package/dist/client/storage.d.ts +6 -3
  84. package/dist/client/storage.js +2 -12
  85. package/dist/client/storage.js.map +1 -0
  86. package/dist/client/types/File.cjs +1 -0
  87. package/dist/client/types/File.cjs.map +1 -0
  88. package/dist/client/types/File.d.ts +9 -5
  89. package/dist/client/types/File.js +1 -3
  90. package/dist/client/types/File.js.map +1 -0
  91. package/dist/client/types/Inputs.cjs +1 -0
  92. package/dist/client/types/Inputs.cjs.map +1 -0
  93. package/dist/client/types/Inputs.d.ts +6 -4
  94. package/dist/client/types/Inputs.js +1 -3
  95. package/dist/client/types/Inputs.js.map +1 -0
  96. package/dist/client/types/Node.cjs +1 -0
  97. package/dist/client/types/Node.cjs.map +1 -0
  98. package/dist/client/types/Node.d.ts +9 -56
  99. package/dist/client/types/Node.js +1 -3
  100. package/dist/client/types/Node.js.map +1 -0
  101. package/dist/client/types/UserAppNotifications.cjs +1 -0
  102. package/dist/client/types/UserAppNotifications.cjs.map +1 -0
  103. package/dist/client/types/UserAppNotifications.d.ts +3 -1
  104. package/dist/client/types/UserAppNotifications.js +1 -3
  105. package/dist/client/types/UserAppNotifications.js.map +1 -0
  106. package/dist/client/types/UserAppSettings.cjs +1 -0
  107. package/dist/client/types/UserAppSettings.cjs.map +1 -0
  108. package/dist/client/types/UserAppSettings.d.ts +3 -1
  109. package/dist/client/types/UserAppSettings.js +1 -3
  110. package/dist/client/types/UserAppSettings.js.map +1 -0
  111. package/dist/client/types/index.cjs +2 -0
  112. package/dist/client/types/index.cjs.map +1 -0
  113. package/dist/client/types/index.d.ts +86 -30
  114. package/dist/client/types/index.js +2 -8
  115. package/dist/client/types/index.js.map +1 -0
  116. package/dist/client/types/selectors.cjs +2 -0
  117. package/dist/client/types/selectors.cjs.map +1 -0
  118. package/dist/client/types/selectors.d.ts +7 -5
  119. package/dist/client/types/selectors.js +2 -138
  120. package/dist/client/types/selectors.js.map +1 -0
  121. package/dist/crypto/file.cjs +2 -0
  122. package/dist/crypto/file.cjs.map +1 -0
  123. package/dist/crypto/file.d.ts +8 -6
  124. package/dist/crypto/file.js +2 -210
  125. package/dist/crypto/file.js.map +1 -0
  126. package/dist/crypto/index.cjs +2 -0
  127. package/dist/crypto/index.cjs.map +1 -0
  128. package/dist/crypto/index.d.ts +11 -9
  129. package/dist/crypto/index.js +2 -47
  130. package/dist/crypto/index.js.map +1 -0
  131. package/dist/error.cjs +1 -0
  132. package/dist/error.cjs.map +1 -0
  133. package/dist/error.d.ts +12 -10
  134. package/dist/error.js +1 -3
  135. package/dist/error.js.map +1 -0
  136. package/dist/index.cjs +2 -0
  137. package/dist/index.cjs.map +1 -0
  138. package/dist/index.d.ts +19 -11
  139. package/dist/index.js +2 -9
  140. package/dist/index.js.map +1 -0
  141. package/dist/minify/index.cjs +2 -0
  142. package/dist/minify/index.cjs.map +1 -0
  143. package/dist/minify/index.d.ts +4 -2
  144. package/dist/minify/index.js +2 -28
  145. package/dist/minify/index.js.map +1 -0
  146. package/dist/minify/lz4.cjs +3 -0
  147. package/dist/minify/lz4.cjs.map +1 -0
  148. package/dist/minify/lz4.d.ts +7 -5
  149. package/dist/minify/lz4.js +3 -627
  150. package/dist/minify/lz4.js.map +1 -0
  151. package/dist/sodium.cjs +2 -0
  152. package/dist/sodium.cjs.map +1 -0
  153. package/dist/sodium.d.ts +5 -3
  154. package/dist/sodium.js +2 -6
  155. package/dist/sodium.js.map +1 -0
  156. package/dist/utils/store-buddy.cjs +2 -0
  157. package/dist/utils/store-buddy.cjs.map +1 -0
  158. package/dist/utils/store-buddy.d.ts +4 -3
  159. package/dist/utils/store-buddy.js +2 -65
  160. package/dist/utils/store-buddy.js.map +1 -0
  161. package/dist/utils/time.cjs +2 -0
  162. package/dist/utils/time.cjs.map +1 -0
  163. package/dist/utils/time.d.ts +4 -2
  164. package/dist/utils/time.js +2 -14
  165. package/dist/utils/time.js.map +1 -0
  166. package/dist/utils/utils.cjs +2 -0
  167. package/dist/utils/utils.cjs.map +1 -0
  168. package/dist/utils/utils.d.ts +6 -4
  169. package/dist/utils/utils.js +2 -57
  170. package/dist/utils/utils.js.map +1 -0
  171. package/dist/worker/md5.cjs +2 -0
  172. package/dist/worker/md5.cjs.map +1 -0
  173. package/dist/worker/md5.d.ts +3 -1
  174. package/dist/worker/md5.js +2 -25
  175. package/dist/worker/md5.js.map +1 -0
  176. package/dist/worker/sodium.cjs +2 -0
  177. package/dist/worker/sodium.cjs.map +1 -0
  178. package/dist/worker/sodium.d.ts +6 -3
  179. package/dist/worker/sodium.js +2 -120
  180. package/dist/worker/sodium.js.map +1 -0
  181. package/dist/worker/workerCodes.cjs +254 -0
  182. package/dist/worker/workerCodes.cjs.map +1 -0
  183. package/dist/worker/workerCodes.d.ts +4 -2
  184. package/dist/worker/workerCodes.js +4 -5
  185. package/dist/worker/workerCodes.js.map +1 -0
  186. package/dist/zeus/const.cjs +2 -0
  187. package/dist/zeus/const.cjs.map +1 -0
  188. package/dist/zeus/const.d.ts +5 -3
  189. package/dist/zeus/const.js +2 -1286
  190. package/dist/zeus/const.js.map +1 -0
  191. package/dist/zeus/index.cjs +5 -0
  192. package/dist/zeus/index.cjs.map +1 -0
  193. package/dist/zeus/index.d.ts +80 -78
  194. package/dist/zeus/index.js +5 -687
  195. package/dist/zeus/index.js.map +1 -0
  196. package/package.json +27 -30
@@ -1,627 +1,3 @@
1
- // lz4-ts @license BSD-3-Clause / Copyright (c) 2015, Pierre Curto / 2016, oov. All rights reserved.
2
-
3
- /**
4
- * Copyright (c) 2015, Pierre Curto
5
- * Copyright (c) 2016, oov
6
- * All rights reserved.
7
- *
8
- * Redistribution and use in source and binary forms, with or without
9
- * modification, are permitted provided that the following conditions are met:
10
- *
11
- * * Redistributions of source code must retain the above copyright notice, this
12
- * list of conditions and the following disclaimer.
13
- *
14
- * * Redistributions in binary form must reproduce the above copyright notice,
15
- * this list of conditions and the following disclaimer in the documentation
16
- * and/or other materials provided with the distribution.
17
- *
18
- * * Neither the name of xxHash nor the names of its
19
- * contributors may be used to endorse or promote products derived from
20
- * this software without specific prior written permission.
21
- *
22
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
23
- * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
25
- * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
26
- * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
27
- * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
28
- * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29
- * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
30
- * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32
- */
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
-
36
- const minMatch = 4; // the minimum size of the match sequence size (4 bytes)
37
-
38
- const winSizeLog = 16; // LZ4 64Kb window size limit
39
-
40
- const winSize = 1 << winSizeLog;
41
- const winMask = winSize - 1; // 64Kb window of previous data for dependent blocks
42
- // hashSizeLog determines the size of the hash table used to quickly find a previous match position.
43
- // Its value influences the compression speed and memory usage, the lower the faster,
44
- // but at the expense of the compression ratio.
45
- // 16 seems to be the best compromise.
46
-
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
-
52
- const skipStrength = 6; // variable step for fast scan
53
-
54
- const hasher = 2654435761 | 0; // prime number used to hash minMatch
55
- // https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Math/imul#Polyfill
56
-
57
- function imulPolyfill(a, b) {
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
- // the final |0 converts the unsigned value into a signed value
63
-
64
- return al * bl + (ah * bl + al * bh << 16 >>> 0) | 0;
65
- }
66
-
67
- const imul = Math.imul ? Math.imul : imulPolyfill;
68
-
69
- function getUint32(a, i) {
70
- return a[i + 3] | a[i + 2] << 8 | a[i + 1] << 16 | a[i] << 24;
71
- }
72
-
73
- function copy(dest, src, di, si, len) {
74
- for (let i = 0; i < len; ++i) {
75
- dest[di++] = src[si++];
76
- }
77
- }
78
-
79
- export function calcUncompressedLen(src) {
80
- const sn = src.length;
81
-
82
- if (sn === 0) {
83
- return 0;
84
- }
85
-
86
- let si = 0;
87
- let di = 0;
88
-
89
- while (true) {
90
- // literals and match lengths (token)
91
- let lLen = src[si] >> 4;
92
- let mLen = src[si] & 0xf;
93
-
94
- if (++si === sn) {
95
- throw errInvalidSource;
96
- } // literals
97
-
98
-
99
- if (lLen > 0) {
100
- if (lLen === 0xf) {
101
- while (src[si] === 0xff) {
102
- lLen += 0xff;
103
-
104
- if (++si === sn) {
105
- throw errInvalidSource;
106
- }
107
- }
108
-
109
- lLen += src[si];
110
-
111
- if (++si === sn) {
112
- throw errInvalidSource;
113
- }
114
- }
115
-
116
- di += lLen;
117
- si += lLen;
118
-
119
- if (si >= sn) {
120
- return di;
121
- }
122
- }
123
-
124
- si += 2;
125
-
126
- if (si >= sn) {
127
- throw errInvalidSource;
128
- }
129
-
130
- const offset = src[si - 2] | src[si - 1] << 8;
131
-
132
- if (di - offset < 0 || offset === 0) {
133
- throw errInvalidSource;
134
- } // match
135
-
136
-
137
- if (mLen === 0xf) {
138
- while (src[si] === 0xff) {
139
- mLen += 0xff;
140
-
141
- if (++si === sn) {
142
- throw errInvalidSource;
143
- }
144
- }
145
-
146
- mLen += src[si];
147
-
148
- if (++si === sn) {
149
- throw errInvalidSource;
150
- }
151
- } // minimum match length is 4
152
-
153
-
154
- mLen += 4; // copy the match (NB. match is at least 4 bytes long)
155
-
156
- for (; mLen >= offset; mLen -= offset) {
157
- di += offset;
158
- }
159
-
160
- di += mLen;
161
- }
162
- }
163
- export function uncompressBlock(src, dest) {
164
- const sn = src.length;
165
- const dn = dest.length;
166
-
167
- if (sn === 0) {
168
- return 0;
169
- }
170
-
171
- let si = 0;
172
- let di = 0;
173
-
174
- while (true) {
175
- // literals and match lengths (token)
176
- let lLen = src[si] >> 4;
177
- let mLen = src[si] & 0xf;
178
-
179
- if (++si === sn) {
180
- throw errInvalidSource;
181
- } // literals
182
-
183
-
184
- if (lLen > 0) {
185
- if (lLen === 0xf) {
186
- while (src[si] === 0xff) {
187
- lLen += 0xff;
188
-
189
- if (++si === sn) {
190
- throw errInvalidSource;
191
- }
192
- }
193
-
194
- lLen += src[si];
195
-
196
- if (++si === sn) {
197
- throw errInvalidSource;
198
- }
199
- }
200
-
201
- if (dn - di < lLen || si + lLen > sn) {
202
- throw errShortBuffer;
203
- }
204
-
205
- copy(dest, src, di, si, lLen);
206
- di += lLen;
207
- si += lLen;
208
-
209
- if (si >= sn) {
210
- return di;
211
- }
212
- }
213
-
214
- si += 2;
215
-
216
- if (si >= sn) {
217
- throw errInvalidSource;
218
- }
219
-
220
- const offset = src[si - 2] | src[si - 1] << 8;
221
-
222
- if (di - offset < 0 || offset === 0) {
223
- throw errInvalidSource;
224
- } // match
225
-
226
-
227
- if (mLen === 0xf) {
228
- while (src[si] === 0xff) {
229
- mLen += 0xff;
230
-
231
- if (++si === sn) {
232
- throw errInvalidSource;
233
- }
234
- }
235
-
236
- mLen += src[si];
237
-
238
- if (++si === sn) {
239
- throw errInvalidSource;
240
- }
241
- } // minimum match length is 4
242
-
243
-
244
- mLen += 4;
245
-
246
- if (dn - di <= mLen) {
247
- throw errShortBuffer;
248
- } // copy the match (NB. match is at least 4 bytes long)
249
-
250
-
251
- for (; mLen >= offset; mLen -= offset) {
252
- copy(dest, dest, di, di - offset, offset);
253
- di += offset;
254
- }
255
-
256
- copy(dest, dest, di, di - offset, mLen);
257
- di += mLen;
258
- }
259
- }
260
- export function compressBlockBound(n) {
261
- return n + (n / 255 | 0) + 16;
262
- }
263
- export function compressBlock(src, dest, soffset) {
264
- const sn = src.length - mfLimit;
265
- const dn = dest.length;
266
-
267
- if (sn <= 0 || dn === 0 || soffset >= sn) {
268
- return 0;
269
- }
270
-
271
- let si = 0,
272
- di = 0; // fast scan strategy:
273
- // we only need a hash table to store the last sequences (4 bytes)
274
-
275
- const hashTable = new Uint32Array(hashSize); // Initialise the hash table with the first 64Kb of the input buffer
276
- // (used when compressing dependent blocks)
277
-
278
- while (si < soffset) {
279
- const h = imul(getUint32(src, si), hasher) >>> hashShift;
280
- hashTable[h] = ++si;
281
- }
282
-
283
- let anchor = si;
284
- let fma = 1 << skipStrength;
285
-
286
- while (si < sn - minMatch) {
287
- // hash the next 4 bytes (sequence)...
288
- const h = imul(getUint32(src, si), hasher) >>> hashShift; // -1 to separate existing entries from new ones
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)
291
-
292
- hashTable[h] = si + 1; // no need to check the last 3 bytes in the first literal 4 bytes as
293
- // this guarantees that the next match, if any, is compressed with
294
- // a lower size, since to have some compression we must have:
295
- // ll+ml-overlap > 1 + (ll-15)/255 + (ml-4-15)/255 + 2 (uncompressed size>compressed size)
296
- // => ll+ml>3+2*overlap => ll+ml>= 4+2*overlap
297
- // and by definition we do have:
298
- // ll >= 1, ml >= 4
299
- // => ll+ml >= 5
300
- // => so overlap must be 0
301
- // the sequence is new, out of bound (64kb) or not valid: try next sequence
302
-
303
- if (ref < 0 || //(fma & ((1 << skipStrength) - 1)) < 4 || // this code seems has a big penalty for size...
304
- si - ref >> winSizeLog > 0 || src[ref] !== src[si] || src[ref + 1] !== src[si + 1] || src[ref + 2] !== src[si + 2] || src[ref + 3] !== src[si + 3]) {
305
- // variable step: improves performance on non-compressible data
306
- si += fma >> skipStrength;
307
- ++fma;
308
- continue;
309
- } // match found
310
-
311
-
312
- fma = 1 << skipStrength;
313
- const lLen = si - anchor;
314
- const offset = si - ref; // encode match length part 1
315
-
316
- si += minMatch;
317
- let mLen = si; // match length has minMatch already
318
-
319
- while (si <= sn && src[si] === src[si - offset]) {
320
- si++;
321
- }
322
-
323
- mLen = si - mLen;
324
-
325
- if (mLen < 0xf) {
326
- dest[di] = mLen;
327
- } else {
328
- dest[di] = 0xf;
329
- } // encode literals length
330
-
331
-
332
- if (lLen < 0xf) {
333
- dest[di] |= lLen << 4;
334
- } else {
335
- dest[di] |= 0xf0;
336
-
337
- if (++di === dn) {
338
- throw errShortBuffer;
339
- }
340
-
341
- let l = lLen - 0xf;
342
-
343
- for (; l >= 0xff; l -= 0xff) {
344
- dest[di] = 0xff;
345
-
346
- if (++di === dn) {
347
- throw errShortBuffer;
348
- }
349
- }
350
-
351
- dest[di] = l & 0xff;
352
- }
353
-
354
- if (++di === dn) {
355
- throw errShortBuffer;
356
- } // literals
357
-
358
-
359
- if (di + lLen >= dn) {
360
- throw errShortBuffer;
361
- }
362
-
363
- copy(dest, src, di, anchor, lLen);
364
- di += lLen;
365
- anchor = si; // encode offset
366
-
367
- di += 2;
368
-
369
- if (di >= dn) {
370
- throw errShortBuffer;
371
- }
372
-
373
- dest[di - 2] = offset;
374
- dest[di - 1] = offset >> 8; // encode match length part 2
375
-
376
- if (mLen >= 0xf) {
377
- for (mLen -= 0xf; mLen >= 0xff; mLen -= 0xff) {
378
- dest[di] = 0xff;
379
-
380
- if (++di === dn) {
381
- throw errShortBuffer;
382
- }
383
- }
384
-
385
- dest[di] = mLen;
386
-
387
- if (++di === dn) {
388
- throw errShortBuffer;
389
- }
390
- }
391
- }
392
-
393
- if (anchor === 0) {
394
- // incompressible
395
- return 0;
396
- } // last literals
397
-
398
-
399
- let lLen = src.length - anchor;
400
-
401
- if (lLen < 0xf) {
402
- dest[di] = lLen << 4;
403
- } else {
404
- dest[di] = 0xf0;
405
-
406
- if (++di === dn) {
407
- throw errShortBuffer;
408
- }
409
-
410
- for (lLen -= 0xf; lLen >= 0xff; lLen -= 0xff) {
411
- dest[di] = 0xff;
412
-
413
- if (++di === dn) {
414
- throw errShortBuffer;
415
- }
416
- }
417
-
418
- dest[di] = lLen;
419
- }
420
-
421
- if (++di === dn) {
422
- throw errShortBuffer;
423
- } // write literals
424
-
425
-
426
- const lastLen = src.length - anchor;
427
- const n = di + lastLen;
428
-
429
- if (n > dn) {
430
- throw errShortBuffer;
431
- } else if (n >= sn) {
432
- // incompressible
433
- return 0;
434
- }
435
-
436
- copy(dest, src, di, anchor, lastLen);
437
- di += lastLen;
438
- return di;
439
- }
440
- export function compressBlockHC(src, dest, soffset) {
441
- const sn = src.length - mfLimit;
442
- const dn = dest.length;
443
-
444
- if (sn <= 0 || dn === 0 || soffset >= sn) {
445
- return 0;
446
- }
447
-
448
- let si = 0;
449
- let di = 0; // Hash Chain strategy:
450
- // we need a hash table and a chain table
451
- // the chain table cannot contain more entries than the window size (64Kb entries)
452
-
453
- const hashTable = new Uint32Array(hashSize);
454
- const chainTable = new Uint32Array(winSize); // Initialise the hash table with the first 64Kb of the input buffer
455
- // (used when compressing dependent blocks)
456
-
457
- while (si < soffset) {
458
- const h = imul(getUint32(src, si), hasher) >>> hashShift;
459
- chainTable[si & winMask] = hashTable[h];
460
- hashTable[h] = ++si;
461
- }
462
-
463
- let anchor = si;
464
-
465
- while (si < sn - minMatch) {
466
- // hash the next 4 bytes (sequence)...
467
- const h = imul(getUint32(src, si), hasher) >>> hashShift; // follow the chain until out of window and give the longest match
468
-
469
- let mLen = 0;
470
- let offset = 0;
471
-
472
- for (let next = hashTable[h] - 1; next > 0 && next > si - winSize; next = chainTable[next & winMask] - 1) {
473
- // the first (mLen==0) or next byte (mLen>=minMatch) at current match length must match to improve on the match length
474
- if (src[next + mLen] === src[si + mLen]) {
475
- for (let ml = 0;; ++ml) {
476
- if (src[next + ml] !== src[si + ml] || si + ml > sn) {
477
- // found a longer match, keep its position and length
478
- if (mLen < ml && ml >= minMatch) {
479
- mLen = ml;
480
- offset = si - next;
481
- }
482
-
483
- break;
484
- }
485
- }
486
- }
487
- }
488
-
489
- chainTable[si & winMask] = hashTable[h];
490
- hashTable[h] = si + 1; // no match found
491
-
492
- if (mLen === 0) {
493
- ++si;
494
- continue;
495
- }
496
-
497
- let si2 = si + 1;
498
- const ml = si + mLen; // match found
499
- // update hash/chain tables with overlaping bytes:
500
- // si already hashed, add everything from si+1 up to the match length
501
-
502
- while (si2 < ml) {
503
- const h = imul(getUint32(src, si2), hasher) >>> hashShift;
504
- chainTable[si2 & winMask] = hashTable[h];
505
- hashTable[h] = ++si2;
506
- }
507
-
508
- const lLen = si - anchor;
509
- si += mLen;
510
- mLen -= minMatch; // match length does not include minMatch
511
-
512
- if (mLen < 0xf) {
513
- dest[di] = mLen;
514
- } else {
515
- dest[di] = 0xf;
516
- } // encode literals length
517
-
518
-
519
- if (lLen < 0xf) {
520
- dest[di] |= lLen << 4;
521
- } else {
522
- dest[di] |= 0xf0;
523
-
524
- if (++di === dn) {
525
- throw errShortBuffer;
526
- }
527
-
528
- let l = lLen - 0xf;
529
-
530
- for (; l >= 0xff; l -= 0xff) {
531
- dest[di] = 0xff;
532
-
533
- if (++di === dn) {
534
- throw errShortBuffer;
535
- }
536
- }
537
-
538
- dest[di] = l & 0xff;
539
- }
540
-
541
- if (++di === dn) {
542
- throw errShortBuffer;
543
- } // literals
544
-
545
-
546
- if (di + lLen >= dn) {
547
- throw errShortBuffer;
548
- }
549
-
550
- copy(dest, src, di, anchor, lLen);
551
- di += lLen;
552
- anchor = si; // encode offset
553
-
554
- di += 2;
555
-
556
- if (di >= dn) {
557
- throw errShortBuffer;
558
- }
559
-
560
- dest[di - 2] = offset;
561
- dest[di - 1] = offset >> 8; // encode match length part 2
562
-
563
- if (mLen >= 0xf) {
564
- for (mLen -= 0xf; mLen >= 0xff; mLen -= 0xff) {
565
- dest[di] = 0xff;
566
-
567
- if (++di === dn) {
568
- throw errShortBuffer;
569
- }
570
- }
571
-
572
- dest[di] = mLen;
573
-
574
- if (++di === dn) {
575
- throw errShortBuffer;
576
- }
577
- }
578
- }
579
-
580
- if (anchor === 0) {
581
- // incompressible
582
- return 0;
583
- } // last literals
584
-
585
-
586
- let lLen = src.length - anchor;
587
-
588
- if (lLen < 0xf) {
589
- dest[di] = lLen << 4;
590
- } else {
591
- dest[di] = 0xf0;
592
-
593
- if (++di === dn) {
594
- throw errShortBuffer;
595
- }
596
-
597
- for (lLen -= 0xf; lLen >= 0xff; lLen -= 0xff) {
598
- dest[di] = 0xff;
599
-
600
- if (++di === dn) {
601
- throw errShortBuffer;
602
- }
603
- }
604
-
605
- dest[di] = lLen;
606
- }
607
-
608
- if (++di === dn) {
609
- throw errShortBuffer;
610
- } // write literals
611
-
612
-
613
- const lastLen = src.length - anchor;
614
- const n = di + lastLen;
615
-
616
- if (n > dn) {
617
- throw errShortBuffer;
618
- } else if (n >= sn) {
619
- // incompressible
620
- return 0;
621
- }
622
-
623
- copy(dest, src, di, anchor, lastLen);
624
- di += lastLen;
625
- return di;
626
- }
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":"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"}
1
+ import"../chunk-KMTF2BZE.js";// lz4-ts @license BSD-3-Clause / Copyright (c) 2015, Pierre Curto / 2016, oov. All rights reserved.
2
+ const m=new Error("invalid source"),h=new Error("short buffer"),S=4,H=16,s=1<<H,E=s-1,I=16,P=1<<I,z=S*8-I,j=8+S,C=6,M=-1640531535;function q(t,i){const e=t>>>16&65535,r=t&65535,o=i>>>16&65535,n=i&65535;return r*n+(e*n+r*o<<16>>>0)|0}const v=Math.imul?Math.imul:q;function T(t,i){return t[i+3]|t[i+2]<<8|t[i+1]<<16|t[i]<<24}function k(t,i,e,r,o){for(let n=0;n<o;++n)t[e++]=i[r++]}function D(t){const i=t.length;if(i===0)return 0;let e=0,r=0;for(;;){let o=t[e]>>4,n=t[e]&15;if(++e===i)throw m;if(o>0){if(o===15){for(;t[e]===255;)if(o+=255,++e===i)throw m;if(o+=t[e],++e===i)throw m}if(r+=o,e+=o,e>=i)return r}if(e+=2,e>=i)throw m;const f=t[e-2]|t[e-1]<<8;if(r-f<0||f===0)throw m;if(n===15){for(;t[e]===255;)if(n+=255,++e===i)throw m;if(n+=t[e],++e===i)throw m}for(n+=4;n>=f;n-=f)r+=f;r+=n}}function F(t,i){const e=t.length,r=i.length;if(e===0)return 0;let o=0,n=0;for(;;){let f=t[o]>>4,x=t[o]&15;if(++o===e)throw m;if(f>0){if(f===15){for(;t[o]===255;)if(f+=255,++o===e)throw m;if(f+=t[o],++o===e)throw m}if(r-n<f||o+f>e)throw h;if(k(i,t,n,o,f),n+=f,o+=f,o>=e)return n}if(o+=2,o>=e)throw m;const w=t[o-2]|t[o-1]<<8;if(n-w<0||w===0)throw m;if(x===15){for(;t[o]===255;)if(x+=255,++o===e)throw m;if(x+=t[o],++o===e)throw m}if(x+=4,r-n<=x)throw h;for(;x>=w;x-=w)k(i,i,n,n-w,w),n+=w;k(i,i,n,n-w,x),n+=x}}function G(t){return t+(t/255|0)+16}function J(t,i,e){const r=t.length-j,o=i.length;if(r<=0||o===0||e>=r)return 0;let n=0,f=0;const x=new Uint32Array(P);for(;n<e;){const b=v(T(t,n),M)>>>z;x[b]=++n}let w=n,c=1<<C;for(;n<r-S;){const b=v(T(t,n),M)>>>z,l=x[b]-1;if(x[b]=n+1,l<0||n-l>>H>0||t[l]!==t[n]||t[l+1]!==t[n+1]||t[l+2]!==t[n+2]||t[l+3]!==t[n+3]){n+=c>>C,++c;continue}c=1<<C;const g=n-w,U=n-l;n+=S;let L=n;for(;n<=r&&t[n]===t[n-U];)n++;if(L=n-L,L<15?i[f]=L:i[f]=15,g<15)i[f]|=g<<4;else{if(i[f]|=240,++f===o)throw h;let y=g-15;for(;y>=255;y-=255)if(i[f]=255,++f===o)throw h;i[f]=y&255}if(++f===o||f+g>=o||(k(i,t,f,w,g),f+=g,w=n,f+=2,f>=o))throw h;if(i[f-2]=U,i[f-1]=U>>8,L>=15){for(L-=15;L>=255;L-=255)if(i[f]=255,++f===o)throw h;if(i[f]=L,++f===o)throw h}}if(w===0)return 0;let a=t.length-w;if(a<15)i[f]=a<<4;else{if(i[f]=240,++f===o)throw h;for(a-=15;a>=255;a-=255)if(i[f]=255,++f===o)throw h;i[f]=a}if(++f===o)throw h;const A=t.length-w,B=f+A;if(B>o)throw h;return B>=r?0:(k(i,t,f,w,A),f+=A,f)}function K(t,i,e){const r=t.length-j,o=i.length;if(r<=0||o===0||e>=r)return 0;let n=0,f=0;const x=new Uint32Array(P),w=new Uint32Array(s);for(;n<e;){const b=v(T(t,n),M)>>>z;w[n&E]=x[b],x[b]=++n}let c=n;for(;n<r-S;){const b=v(T(t,n),M)>>>z;let l=0,g=0;for(let u=x[b]-1;u>0&&u>n-s;u=w[u&E]-1)if(t[u+l]===t[n+l]){for(let p=0;;++p)if(t[u+p]!==t[n+p]||n+p>r){l<p&&p>=S&&(l=p,g=n-u);break}}if(w[n&E]=x[b],x[b]=n+1,l===0){++n;continue}let U=n+1;const L=n+l;for(;U<L;){const u=v(T(t,U),M)>>>z;w[U&E]=x[u],x[u]=++U}const y=n-c;if(n+=l,l-=S,l<15?i[f]=l:i[f]=15,y<15)i[f]|=y<<4;else{if(i[f]|=240,++f===o)throw h;let u=y-15;for(;u>=255;u-=255)if(i[f]=255,++f===o)throw h;i[f]=u&255}if(++f===o||f+y>=o||(k(i,t,f,c,y),f+=y,c=n,f+=2,f>=o))throw h;if(i[f-2]=g,i[f-1]=g>>8,l>=15){for(l-=15;l>=255;l-=255)if(i[f]=255,++f===o)throw h;if(i[f]=l,++f===o)throw h}}if(c===0)return 0;let a=t.length-c;if(a<15)i[f]=a<<4;else{if(i[f]=240,++f===o)throw h;for(a-=15;a>=255;a-=255)if(i[f]=255,++f===o)throw h;i[f]=a}if(++f===o)throw h;const A=t.length-c,B=f+A;if(B>o)throw h;return B>=r?0:(k(i,t,f,c,A),f+=A,f)}export{D as calcUncompressedLen,J as compressBlock,G as compressBlockBound,K as compressBlockHC,F as uncompressBlock};
3
+ //# sourceMappingURL=lz4.js.map