zstdlib 0.3.0-x86-mingw32 → 0.8.0-x86-mingw32

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 (88) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGES.md +30 -1
  3. data/README.md +2 -2
  4. data/Rakefile +1 -1
  5. data/ext/zstdlib/extconf.rb +3 -3
  6. data/ext/zstdlib/ruby/zlib-2.7/zstdlib.c +4895 -0
  7. data/ext/zstdlib/ruby/zlib-3.0/zstdlib.c +4994 -0
  8. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/common/bitstream.h +59 -51
  9. data/ext/zstdlib/zstd-1.5.0/lib/common/compiler.h +289 -0
  10. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/common/cpu.h +1 -3
  11. data/ext/zstdlib/zstd-1.5.0/lib/common/debug.c +24 -0
  12. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/common/debug.h +22 -49
  13. data/ext/zstdlib/zstd-1.5.0/lib/common/entropy_common.c +362 -0
  14. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/common/error_private.c +3 -1
  15. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/common/error_private.h +8 -4
  16. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/common/fse.h +50 -42
  17. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/common/fse_decompress.c +149 -55
  18. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/common/huf.h +43 -39
  19. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/common/mem.h +69 -25
  20. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/common/pool.c +30 -20
  21. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/common/pool.h +3 -3
  22. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/common/threading.c +51 -4
  23. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/common/threading.h +36 -4
  24. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/common/xxhash.c +40 -92
  25. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/common/xxhash.h +12 -32
  26. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/common/zstd_common.c +10 -10
  27. data/ext/zstdlib/zstd-1.5.0/lib/common/zstd_deps.h +111 -0
  28. data/ext/zstdlib/zstd-1.5.0/lib/common/zstd_internal.h +490 -0
  29. data/ext/zstdlib/zstd-1.5.0/lib/common/zstd_trace.h +154 -0
  30. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/compress/fse_compress.c +47 -63
  31. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/compress/hist.c +41 -63
  32. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/compress/hist.h +13 -33
  33. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/compress/huf_compress.c +332 -193
  34. data/ext/zstdlib/zstd-1.5.0/lib/compress/zstd_compress.c +6393 -0
  35. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/compress/zstd_compress_internal.h +522 -86
  36. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/compress/zstd_compress_literals.c +25 -16
  37. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/compress/zstd_compress_literals.h +2 -2
  38. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/compress/zstd_compress_sequences.c +50 -24
  39. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/compress/zstd_compress_sequences.h +11 -4
  40. data/ext/zstdlib/zstd-1.5.0/lib/compress/zstd_compress_superblock.c +572 -0
  41. data/ext/zstdlib/zstd-1.5.0/lib/compress/zstd_compress_superblock.h +32 -0
  42. data/ext/zstdlib/zstd-1.5.0/lib/compress/zstd_cwksp.h +662 -0
  43. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/compress/zstd_double_fast.c +43 -41
  44. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/compress/zstd_double_fast.h +2 -2
  45. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/compress/zstd_fast.c +85 -80
  46. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/compress/zstd_fast.h +2 -2
  47. data/ext/zstdlib/zstd-1.5.0/lib/compress/zstd_lazy.c +2184 -0
  48. data/ext/zstdlib/zstd-1.5.0/lib/compress/zstd_lazy.h +125 -0
  49. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/compress/zstd_ldm.c +333 -208
  50. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/compress/zstd_ldm.h +15 -3
  51. data/ext/zstdlib/zstd-1.5.0/lib/compress/zstd_ldm_geartab.h +103 -0
  52. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/compress/zstd_opt.c +228 -129
  53. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/compress/zstd_opt.h +1 -1
  54. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/compress/zstdmt_compress.c +151 -440
  55. data/ext/zstdlib/zstd-1.5.0/lib/compress/zstdmt_compress.h +110 -0
  56. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/decompress/huf_decompress.c +395 -276
  57. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/decompress/zstd_ddict.c +20 -16
  58. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/decompress/zstd_ddict.h +3 -3
  59. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/decompress/zstd_decompress.c +628 -231
  60. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/decompress/zstd_decompress_block.c +606 -380
  61. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/decompress/zstd_decompress_block.h +8 -5
  62. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/decompress/zstd_decompress_internal.h +39 -9
  63. data/ext/zstdlib/zstd-1.5.0/lib/zdict.h +452 -0
  64. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/lib/zstd.h +740 -153
  65. data/ext/zstdlib/{zstd-1.4.2/lib/common → zstd-1.5.0/lib}/zstd_errors.h +3 -1
  66. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/zlibWrapper/gzclose.c +1 -1
  67. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/zlibWrapper/gzcompatibility.h +1 -1
  68. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/zlibWrapper/gzguts.h +0 -0
  69. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/zlibWrapper/gzlib.c +9 -9
  70. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/zlibWrapper/gzread.c +16 -8
  71. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/zlibWrapper/gzwrite.c +8 -8
  72. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/zlibWrapper/zstd_zlibwrapper.c +131 -45
  73. data/ext/zstdlib/{zstd-1.4.2 → zstd-1.5.0}/zlibWrapper/zstd_zlibwrapper.h +1 -1
  74. data/lib/2.2/zstdlib.so +0 -0
  75. data/lib/2.3/zstdlib.so +0 -0
  76. data/lib/2.4/zstdlib.so +0 -0
  77. data/lib/2.5/zstdlib.so +0 -0
  78. data/lib/2.6/zstdlib.so +0 -0
  79. data/lib/2.7/zstdlib.so +0 -0
  80. metadata +76 -67
  81. data/ext/zstdlib/zstd-1.4.2/lib/common/compiler.h +0 -147
  82. data/ext/zstdlib/zstd-1.4.2/lib/common/debug.c +0 -44
  83. data/ext/zstdlib/zstd-1.4.2/lib/common/entropy_common.c +0 -236
  84. data/ext/zstdlib/zstd-1.4.2/lib/common/zstd_internal.h +0 -371
  85. data/ext/zstdlib/zstd-1.4.2/lib/compress/zstd_compress.c +0 -3904
  86. data/ext/zstdlib/zstd-1.4.2/lib/compress/zstd_lazy.c +0 -1111
  87. data/ext/zstdlib/zstd-1.4.2/lib/compress/zstd_lazy.h +0 -67
  88. data/ext/zstdlib/zstd-1.4.2/lib/compress/zstdmt_compress.h +0 -192
@@ -1,5 +1,5 @@
1
1
  /*
2
- * Copyright (c) 2016-present, Yann Collet, Facebook, Inc.
2
+ * Copyright (c) Yann Collet, Facebook, Inc.
3
3
  * All rights reserved.
4
4
  *
5
5
  * This source code is licensed under both the BSD-style license (found in the
@@ -76,6 +76,8 @@ typedef enum {
76
76
  /* following error codes are __NOT STABLE__, they can be removed or changed in future versions */
77
77
  ZSTD_error_frameIndex_tooLarge = 100,
78
78
  ZSTD_error_seekableIO = 102,
79
+ ZSTD_error_dstBuffer_wrong = 104,
80
+ ZSTD_error_srcBuffer_wrong = 105,
79
81
  ZSTD_error_maxCode = 120 /* never EVER use this value directly, it can change in future versions! Use ZSTD_isError() instead */
80
82
  } ZSTD_ErrorCode;
81
83
 
@@ -19,7 +19,7 @@ int ZEXPORT gzclose(file)
19
19
 
20
20
  if (file == NULL)
21
21
  return Z_STREAM_ERROR;
22
- state = (gz_statep)file;
22
+ state.file = file;
23
23
 
24
24
  return state.state->mode == GZ_READ ? gzclose_r(file) : gzclose_w(file);
25
25
  #else
@@ -1,5 +1,5 @@
1
1
  /*
2
- * Copyright (c) 2016-present, Przemyslaw Skibinski, Yann Collet, Facebook, Inc.
2
+ * Copyright (c) 2016-2021, Przemyslaw Skibinski, Yann Collet, Facebook, Inc.
3
3
  * All rights reserved.
4
4
  *
5
5
  * This source code is licensed under both the BSD-style license (found in the
@@ -216,7 +216,7 @@ local gzFile gz_open(path, fd, mode)
216
216
  #if !defined(NO_snprintf) && !defined(NO_vsnprintf)
217
217
  (void)snprintf(state.state->path, len + 1, "%s", (const char *)path);
218
218
  #else
219
- strcpy(state.state->path, path);
219
+ strcpy(state.state->path, (const char*)path);
220
220
  #endif
221
221
 
222
222
  /* compute the flags for open() */
@@ -325,7 +325,7 @@ int ZEXPORT gzbuffer(file, size)
325
325
  /* get internal structure and check integrity */
326
326
  if (file == NULL)
327
327
  return -1;
328
- state = (gz_statep)file;
328
+ state.file = file;
329
329
  if (state.state->mode != GZ_READ && state.state->mode != GZ_WRITE)
330
330
  return -1;
331
331
 
@@ -351,7 +351,7 @@ int ZEXPORT gzrewind(file)
351
351
  /* get internal structure */
352
352
  if (file == NULL)
353
353
  return -1;
354
- state = (gz_statep)file;
354
+ state.file = file;
355
355
 
356
356
  /* check that we're reading and that there's no error */
357
357
  if (state.state->mode != GZ_READ ||
@@ -378,7 +378,7 @@ z_off64_t ZEXPORT gzseek64(file, offset, whence)
378
378
  /* get internal structure and check integrity */
379
379
  if (file == NULL)
380
380
  return -1;
381
- state = (gz_statep)file;
381
+ state.file = file;
382
382
  if (state.state->mode != GZ_READ && state.state->mode != GZ_WRITE)
383
383
  return -1;
384
384
 
@@ -463,7 +463,7 @@ z_off64_t ZEXPORT gztell64(file)
463
463
  /* get internal structure and check integrity */
464
464
  if (file == NULL)
465
465
  return -1;
466
- state = (gz_statep)file;
466
+ state.file = file;
467
467
  if (state.state->mode != GZ_READ && state.state->mode != GZ_WRITE)
468
468
  return -1;
469
469
 
@@ -491,7 +491,7 @@ z_off64_t ZEXPORT gzoffset64(file)
491
491
  /* get internal structure and check integrity */
492
492
  if (file == NULL)
493
493
  return -1;
494
- state = (gz_statep)file;
494
+ state.file = file;
495
495
  if (state.state->mode != GZ_READ && state.state->mode != GZ_WRITE)
496
496
  return -1;
497
497
 
@@ -523,7 +523,7 @@ int ZEXPORT gzeof(file)
523
523
  /* get internal structure and check integrity */
524
524
  if (file == NULL)
525
525
  return 0;
526
- state = (gz_statep)file;
526
+ state.file = file;
527
527
  if (state.state->mode != GZ_READ && state.state->mode != GZ_WRITE)
528
528
  return 0;
529
529
 
@@ -541,7 +541,7 @@ const char * ZEXPORT gzerror(file, errnum)
541
541
  /* get internal structure and check integrity */
542
542
  if (file == NULL)
543
543
  return NULL;
544
- state = (gz_statep)file;
544
+ state.file = file;
545
545
  if (state.state->mode != GZ_READ && state.state->mode != GZ_WRITE)
546
546
  return NULL;
547
547
 
@@ -561,7 +561,7 @@ void ZEXPORT gzclearerr(file)
561
561
  /* get internal structure and check integrity */
562
562
  if (file == NULL)
563
563
  return;
564
- state = (gz_statep)file;
564
+ state.file = file;
565
565
  if (state.state->mode != GZ_READ && state.state->mode != GZ_WRITE)
566
566
  return;
567
567
 
@@ -8,6 +8,14 @@
8
8
 
9
9
  #include "gzguts.h"
10
10
 
11
+ /* fix for Visual Studio, which doesn't support ssize_t type.
12
+ * see https://github.com/facebook/zstd/issues/1800#issuecomment-545945050 */
13
+ #if defined(_MSC_VER) && !defined(ssize_t)
14
+ # include <BaseTsd.h>
15
+ typedef SSIZE_T ssize_t;
16
+ #endif
17
+
18
+
11
19
  /* Local functions */
12
20
  local int gz_load OF((gz_statep, unsigned char *, unsigned, unsigned *));
13
21
  local int gz_avail OF((gz_statep));
@@ -386,7 +394,7 @@ int ZEXPORT gzread(file, buf, len)
386
394
  /* get internal structure */
387
395
  if (file == NULL)
388
396
  return -1;
389
- state = (gz_statep)file;
397
+ state.file = file;
390
398
 
391
399
  /* check that we're reading and that there's no (serious) error */
392
400
  if (state.state->mode != GZ_READ ||
@@ -424,7 +432,7 @@ z_size_t ZEXPORT gzfread(buf, size, nitems, file)
424
432
  /* get internal structure */
425
433
  if (file == NULL)
426
434
  return 0;
427
- state = (gz_statep)file;
435
+ state.file = file;
428
436
 
429
437
  /* check that we're reading and that there's no (serious) error */
430
438
  if (state.state->mode != GZ_READ ||
@@ -470,7 +478,7 @@ int ZEXPORT gzgetc(file)
470
478
  /* get internal structure */
471
479
  if (file == NULL)
472
480
  return -1;
473
- state = (gz_statep)file;
481
+ state.file = file;
474
482
 
475
483
  /* check that we're reading and that there's no (serious) error */
476
484
  if (state.state->mode != GZ_READ ||
@@ -485,7 +493,7 @@ int ZEXPORT gzgetc(file)
485
493
  }
486
494
 
487
495
  /* nothing there -- try gz_read() */
488
- ret = (unsigned)gz_read(state, buf, 1);
496
+ ret = (int)gz_read(state, buf, 1);
489
497
  return ret < 1 ? -1 : buf[0];
490
498
  }
491
499
 
@@ -505,7 +513,7 @@ int ZEXPORT gzungetc(c, file)
505
513
  /* get internal structure */
506
514
  if (file == NULL)
507
515
  return -1;
508
- state = (gz_statep)file;
516
+ state.file = file;
509
517
 
510
518
  /* check that we're reading and that there's no (serious) error */
511
519
  if (state.state->mode != GZ_READ ||
@@ -569,7 +577,7 @@ char * ZEXPORT gzgets(file, buf, len)
569
577
  /* check parameters and get internal structure */
570
578
  if (file == NULL || buf == NULL || len < 1)
571
579
  return NULL;
572
- state = (gz_statep)file;
580
+ state.file = file;
573
581
 
574
582
  /* check that we're reading and that there's no (serious) error */
575
583
  if (state.state->mode != GZ_READ ||
@@ -628,7 +636,7 @@ int ZEXPORT gzdirect(file)
628
636
  /* get internal structure */
629
637
  if (file == NULL)
630
638
  return 0;
631
- state = (gz_statep)file;
639
+ state.file = file;
632
640
 
633
641
  /* if the state is not known, but we can find out, then do so (this is
634
642
  mainly for right after a gzopen() or gzdopen()) */
@@ -649,7 +657,7 @@ int ZEXPORT gzclose_r(file)
649
657
  /* get internal structure */
650
658
  if (file == NULL)
651
659
  return Z_STREAM_ERROR;
652
- state = (gz_statep)file;
660
+ state.file = file;
653
661
 
654
662
  /* check that we're reading */
655
663
  if (state.state->mode != GZ_READ)
@@ -258,7 +258,7 @@ int ZEXPORT gzwrite(file, buf, len)
258
258
  /* get internal structure */
259
259
  if (file == NULL)
260
260
  return 0;
261
- state = (gz_statep)file;
261
+ state.file = file;
262
262
 
263
263
  /* check that we're writing and that there's no error */
264
264
  if (state.state->mode != GZ_WRITE || state.state->err != Z_OK)
@@ -289,7 +289,7 @@ z_size_t ZEXPORT gzfwrite(buf, size, nitems, file)
289
289
  assert(size != 0);
290
290
  if (file == NULL)
291
291
  return 0;
292
- state = (gz_statep)file;
292
+ state.file = file;
293
293
 
294
294
  /* check that we're writing and that there's no error */
295
295
  if (state.state->mode != GZ_WRITE || state.state->err != Z_OK)
@@ -319,7 +319,7 @@ int ZEXPORT gzputc(file, c)
319
319
  /* get internal structure */
320
320
  if (file == NULL)
321
321
  return -1;
322
- state = (gz_statep)file;
322
+ state.file = file;
323
323
  strm = &(state.state->strm);
324
324
 
325
325
  /* check that we're writing and that there's no error */
@@ -366,7 +366,7 @@ int ZEXPORT gzputs(file, str)
366
366
  /* get internal structure */
367
367
  if (file == NULL)
368
368
  return -1;
369
- state = (gz_statep)file;
369
+ state.file = file;
370
370
 
371
371
  /* check that we're writing and that there's no error */
372
372
  if (state.state->mode != GZ_WRITE || state.state->err != Z_OK)
@@ -393,7 +393,7 @@ int ZEXPORTVA gzvprintf(gzFile file, const char *format, va_list va)
393
393
  /* get internal structure */
394
394
  if (file == NULL)
395
395
  return Z_STREAM_ERROR;
396
- state = (gz_statep)file;
396
+ state.file = file;
397
397
  strm = &(state.state->strm);
398
398
 
399
399
  /* check that we're writing and that there's no error */
@@ -565,7 +565,7 @@ int ZEXPORT gzflush(file, flush)
565
565
  /* get internal structure */
566
566
  if (file == NULL)
567
567
  return Z_STREAM_ERROR;
568
- state = (gz_statep)file;
568
+ state.file = file;
569
569
 
570
570
  /* check that we're writing and that there's no error */
571
571
  if (state.state->mode != GZ_WRITE || state.state->err != Z_OK)
@@ -599,7 +599,7 @@ int ZEXPORT gzsetparams(file, level, strategy)
599
599
  /* get internal structure */
600
600
  if (file == NULL)
601
601
  return Z_STREAM_ERROR;
602
- state = (gz_statep)file;
602
+ state.file = file;
603
603
  strm = &(state.state->strm);
604
604
 
605
605
  /* check that we're writing and that there's no error */
@@ -639,7 +639,7 @@ int ZEXPORT gzclose_w(file)
639
639
  /* get internal structure */
640
640
  if (file == NULL)
641
641
  return Z_STREAM_ERROR;
642
- state = (gz_statep)file;
642
+ state.file = file;
643
643
 
644
644
  /* check that we're writing */
645
645
  if (state.state->mode != GZ_WRITE)
@@ -1,5 +1,5 @@
1
1
  /*
2
- * Copyright (c) 2016-present, Przemyslaw Skibinski, Yann Collet, Facebook, Inc.
2
+ * Copyright (c) 2016-2021, Przemyslaw Skibinski, Yann Collet, Facebook, Inc.
3
3
  * All rights reserved.
4
4
  *
5
5
  * This source code is licensed under both the BSD-style license (found in the
@@ -19,19 +19,19 @@
19
19
  #include <stdlib.h>
20
20
  #include <stdio.h> /* vsprintf */
21
21
  #include <stdarg.h> /* va_list, for z_gzprintf */
22
+ #include <string.h>
22
23
  #define NO_DUMMY_DECL
23
24
  #define ZLIB_CONST
24
25
  #include <zlib.h> /* without #define Z_PREFIX */
25
26
  #include "zstd_zlibwrapper.h"
26
- #define ZSTD_STATIC_LINKING_ONLY /* ZSTD_isFrame, ZSTD_MAGICNUMBER */
27
+ #define ZSTD_STATIC_LINKING_ONLY /* ZSTD_isFrame, ZSTD_MAGICNUMBER, ZSTD_customMem */
27
28
  #include "zstd.h"
28
- #include "zstd_internal.h" /* ZSTD_malloc, ZSTD_free */
29
29
 
30
30
 
31
31
  /* === Constants === */
32
32
  #define Z_INFLATE_SYNC 8
33
33
  #define ZLIB_HEADERSIZE 4
34
- #define ZSTD_HEADERSIZE ZSTD_FRAMEHEADERSIZE_MIN
34
+ #define ZSTD_HEADERSIZE ZSTD_FRAMEHEADERSIZE_MIN(ZSTD_f_zstd1)
35
35
  #define ZWRAP_DEFAULT_CLEVEL 3 /* Z_DEFAULT_COMPRESSION is translated to ZWRAP_DEFAULT_CLEVEL for zstd */
36
36
 
37
37
 
@@ -42,6 +42,45 @@
42
42
  #define FINISH_WITH_GZ_ERR(msg) { (void)msg; return Z_STREAM_ERROR; }
43
43
  #define FINISH_WITH_NULL_ERR(msg) { (void)msg; return NULL; }
44
44
 
45
+ /* === Utility === */
46
+
47
+ #define MIN(x,y) ((x) < (y) ? (x) : (y))
48
+
49
+ static unsigned ZWRAP_isLittleEndian(void)
50
+ {
51
+ const union { unsigned u; char c[4]; } one = { 1 }; /* don't use static : performance detrimental */
52
+ return one.c[0];
53
+ }
54
+
55
+ #ifndef __has_builtin
56
+ # define __has_builtin(x) 0
57
+ #endif
58
+
59
+ static unsigned ZWRAP_swap32(unsigned in)
60
+ {
61
+ #if defined(_MSC_VER) /* Visual Studio */
62
+ return _byteswap_ulong(in);
63
+ #elif (defined (__GNUC__) && (__GNUC__ * 100 + __GNUC_MINOR__ >= 403)) \
64
+ || (defined(__clang__) && __has_builtin(__builtin_bswap32))
65
+ return __builtin_bswap32(in);
66
+ #else
67
+ return ((in << 24) & 0xff000000 ) |
68
+ ((in << 8) & 0x00ff0000 ) |
69
+ ((in >> 8) & 0x0000ff00 ) |
70
+ ((in >> 24) & 0x000000ff );
71
+ #endif
72
+ }
73
+
74
+ static unsigned ZWRAP_readLE32(const void* ptr)
75
+ {
76
+ unsigned value;
77
+ memcpy(&value, ptr, sizeof(value));
78
+ if (ZWRAP_isLittleEndian())
79
+ return value;
80
+ else
81
+ return ZWRAP_swap32(value);
82
+ }
83
+
45
84
 
46
85
  /* === Wrapper === */
47
86
  static int g_ZWRAP_useZSTDcompression = ZWRAP_USE_ZSTD; /* 0 = don't use ZSTD */
@@ -54,7 +93,7 @@ int ZWRAP_isUsingZSTDcompression(void) { return g_ZWRAP_useZSTDcompression; }
54
93
 
55
94
  static ZWRAP_decompress_type g_ZWRAPdecompressionType = ZWRAP_AUTO;
56
95
 
57
- void ZWRAP_setDecompressionType(ZWRAP_decompress_type type) { g_ZWRAPdecompressionType = type; };
96
+ void ZWRAP_setDecompressionType(ZWRAP_decompress_type type) { g_ZWRAPdecompressionType = type; }
58
97
 
59
98
  ZWRAP_decompress_type ZWRAP_getDecompressionType(void) { return g_ZWRAPdecompressionType; }
60
99
 
@@ -64,8 +103,6 @@ const char * zstdVersion(void) { return ZSTD_VERSION_STRING; }
64
103
 
65
104
  ZEXTERN const char * ZEXPORT z_zlibVersion OF((void)) { return zlibVersion(); }
66
105
 
67
-
68
-
69
106
  static void* ZWRAP_allocFunction(void* opaque, size_t size)
70
107
  {
71
108
  z_streamp strm = (z_streamp) opaque;
@@ -81,6 +118,35 @@ static void ZWRAP_freeFunction(void* opaque, void* address)
81
118
  /* if (address) LOG_WRAPPERC("ZWRAP free %p \n", address); */
82
119
  }
83
120
 
121
+ static void* ZWRAP_customMalloc(size_t size, ZSTD_customMem customMem)
122
+ {
123
+ if (customMem.customAlloc)
124
+ return customMem.customAlloc(customMem.opaque, size);
125
+ return malloc(size);
126
+ }
127
+
128
+ static void* ZWRAP_customCalloc(size_t size, ZSTD_customMem customMem)
129
+ {
130
+ if (customMem.customAlloc) {
131
+ /* calloc implemented as malloc+memset;
132
+ * not as efficient as calloc, but next best guess for custom malloc */
133
+ void* const ptr = customMem.customAlloc(customMem.opaque, size);
134
+ memset(ptr, 0, size);
135
+ return ptr;
136
+ }
137
+ return calloc(1, size);
138
+ }
139
+
140
+ static void ZWRAP_customFree(void* ptr, ZSTD_customMem customMem)
141
+ {
142
+ if (ptr!=NULL) {
143
+ if (customMem.customFree)
144
+ customMem.customFree(customMem.opaque, ptr);
145
+ else
146
+ free(ptr);
147
+ }
148
+ }
149
+
84
150
 
85
151
 
86
152
  /* === Compression === */
@@ -99,7 +165,7 @@ typedef struct {
99
165
  unsigned long long pledgedSrcSize;
100
166
  } ZWRAP_CCtx;
101
167
 
102
- typedef ZWRAP_CCtx internal_state;
168
+ /* typedef ZWRAP_CCtx internal_state; */
103
169
 
104
170
 
105
171
 
@@ -107,7 +173,7 @@ static size_t ZWRAP_freeCCtx(ZWRAP_CCtx* zwc)
107
173
  {
108
174
  if (zwc==NULL) return 0; /* support free on NULL */
109
175
  ZSTD_freeCStream(zwc->zbc);
110
- ZSTD_free(zwc, zwc->customMem);
176
+ ZWRAP_customFree(zwc, zwc->customMem);
111
177
  return 0;
112
178
  }
113
179
 
@@ -115,18 +181,19 @@ static size_t ZWRAP_freeCCtx(ZWRAP_CCtx* zwc)
115
181
  static ZWRAP_CCtx* ZWRAP_createCCtx(z_streamp strm)
116
182
  {
117
183
  ZWRAP_CCtx* zwc;
184
+ ZSTD_customMem customMem = { NULL, NULL, NULL };
118
185
 
119
186
  if (strm->zalloc && strm->zfree) {
120
- zwc = (ZWRAP_CCtx*)strm->zalloc(strm->opaque, 1, sizeof(ZWRAP_CCtx));
121
- if (zwc==NULL) return NULL;
122
- memset(zwc, 0, sizeof(ZWRAP_CCtx));
123
- memcpy(&zwc->allocFunc, strm, sizeof(z_stream));
124
- { ZSTD_customMem const ZWRAP_customMem = { ZWRAP_allocFunction, ZWRAP_freeFunction, &zwc->allocFunc };
125
- zwc->customMem = ZWRAP_customMem; }
126
- } else {
127
- zwc = (ZWRAP_CCtx*)calloc(1, sizeof(*zwc));
128
- if (zwc==NULL) return NULL;
187
+ customMem.customAlloc = ZWRAP_allocFunction;
188
+ customMem.customFree = ZWRAP_freeFunction;
129
189
  }
190
+ customMem.opaque = strm;
191
+
192
+ zwc = (ZWRAP_CCtx*)ZWRAP_customCalloc(sizeof(ZWRAP_CCtx), customMem);
193
+ if (zwc == NULL) return NULL;
194
+ zwc->allocFunc = *strm;
195
+ customMem.opaque = &zwc->allocFunc;
196
+ zwc->customMem = customMem;
130
197
 
131
198
  return zwc;
132
199
  }
@@ -138,12 +205,21 @@ static int ZWRAP_initializeCStream(ZWRAP_CCtx* zwc, const void* dict, size_t dic
138
205
  if (zwc == NULL || zwc->zbc == NULL) return Z_STREAM_ERROR;
139
206
 
140
207
  if (!pledgedSrcSize) pledgedSrcSize = zwc->pledgedSrcSize;
141
- { ZSTD_parameters const params = ZSTD_getParams(zwc->compressionLevel, pledgedSrcSize, dictSize);
142
- size_t initErr;
208
+ { unsigned initErr = 0;
209
+ ZSTD_parameters const params = ZSTD_getParams(zwc->compressionLevel, pledgedSrcSize, dictSize);
210
+ ZSTD_CCtx_params* cctxParams = ZSTD_createCCtxParams();
211
+ if (!cctxParams) return Z_STREAM_ERROR;
143
212
  LOG_WRAPPERC("pledgedSrcSize=%d windowLog=%d chainLog=%d hashLog=%d searchLog=%d minMatch=%d strategy=%d\n",
144
213
  (int)pledgedSrcSize, params.cParams.windowLog, params.cParams.chainLog, params.cParams.hashLog, params.cParams.searchLog, params.cParams.minMatch, params.cParams.strategy);
145
- initErr = ZSTD_initCStream_advanced(zwc->zbc, dict, dictSize, params, pledgedSrcSize);
146
- if (ZSTD_isError(initErr)) return Z_STREAM_ERROR;
214
+
215
+ initErr |= ZSTD_isError(ZSTD_CCtx_reset(zwc->zbc, ZSTD_reset_session_only));
216
+ initErr |= ZSTD_isError(ZSTD_CCtxParams_init_advanced(cctxParams, params));
217
+ initErr |= ZSTD_isError(ZSTD_CCtx_setParametersUsingCCtxParams(zwc->zbc, cctxParams));
218
+ initErr |= ZSTD_isError(ZSTD_CCtx_setPledgedSrcSize(zwc->zbc, pledgedSrcSize));
219
+ initErr |= ZSTD_isError(ZSTD_CCtx_loadDictionary(zwc->zbc, dict, dictSize));
220
+
221
+ ZSTD_freeCCtxParams(cctxParams);
222
+ if (initErr) return Z_STREAM_ERROR;
147
223
  }
148
224
 
149
225
  return Z_OK;
@@ -179,6 +255,10 @@ int ZWRAP_setPledgedSrcSize(z_streamp strm, unsigned long long pledgedSrcSize)
179
255
  return Z_OK;
180
256
  }
181
257
 
258
+ static struct internal_state* convert_into_sis(void* ptr)
259
+ {
260
+ return (struct internal_state*) ptr;
261
+ }
182
262
 
183
263
  ZEXTERN int ZEXPORT z_deflateInit_ OF((z_streamp strm, int level,
184
264
  const char *version, int stream_size))
@@ -199,7 +279,7 @@ ZEXTERN int ZEXPORT z_deflateInit_ OF((z_streamp strm, int level,
199
279
  zwc->streamEnd = 0;
200
280
  zwc->totalInBytes = 0;
201
281
  zwc->compressionLevel = level;
202
- strm->state = (struct internal_state*) zwc; /* use state which in not used by user */
282
+ strm->state = convert_into_sis(zwc); /* use state which in not used by user */
203
283
  strm->total_in = 0;
204
284
  strm->total_out = 0;
205
285
  strm->adler = 0;
@@ -301,9 +381,15 @@ ZEXTERN int ZEXPORT z_deflate OF((z_streamp strm, int flush))
301
381
  } else {
302
382
  if (zwc->totalInBytes == 0) {
303
383
  if (zwc->comprState == ZWRAP_useReset) {
304
- size_t const resetErr = ZSTD_resetCStream(zwc->zbc, (flush == Z_FINISH) ? strm->avail_in : zwc->pledgedSrcSize);
384
+ size_t resetErr = ZSTD_CCtx_reset(zwc->zbc, ZSTD_reset_session_only);
385
+ if (ZSTD_isError(resetErr)) {
386
+ LOG_WRAPPERC("ERROR: ZSTD_CCtx_reset errorCode=%s\n",
387
+ ZSTD_getErrorName(resetErr));
388
+ return ZWRAPC_finishWithError(zwc, strm, 0);
389
+ }
390
+ resetErr = ZSTD_CCtx_setPledgedSrcSize(zwc->zbc, (flush == Z_FINISH) ? strm->avail_in : zwc->pledgedSrcSize);
305
391
  if (ZSTD_isError(resetErr)) {
306
- LOG_WRAPPERC("ERROR: ZSTD_resetCStream errorCode=%s\n",
392
+ LOG_WRAPPERC("ERROR: ZSTD_CCtx_setPledgedSrcSize errorCode=%s\n",
307
393
  ZSTD_getErrorName(resetErr));
308
394
  return ZWRAPC_finishWithError(zwc, strm, 0);
309
395
  }
@@ -455,19 +541,19 @@ static void ZWRAP_initDCtx(ZWRAP_DCtx* zwd)
455
541
  static ZWRAP_DCtx* ZWRAP_createDCtx(z_streamp strm)
456
542
  {
457
543
  ZWRAP_DCtx* zwd;
458
- MEM_STATIC_ASSERT(sizeof(zwd->headerBuf) >= ZSTD_FRAMEHEADERSIZE_MIN); /* check static buffer size condition */
544
+ ZSTD_customMem customMem = { NULL, NULL, NULL };
459
545
 
460
546
  if (strm->zalloc && strm->zfree) {
461
- zwd = (ZWRAP_DCtx*)strm->zalloc(strm->opaque, 1, sizeof(ZWRAP_DCtx));
462
- if (zwd==NULL) return NULL;
463
- memset(zwd, 0, sizeof(ZWRAP_DCtx));
464
- zwd->allocFunc = *strm; /* just to copy zalloc, zfree & opaque */
465
- { ZSTD_customMem const ZWRAP_customMem = { ZWRAP_allocFunction, ZWRAP_freeFunction, &zwd->allocFunc };
466
- zwd->customMem = ZWRAP_customMem; }
467
- } else {
468
- zwd = (ZWRAP_DCtx*)calloc(1, sizeof(*zwd));
469
- if (zwd==NULL) return NULL;
547
+ customMem.customAlloc = ZWRAP_allocFunction;
548
+ customMem.customFree = ZWRAP_freeFunction;
470
549
  }
550
+ customMem.opaque = strm;
551
+
552
+ zwd = (ZWRAP_DCtx*)ZWRAP_customCalloc(sizeof(ZWRAP_DCtx), customMem);
553
+ if (zwd == NULL) return NULL;
554
+ zwd->allocFunc = *strm;
555
+ customMem.opaque = &zwd->allocFunc;
556
+ zwd->customMem = customMem;
471
557
 
472
558
  ZWRAP_initDCtx(zwd);
473
559
  return zwd;
@@ -477,8 +563,8 @@ static size_t ZWRAP_freeDCtx(ZWRAP_DCtx* zwd)
477
563
  {
478
564
  if (zwd==NULL) return 0; /* support free on null */
479
565
  ZSTD_freeDStream(zwd->zbd);
480
- ZSTD_free(zwd->version, zwd->customMem);
481
- ZSTD_free(zwd, zwd->customMem);
566
+ ZWRAP_customFree(zwd->version, zwd->customMem);
567
+ ZWRAP_customFree(zwd, zwd->customMem);
482
568
  return 0;
483
569
  }
484
570
 
@@ -509,7 +595,7 @@ static int ZWRAPD_finishWithErrorMsg(z_streamp strm, char* message)
509
595
 
510
596
 
511
597
  ZEXTERN int ZEXPORT z_inflateInit_ OF((z_streamp strm,
512
- const char *version, int stream_size))
598
+ const char* version, int stream_size))
513
599
  {
514
600
  if (g_ZWRAPdecompressionType == ZWRAP_FORCE_ZLIB) {
515
601
  strm->reserved = ZWRAP_ZLIB_STREAM;
@@ -520,13 +606,13 @@ ZEXTERN int ZEXPORT z_inflateInit_ OF((z_streamp strm,
520
606
  LOG_WRAPPERD("- inflateInit\n");
521
607
  if (zwd == NULL) return ZWRAPD_finishWithError(zwd, strm, 0);
522
608
 
523
- zwd->version = ZSTD_malloc(strlen(version)+1, zwd->customMem);
609
+ zwd->version = (char*)ZWRAP_customMalloc(strlen(version)+1, zwd->customMem);
524
610
  if (zwd->version == NULL) return ZWRAPD_finishWithError(zwd, strm, 0);
525
611
  strcpy(zwd->version, version);
526
612
 
527
613
  zwd->stream_size = stream_size;
528
614
  zwd->totalInBytes = 0;
529
- strm->state = (struct internal_state*) zwd;
615
+ strm->state = convert_into_sis(zwd);
530
616
  strm->total_in = 0;
531
617
  strm->total_out = 0;
532
618
  strm->reserved = ZWRAP_UNKNOWN_STREAM;
@@ -666,7 +752,7 @@ ZEXTERN int ZEXPORT z_inflate OF((z_streamp strm, int flush))
666
752
 
667
753
  if (zwd->totalInBytes < ZLIB_HEADERSIZE) {
668
754
  if (zwd->totalInBytes == 0 && strm->avail_in >= ZLIB_HEADERSIZE) {
669
- if (MEM_readLE32(strm->next_in) != ZSTD_MAGICNUMBER) {
755
+ if (ZWRAP_readLE32(strm->next_in) != ZSTD_MAGICNUMBER) {
670
756
  { int const initErr = (zwd->windowBits) ?
671
757
  inflateInit2_(strm, zwd->windowBits, zwd->version, zwd->stream_size) :
672
758
  inflateInit_(strm, zwd->version, zwd->stream_size);
@@ -694,7 +780,7 @@ ZEXTERN int ZEXPORT z_inflate OF((z_streamp strm, int flush))
694
780
  strm->avail_in -= srcSize;
695
781
  if (zwd->totalInBytes < ZLIB_HEADERSIZE) return Z_OK;
696
782
 
697
- if (MEM_readLE32(zwd->headerBuf) != ZSTD_MAGICNUMBER) {
783
+ if (ZWRAP_readLE32(zwd->headerBuf) != ZSTD_MAGICNUMBER) {
698
784
  z_stream strm2;
699
785
  strm2.next_in = strm->next_in;
700
786
  strm2.avail_in = strm->avail_in;
@@ -758,7 +844,7 @@ ZEXTERN int ZEXPORT z_inflate OF((z_streamp strm, int flush))
758
844
  goto error;
759
845
  }
760
846
  } else {
761
- size_t const resetErr = ZSTD_resetDStream(zwd->zbd);
847
+ size_t const resetErr = ZSTD_DCtx_reset(zwd->zbd, ZSTD_reset_session_only);
762
848
  if (ZSTD_isError(resetErr)) goto error;
763
849
  }
764
850
  } else {
@@ -778,7 +864,7 @@ ZEXTERN int ZEXPORT z_inflate OF((z_streamp strm, int flush))
778
864
  goto error;
779
865
  }
780
866
  } else {
781
- size_t const resetErr = ZSTD_resetDStream(zwd->zbd);
867
+ size_t const resetErr = ZSTD_DCtx_reset(zwd->zbd, ZSTD_reset_session_only);
782
868
  if (ZSTD_isError(resetErr)) goto error;
783
869
  }
784
870
 
@@ -1003,7 +1089,7 @@ ZEXTERN int ZEXPORT z_inflateBackEnd OF((z_streamp strm))
1003
1089
  }
1004
1090
 
1005
1091
 
1006
- ZEXTERN uLong ZEXPORT z_zlibCompileFlags OF((void)) { return zlibCompileFlags(); };
1092
+ ZEXTERN uLong ZEXPORT z_zlibCompileFlags OF((void)) { return zlibCompileFlags(); }
1007
1093
 
1008
1094
 
1009
1095