zstdlib 0.1.1-x86-mingw32 → 0.1.2-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.
@@ -1,3 +1,4 @@
1
+ #include <zstd.h>
1
2
  /*
2
3
  * zlib.c - An interface for zlib.
3
4
  *
@@ -7,7 +8,7 @@
7
8
  */
8
9
 
9
10
  #include <ruby.h>
10
- #include <zlib.h>
11
+ #include <zstd_zlibwrapper.h>
11
12
  #include <time.h>
12
13
  #include <ruby/io.h>
13
14
  #include <ruby/thread.h>
@@ -250,48 +251,48 @@ static VALUE rb_gzreader_readlines(int, VALUE*, VALUE);
250
251
  * Using the wrapper to compress strings with default parameters is quite
251
252
  * simple:
252
253
  *
253
- * require "zlib"
254
+ * require "zstdlib"
254
255
  *
255
256
  * data_to_compress = File.read("don_quixote.txt")
256
257
  *
257
258
  * puts "Input size: #{data_to_compress.size}"
258
259
  * #=> Input size: 2347740
259
260
  *
260
- * data_compressed = Zlib::Deflate.deflate(data_to_compress)
261
+ * data_compressed = Zstdlib::Deflate.deflate(data_to_compress)
261
262
  *
262
263
  * puts "Compressed size: #{data_compressed.size}"
263
264
  * #=> Compressed size: 887238
264
265
  *
265
- * uncompressed_data = Zlib::Inflate.inflate(data_compressed)
266
+ * uncompressed_data = Zstdlib::Inflate.inflate(data_compressed)
266
267
  *
267
268
  * puts "Uncompressed data is: #{uncompressed_data}"
268
269
  * #=> Uncompressed data is: The Project Gutenberg EBook of Don Quixote...
269
270
  *
270
271
  * == Class tree
271
272
  *
272
- * - Zlib::Deflate
273
- * - Zlib::Inflate
274
- * - Zlib::ZStream
275
- * - Zlib::Error
276
- * - Zlib::StreamEnd
277
- * - Zlib::NeedDict
278
- * - Zlib::DataError
279
- * - Zlib::StreamError
280
- * - Zlib::MemError
281
- * - Zlib::BufError
282
- * - Zlib::VersionError
273
+ * - Zstdlib::Deflate
274
+ * - Zstdlib::Inflate
275
+ * - Zstdlib::ZStream
276
+ * - Zstdlib::Error
277
+ * - Zstdlib::StreamEnd
278
+ * - Zstdlib::NeedDict
279
+ * - Zstdlib::DataError
280
+ * - Zstdlib::StreamError
281
+ * - Zstdlib::MemError
282
+ * - Zstdlib::BufError
283
+ * - Zstdlib::VersionError
283
284
  *
284
285
  * (if you have GZIP_SUPPORT)
285
- * - Zlib::GzipReader
286
- * - Zlib::GzipWriter
287
- * - Zlib::GzipFile
288
- * - Zlib::GzipFile::Error
289
- * - Zlib::GzipFile::LengthError
290
- * - Zlib::GzipFile::CRCError
291
- * - Zlib::GzipFile::NoFooter
286
+ * - Zstdlib::GzipReader
287
+ * - Zstdlib::GzipWriter
288
+ * - Zstdlib::GzipFile
289
+ * - Zstdlib::GzipFile::Error
290
+ * - Zstdlib::GzipFile::LengthError
291
+ * - Zstdlib::GzipFile::CRCError
292
+ * - Zstdlib::GzipFile::NoFooter
292
293
  *
293
294
  */
294
- void Init_zlib(void);
295
+ void Init_zstdlib(void);
295
296
 
296
297
  /*--------- Exceptions --------*/
297
298
 
@@ -351,9 +352,22 @@ finalizer_warn(const char *msg)
351
352
 
352
353
 
353
354
  /*-------- module Zlib --------*/
355
+ /*
356
+ * Document-method: Zstdlib.zstd_version
357
+ *
358
+ * Returns the string which represents the version of zstd library.
359
+ */
360
+ static VALUE
361
+ rb_zstd_version(VALUE klass)
362
+ {
363
+ VALUE str;
364
+ str = rb_str_new2(ZSTD_versionString());
365
+ OBJ_TAINT(str);
366
+ return str;
367
+ }
354
368
 
355
369
  /*
356
- * Document-method: Zlib.zlib_version
370
+ * Document-method: Zstdlib.zlib_version
357
371
  *
358
372
  * Returns the string which represents the version of zlib library.
359
373
  */
@@ -414,9 +428,9 @@ do_checksum(int argc, VALUE *argv, uLong (*func)(uLong, const Bytef*, uInt))
414
428
  }
415
429
 
416
430
  /*
417
- * Document-method: Zlib.adler32
431
+ * Document-method: Zstdlib.adler32
418
432
  *
419
- * call-seq: Zlib.adler32(string, adler)
433
+ * call-seq: Zstdlib.adler32(string, adler)
420
434
  *
421
435
  * Calculates Adler-32 checksum for +string+, and returns updated value of
422
436
  * +adler+. If +string+ is omitted, it returns the Adler-32 initial value. If
@@ -424,10 +438,10 @@ do_checksum(int argc, VALUE *argv, uLong (*func)(uLong, const Bytef*, uInt))
424
438
  *
425
439
  * Example usage:
426
440
  *
427
- * require "zlib"
441
+ * require "zstdlib"
428
442
  *
429
443
  * data = "foo"
430
- * puts "Adler32 checksum: #{Zlib.adler32(data).to_s(16)}"
444
+ * puts "Adler32 checksum: #{Zstdlib.adler32(data).to_s(16)}"
431
445
  * #=> Adler32 checksum: 2820145
432
446
  *
433
447
  */
@@ -439,9 +453,9 @@ rb_zlib_adler32(int argc, VALUE *argv, VALUE klass)
439
453
 
440
454
  #ifdef HAVE_ADLER32_COMBINE
441
455
  /*
442
- * Document-method: Zlib.adler32_combine
456
+ * Document-method: Zstdlib.adler32_combine
443
457
  *
444
- * call-seq: Zlib.adler32_combine(adler1, adler2, len2)
458
+ * call-seq: Zstdlib.adler32_combine(adler1, adler2, len2)
445
459
  *
446
460
  * Combine two Adler-32 check values in to one. +alder1+ is the first Adler-32
447
461
  * value, +adler2+ is the second Adler-32 value. +len2+ is the length of the
@@ -459,9 +473,9 @@ rb_zlib_adler32_combine(VALUE klass, VALUE adler1, VALUE adler2, VALUE len2)
459
473
  #endif
460
474
 
461
475
  /*
462
- * Document-method: Zlib.crc32
476
+ * Document-method: Zstdlib.crc32
463
477
  *
464
- * call-seq: Zlib.crc32(string, crc)
478
+ * call-seq: Zstdlib.crc32(string, crc)
465
479
  *
466
480
  * Calculates CRC checksum for +string+, and returns updated value of +crc+. If
467
481
  * +string+ is omitted, it returns the CRC initial value. If +crc+ is omitted, it
@@ -477,9 +491,9 @@ rb_zlib_crc32(int argc, VALUE *argv, VALUE klass)
477
491
 
478
492
  #ifdef HAVE_CRC32_COMBINE
479
493
  /*
480
- * Document-method: Zlib.crc32_combine
494
+ * Document-method: Zstdlib.crc32_combine
481
495
  *
482
- * call-seq: Zlib.crc32_combine(crc1, crc2, len2)
496
+ * call-seq: Zstdlib.crc32_combine(crc1, crc2, len2)
483
497
  *
484
498
  * Combine two CRC-32 check values in to one. +crc1+ is the first CRC-32
485
499
  * value, +crc2+ is the second CRC-32 value. +len2+ is the length of the
@@ -497,7 +511,7 @@ rb_zlib_crc32_combine(VALUE klass, VALUE crc1, VALUE crc2, VALUE len2)
497
511
  #endif
498
512
 
499
513
  /*
500
- * Document-method: Zlib.crc_table
514
+ * Document-method: Zstdlib.crc_table
501
515
  *
502
516
  * Returns the table for calculating CRC checksum as an array.
503
517
  */
@@ -1171,19 +1185,19 @@ get_zstream(VALUE obj)
1171
1185
  /* ------------------------------------------------------------------------- */
1172
1186
 
1173
1187
  /*
1174
- * Document-class: Zlib::ZStream
1188
+ * Document-class: Zstdlib::ZStream
1175
1189
  *
1176
- * Zlib::ZStream is the abstract class for the stream which handles the
1190
+ * Zstdlib::ZStream is the abstract class for the stream which handles the
1177
1191
  * compressed data. The operations are defined in the subclasses:
1178
- * Zlib::Deflate for compression, and Zlib::Inflate for decompression.
1192
+ * Zstdlib::Deflate for compression, and Zstdlib::Inflate for decompression.
1179
1193
  *
1180
- * An instance of Zlib::ZStream has one stream (struct zstream in the source)
1194
+ * An instance of Zstdlib::ZStream has one stream (struct zstream in the source)
1181
1195
  * and two variable-length buffers which associated to the input (next_in) of
1182
1196
  * the stream and the output (next_out) of the stream. In this document,
1183
1197
  * "input buffer" means the buffer for input, and "output buffer" means the
1184
1198
  * buffer for output.
1185
1199
  *
1186
- * Data input into an instance of Zlib::ZStream are temporally stored into
1200
+ * Data input into an instance of Zstdlib::ZStream are temporally stored into
1187
1201
  * the end of input buffer, and then data in input buffer are processed from
1188
1202
  * the beginning of the buffer until no more output from the stream is
1189
1203
  * produced (i.e. until avail_out > 0 after processing). During processing,
@@ -1195,7 +1209,7 @@ get_zstream(VALUE obj)
1195
1209
  *
1196
1210
  * Here is an ascii art for describing above:
1197
1211
  *
1198
- * +================ an instance of Zlib::ZStream ================+
1212
+ * +================ an instance of Zstdlib::ZStream ================+
1199
1213
  * || ||
1200
1214
  * || +--------+ +-------+ +--------+ ||
1201
1215
  * || +--| output |<---------|zstream|<---------| input |<--+ ||
@@ -1208,15 +1222,15 @@ get_zstream(VALUE obj)
1208
1222
  * "output data" "input data"
1209
1223
  *
1210
1224
  * If an error occurs during processing input buffer, an exception which is a
1211
- * subclass of Zlib::Error is raised. At that time, both input and output
1225
+ * subclass of Zstdlib::Error is raised. At that time, both input and output
1212
1226
  * buffer keep their conditions at the time when the error occurs.
1213
1227
  *
1214
1228
  * == Method Catalogue
1215
1229
  *
1216
1230
  * Many of the methods in this class are fairly low-level and unlikely to be
1217
1231
  * of interest to users. In fact, users are unlikely to use this class
1218
- * directly; rather they will be interested in Zlib::Inflate and
1219
- * Zlib::Deflate.
1232
+ * directly; rather they will be interested in Zstdlib::Inflate and
1233
+ * Zstdlib::Deflate.
1220
1234
  *
1221
1235
  * The higher level methods are listed below.
1222
1236
  *
@@ -1408,9 +1422,9 @@ rb_zstream_closed_p(VALUE obj)
1408
1422
  /* ------------------------------------------------------------------------- */
1409
1423
 
1410
1424
  /*
1411
- * Document-class: Zlib::Deflate
1425
+ * Document-class: Zstdlib::Deflate
1412
1426
  *
1413
- * Zlib::Deflate is the class for compressing data. See Zlib::ZStream for more
1427
+ * Zstdlib::Deflate is the class for compressing data. See Zstdlib::ZStream for more
1414
1428
  * information.
1415
1429
  */
1416
1430
 
@@ -1418,7 +1432,7 @@ rb_zstream_closed_p(VALUE obj)
1418
1432
  (NIL_P((val)) ? (ifnil) \
1419
1433
  : (FIX2INT((val))))
1420
1434
 
1421
- #define ARG_LEVEL(val) FIXNUMARG((val), Z_DEFAULT_COMPRESSION)
1435
+ #define ARG_LEVEL(val) FIXNUMARG((val), ZSTD_CLEVEL_DEFAULT)
1422
1436
  #define ARG_WBITS(val) FIXNUMARG((val), MAX_WBITS)
1423
1437
  #define ARG_MEMLEVEL(val) FIXNUMARG((val), DEF_MEM_LEVEL)
1424
1438
  #define ARG_STRATEGY(val) FIXNUMARG((val), Z_DEFAULT_STRATEGY)
@@ -1432,10 +1446,10 @@ rb_deflate_s_allocate(VALUE klass)
1432
1446
  }
1433
1447
 
1434
1448
  /*
1435
- * Document-method: Zlib::Deflate.new
1449
+ * Document-method: Zstdlib::Deflate.new
1436
1450
  *
1437
1451
  * call-seq:
1438
- * Zlib::Deflate.new(level=DEFAULT_COMPRESSION, window_bits=MAX_WBITS, mem_level=DEF_MEM_LEVEL, strategy=DEFAULT_STRATEGY)
1452
+ * Zstdlib::Deflate.new(level=DEFAULT_COMPRESSION, window_bits=MAX_WBITS, mem_level=DEF_MEM_LEVEL, strategy=DEFAULT_STRATEGY)
1439
1453
  *
1440
1454
  * Creates a new deflate stream for compression. If a given argument is nil,
1441
1455
  * the default value of that argument is used.
@@ -1444,10 +1458,10 @@ rb_deflate_s_allocate(VALUE klass)
1444
1458
  * compression) and 9 (best compression). The following constants have been
1445
1459
  * defined to make code more readable:
1446
1460
  *
1447
- * * Zlib::DEFAULT_COMPRESSION
1448
- * * Zlib::NO_COMPRESSION
1449
- * * Zlib::BEST_SPEED
1450
- * * Zlib::BEST_COMPRESSION
1461
+ * * Zstdlib::DEFAULT_COMPRESSION
1462
+ * * Zstdlib::NO_COMPRESSION
1463
+ * * Zstdlib::BEST_SPEED
1464
+ * * Zstdlib::BEST_COMPRESSION
1451
1465
  *
1452
1466
  * See http://www.zlib.net/manual.html#Constants for further information.
1453
1467
  *
@@ -1460,17 +1474,17 @@ rb_deflate_s_allocate(VALUE klass)
1460
1474
  * compression ratio while 9 uses maximum memory for optimal speed. The
1461
1475
  * default value is 8. Two constants are defined:
1462
1476
  *
1463
- * * Zlib::DEF_MEM_LEVEL
1464
- * * Zlib::MAX_MEM_LEVEL
1477
+ * * Zstdlib::DEF_MEM_LEVEL
1478
+ * * Zstdlib::MAX_MEM_LEVEL
1465
1479
  *
1466
1480
  * The +strategy+ sets the deflate compression strategy. The following
1467
1481
  * strategies are available:
1468
1482
  *
1469
- * Zlib::DEFAULT_STRATEGY:: For normal data
1470
- * Zlib::FILTERED:: For data produced by a filter or predictor
1471
- * Zlib::FIXED:: Prevents dynamic Huffman codes
1472
- * Zlib::HUFFMAN_ONLY:: Prevents string matching
1473
- * Zlib::RLE:: Designed for better compression of PNG image data
1483
+ * Zstdlib::DEFAULT_STRATEGY:: For normal data
1484
+ * Zstdlib::FILTERED:: For data produced by a filter or predictor
1485
+ * Zstdlib::FIXED:: Prevents dynamic Huffman codes
1486
+ * Zstdlib::HUFFMAN_ONLY:: Prevents string matching
1487
+ * Zstdlib::RLE:: Designed for better compression of PNG image data
1474
1488
  *
1475
1489
  * See the constants for further description.
1476
1490
  *
@@ -1479,16 +1493,16 @@ rb_deflate_s_allocate(VALUE klass)
1479
1493
  * === Basic
1480
1494
  *
1481
1495
  * open "compressed.file", "w+" do |io|
1482
- * io << Zlib::Deflate.new.deflate(File.read("big.file"))
1496
+ * io << Zstdlib::Deflate.new.deflate(File.read("big.file"))
1483
1497
  * end
1484
1498
  *
1485
1499
  * === Custom compression
1486
1500
  *
1487
1501
  * open "compressed.file", "w+" do |compressed_io|
1488
- * deflate = Zlib::Deflate.new(Zlib::BEST_COMPRESSION,
1489
- * Zlib::MAX_WBITS,
1490
- * Zlib::MAX_MEM_LEVEL,
1491
- * Zlib::HUFFMAN_ONLY)
1502
+ * deflate = Zstdlib::Deflate.new(Zstdlib::BEST_COMPRESSION,
1503
+ * Zstdlib::MAX_WBITS,
1504
+ * Zstdlib::MAX_MEM_LEVEL,
1505
+ * Zstdlib::HUFFMAN_ONLY)
1492
1506
  *
1493
1507
  * begin
1494
1508
  * open "big.file" do |big_io|
@@ -1526,7 +1540,7 @@ rb_deflate_initialize(int argc, VALUE *argv, VALUE obj)
1526
1540
  }
1527
1541
 
1528
1542
  /*
1529
- * Document-method: Zlib::Deflate#initialize_copy
1543
+ * Document-method: Zstdlib::Deflate#initialize_copy
1530
1544
  *
1531
1545
  * Duplicates the deflate stream.
1532
1546
  */
@@ -1562,26 +1576,26 @@ deflate_run(VALUE args)
1562
1576
  }
1563
1577
 
1564
1578
  /*
1565
- * Document-method: Zlib::Deflate.deflate
1579
+ * Document-method: Zstdlib::Deflate.deflate
1566
1580
  *
1567
1581
  * call-seq:
1568
- * Zlib.deflate(string[, level])
1569
- * Zlib::Deflate.deflate(string[, level])
1582
+ * Zstdlib.deflate(string[, level])
1583
+ * Zstdlib::Deflate.deflate(string[, level])
1570
1584
  *
1571
1585
  * Compresses the given +string+. Valid values of level are
1572
- * Zlib::NO_COMPRESSION, Zlib::BEST_SPEED, Zlib::BEST_COMPRESSION,
1573
- * Zlib::DEFAULT_COMPRESSION, or an integer from 0 to 9.
1586
+ * Zstdlib::NO_COMPRESSION, Zstdlib::BEST_SPEED, Zstdlib::BEST_COMPRESSION,
1587
+ * Zstdlib::DEFAULT_COMPRESSION, or an integer from 0 to 9.
1574
1588
  *
1575
1589
  * This method is almost equivalent to the following code:
1576
1590
  *
1577
1591
  * def deflate(string, level)
1578
- * z = Zlib::Deflate.new(level)
1579
- * dst = z.deflate(string, Zlib::FINISH)
1592
+ * z = Zstdlib::Deflate.new(level)
1593
+ * dst = z.deflate(string, Zstdlib::FINISH)
1580
1594
  * z.close
1581
1595
  * dst
1582
1596
  * end
1583
1597
  *
1584
- * See also Zlib.inflate
1598
+ * See also Zstdlib.inflate
1585
1599
  *
1586
1600
  */
1587
1601
  static VALUE
@@ -1624,16 +1638,16 @@ do_deflate(struct zstream *z, VALUE src, int flush)
1624
1638
  }
1625
1639
 
1626
1640
  /*
1627
- * Document-method: Zlib::Deflate#deflate
1641
+ * Document-method: Zstdlib::Deflate#deflate
1628
1642
  *
1629
1643
  * call-seq:
1630
- * z.deflate(string, flush = Zlib::NO_FLUSH) -> String
1631
- * z.deflate(string, flush = Zlib::NO_FLUSH) { |chunk| ... } -> nil
1644
+ * z.deflate(string, flush = Zstdlib::NO_FLUSH) -> String
1645
+ * z.deflate(string, flush = Zstdlib::NO_FLUSH) { |chunk| ... } -> nil
1632
1646
  *
1633
1647
  * Inputs +string+ into the deflate stream and returns the output from the
1634
1648
  * stream. On calling this method, both the input and the output buffers of
1635
1649
  * the stream are flushed. If +string+ is nil, this method finishes the
1636
- * stream, just like Zlib::ZStream#finish.
1650
+ * stream, just like Zstdlib::ZStream#finish.
1637
1651
  *
1638
1652
  * If a block is given consecutive deflated chunks from the +string+ are
1639
1653
  * yielded to the block and +nil+ is returned.
@@ -1641,10 +1655,10 @@ do_deflate(struct zstream *z, VALUE src, int flush)
1641
1655
  * The +flush+ parameter specifies the flush mode. The following constants
1642
1656
  * may be used:
1643
1657
  *
1644
- * Zlib::NO_FLUSH:: The default
1645
- * Zlib::SYNC_FLUSH:: Flushes the output to a byte boundary
1646
- * Zlib::FULL_FLUSH:: SYNC_FLUSH + resets the compression state
1647
- * Zlib::FINISH:: Pending input is processed, pending output is flushed.
1658
+ * Zstdlib::NO_FLUSH:: The default
1659
+ * Zstdlib::SYNC_FLUSH:: Flushes the output to a byte boundary
1660
+ * Zstdlib::FULL_FLUSH:: SYNC_FLUSH + resets the compression state
1661
+ * Zstdlib::FINISH:: Pending input is processed, pending output is flushed.
1648
1662
  *
1649
1663
  * See the constants for further description.
1650
1664
  *
@@ -1663,12 +1677,12 @@ rb_deflate_deflate(int argc, VALUE *argv, VALUE obj)
1663
1677
  }
1664
1678
 
1665
1679
  /*
1666
- * Document-method: Zlib::Deflate#<<
1680
+ * Document-method: Zstdlib::Deflate#<<
1667
1681
  *
1668
1682
  * call-seq: << string
1669
1683
  *
1670
- * Inputs +string+ into the deflate stream just like Zlib::Deflate#deflate, but
1671
- * returns the Zlib::Deflate object itself. The output from the stream is
1684
+ * Inputs +string+ into the deflate stream just like Zstdlib::Deflate#deflate, but
1685
+ * returns the Zstdlib::Deflate object itself. The output from the stream is
1672
1686
  * preserved in output buffer.
1673
1687
  */
1674
1688
  static VALUE
@@ -1680,18 +1694,18 @@ rb_deflate_addstr(VALUE obj, VALUE src)
1680
1694
  }
1681
1695
 
1682
1696
  /*
1683
- * Document-method: Zlib::Deflate#flush
1697
+ * Document-method: Zstdlib::Deflate#flush
1684
1698
  *
1685
1699
  * call-seq:
1686
- * flush(flush = Zlib::SYNC_FLUSH) -> String
1687
- * flush(flush = Zlib::SYNC_FLUSH) { |chunk| ... } -> nil
1700
+ * flush(flush = Zstdlib::SYNC_FLUSH) -> String
1701
+ * flush(flush = Zstdlib::SYNC_FLUSH) { |chunk| ... } -> nil
1688
1702
  *
1689
1703
  * This method is equivalent to <tt>deflate('', flush)</tt>. This method is
1690
1704
  * just provided to improve the readability of your Ruby program. If a block
1691
1705
  * is given chunks of deflate output are yielded to the block until the buffer
1692
1706
  * is flushed.
1693
1707
  *
1694
- * See Zlib::Deflate#deflate for detail on the +flush+ constants NO_FLUSH,
1708
+ * See Zstdlib::Deflate#deflate for detail on the +flush+ constants NO_FLUSH,
1695
1709
  * SYNC_FLUSH, FULL_FLUSH and FINISH.
1696
1710
  */
1697
1711
  static VALUE
@@ -1711,7 +1725,7 @@ rb_deflate_flush(int argc, VALUE *argv, VALUE obj)
1711
1725
  }
1712
1726
 
1713
1727
  /*
1714
- * Document-method: Zlib::Deflate.params
1728
+ * Document-method: Zstdlib::Deflate.params
1715
1729
  *
1716
1730
  * call-seq: params(level, strategy)
1717
1731
  *
@@ -1719,7 +1733,7 @@ rb_deflate_flush(int argc, VALUE *argv, VALUE obj)
1719
1733
  * different types of data that require different types of compression. Any
1720
1734
  * unprocessed data is flushed before changing the params.
1721
1735
  *
1722
- * See Zlib::Deflate.new for a description of +level+ and +strategy+.
1736
+ * See Zstdlib::Deflate.new for a description of +level+ and +strategy+.
1723
1737
  *
1724
1738
  */
1725
1739
  static VALUE
@@ -1754,12 +1768,12 @@ rb_deflate_params(VALUE obj, VALUE v_level, VALUE v_strategy)
1754
1768
  }
1755
1769
 
1756
1770
  /*
1757
- * Document-method: Zlib::Deflate.set_dictionary
1771
+ * Document-method: Zstdlib::Deflate.set_dictionary
1758
1772
  *
1759
1773
  * call-seq: set_dictionary(string)
1760
1774
  *
1761
1775
  * Sets the preset dictionary and returns +string+. This method is available
1762
- * just only after Zlib::Deflate.new or Zlib::ZStream#reset method was called.
1776
+ * just only after Zstdlib::Deflate.new or Zstdlib::ZStream#reset method was called.
1763
1777
  * See zlib.h for details.
1764
1778
  *
1765
1779
  * Can raise errors of Z_STREAM_ERROR if a parameter is invalid (such as
@@ -1789,10 +1803,10 @@ rb_deflate_set_dictionary(VALUE obj, VALUE dic)
1789
1803
  /* ------------------------------------------------------------------------- */
1790
1804
 
1791
1805
  /*
1792
- * Document-class: Zlib::Inflate
1806
+ * Document-class: Zstdlib::Inflate
1793
1807
  *
1794
1808
  * Zlib:Inflate is the class for decompressing compressed data. Unlike
1795
- * Zlib::Deflate, an instance of this class is not able to duplicate (clone,
1809
+ * Zstdlib::Deflate, an instance of this class is not able to duplicate (clone,
1796
1810
  * dup) itself.
1797
1811
  */
1798
1812
 
@@ -1805,10 +1819,10 @@ rb_inflate_s_allocate(VALUE klass)
1805
1819
  }
1806
1820
 
1807
1821
  /*
1808
- * Document-method: Zlib::Inflate.new
1822
+ * Document-method: Zstdlib::Inflate.new
1809
1823
  *
1810
1824
  * call-seq:
1811
- * Zlib::Inflate.new(window_bits = Zlib::MAX_WBITS)
1825
+ * Zstdlib::Inflate.new(window_bits = Zstdlib::MAX_WBITS)
1812
1826
  *
1813
1827
  * Creates a new inflate stream for decompression. +window_bits+ sets the
1814
1828
  * size of the history buffer and can have the following values:
@@ -1825,7 +1839,7 @@ rb_inflate_s_allocate(VALUE klass)
1825
1839
  * Greater than 15::
1826
1840
  * Add 32 to window_bits to enable zlib and gzip decoding with automatic
1827
1841
  * header detection, or add 16 to decode only the gzip format (a
1828
- * Zlib::DataError will be raised for a non-gzip stream).
1842
+ * Zstdlib::DataError will be raised for a non-gzip stream).
1829
1843
  *
1830
1844
  * (-8..-15)::
1831
1845
  * Enables raw deflate mode which will not generate a check value, and will
@@ -1837,7 +1851,7 @@ rb_inflate_s_allocate(VALUE klass)
1837
1851
  * == Example
1838
1852
  *
1839
1853
  * open "compressed.file" do |compressed_io|
1840
- * zi = Zlib::Inflate.new(Zlib::MAX_WBITS + 32)
1854
+ * zi = Zstdlib::Inflate.new(Zstdlib::MAX_WBITS + 32)
1841
1855
  *
1842
1856
  * begin
1843
1857
  * open "uncompressed.file", "w+" do |uncompressed_io|
@@ -1880,26 +1894,26 @@ inflate_run(VALUE args)
1880
1894
  }
1881
1895
 
1882
1896
  /*
1883
- * Document-method: Zlib::inflate
1897
+ * Document-method: Zstdlib::inflate
1884
1898
  *
1885
1899
  * call-seq:
1886
- * Zlib.inflate(string)
1887
- * Zlib::Inflate.inflate(string)
1900
+ * Zstdlib.inflate(string)
1901
+ * Zstdlib::Inflate.inflate(string)
1888
1902
  *
1889
- * Decompresses +string+. Raises a Zlib::NeedDict exception if a preset
1903
+ * Decompresses +string+. Raises a Zstdlib::NeedDict exception if a preset
1890
1904
  * dictionary is needed for decompression.
1891
1905
  *
1892
1906
  * This method is almost equivalent to the following code:
1893
1907
  *
1894
1908
  * def inflate(string)
1895
- * zstream = Zlib::Inflate.new
1909
+ * zstream = Zstdlib::Inflate.new
1896
1910
  * buf = zstream.inflate(string)
1897
1911
  * zstream.finish
1898
1912
  * zstream.close
1899
1913
  * buf
1900
1914
  * end
1901
1915
  *
1902
- * See also Zlib.deflate
1916
+ * See also Zstdlib.deflate
1903
1917
  *
1904
1918
  */
1905
1919
  static VALUE
@@ -1938,7 +1952,7 @@ do_inflate(struct zstream *z, VALUE src)
1938
1952
  }
1939
1953
  }
1940
1954
 
1941
- /* Document-method: Zlib::Inflate#add_dictionary
1955
+ /* Document-method: Zstdlib::Inflate#add_dictionary
1942
1956
  *
1943
1957
  * call-seq: add_dictionary(string)
1944
1958
  *
@@ -1959,7 +1973,7 @@ rb_inflate_add_dictionary(VALUE obj, VALUE dictionary)
1959
1973
  }
1960
1974
 
1961
1975
  /*
1962
- * Document-method: Zlib::Inflate#inflate
1976
+ * Document-method: Zstdlib::Inflate#inflate
1963
1977
  *
1964
1978
  * call-seq:
1965
1979
  * inflate(deflate_string) -> String
@@ -1968,22 +1982,22 @@ rb_inflate_add_dictionary(VALUE obj, VALUE dictionary)
1968
1982
  * Inputs +deflate_string+ into the inflate stream and returns the output from
1969
1983
  * the stream. Calling this method, both the input and the output buffer of
1970
1984
  * the stream are flushed. If string is +nil+, this method finishes the
1971
- * stream, just like Zlib::ZStream#finish.
1985
+ * stream, just like Zstdlib::ZStream#finish.
1972
1986
  *
1973
1987
  * If a block is given consecutive inflated chunks from the +deflate_string+
1974
1988
  * are yielded to the block and +nil+ is returned.
1975
1989
  *
1976
- * Raises a Zlib::NeedDict exception if a preset dictionary is needed to
1977
- * decompress. Set the dictionary by Zlib::Inflate#set_dictionary and then
1990
+ * Raises a Zstdlib::NeedDict exception if a preset dictionary is needed to
1991
+ * decompress. Set the dictionary by Zstdlib::Inflate#set_dictionary and then
1978
1992
  * call this method again with an empty string to flush the stream:
1979
1993
  *
1980
- * inflater = Zlib::Inflate.new
1994
+ * inflater = Zstdlib::Inflate.new
1981
1995
  *
1982
1996
  * begin
1983
1997
  * out = inflater.inflate compressed
1984
- * rescue Zlib::NeedDict
1998
+ * rescue Zstdlib::NeedDict
1985
1999
  * # ensure the dictionary matches the stream's required dictionary
1986
- * raise unless inflater.adler == Zlib.adler32(dictionary)
2000
+ * raise unless inflater.adler == Zstdlib.adler32(dictionary)
1987
2001
  *
1988
2002
  * inflater.set_dictionary dictionary
1989
2003
  * inflater.inflate ''
@@ -1993,7 +2007,7 @@ rb_inflate_add_dictionary(VALUE obj, VALUE dictionary)
1993
2007
  *
1994
2008
  * inflater.close
1995
2009
  *
1996
- * See also Zlib::Inflate.new
2010
+ * See also Zstdlib::Inflate.new
1997
2011
  */
1998
2012
  static VALUE
1999
2013
  rb_inflate_inflate(VALUE obj, VALUE src)
@@ -2028,8 +2042,8 @@ rb_inflate_inflate(VALUE obj, VALUE src)
2028
2042
  /*
2029
2043
  * call-seq: << string
2030
2044
  *
2031
- * Inputs +string+ into the inflate stream just like Zlib::Inflate#inflate, but
2032
- * returns the Zlib::Inflate object itself. The output from the stream is
2045
+ * Inputs +string+ into the inflate stream just like Zstdlib::Inflate#inflate, but
2046
+ * returns the Zstdlib::Inflate object itself. The output from the stream is
2033
2047
  * preserved in output buffer.
2034
2048
  */
2035
2049
  static VALUE
@@ -2097,10 +2111,10 @@ rb_inflate_sync_point_p(VALUE obj)
2097
2111
  }
2098
2112
 
2099
2113
  /*
2100
- * Document-method: Zlib::Inflate#set_dictionary
2114
+ * Document-method: Zstdlib::Inflate#set_dictionary
2101
2115
  *
2102
2116
  * Sets the preset dictionary and returns +string+. This method is available just
2103
- * only after a Zlib::NeedDict exception was raised. See zlib.h for details.
2117
+ * only after a Zstdlib::NeedDict exception was raised. See zlib.h for details.
2104
2118
  *
2105
2119
  */
2106
2120
  static VALUE
@@ -2227,7 +2241,7 @@ gzfile_free(void *p)
2227
2241
 
2228
2242
  if (ZSTREAM_IS_READY(z)) {
2229
2243
  if (z->func == &deflate_funcs) {
2230
- finalizer_warn("Zlib::GzipWriter object must be closed explicitly.");
2244
+ finalizer_warn("Zstdlib::GzipWriter object must be closed explicitly.");
2231
2245
  }
2232
2246
  zstream_finalize(z);
2233
2247
  }
@@ -2375,7 +2389,7 @@ gzfile_read_raw_ensure(struct gzfile *gz, long size)
2375
2389
  {
2376
2390
  VALUE str;
2377
2391
 
2378
- if (gz->io == Qundef) { /* Zlib.gunzip */
2392
+ if (gz->io == Qundef) { /* Zstdlib.gunzip */
2379
2393
  if (NIL_P(gz->z.input) || RSTRING_LEN(gz->z.input) < size)
2380
2394
  rb_raise(cGzError, "unexpected end of string");
2381
2395
  }
@@ -2447,7 +2461,7 @@ gzfile_raise(struct gzfile *gz, VALUE klass, const char *message)
2447
2461
  }
2448
2462
 
2449
2463
  /*
2450
- * Document-method: Zlib::GzipFile::Error#inspect
2464
+ * Document-method: Zstdlib::GzipFile::Error#inspect
2451
2465
  *
2452
2466
  * Constructs a String of the GzipFile Error
2453
2467
  */
@@ -2485,7 +2499,7 @@ gzfile_make_header(struct gzfile *gz)
2485
2499
  if (gz->level == Z_BEST_SPEED) {
2486
2500
  extraflags |= GZ_EXTRAFLAG_FAST;
2487
2501
  }
2488
- else if (gz->level == Z_BEST_COMPRESSION) {
2502
+ else if (gz->level == ZSTD_maxCLevel()) {
2489
2503
  extraflags |= GZ_EXTRAFLAG_SLOW;
2490
2504
  }
2491
2505
 
@@ -2556,10 +2570,10 @@ gzfile_read_header(struct gzfile *gz)
2556
2570
  gz->level = Z_BEST_SPEED;
2557
2571
  }
2558
2572
  else if (head[8] & GZ_EXTRAFLAG_SLOW) {
2559
- gz->level = Z_BEST_COMPRESSION;
2573
+ gz->level = ZSTD_maxCLevel();
2560
2574
  }
2561
2575
  else {
2562
- gz->level = Z_DEFAULT_COMPRESSION;
2576
+ gz->level = ZSTD_CLEVEL_DEFAULT;
2563
2577
  }
2564
2578
 
2565
2579
  gz->mtime = gzfile_get32(&head[4]);
@@ -2948,40 +2962,40 @@ get_gzfile(VALUE obj)
2948
2962
  /* ------------------------------------------------------------------------- */
2949
2963
 
2950
2964
  /*
2951
- * Document-class: Zlib::GzipFile
2965
+ * Document-class: Zstdlib::GzipFile
2952
2966
  *
2953
- * Zlib::GzipFile is an abstract class for handling a gzip formatted
2967
+ * Zstdlib::GzipFile is an abstract class for handling a gzip formatted
2954
2968
  * compressed file. The operations are defined in the subclasses,
2955
- * Zlib::GzipReader for reading, and Zlib::GzipWriter for writing.
2969
+ * Zstdlib::GzipReader for reading, and Zstdlib::GzipWriter for writing.
2956
2970
  *
2957
2971
  * GzipReader should be used by associating an IO, or IO-like, object.
2958
2972
  *
2959
2973
  * == Method Catalogue
2960
2974
  *
2961
2975
  * - ::wrap
2962
- * - ::open (Zlib::GzipReader::open and Zlib::GzipWriter::open)
2976
+ * - ::open (Zstdlib::GzipReader::open and Zstdlib::GzipWriter::open)
2963
2977
  * - #close
2964
2978
  * - #closed?
2965
2979
  * - #comment
2966
- * - comment= (Zlib::GzipWriter#comment=)
2980
+ * - comment= (Zstdlib::GzipWriter#comment=)
2967
2981
  * - #crc
2968
- * - eof? (Zlib::GzipReader#eof?)
2982
+ * - eof? (Zstdlib::GzipReader#eof?)
2969
2983
  * - #finish
2970
2984
  * - #level
2971
- * - lineno (Zlib::GzipReader#lineno)
2972
- * - lineno= (Zlib::GzipReader#lineno=)
2985
+ * - lineno (Zstdlib::GzipReader#lineno)
2986
+ * - lineno= (Zstdlib::GzipReader#lineno=)
2973
2987
  * - #mtime
2974
- * - mtime= (Zlib::GzipWriter#mtime=)
2988
+ * - mtime= (Zstdlib::GzipWriter#mtime=)
2975
2989
  * - #orig_name
2976
- * - orig_name (Zlib::GzipWriter#orig_name=)
2990
+ * - orig_name (Zstdlib::GzipWriter#orig_name=)
2977
2991
  * - #os_code
2978
2992
  * - path (when the underlying IO supports #path)
2979
2993
  * - #sync
2980
2994
  * - #sync=
2981
2995
  * - #to_io
2982
2996
  *
2983
- * (due to internal structure, documentation may appear under Zlib::GzipReader
2984
- * or Zlib::GzipWriter)
2997
+ * (due to internal structure, documentation may appear under Zstdlib::GzipReader
2998
+ * or Zstdlib::GzipWriter)
2985
2999
  */
2986
3000
 
2987
3001
 
@@ -3040,11 +3054,11 @@ gzfile_wrap(int argc, VALUE *argv, VALUE klass, int close_io_on_error)
3040
3054
  }
3041
3055
 
3042
3056
  /*
3043
- * Document-method: Zlib::GzipFile.wrap
3057
+ * Document-method: Zstdlib::GzipFile.wrap
3044
3058
  *
3045
3059
  * call-seq:
3046
- * Zlib::GzipReader.wrap(io, ...) { |gz| ... }
3047
- * Zlib::GzipWriter.wrap(io, ...) { |gz| ... }
3060
+ * Zstdlib::GzipReader.wrap(io, ...) { |gz| ... }
3061
+ * Zstdlib::GzipWriter.wrap(io, ...) { |gz| ... }
3048
3062
  *
3049
3063
  * Creates a GzipReader or GzipWriter associated with +io+, passing in any
3050
3064
  * necessary extra options, and executes the block with the newly created
@@ -3052,7 +3066,7 @@ gzfile_wrap(int argc, VALUE *argv, VALUE klass, int close_io_on_error)
3052
3066
  *
3053
3067
  * The GzipFile object will be closed automatically after executing the block.
3054
3068
  * If you want to keep the associated IO object open, you may call
3055
- * Zlib::GzipFile#finish method in the block.
3069
+ * Zstdlib::GzipFile#finish method in the block.
3056
3070
  */
3057
3071
  static VALUE
3058
3072
  rb_gzfile_s_wrap(int argc, VALUE *argv, VALUE klass)
@@ -3061,9 +3075,9 @@ rb_gzfile_s_wrap(int argc, VALUE *argv, VALUE klass)
3061
3075
  }
3062
3076
 
3063
3077
  /*
3064
- * Document-method: Zlib::GzipFile.open
3078
+ * Document-method: Zstdlib::GzipFile.open
3065
3079
  *
3066
- * See Zlib::GzipReader#open and Zlib::GzipWriter#open.
3080
+ * See Zstdlib::GzipReader#open and Zstdlib::GzipWriter#open.
3067
3081
  */
3068
3082
  static VALUE
3069
3083
  gzfile_s_open(int argc, VALUE *argv, VALUE klass, const char *mode)
@@ -3078,7 +3092,7 @@ gzfile_s_open(int argc, VALUE *argv, VALUE klass, const char *mode)
3078
3092
  }
3079
3093
 
3080
3094
  /*
3081
- * Document-method: Zlib::GzipFile#to_io
3095
+ * Document-method: Zstdlib::GzipFile#to_io
3082
3096
  *
3083
3097
  * Same as IO.
3084
3098
  */
@@ -3089,7 +3103,7 @@ rb_gzfile_to_io(VALUE obj)
3089
3103
  }
3090
3104
 
3091
3105
  /*
3092
- * Document-method: Zlib::GzipFile#crc
3106
+ * Document-method: Zstdlib::GzipFile#crc
3093
3107
  *
3094
3108
  * Returns CRC value of the uncompressed data.
3095
3109
  */
@@ -3100,7 +3114,7 @@ rb_gzfile_crc(VALUE obj)
3100
3114
  }
3101
3115
 
3102
3116
  /*
3103
- * Document-method: Zlib::GzipFile#mtime
3117
+ * Document-method: Zstdlib::GzipFile#mtime
3104
3118
  *
3105
3119
  * Returns last modification time recorded in the gzip file header.
3106
3120
  */
@@ -3111,7 +3125,7 @@ rb_gzfile_mtime(VALUE obj)
3111
3125
  }
3112
3126
 
3113
3127
  /*
3114
- * Document-method: Zlib::GzipFile#level
3128
+ * Document-method: Zstdlib::GzipFile#level
3115
3129
  *
3116
3130
  * Returns compression level.
3117
3131
  */
@@ -3122,7 +3136,7 @@ rb_gzfile_level(VALUE obj)
3122
3136
  }
3123
3137
 
3124
3138
  /*
3125
- * Document-method: Zlib::GzipFile#os_code
3139
+ * Document-method: Zstdlib::GzipFile#os_code
3126
3140
  *
3127
3141
  * Returns OS code number recorded in the gzip file header.
3128
3142
  */
@@ -3133,7 +3147,7 @@ rb_gzfile_os_code(VALUE obj)
3133
3147
  }
3134
3148
 
3135
3149
  /*
3136
- * Document-method: Zlib::GzipFile#orig_name
3150
+ * Document-method: Zstdlib::GzipFile#orig_name
3137
3151
  *
3138
3152
  * Returns original filename recorded in the gzip file header, or +nil+ if
3139
3153
  * original filename is not present.
@@ -3150,7 +3164,7 @@ rb_gzfile_orig_name(VALUE obj)
3150
3164
  }
3151
3165
 
3152
3166
  /*
3153
- * Document-method: Zlib::GzipFile#comment
3167
+ * Document-method: Zstdlib::GzipFile#comment
3154
3168
  *
3155
3169
  * Returns comments recorded in the gzip file header, or nil if the comments
3156
3170
  * is not present.
@@ -3167,7 +3181,7 @@ rb_gzfile_comment(VALUE obj)
3167
3181
  }
3168
3182
 
3169
3183
  /*
3170
- * Document-method: Zlib::GzipFile#lineno
3184
+ * Document-method: Zstdlib::GzipFile#lineno
3171
3185
  *
3172
3186
  * The line number of the last row read from this file.
3173
3187
  */
@@ -3178,7 +3192,7 @@ rb_gzfile_lineno(VALUE obj)
3178
3192
  }
3179
3193
 
3180
3194
  /*
3181
- * Document-method: Zlib::GzipReader#lineno=
3195
+ * Document-method: Zstdlib::GzipReader#lineno=
3182
3196
  *
3183
3197
  * Specify line number of the last row read from this file.
3184
3198
  */
@@ -3191,7 +3205,7 @@ rb_gzfile_set_lineno(VALUE obj, VALUE lineno)
3191
3205
  }
3192
3206
 
3193
3207
  /*
3194
- * Document-method: Zlib::GzipWriter#mtime=
3208
+ * Document-method: Zstdlib::GzipWriter#mtime=
3195
3209
  *
3196
3210
  * Specify the modification time (+mtime+) in the gzip header.
3197
3211
  * Using an Integer.
@@ -3226,7 +3240,7 @@ rb_gzfile_set_mtime(VALUE obj, VALUE mtime)
3226
3240
  }
3227
3241
 
3228
3242
  /*
3229
- * Document-method: Zlib::GzipFile#orig_name=
3243
+ * Document-method: Zstdlib::GzipFile#orig_name=
3230
3244
  *
3231
3245
  * Specify the original name (+str+) in the gzip header.
3232
3246
  */
@@ -3250,7 +3264,7 @@ rb_gzfile_set_orig_name(VALUE obj, VALUE str)
3250
3264
  }
3251
3265
 
3252
3266
  /*
3253
- * Document-method: Zlib::GzipFile#comment=
3267
+ * Document-method: Zstdlib::GzipFile#comment=
3254
3268
  *
3255
3269
  * Specify the comment (+str+) in the gzip header.
3256
3270
  */
@@ -3274,7 +3288,7 @@ rb_gzfile_set_comment(VALUE obj, VALUE str)
3274
3288
  }
3275
3289
 
3276
3290
  /*
3277
- * Document-method: Zlib::GzipFile#close
3291
+ * Document-method: Zstdlib::GzipFile#close
3278
3292
  *
3279
3293
  * Closes the GzipFile object. This method calls close method of the
3280
3294
  * associated IO object. Returns the associated IO object.
@@ -3295,9 +3309,9 @@ rb_gzfile_close(VALUE obj)
3295
3309
  }
3296
3310
 
3297
3311
  /*
3298
- * Document-method: Zlib::GzipFile#finish
3312
+ * Document-method: Zstdlib::GzipFile#finish
3299
3313
  *
3300
- * Closes the GzipFile object. Unlike Zlib::GzipFile#close, this method never
3314
+ * Closes the GzipFile object. Unlike Zstdlib::GzipFile#close, this method never
3301
3315
  * calls the close method of the associated IO object. Returns the associated IO
3302
3316
  * object.
3303
3317
  */
@@ -3313,7 +3327,7 @@ rb_gzfile_finish(VALUE obj)
3313
3327
  }
3314
3328
 
3315
3329
  /*
3316
- * Document-method: Zlib::GzipFile#closed?
3330
+ * Document-method: Zstdlib::GzipFile#closed?
3317
3331
  *
3318
3332
  * Same as IO#closed?
3319
3333
  *
@@ -3327,7 +3341,7 @@ rb_gzfile_closed_p(VALUE obj)
3327
3341
  }
3328
3342
 
3329
3343
  /*
3330
- * Document-method: Zlib::GzipFile#eof?
3344
+ * Document-method: Zstdlib::GzipFile#eof?
3331
3345
  *
3332
3346
  * Returns +true+ or +false+ whether the stream has reached the end.
3333
3347
  */
@@ -3339,7 +3353,7 @@ rb_gzfile_eof_p(VALUE obj)
3339
3353
  }
3340
3354
 
3341
3355
  /*
3342
- * Document-method: Zlib::GzipFile#sync
3356
+ * Document-method: Zstdlib::GzipFile#sync
3343
3357
  *
3344
3358
  * Same as IO#sync
3345
3359
  *
@@ -3351,7 +3365,7 @@ rb_gzfile_sync(VALUE obj)
3351
3365
  }
3352
3366
 
3353
3367
  /*
3354
- * Document-method: Zlib::GzipFile#sync=
3368
+ * Document-method: Zstdlib::GzipFile#sync=
3355
3369
  *
3356
3370
  * call-seq: sync = flag
3357
3371
  *
@@ -3374,7 +3388,7 @@ rb_gzfile_set_sync(VALUE obj, VALUE mode)
3374
3388
  }
3375
3389
 
3376
3390
  /*
3377
- * Document-method: Zlib::GzipFile#total_in
3391
+ * Document-method: Zstdlib::GzipFile#total_in
3378
3392
  *
3379
3393
  * Total number of input bytes read so far.
3380
3394
  */
@@ -3385,7 +3399,7 @@ rb_gzfile_total_in(VALUE obj)
3385
3399
  }
3386
3400
 
3387
3401
  /*
3388
- * Document-method: Zlib::GzipFile#total_out
3402
+ * Document-method: Zstdlib::GzipFile#total_out
3389
3403
  *
3390
3404
  * Total number of output bytes output so far.
3391
3405
  */
@@ -3404,7 +3418,7 @@ rb_gzfile_total_out(VALUE obj)
3404
3418
  }
3405
3419
 
3406
3420
  /*
3407
- * Document-method: Zlib::GzipFile#path
3421
+ * Document-method: Zstdlib::GzipFile#path
3408
3422
  *
3409
3423
  * call-seq: path
3410
3424
  *
@@ -3436,19 +3450,19 @@ rb_gzfile_ecopts(struct gzfile *gz, VALUE opts)
3436
3450
  /* ------------------------------------------------------------------------- */
3437
3451
 
3438
3452
  /*
3439
- * Document-class: Zlib::GzipWriter
3453
+ * Document-class: Zstdlib::GzipWriter
3440
3454
  *
3441
- * Zlib::GzipWriter is a class for writing gzipped files. GzipWriter should
3455
+ * Zstdlib::GzipWriter is a class for writing gzipped files. GzipWriter should
3442
3456
  * be used with an instance of IO, or IO-like, object.
3443
3457
  *
3444
3458
  * Following two example generate the same result.
3445
3459
  *
3446
- * Zlib::GzipWriter.open('hoge.gz') do |gz|
3460
+ * Zstdlib::GzipWriter.open('hoge.gz') do |gz|
3447
3461
  * gz.write 'jugemu jugemu gokou no surikire...'
3448
3462
  * end
3449
3463
  *
3450
3464
  * File.open('hoge.gz', 'w') do |f|
3451
- * gz = Zlib::GzipWriter.new(f)
3465
+ * gz = Zstdlib::GzipWriter.new(f)
3452
3466
  * gz.write 'jugemu jugemu gokou no surikire...'
3453
3467
  * gz.close
3454
3468
  * end
@@ -3456,14 +3470,14 @@ rb_gzfile_ecopts(struct gzfile *gz, VALUE opts)
3456
3470
  * To make like gzip(1) does, run following:
3457
3471
  *
3458
3472
  * orig = 'hoge.txt'
3459
- * Zlib::GzipWriter.open('hoge.gz') do |gz|
3473
+ * Zstdlib::GzipWriter.open('hoge.gz') do |gz|
3460
3474
  * gz.mtime = File.mtime(orig)
3461
3475
  * gz.orig_name = orig
3462
3476
  * gz.write IO.binread(orig)
3463
3477
  * end
3464
3478
  *
3465
3479
  * NOTE: Due to the limitation of Ruby's finalizer, you must explicitly close
3466
- * GzipWriter objects by Zlib::GzipWriter#close etc. Otherwise, GzipWriter
3480
+ * GzipWriter objects by Zstdlib::GzipWriter#close etc. Otherwise, GzipWriter
3467
3481
  * will be not able to write the gzip footer and will generate a broken gzip
3468
3482
  * file.
3469
3483
  */
@@ -3475,11 +3489,11 @@ rb_gzwriter_s_allocate(VALUE klass)
3475
3489
  }
3476
3490
 
3477
3491
  /*
3478
- * call-seq: Zlib::GzipWriter.open(filename, level=nil, strategy=nil) { |gz| ... }
3492
+ * call-seq: Zstdlib::GzipWriter.open(filename, level=nil, strategy=nil) { |gz| ... }
3479
3493
  *
3480
3494
  * Opens a file specified by +filename+ for writing gzip compressed data, and
3481
3495
  * returns a GzipWriter object associated with that file. Further details of
3482
- * this method are found in Zlib::GzipWriter.new and Zlib::GzipFile.wrap.
3496
+ * this method are found in Zstdlib::GzipWriter.new and Zstdlib::GzipFile.wrap.
3483
3497
  */
3484
3498
  static VALUE
3485
3499
  rb_gzwriter_s_open(int argc, VALUE *argv, VALUE klass)
@@ -3489,10 +3503,10 @@ rb_gzwriter_s_open(int argc, VALUE *argv, VALUE klass)
3489
3503
 
3490
3504
  /*
3491
3505
  * call-seq:
3492
- * Zlib::GzipWriter.new(io, level = nil, strategy = nil, options = {})
3506
+ * Zstdlib::GzipWriter.new(io, level = nil, strategy = nil, options = {})
3493
3507
  *
3494
3508
  * Creates a GzipWriter object associated with +io+. +level+ and +strategy+
3495
- * should be the same as the arguments of Zlib::Deflate.new. The GzipWriter
3509
+ * should be the same as the arguments of Zstdlib::Deflate.new. The GzipWriter
3496
3510
  * object writes gzipped data to +io+. +io+ must respond to the
3497
3511
  * +write+ method that behaves the same as IO#write.
3498
3512
  *
@@ -3538,8 +3552,8 @@ rb_gzwriter_initialize(int argc, VALUE *argv, VALUE obj)
3538
3552
  * call-seq: flush(flush=nil)
3539
3553
  *
3540
3554
  * Flushes all the internal buffers of the GzipWriter object. The meaning of
3541
- * +flush+ is same as in Zlib::Deflate#deflate. <tt>Zlib::SYNC_FLUSH</tt> is used if
3542
- * +flush+ is omitted. It is no use giving flush <tt>Zlib::NO_FLUSH</tt>.
3555
+ * +flush+ is same as in Zstdlib::Deflate#deflate. <tt>Zstdlib::SYNC_FLUSH</tt> is used if
3556
+ * +flush+ is omitted. It is no use giving flush <tt>Zstdlib::NO_FLUSH</tt>.
3543
3557
  */
3544
3558
  static VALUE
3545
3559
  rb_gzwriter_flush(int argc, VALUE *argv, VALUE obj)
@@ -3625,25 +3639,25 @@ rb_gzwriter_putc(VALUE obj, VALUE ch)
3625
3639
  /* ------------------------------------------------------------------------- */
3626
3640
 
3627
3641
  /*
3628
- * Document-class: Zlib::GzipReader
3642
+ * Document-class: Zstdlib::GzipReader
3629
3643
  *
3630
- * Zlib::GzipReader is the class for reading a gzipped file. GzipReader should
3644
+ * Zstdlib::GzipReader is the class for reading a gzipped file. GzipReader should
3631
3645
  * be used as an IO, or -IO-like, object.
3632
3646
  *
3633
- * Zlib::GzipReader.open('hoge.gz') {|gz|
3647
+ * Zstdlib::GzipReader.open('hoge.gz') {|gz|
3634
3648
  * print gz.read
3635
3649
  * }
3636
3650
  *
3637
3651
  * File.open('hoge.gz') do |f|
3638
- * gz = Zlib::GzipReader.new(f)
3652
+ * gz = Zstdlib::GzipReader.new(f)
3639
3653
  * print gz.read
3640
3654
  * gz.close
3641
3655
  * end
3642
3656
  *
3643
3657
  * == Method Catalogue
3644
3658
  *
3645
- * The following methods in Zlib::GzipReader are just like their counterparts
3646
- * in IO, but they raise Zlib::Error or Zlib::GzipFile::Error exception if an
3659
+ * The following methods in Zstdlib::GzipReader are just like their counterparts
3660
+ * in IO, but they raise Zstdlib::Error or Zstdlib::GzipFile::Error exception if an
3647
3661
  * error was found in the gzip file.
3648
3662
  * - #each
3649
3663
  * - #each_line
@@ -3661,15 +3675,15 @@ rb_gzwriter_putc(VALUE obj, VALUE ch)
3661
3675
  * Be careful of the footer of the gzip file. A gzip file has the checksum of
3662
3676
  * pre-compressed data in its footer. GzipReader checks all uncompressed data
3663
3677
  * against that checksum at the following cases, and if it fails, raises
3664
- * <tt>Zlib::GzipFile::NoFooter</tt>, <tt>Zlib::GzipFile::CRCError</tt>, or
3665
- * <tt>Zlib::GzipFile::LengthError</tt> exception.
3678
+ * <tt>Zstdlib::GzipFile::NoFooter</tt>, <tt>Zstdlib::GzipFile::CRCError</tt>, or
3679
+ * <tt>Zstdlib::GzipFile::LengthError</tt> exception.
3666
3680
  *
3667
3681
  * - When an reading request is received beyond the end of file (the end of
3668
- * compressed data). That is, when Zlib::GzipReader#read,
3669
- * Zlib::GzipReader#gets, or some other methods for reading returns nil.
3670
- * - When Zlib::GzipFile#close method is called after the object reaches the
3682
+ * compressed data). That is, when Zstdlib::GzipReader#read,
3683
+ * Zstdlib::GzipReader#gets, or some other methods for reading returns nil.
3684
+ * - When Zstdlib::GzipFile#close method is called after the object reaches the
3671
3685
  * end of file.
3672
- * - When Zlib::GzipReader#unused method is called after the object reaches
3686
+ * - When Zstdlib::GzipReader#unused method is called after the object reaches
3673
3687
  * the end of file.
3674
3688
  *
3675
3689
  * The rest of the methods are adequately described in their own
@@ -3683,13 +3697,13 @@ rb_gzreader_s_allocate(VALUE klass)
3683
3697
  }
3684
3698
 
3685
3699
  /*
3686
- * Document-method: Zlib::GzipReader.open
3700
+ * Document-method: Zstdlib::GzipReader.open
3687
3701
  *
3688
- * call-seq: Zlib::GzipReader.open(filename) {|gz| ... }
3702
+ * call-seq: Zstdlib::GzipReader.open(filename) {|gz| ... }
3689
3703
  *
3690
3704
  * Opens a file specified by +filename+ as a gzipped file, and returns a
3691
3705
  * GzipReader object associated with that file. Further details of this method
3692
- * are in Zlib::GzipReader.new and ZLib::GzipFile.wrap.
3706
+ * are in Zstdlib::GzipReader.new and ZLib::GzipFile.wrap.
3693
3707
  */
3694
3708
  static VALUE
3695
3709
  rb_gzreader_s_open(int argc, VALUE *argv, VALUE klass)
@@ -3698,10 +3712,10 @@ rb_gzreader_s_open(int argc, VALUE *argv, VALUE klass)
3698
3712
  }
3699
3713
 
3700
3714
  /*
3701
- * Document-method: Zlib::GzipReader.new
3715
+ * Document-method: Zstdlib::GzipReader.new
3702
3716
  *
3703
3717
  * call-seq:
3704
- * Zlib::GzipReader.new(io, options = {})
3718
+ * Zstdlib::GzipReader.new(io, options = {})
3705
3719
  *
3706
3720
  * Creates a GzipReader object associated with +io+. The GzipReader object reads
3707
3721
  * gzipped data from +io+, and parses/decompresses it. The +io+ must
@@ -3711,7 +3725,7 @@ rb_gzreader_s_open(int argc, VALUE *argv, VALUE klass)
3711
3725
  * +:external_encoding+, +:internal_encoding+ and +:encoding+ may be set as in
3712
3726
  * IO::new.
3713
3727
  *
3714
- * If the gzip file header is incorrect, raises an Zlib::GzipFile::Error
3728
+ * If the gzip file header is incorrect, raises an Zstdlib::GzipFile::Error
3715
3729
  * exception.
3716
3730
  */
3717
3731
  static VALUE
@@ -3743,7 +3757,7 @@ rb_gzreader_initialize(int argc, VALUE *argv, VALUE obj)
3743
3757
  }
3744
3758
 
3745
3759
  /*
3746
- * Document-method: Zlib::GzipReader#rewind
3760
+ * Document-method: Zstdlib::GzipReader#rewind
3747
3761
  *
3748
3762
  * Resets the position of the file pointer to the point created the GzipReader
3749
3763
  * object. The associated IO object needs to respond to the +seek+ method.
@@ -3757,7 +3771,7 @@ rb_gzreader_rewind(VALUE obj)
3757
3771
  }
3758
3772
 
3759
3773
  /*
3760
- * Document-method: Zlib::GzipReader#unused
3774
+ * Document-method: Zstdlib::GzipReader#unused
3761
3775
  *
3762
3776
  * Returns the rest of the data which had read for parsing gzip format, or
3763
3777
  * +nil+ if the whole gzip file is not parsed yet.
@@ -3771,9 +3785,9 @@ rb_gzreader_unused(VALUE obj)
3771
3785
  }
3772
3786
 
3773
3787
  /*
3774
- * Document-method: Zlib::GzipReader#read
3788
+ * Document-method: Zstdlib::GzipReader#read
3775
3789
  *
3776
- * See Zlib::GzipReader documentation for a description.
3790
+ * See Zstdlib::GzipReader documentation for a description.
3777
3791
  */
3778
3792
  static VALUE
3779
3793
  rb_gzreader_read(int argc, VALUE *argv, VALUE obj)
@@ -3795,7 +3809,7 @@ rb_gzreader_read(int argc, VALUE *argv, VALUE obj)
3795
3809
  }
3796
3810
 
3797
3811
  /*
3798
- * Document-method: Zlib::GzipReader#readpartial
3812
+ * Document-method: Zstdlib::GzipReader#readpartial
3799
3813
  *
3800
3814
  * call-seq:
3801
3815
  * gzipreader.readpartial(maxlen [, outbuf]) => string, outbuf
@@ -3825,9 +3839,9 @@ rb_gzreader_readpartial(int argc, VALUE *argv, VALUE obj)
3825
3839
  }
3826
3840
 
3827
3841
  /*
3828
- * Document-method: Zlib::GzipReader#getc
3842
+ * Document-method: Zstdlib::GzipReader#getc
3829
3843
  *
3830
- * See Zlib::GzipReader documentation for a description.
3844
+ * See Zstdlib::GzipReader documentation for a description.
3831
3845
  */
3832
3846
  static VALUE
3833
3847
  rb_gzreader_getc(VALUE obj)
@@ -3838,9 +3852,9 @@ rb_gzreader_getc(VALUE obj)
3838
3852
  }
3839
3853
 
3840
3854
  /*
3841
- * Document-method: Zlib::GzipReader#readchar
3855
+ * Document-method: Zstdlib::GzipReader#readchar
3842
3856
  *
3843
- * See Zlib::GzipReader documentation for a description.
3857
+ * See Zstdlib::GzipReader documentation for a description.
3844
3858
  */
3845
3859
  static VALUE
3846
3860
  rb_gzreader_readchar(VALUE obj)
@@ -3854,9 +3868,9 @@ rb_gzreader_readchar(VALUE obj)
3854
3868
  }
3855
3869
 
3856
3870
  /*
3857
- * Document-method: Zlib::GzipReader#getbyte
3871
+ * Document-method: Zstdlib::GzipReader#getbyte
3858
3872
  *
3859
- * See Zlib::GzipReader documentation for a description.
3873
+ * See Zstdlib::GzipReader documentation for a description.
3860
3874
  */
3861
3875
  static VALUE
3862
3876
  rb_gzreader_getbyte(VALUE obj)
@@ -3872,9 +3886,9 @@ rb_gzreader_getbyte(VALUE obj)
3872
3886
  }
3873
3887
 
3874
3888
  /*
3875
- * Document-method: Zlib::GzipReader#readbyte
3889
+ * Document-method: Zstdlib::GzipReader#readbyte
3876
3890
  *
3877
- * See Zlib::GzipReader documentation for a description.
3891
+ * See Zstdlib::GzipReader documentation for a description.
3878
3892
  */
3879
3893
  static VALUE
3880
3894
  rb_gzreader_readbyte(VALUE obj)
@@ -3888,9 +3902,9 @@ rb_gzreader_readbyte(VALUE obj)
3888
3902
  }
3889
3903
 
3890
3904
  /*
3891
- * Document-method: Zlib::GzipReader#each_char
3905
+ * Document-method: Zstdlib::GzipReader#each_char
3892
3906
  *
3893
- * See Zlib::GzipReader documentation for a description.
3907
+ * See Zstdlib::GzipReader documentation for a description.
3894
3908
  */
3895
3909
  static VALUE
3896
3910
  rb_gzreader_each_char(VALUE obj)
@@ -3906,9 +3920,9 @@ rb_gzreader_each_char(VALUE obj)
3906
3920
  }
3907
3921
 
3908
3922
  /*
3909
- * Document-method: Zlib::GzipReader#each_byte
3923
+ * Document-method: Zstdlib::GzipReader#each_byte
3910
3924
  *
3911
- * See Zlib::GzipReader documentation for a description.
3925
+ * See Zstdlib::GzipReader documentation for a description.
3912
3926
  */
3913
3927
  static VALUE
3914
3928
  rb_gzreader_each_byte(VALUE obj)
@@ -3924,23 +3938,23 @@ rb_gzreader_each_byte(VALUE obj)
3924
3938
  }
3925
3939
 
3926
3940
  /*
3927
- * Document-method: Zlib::GzipReader#bytes
3941
+ * Document-method: Zstdlib::GzipReader#bytes
3928
3942
  *
3929
3943
  * This is a deprecated alias for <code>each_byte</code>.
3930
3944
  */
3931
3945
  static VALUE
3932
3946
  rb_gzreader_bytes(VALUE obj)
3933
3947
  {
3934
- rb_warn("Zlib::GzipReader#bytes is deprecated; use #each_byte instead");
3948
+ rb_warn("Zstdlib::GzipReader#bytes is deprecated; use #each_byte instead");
3935
3949
  if (!rb_block_given_p())
3936
3950
  return rb_enumeratorize(obj, ID2SYM(rb_intern("each_byte")), 0, 0);
3937
3951
  return rb_gzreader_each_byte(obj);
3938
3952
  }
3939
3953
 
3940
3954
  /*
3941
- * Document-method: Zlib::GzipReader#ungetc
3955
+ * Document-method: Zstdlib::GzipReader#ungetc
3942
3956
  *
3943
- * See Zlib::GzipReader documentation for a description.
3957
+ * See Zstdlib::GzipReader documentation for a description.
3944
3958
  */
3945
3959
  static VALUE
3946
3960
  rb_gzreader_ungetc(VALUE obj, VALUE s)
@@ -3960,9 +3974,9 @@ rb_gzreader_ungetc(VALUE obj, VALUE s)
3960
3974
  }
3961
3975
 
3962
3976
  /*
3963
- * Document-method: Zlib::GzipReader#ungetbyte
3977
+ * Document-method: Zstdlib::GzipReader#ungetbyte
3964
3978
  *
3965
- * See Zlib::GzipReader documentation for a description.
3979
+ * See Zstdlib::GzipReader documentation for a description.
3966
3980
  */
3967
3981
  static VALUE
3968
3982
  rb_gzreader_ungetbyte(VALUE obj, VALUE ch)
@@ -4160,9 +4174,9 @@ gzreader_gets(int argc, VALUE *argv, VALUE obj)
4160
4174
  }
4161
4175
 
4162
4176
  /*
4163
- * Document-method: Zlib::GzipReader#gets
4177
+ * Document-method: Zstdlib::GzipReader#gets
4164
4178
  *
4165
- * See Zlib::GzipReader documentation for a description.
4179
+ * See Zstdlib::GzipReader documentation for a description.
4166
4180
  */
4167
4181
  static VALUE
4168
4182
  rb_gzreader_gets(int argc, VALUE *argv, VALUE obj)
@@ -4176,9 +4190,9 @@ rb_gzreader_gets(int argc, VALUE *argv, VALUE obj)
4176
4190
  }
4177
4191
 
4178
4192
  /*
4179
- * Document-method: Zlib::GzipReader#readline
4193
+ * Document-method: Zstdlib::GzipReader#readline
4180
4194
  *
4181
- * See Zlib::GzipReader documentation for a description.
4195
+ * See Zstdlib::GzipReader documentation for a description.
4182
4196
  */
4183
4197
  static VALUE
4184
4198
  rb_gzreader_readline(int argc, VALUE *argv, VALUE obj)
@@ -4192,9 +4206,9 @@ rb_gzreader_readline(int argc, VALUE *argv, VALUE obj)
4192
4206
  }
4193
4207
 
4194
4208
  /*
4195
- * Document-method: Zlib::GzipReader#each
4209
+ * Document-method: Zstdlib::GzipReader#each
4196
4210
  *
4197
- * See Zlib::GzipReader documentation for a description.
4211
+ * See Zstdlib::GzipReader documentation for a description.
4198
4212
  */
4199
4213
  static VALUE
4200
4214
  rb_gzreader_each(int argc, VALUE *argv, VALUE obj)
@@ -4210,23 +4224,23 @@ rb_gzreader_each(int argc, VALUE *argv, VALUE obj)
4210
4224
  }
4211
4225
 
4212
4226
  /*
4213
- * Document-method: Zlib::GzipReader#lines
4227
+ * Document-method: Zstdlib::GzipReader#lines
4214
4228
  *
4215
4229
  * This is a deprecated alias for <code>each_line</code>.
4216
4230
  */
4217
4231
  static VALUE
4218
4232
  rb_gzreader_lines(int argc, VALUE *argv, VALUE obj)
4219
4233
  {
4220
- rb_warn("Zlib::GzipReader#lines is deprecated; use #each_line instead");
4234
+ rb_warn("Zstdlib::GzipReader#lines is deprecated; use #each_line instead");
4221
4235
  if (!rb_block_given_p())
4222
4236
  return rb_enumeratorize(obj, ID2SYM(rb_intern("each_line")), argc, argv);
4223
4237
  return rb_gzreader_each(argc, argv, obj);
4224
4238
  }
4225
4239
 
4226
4240
  /*
4227
- * Document-method: Zlib::GzipReader#readlines
4241
+ * Document-method: Zstdlib::GzipReader#readlines
4228
4242
  *
4229
- * See Zlib::GzipReader documentation for a description.
4243
+ * See Zstdlib::GzipReader documentation for a description.
4230
4244
  */
4231
4245
  static VALUE
4232
4246
  rb_gzreader_readlines(int argc, VALUE *argv, VALUE obj)
@@ -4240,9 +4254,9 @@ rb_gzreader_readlines(int argc, VALUE *argv, VALUE obj)
4240
4254
  }
4241
4255
 
4242
4256
  /*
4243
- * Document-method: Zlib::GzipReader#external_encoding
4257
+ * Document-method: Zstdlib::GzipReader#external_encoding
4244
4258
  *
4245
- * See Zlib::GzipReader documentation for a description.
4259
+ * See Zstdlib::GzipReader documentation for a description.
4246
4260
  */
4247
4261
  static VALUE
4248
4262
  rb_gzreader_external_encoding(VALUE self)
@@ -4274,24 +4288,24 @@ static VALUE zlib_gzip_run(VALUE arg);
4274
4288
 
4275
4289
  /*
4276
4290
  * call-seq:
4277
- * Zlib.gzip(src, level: nil, strategy: nil) -> String
4291
+ * Zstdlib.gzip(src, level: nil, strategy: nil) -> String
4278
4292
  *
4279
4293
  * Gzip the given +string+. Valid values of level are
4280
- * Zlib::NO_COMPRESSION, Zlib::BEST_SPEED, Zlib::BEST_COMPRESSION,
4281
- * Zlib::DEFAULT_COMPRESSION (default), or an integer from 0 to 9.
4294
+ * Zstdlib::NO_COMPRESSION, Zstdlib::BEST_SPEED, Zstdlib::BEST_COMPRESSION,
4295
+ * Zstdlib::DEFAULT_COMPRESSION (default), or an integer from 0 to 9.
4282
4296
  *
4283
4297
  * This method is almost equivalent to the following code:
4284
4298
  *
4285
4299
  * def gzip(string, level: nil, strategy: nil)
4286
4300
  * sio = StringIO.new
4287
4301
  * sio.binmode
4288
- * gz = Zlib::GzipWriter.new(sio, level, strategy)
4302
+ * gz = Zstdlib::GzipWriter.new(sio, level, strategy)
4289
4303
  * gz.write(string)
4290
4304
  * gz.close
4291
4305
  * sio.string
4292
4306
  * end
4293
4307
  *
4294
- * See also Zlib.gunzip
4308
+ * See also Zstdlib.gunzip
4295
4309
  *
4296
4310
  */
4297
4311
  static VALUE
@@ -4361,7 +4375,7 @@ static VALUE zlib_gunzip_run(VALUE arg);
4361
4375
 
4362
4376
  /*
4363
4377
  * call-seq:
4364
- * Zlib.gunzip(src) -> String
4378
+ * Zstdlib.gunzip(src) -> String
4365
4379
  *
4366
4380
  * Decode the given gzipped +string+.
4367
4381
  *
@@ -4369,13 +4383,13 @@ static VALUE zlib_gunzip_run(VALUE arg);
4369
4383
  *
4370
4384
  * def gunzip(string)
4371
4385
  * sio = StringIO.new(string)
4372
- * gz = Zlib::GzipReader.new(sio, encoding: Encoding::ASCII_8BIT)
4386
+ * gz = Zstdlib::GzipReader.new(sio, encoding: Encoding::ASCII_8BIT)
4373
4387
  * gz.read
4374
4388
  * ensure
4375
4389
  * gz&.close
4376
4390
  * end
4377
4391
  *
4378
- * See also Zlib.gzip
4392
+ * See also Zstdlib.gzip
4379
4393
  */
4380
4394
  static VALUE
4381
4395
  zlib_gunzip(VALUE klass, VALUE src)
@@ -4419,14 +4433,14 @@ zlib_gunzip_run(VALUE arg)
4419
4433
  #endif /* GZIP_SUPPORT */
4420
4434
 
4421
4435
  void
4422
- Init_zlib(void)
4436
+ Init_zstdlib(void)
4423
4437
  {
4424
4438
  VALUE mZlib, cZStream, cDeflate, cInflate;
4425
4439
  #if GZIP_SUPPORT
4426
4440
  VALUE cGzipFile, cGzipWriter, cGzipReader;
4427
4441
  #endif
4428
4442
 
4429
- mZlib = rb_define_module("Zlib");
4443
+ mZlib = rb_define_module("Zstdlib");
4430
4444
 
4431
4445
  id_dictionaries = rb_intern("@dictionaries");
4432
4446
 
@@ -4450,6 +4464,8 @@ Init_zlib(void)
4450
4464
  rb_define_const(mZlib, "VERSION", rb_str_new2(RUBY_ZLIB_VERSION));
4451
4465
  /* The string which represents the version of zlib.h */
4452
4466
  rb_define_const(mZlib, "ZLIB_VERSION", rb_str_new2(ZLIB_VERSION));
4467
+ rb_define_const(mZlib, "ZSTD_VERSION", rb_str_new2(ZSTD_versionString()));
4468
+ rb_define_module_function(mZlib, "zstd_version", rb_zstd_version, 0);
4453
4469
 
4454
4470
  cZStream = rb_define_class_under(mZlib, "ZStream", rb_cObject);
4455
4471
  rb_undef_alloc_func(cZStream);
@@ -4473,7 +4489,7 @@ Init_zlib(void)
4473
4489
 
4474
4490
  /* Represents binary data as guessed by deflate.
4475
4491
  *
4476
- * See Zlib::Deflate#data_type. */
4492
+ * See Zstdlib::Deflate#data_type. */
4477
4493
  rb_define_const(mZlib, "BINARY", INT2FIX(Z_BINARY));
4478
4494
 
4479
4495
  /* Represents text data as guessed by deflate.
@@ -4481,19 +4497,19 @@ Init_zlib(void)
4481
4497
  * NOTE: The underlying constant Z_ASCII was deprecated in favor of Z_TEXT
4482
4498
  * in zlib 1.2.2. New applications should not use this constant.
4483
4499
  *
4484
- * See Zlib::Deflate#data_type. */
4500
+ * See Zstdlib::Deflate#data_type. */
4485
4501
  rb_define_const(mZlib, "ASCII", INT2FIX(Z_ASCII));
4486
4502
 
4487
4503
  #ifdef Z_TEXT
4488
4504
  /* Represents text data as guessed by deflate.
4489
4505
  *
4490
- * See Zlib::Deflate#data_type. */
4506
+ * See Zstdlib::Deflate#data_type. */
4491
4507
  rb_define_const(mZlib, "TEXT", INT2FIX(Z_TEXT));
4492
4508
  #endif
4493
4509
 
4494
4510
  /* Represents an unknown data type as guessed by deflate.
4495
4511
  *
4496
- * See Zlib::Deflate#data_type. */
4512
+ * See Zstdlib::Deflate#data_type. */
4497
4513
  rb_define_const(mZlib, "UNKNOWN", INT2FIX(Z_UNKNOWN));
4498
4514
 
4499
4515
  cDeflate = rb_define_class_under(mZlib, "Deflate", cZStream);
@@ -4527,12 +4543,12 @@ Init_zlib(void)
4527
4543
  /* Fastest compression level, but with the lowest space savings. */
4528
4544
  rb_define_const(mZlib, "BEST_SPEED", INT2FIX(Z_BEST_SPEED));
4529
4545
  /* Slowest compression level, but with the best space savings. */
4530
- rb_define_const(mZlib, "BEST_COMPRESSION", INT2FIX(Z_BEST_COMPRESSION));
4546
+ rb_define_const(mZlib, "BEST_COMPRESSION", INT2FIX(ZSTD_maxCLevel()));
4531
4547
  /* Default compression level which is a good trade-off between space and
4532
4548
  * time
4533
4549
  */
4534
4550
  rb_define_const(mZlib, "DEFAULT_COMPRESSION",
4535
- INT2FIX(Z_DEFAULT_COMPRESSION));
4551
+ INT2FIX(ZSTD_CLEVEL_DEFAULT));
4536
4552
 
4537
4553
  /* Deflate strategy for data produced by a filter (or predictor). The
4538
4554
  * effect of FILTERED is to force more Huffman codes and less string
@@ -4563,7 +4579,7 @@ Init_zlib(void)
4563
4579
  rb_define_const(mZlib, "DEFAULT_STRATEGY", INT2FIX(Z_DEFAULT_STRATEGY));
4564
4580
 
4565
4581
  /* The maximum size of the zlib history buffer. Note that zlib allows
4566
- * larger values to enable different inflate modes. See Zlib::Inflate.new
4582
+ * larger values to enable different inflate modes. See Zstdlib::Inflate.new
4567
4583
  * for details.
4568
4584
  */
4569
4585
  rb_define_const(mZlib, "MAX_WBITS", INT2FIX(MAX_WBITS));
@@ -4730,28 +4746,28 @@ Init_zlib(void)
4730
4746
  /* Document error classes. */
4731
4747
 
4732
4748
  /*
4733
- * Document-class: Zlib::Error
4749
+ * Document-class: Zstdlib::Error
4734
4750
  *
4735
4751
  * The superclass for all exceptions raised by Ruby/zlib.
4736
4752
  *
4737
- * The following exceptions are defined as subclasses of Zlib::Error. These
4753
+ * The following exceptions are defined as subclasses of Zstdlib::Error. These
4738
4754
  * exceptions are raised when zlib library functions return with an error
4739
4755
  * status.
4740
4756
  *
4741
- * - Zlib::StreamEnd
4742
- * - Zlib::NeedDict
4743
- * - Zlib::DataError
4744
- * - Zlib::StreamError
4745
- * - Zlib::MemError
4746
- * - Zlib::BufError
4747
- * - Zlib::VersionError
4757
+ * - Zstdlib::StreamEnd
4758
+ * - Zstdlib::NeedDict
4759
+ * - Zstdlib::DataError
4760
+ * - Zstdlib::StreamError
4761
+ * - Zstdlib::MemError
4762
+ * - Zstdlib::BufError
4763
+ * - Zstdlib::VersionError
4748
4764
  *
4749
4765
  */
4750
4766
 
4751
4767
  /*
4752
- * Document-class: Zlib::StreamEnd
4768
+ * Document-class: Zstdlib::StreamEnd
4753
4769
  *
4754
- * Subclass of Zlib::Error
4770
+ * Subclass of Zstdlib::Error
4755
4771
  *
4756
4772
  * When zlib returns a Z_STREAM_END
4757
4773
  * is return if the end of the compressed data has been reached
@@ -4760,20 +4776,20 @@ Init_zlib(void)
4760
4776
  */
4761
4777
 
4762
4778
  /*
4763
- * Document-class: Zlib::NeedDict
4779
+ * Document-class: Zstdlib::NeedDict
4764
4780
  *
4765
- * Subclass of Zlib::Error
4781
+ * Subclass of Zstdlib::Error
4766
4782
  *
4767
4783
  * When zlib returns a Z_NEED_DICT
4768
4784
  * if a preset dictionary is needed at this point.
4769
4785
  *
4770
- * Used by Zlib::Inflate.inflate and <tt>Zlib.inflate</tt>
4786
+ * Used by Zstdlib::Inflate.inflate and <tt>Zstdlib.inflate</tt>
4771
4787
  */
4772
4788
 
4773
4789
  /*
4774
- * Document-class: Zlib::VersionError
4790
+ * Document-class: Zstdlib::VersionError
4775
4791
  *
4776
- * Subclass of Zlib::Error
4792
+ * Subclass of Zstdlib::Error
4777
4793
  *
4778
4794
  * When zlib returns a Z_VERSION_ERROR,
4779
4795
  * usually if the zlib library version is incompatible with the
@@ -4782,9 +4798,9 @@ Init_zlib(void)
4782
4798
  */
4783
4799
 
4784
4800
  /*
4785
- * Document-class: Zlib::MemError
4801
+ * Document-class: Zstdlib::MemError
4786
4802
  *
4787
- * Subclass of Zlib::Error
4803
+ * Subclass of Zstdlib::Error
4788
4804
  *
4789
4805
  * When zlib returns a Z_MEM_ERROR,
4790
4806
  * usually if there was not enough memory.
@@ -4792,9 +4808,9 @@ Init_zlib(void)
4792
4808
  */
4793
4809
 
4794
4810
  /*
4795
- * Document-class: Zlib::StreamError
4811
+ * Document-class: Zstdlib::StreamError
4796
4812
  *
4797
- * Subclass of Zlib::Error
4813
+ * Subclass of Zstdlib::Error
4798
4814
  *
4799
4815
  * When zlib returns a Z_STREAM_ERROR,
4800
4816
  * usually if the stream state was inconsistent.
@@ -4802,44 +4818,44 @@ Init_zlib(void)
4802
4818
  */
4803
4819
 
4804
4820
  /*
4805
- * Document-class: Zlib::BufError
4821
+ * Document-class: Zstdlib::BufError
4806
4822
  *
4807
- * Subclass of Zlib::Error when zlib returns a Z_BUF_ERROR.
4823
+ * Subclass of Zstdlib::Error when zlib returns a Z_BUF_ERROR.
4808
4824
  *
4809
4825
  * Usually if no progress is possible.
4810
4826
  *
4811
4827
  */
4812
4828
 
4813
4829
  /*
4814
- * Document-class: Zlib::DataError
4830
+ * Document-class: Zstdlib::DataError
4815
4831
  *
4816
- * Subclass of Zlib::Error when zlib returns a Z_DATA_ERROR.
4832
+ * Subclass of Zstdlib::Error when zlib returns a Z_DATA_ERROR.
4817
4833
  *
4818
4834
  * Usually if a stream was prematurely freed.
4819
4835
  *
4820
4836
  */
4821
4837
 
4822
4838
  /*
4823
- * Document-class: Zlib::GzipFile::Error
4839
+ * Document-class: Zstdlib::GzipFile::Error
4824
4840
  *
4825
4841
  * Base class of errors that occur when processing GZIP files.
4826
4842
  */
4827
4843
 
4828
4844
  /*
4829
- * Document-class: Zlib::GzipFile::NoFooter
4845
+ * Document-class: Zstdlib::GzipFile::NoFooter
4830
4846
  *
4831
4847
  * Raised when gzip file footer is not found.
4832
4848
  */
4833
4849
 
4834
4850
  /*
4835
- * Document-class: Zlib::GzipFile::CRCError
4851
+ * Document-class: Zstdlib::GzipFile::CRCError
4836
4852
  *
4837
4853
  * Raised when the CRC checksum recorded in gzip file footer is not equivalent
4838
4854
  * to the CRC checksum of the actual uncompressed data.
4839
4855
  */
4840
4856
 
4841
4857
  /*
4842
- * Document-class: Zlib::GzipFile::LengthError
4858
+ * Document-class: Zstdlib::GzipFile::LengthError
4843
4859
  *
4844
4860
  * Raised when the data length recorded in the gzip file footer is not equivalent
4845
4861
  * to the length of the actual uncompressed data.