@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.
Files changed (63) hide show
  1. package/dist/BaseClient.d.ts +33 -53
  2. package/dist/BaseClient.js +886 -2093
  3. package/dist/PopupTools.js +20 -21
  4. package/dist/ZeusThunder.js +50 -84
  5. package/dist/cache.d.ts +2 -3
  6. package/dist/cache.js +4 -5
  7. package/dist/client/admin/index.js +77 -165
  8. package/dist/client/convert/file.d.ts +3 -3
  9. package/dist/client/convert/file.js +18 -23
  10. package/dist/client/convert/mail.js +13 -13
  11. package/dist/client/convert/node.d.ts +9 -0
  12. package/dist/client/convert/node.js +101 -0
  13. package/dist/client/helpers.js +41 -41
  14. package/dist/client/index.d.ts +63 -74
  15. package/dist/client/index.js +2727 -5759
  16. package/dist/client/storage.js +7 -7
  17. package/dist/client/types/File.d.ts +6 -13
  18. package/dist/client/types/File.js +1 -1
  19. package/dist/client/types/Inputs.d.ts +2 -7
  20. package/dist/client/types/Inputs.js +1 -1
  21. package/dist/client/types/Node.d.ts +49 -0
  22. package/dist/client/types/Node.js +3 -0
  23. package/dist/client/types/UserAppNotifications.d.ts +1 -1
  24. package/dist/client/types/UserAppNotifications.js +1 -1
  25. package/dist/client/types/UserAppSettings.js +1 -1
  26. package/dist/client/types/index.d.ts +7 -13
  27. package/dist/client/types/index.js +2 -4
  28. package/dist/client/types/selectors.d.ts +476 -0
  29. package/dist/client/types/selectors.js +125 -0
  30. package/dist/crypto/file.js +122 -203
  31. package/dist/crypto/index.js +14 -12
  32. package/dist/error.js +1 -1
  33. package/dist/index.d.ts +1 -2
  34. package/dist/index.js +2 -34
  35. package/dist/minify/index.js +7 -7
  36. package/dist/minify/lz4.js +87 -93
  37. package/dist/sodium.js +3 -25
  38. package/dist/utils/store-buddy.js +11 -15
  39. package/dist/utils/time.js +4 -12
  40. package/dist/{utils.d.ts → utils/utils.d.ts} +0 -0
  41. package/dist/utils/utils.js +57 -0
  42. package/dist/worker/__mock__/sodium.worker.js +35 -32
  43. package/dist/worker/md5.js +21 -39
  44. package/dist/worker/sodium.js +95 -130
  45. package/dist/worker/workerCodes.js +3 -3
  46. package/dist/zeus/const.d.ts +5 -0
  47. package/dist/zeus/const.js +303 -1360
  48. package/dist/zeus/index.d.ts +1805 -1817
  49. package/dist/zeus/index.js +542 -434
  50. package/package.json +40 -39
  51. package/dist/client/convert/folder.d.ts +0 -8
  52. package/dist/client/convert/folder.js +0 -264
  53. package/dist/client/convert/vFile.d.ts +0 -5
  54. package/dist/client/convert/vFile.js +0 -164
  55. package/dist/client/types/FilesOnUsersOnApplications.d.ts +0 -9
  56. package/dist/client/types/FilesOnUsersOnApplications.js +0 -3
  57. package/dist/client/types/Folder.d.ts +0 -68
  58. package/dist/client/types/Folder.js +0 -7
  59. package/dist/client/types/VFile.d.ts +0 -62
  60. package/dist/client/types/VFile.js +0 -4
  61. package/dist/client/types/queries.d.ts +0 -535
  62. package/dist/client/types/queries.js +0 -192
  63. package/dist/utils.js +0 -188
@@ -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
- var compressed = new Uint8Array(compressBlockBound(data.byteLength));
9
- var compressedSize = compressBlockHC(data, compressed, 0);
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
- var realData = data.slice(1);
18
+ const realData = data.slice(1);
19
19
 
20
20
  if (data[0] === 0) {
21
21
  return realData;
22
22
  }
23
23
 
24
- var dst = new Uint8Array(calcUncompressedLen(realData));
25
- var uncompressedSize = uncompressBlock(realData, dst);
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9taW5pZnkvaW5kZXgudHMiXSwibmFtZXMiOlsiY2FsY1VuY29tcHJlc3NlZExlbiIsImNvbXByZXNzQmxvY2tCb3VuZCIsImNvbXByZXNzQmxvY2tIQyIsInVuY29tcHJlc3NCbG9jayIsImNvbmNhdGVuYXRlIiwiY29tcHJlc3MiLCJkYXRhIiwiYnl0ZUxlbmd0aCIsIlVpbnQ4QXJyYXkiLCJjb21wcmVzc2VkIiwiY29tcHJlc3NlZFNpemUiLCJzbGljZSIsInVuY29tcHJlc3MiLCJyZWFsRGF0YSIsImRzdCIsInVuY29tcHJlc3NlZFNpemUiXSwibWFwcGluZ3MiOiJBQUFBLFNBQ0VBLG1CQURGLEVBRUVDLGtCQUZGLEVBR0VDLGVBSEYsRUFJRUMsZUFKRixRQUtPLFVBTFA7QUFNQSxTQUFTQyxXQUFULFFBQTRCLGFBQTVCO0FBRUEsT0FBTyxTQUFTQyxRQUFULENBQWtCQyxJQUFsQixFQUFnRDtBQUNyRCxNQUFJQSxJQUFJLENBQUNDLFVBQUwsR0FBa0IsUUFBdEIsRUFBa0M7QUFDaEMsV0FBT0gsV0FBVyxDQUFDLElBQUlJLFVBQUosQ0FBZSxDQUFDLENBQUQsQ0FBZixDQUFELEVBQXNCRixJQUF0QixDQUFsQjtBQUNEOztBQUNELE1BQU1HLFVBQVUsR0FBRyxJQUFJRCxVQUFKLENBQWVQLGtCQUFrQixDQUFDSyxJQUFJLENBQUNDLFVBQU4sQ0FBakMsQ0FBbkI7QUFDQSxNQUFNRyxjQUFjLEdBQUdSLGVBQWUsQ0FBQ0ksSUFBRCxFQUFPRyxVQUFQLEVBQW1CLENBQW5CLENBQXRDOztBQUNBLE1BQUlDLGNBQWMsS0FBSyxDQUF2QixFQUEwQjtBQUN4QixXQUFPTixXQUFXLENBQUMsSUFBSUksVUFBSixDQUFlLENBQUMsQ0FBRCxDQUFmLENBQUQsRUFBc0JGLElBQXRCLENBQWxCO0FBQ0Q7O0FBQ0QsU0FBT0YsV0FBVyxDQUFDLElBQUlJLFVBQUosQ0FBZSxDQUFDLENBQUQsQ0FBZixDQUFELEVBQXNCQyxVQUFVLENBQUNFLEtBQVgsQ0FBaUIsQ0FBakIsRUFBb0JELGNBQXBCLENBQXRCLENBQWxCO0FBQ0Q7QUFFRCxPQUFPLFNBQVNFLFVBQVQsQ0FBb0JOLElBQXBCLEVBQWtEO0FBQ3ZELE1BQU1PLFFBQVEsR0FBR1AsSUFBSSxDQUFDSyxLQUFMLENBQVcsQ0FBWCxDQUFqQjs7QUFDQSxNQUFJTCxJQUFJLENBQUMsQ0FBRCxDQUFKLEtBQVksQ0FBaEIsRUFBbUI7QUFDakIsV0FBT08sUUFBUDtBQUNEOztBQUNELE1BQU1DLEdBQUcsR0FBRyxJQUFJTixVQUFKLENBQWVSLG1CQUFtQixDQUFDYSxRQUFELENBQWxDLENBQVo7QUFDQSxNQUFNRSxnQkFBZ0IsR0FBR1osZUFBZSxDQUFDVSxRQUFELEVBQVdDLEdBQVgsQ0FBeEM7QUFDQSxTQUFPQSxHQUFHLENBQUNILEtBQUosQ0FBVSxDQUFWLEVBQWFJLGdCQUFiLENBQVA7QUFDRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIGNhbGNVbmNvbXByZXNzZWRMZW4sXG4gIGNvbXByZXNzQmxvY2tCb3VuZCxcbiAgY29tcHJlc3NCbG9ja0hDLFxuICB1bmNvbXByZXNzQmxvY2tcbn0gZnJvbSBcIi4vbHo0LmpzXCI7XG5pbXBvcnQgeyBjb25jYXRlbmF0ZSB9IGZyb20gXCIuLi91dGlscy5qc1wiO1xuXG5leHBvcnQgZnVuY3Rpb24gY29tcHJlc3MoZGF0YTogVWludDhBcnJheSk6IFVpbnQ4QXJyYXkge1xuICBpZiAoZGF0YS5ieXRlTGVuZ3RoID4gMTVfMDAwXzAwMCkge1xuICAgIHJldHVybiBjb25jYXRlbmF0ZShuZXcgVWludDhBcnJheShbMF0pLCBkYXRhKTtcbiAgfVxuICBjb25zdCBjb21wcmVzc2VkID0gbmV3IFVpbnQ4QXJyYXkoY29tcHJlc3NCbG9ja0JvdW5kKGRhdGEuYnl0ZUxlbmd0aCkpO1xuICBjb25zdCBjb21wcmVzc2VkU2l6ZSA9IGNvbXByZXNzQmxvY2tIQyhkYXRhLCBjb21wcmVzc2VkLCAwKTtcbiAgaWYgKGNvbXByZXNzZWRTaXplID09PSAwKSB7XG4gICAgcmV0dXJuIGNvbmNhdGVuYXRlKG5ldyBVaW50OEFycmF5KFswXSksIGRhdGEpO1xuICB9XG4gIHJldHVybiBjb25jYXRlbmF0ZShuZXcgVWludDhBcnJheShbMV0pLCBjb21wcmVzc2VkLnNsaWNlKDAsIGNvbXByZXNzZWRTaXplKSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB1bmNvbXByZXNzKGRhdGE6IFVpbnQ4QXJyYXkpOiBVaW50OEFycmF5IHtcbiAgY29uc3QgcmVhbERhdGEgPSBkYXRhLnNsaWNlKDEpO1xuICBpZiAoZGF0YVswXSA9PT0gMCkge1xuICAgIHJldHVybiByZWFsRGF0YTtcbiAgfVxuICBjb25zdCBkc3QgPSBuZXcgVWludDhBcnJheShjYWxjVW5jb21wcmVzc2VkTGVuKHJlYWxEYXRhKSk7XG4gIGNvbnN0IHVuY29tcHJlc3NlZFNpemUgPSB1bmNvbXByZXNzQmxvY2socmVhbERhdGEsIGRzdCk7XG4gIHJldHVybiBkc3Quc2xpY2UoMCwgdW5jb21wcmVzc2VkU2l6ZSk7XG59XG4iXX0=
28
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjYWxjVW5jb21wcmVzc2VkTGVuIiwiY29tcHJlc3NCbG9ja0JvdW5kIiwiY29tcHJlc3NCbG9ja0hDIiwidW5jb21wcmVzc0Jsb2NrIiwiY29uY2F0ZW5hdGUiLCJjb21wcmVzcyIsImRhdGEiLCJieXRlTGVuZ3RoIiwiVWludDhBcnJheSIsImNvbXByZXNzZWQiLCJjb21wcmVzc2VkU2l6ZSIsInNsaWNlIiwidW5jb21wcmVzcyIsInJlYWxEYXRhIiwiZHN0IiwidW5jb21wcmVzc2VkU2l6ZSJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9taW5pZnkvaW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgY2FsY1VuY29tcHJlc3NlZExlbixcbiAgY29tcHJlc3NCbG9ja0JvdW5kLFxuICBjb21wcmVzc0Jsb2NrSEMsXG4gIHVuY29tcHJlc3NCbG9ja1xufSBmcm9tIFwiLi9sejQuanNcIjtcbmltcG9ydCB7IGNvbmNhdGVuYXRlIH0gZnJvbSBcIi4uL3V0aWxzL3V0aWxzLmpzXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBjb21wcmVzcyhkYXRhOiBVaW50OEFycmF5KTogVWludDhBcnJheSB7XG4gIGlmIChkYXRhLmJ5dGVMZW5ndGggPiAxNV8wMDBfMDAwKSB7XG4gICAgcmV0dXJuIGNvbmNhdGVuYXRlKG5ldyBVaW50OEFycmF5KFswXSksIGRhdGEpO1xuICB9XG4gIGNvbnN0IGNvbXByZXNzZWQgPSBuZXcgVWludDhBcnJheShjb21wcmVzc0Jsb2NrQm91bmQoZGF0YS5ieXRlTGVuZ3RoKSk7XG4gIGNvbnN0IGNvbXByZXNzZWRTaXplID0gY29tcHJlc3NCbG9ja0hDKGRhdGEsIGNvbXByZXNzZWQsIDApO1xuICBpZiAoY29tcHJlc3NlZFNpemUgPT09IDApIHtcbiAgICByZXR1cm4gY29uY2F0ZW5hdGUobmV3IFVpbnQ4QXJyYXkoWzBdKSwgZGF0YSk7XG4gIH1cbiAgcmV0dXJuIGNvbmNhdGVuYXRlKG5ldyBVaW50OEFycmF5KFsxXSksIGNvbXByZXNzZWQuc2xpY2UoMCwgY29tcHJlc3NlZFNpemUpKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHVuY29tcHJlc3MoZGF0YTogVWludDhBcnJheSk6IFVpbnQ4QXJyYXkge1xuICBjb25zdCByZWFsRGF0YSA9IGRhdGEuc2xpY2UoMSk7XG4gIGlmIChkYXRhWzBdID09PSAwKSB7XG4gICAgcmV0dXJuIHJlYWxEYXRhO1xuICB9XG4gIGNvbnN0IGRzdCA9IG5ldyBVaW50OEFycmF5KGNhbGNVbmNvbXByZXNzZWRMZW4ocmVhbERhdGEpKTtcbiAgY29uc3QgdW5jb21wcmVzc2VkU2l6ZSA9IHVuY29tcHJlc3NCbG9jayhyZWFsRGF0YSwgZHN0KTtcbiAgcmV0dXJuIGRzdC5zbGljZSgwLCB1bmNvbXByZXNzZWRTaXplKTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsU0FDRUEsbUJBREYsRUFFRUMsa0JBRkYsRUFHRUMsZUFIRixFQUlFQyxlQUpGLFFBS08sVUFMUDtBQU1BLFNBQVNDLFdBQVQsUUFBNEIsbUJBQTVCO0FBRUEsT0FBTyxTQUFTQyxRQUFULENBQWtCQyxJQUFsQixFQUFnRDtFQUNyRCxJQUFJQSxJQUFJLENBQUNDLFVBQUwsR0FBa0IsUUFBdEIsRUFBa0M7SUFDaEMsT0FBT0gsV0FBVyxDQUFDLElBQUlJLFVBQUosQ0FBZSxDQUFDLENBQUQsQ0FBZixDQUFELEVBQXNCRixJQUF0QixDQUFsQjtFQUNEOztFQUNELE1BQU1HLFVBQVUsR0FBRyxJQUFJRCxVQUFKLENBQWVQLGtCQUFrQixDQUFDSyxJQUFJLENBQUNDLFVBQU4sQ0FBakMsQ0FBbkI7RUFDQSxNQUFNRyxjQUFjLEdBQUdSLGVBQWUsQ0FBQ0ksSUFBRCxFQUFPRyxVQUFQLEVBQW1CLENBQW5CLENBQXRDOztFQUNBLElBQUlDLGNBQWMsS0FBSyxDQUF2QixFQUEwQjtJQUN4QixPQUFPTixXQUFXLENBQUMsSUFBSUksVUFBSixDQUFlLENBQUMsQ0FBRCxDQUFmLENBQUQsRUFBc0JGLElBQXRCLENBQWxCO0VBQ0Q7O0VBQ0QsT0FBT0YsV0FBVyxDQUFDLElBQUlJLFVBQUosQ0FBZSxDQUFDLENBQUQsQ0FBZixDQUFELEVBQXNCQyxVQUFVLENBQUNFLEtBQVgsQ0FBaUIsQ0FBakIsRUFBb0JELGNBQXBCLENBQXRCLENBQWxCO0FBQ0Q7QUFFRCxPQUFPLFNBQVNFLFVBQVQsQ0FBb0JOLElBQXBCLEVBQWtEO0VBQ3ZELE1BQU1PLFFBQVEsR0FBR1AsSUFBSSxDQUFDSyxLQUFMLENBQVcsQ0FBWCxDQUFqQjs7RUFDQSxJQUFJTCxJQUFJLENBQUMsQ0FBRCxDQUFKLEtBQVksQ0FBaEIsRUFBbUI7SUFDakIsT0FBT08sUUFBUDtFQUNEOztFQUNELE1BQU1DLEdBQUcsR0FBRyxJQUFJTixVQUFKLENBQWVSLG1CQUFtQixDQUFDYSxRQUFELENBQWxDLENBQVo7RUFDQSxNQUFNRSxnQkFBZ0IsR0FBR1osZUFBZSxDQUFDVSxRQUFELEVBQVdDLEdBQVgsQ0FBeEM7RUFDQSxPQUFPQSxHQUFHLENBQUNILEtBQUosQ0FBVSxDQUFWLEVBQWFJLGdCQUFiLENBQVA7QUFDRCJ9
@@ -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
- var errInvalidSource = new Error("invalid source");
34
- var errShortBuffer = new Error("short buffer"); // The following constants are used to setup the compression algorithm.
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
- var minMatch = 4; // the minimum size of the match sequence size (4 bytes)
36
+ const minMatch = 4; // the minimum size of the match sequence size (4 bytes)
37
37
 
38
- var winSizeLog = 16; // LZ4 64Kb window size limit
38
+ const winSizeLog = 16; // LZ4 64Kb window size limit
39
39
 
40
- var winSize = 1 << winSizeLog;
41
- var winMask = winSize - 1; // 64Kb window of previous data for dependent blocks
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
- var hashSizeLog = 16;
48
- var hashSize = 1 << hashSizeLog;
49
- var hashShift = minMatch * 8 - hashSizeLog;
50
- var mfLimit = 8 + minMatch; // The last match cannot start within the last 12 bytes.
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
- var skipStrength = 6; // variable step for fast scan
52
+ const skipStrength = 6; // variable step for fast scan
53
53
 
54
- var hasher = 2654435761 | 0; // prime number used to hash minMatch
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
- var ah = a >>> 16 & 0xffff;
59
- var al = a & 0xffff;
60
- var bh = b >>> 16 & 0xffff;
61
- var bl = b & 0xffff; // the shift by 0 fixes the sign on the high part
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
- var imul = Math.imul ? Math.imul : imulPolyfill;
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 (var i = 0; i < len; ++i) {
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
- var sn = src.length;
80
+ const sn = src.length;
81
81
 
82
82
  if (sn === 0) {
83
83
  return 0;
84
84
  }
85
85
 
86
- var si = 0;
87
- var di = 0;
86
+ let si = 0;
87
+ let di = 0;
88
88
 
89
89
  while (true) {
90
90
  // literals and match lengths (token)
91
- var lLen = src[si] >> 4;
92
- var mLen = src[si] & 0xf;
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
- var offset = src[si - 2] | src[si - 1] << 8;
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
- var sn = src.length;
165
- var dn = dest.length;
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
- var si = 0;
172
- var di = 0;
171
+ let si = 0;
172
+ let di = 0;
173
173
 
174
174
  while (true) {
175
175
  // literals and match lengths (token)
176
- var lLen = src[si] >> 4;
177
- var mLen = src[si] & 0xf;
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
- var offset = src[si - 2] | src[si - 1] << 8;
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
- var sn = src.length - mfLimit;
265
- var dn = dest.length;
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
- var si = 0,
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
- var hashTable = new Uint32Array(hashSize); // Initialise the hash table with the first 64Kb of the input buffer
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
- var h = imul(getUint32(src, si), hasher) >>> hashShift;
279
+ const h = imul(getUint32(src, si), hasher) >>> hashShift;
280
280
  hashTable[h] = ++si;
281
281
  }
282
282
 
283
- var anchor = si;
284
- var fma = 1 << skipStrength;
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
- var _h = imul(getUint32(src, si), hasher) >>> hashShift; // -1 to separate existing entries from new ones
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
- var ref = hashTable[_h] - 1; // ...and store the position of the hash in the hash table (+1 to compensate the -1 upon saving)
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
- var _lLen = si - anchor;
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
- var mLen = si; // match length has minMatch already
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 (_lLen < 0xf) {
336
- dest[di] |= _lLen << 4;
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
- var l = _lLen - 0xf;
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 + _lLen >= dn) {
359
+ if (di + lLen >= dn) {
363
360
  throw errShortBuffer;
364
361
  }
365
362
 
366
- copy(dest, src, di, anchor, _lLen);
367
- di += _lLen;
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
- var lLen = src.length - anchor;
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
- var lastLen = src.length - anchor;
430
- var n = di + lastLen;
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
- var sn = src.length - mfLimit;
445
- var dn = dest.length;
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
- var si = 0;
452
- var di = 0; // Hash Chain strategy:
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
- var hashTable = new Uint32Array(hashSize);
457
- var chainTable = new Uint32Array(winSize); // Initialise the hash table with the first 64Kb of the input buffer
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
- var h = imul(getUint32(src, si), hasher) >>> hashShift;
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
- var anchor = si;
463
+ let anchor = si;
467
464
 
468
465
  while (si < sn - minMatch) {
469
466
  // hash the next 4 bytes (sequence)...
470
- var _h2 = imul(getUint32(src, si), hasher) >>> hashShift; // follow the chain until out of window and give the longest match
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
- var mLen = 0;
474
- var offset = 0;
469
+ let mLen = 0;
470
+ let offset = 0;
475
471
 
476
- for (var next = hashTable[_h2] - 1; next > 0 && next > si - winSize; next = chainTable[next & winMask] - 1) {
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 (var _ml = 0;; ++_ml) {
480
- if (src[next + _ml] !== src[si + _ml] || si + _ml > sn) {
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 < _ml && _ml >= minMatch) {
483
- mLen = _ml;
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[_h2];
494
- hashTable[_h2] = si + 1; // no match found
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
- var si2 = si + 1;
502
- var ml = si + mLen; // match found
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
- var _h3 = imul(getUint32(src, si2), hasher) >>> hashShift;
508
-
509
- chainTable[si2 & winMask] = hashTable[_h3];
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
- var _lLen2 = si - anchor;
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 (_lLen2 < 0xf) {
526
- dest[di] |= _lLen2 << 4;
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
- var l = _lLen2 - 0xf;
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 + _lLen2 >= dn) {
546
+ if (di + lLen >= dn) {
553
547
  throw errShortBuffer;
554
548
  }
555
549
 
556
- copy(dest, src, di, anchor, _lLen2);
557
- di += _lLen2;
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
- var lLen = src.length - anchor;
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
- var lastLen = src.length - anchor;
620
- var n = di + lastLen;
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":"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"}