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.
- checksums.yaml +4 -4
- data/CHANGES.md +8 -0
- data/README.md +5 -2
- data/ext/zstdlib/extconf.rb +1 -11
- data/ext/zstdlib/ruby/zlib-2.2/{zlib.c → zstdlib.c} +279 -263
- data/ext/zstdlib/ruby/zlib-2.3/{zlib.c → zstdlib.c} +281 -265
- data/ext/zstdlib/ruby/zlib-2.4/{zlib.c → zstdlib.c} +290 -274
- data/ext/zstdlib/ruby/zlib-2.5/{zlib.c → zstdlib.c} +290 -274
- data/ext/zstdlib/ruby/zlib-2.6/{zlib.c → zstdlib.c} +290 -274
- data/lib/2.2/zstdlib.so +0 -0
- data/lib/2.3/zstdlib.so +0 -0
- data/lib/2.4/zstdlib.so +0 -0
- data/lib/2.5/zstdlib.so +0 -0
- data/lib/2.6/zstdlib.so +0 -0
- metadata +7 -7
@@ -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 <
|
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 "
|
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 =
|
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 =
|
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
|
-
* -
|
273
|
-
* -
|
274
|
-
* -
|
275
|
-
* -
|
276
|
-
* -
|
277
|
-
* -
|
278
|
-
* -
|
279
|
-
* -
|
280
|
-
* -
|
281
|
-
* -
|
282
|
-
* -
|
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
|
-
* -
|
286
|
-
* -
|
287
|
-
* -
|
288
|
-
* -
|
289
|
-
* -
|
290
|
-
* -
|
291
|
-
* -
|
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
|
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:
|
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:
|
431
|
+
* Document-method: Zstdlib.adler32
|
418
432
|
*
|
419
|
-
* call-seq:
|
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 "
|
441
|
+
* require "zstdlib"
|
428
442
|
*
|
429
443
|
* data = "foo"
|
430
|
-
* puts "Adler32 checksum: #{
|
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:
|
456
|
+
* Document-method: Zstdlib.adler32_combine
|
443
457
|
*
|
444
|
-
* call-seq:
|
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:
|
476
|
+
* Document-method: Zstdlib.crc32
|
463
477
|
*
|
464
|
-
* call-seq:
|
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:
|
494
|
+
* Document-method: Zstdlib.crc32_combine
|
481
495
|
*
|
482
|
-
* call-seq:
|
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:
|
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:
|
1188
|
+
* Document-class: Zstdlib::ZStream
|
1175
1189
|
*
|
1176
|
-
*
|
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
|
-
*
|
1192
|
+
* Zstdlib::Deflate for compression, and Zstdlib::Inflate for decompression.
|
1179
1193
|
*
|
1180
|
-
* An instance of
|
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
|
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
|
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
|
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
|
1219
|
-
*
|
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:
|
1425
|
+
* Document-class: Zstdlib::Deflate
|
1412
1426
|
*
|
1413
|
-
*
|
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),
|
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:
|
1449
|
+
* Document-method: Zstdlib::Deflate.new
|
1436
1450
|
*
|
1437
1451
|
* call-seq:
|
1438
|
-
*
|
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
|
-
* *
|
1448
|
-
* *
|
1449
|
-
* *
|
1450
|
-
* *
|
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
|
-
* *
|
1464
|
-
* *
|
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
|
-
*
|
1470
|
-
*
|
1471
|
-
*
|
1472
|
-
*
|
1473
|
-
*
|
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 <<
|
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 =
|
1489
|
-
*
|
1490
|
-
*
|
1491
|
-
*
|
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:
|
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:
|
1579
|
+
* Document-method: Zstdlib::Deflate.deflate
|
1566
1580
|
*
|
1567
1581
|
* call-seq:
|
1568
|
-
*
|
1569
|
-
*
|
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
|
-
*
|
1573
|
-
*
|
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 =
|
1579
|
-
* dst = z.deflate(string,
|
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
|
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:
|
1641
|
+
* Document-method: Zstdlib::Deflate#deflate
|
1628
1642
|
*
|
1629
1643
|
* call-seq:
|
1630
|
-
* z.deflate(string, flush =
|
1631
|
-
* z.deflate(string, flush =
|
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
|
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
|
-
*
|
1645
|
-
*
|
1646
|
-
*
|
1647
|
-
*
|
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:
|
1680
|
+
* Document-method: Zstdlib::Deflate#<<
|
1667
1681
|
*
|
1668
1682
|
* call-seq: << string
|
1669
1683
|
*
|
1670
|
-
* Inputs +string+ into the deflate stream just like
|
1671
|
-
* returns the
|
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:
|
1697
|
+
* Document-method: Zstdlib::Deflate#flush
|
1684
1698
|
*
|
1685
1699
|
* call-seq:
|
1686
|
-
* flush(flush =
|
1687
|
-
* flush(flush =
|
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
|
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:
|
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
|
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:
|
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
|
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:
|
1806
|
+
* Document-class: Zstdlib::Inflate
|
1793
1807
|
*
|
1794
1808
|
* Zlib:Inflate is the class for decompressing compressed data. Unlike
|
1795
|
-
*
|
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:
|
1822
|
+
* Document-method: Zstdlib::Inflate.new
|
1809
1823
|
*
|
1810
1824
|
* call-seq:
|
1811
|
-
*
|
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
|
-
*
|
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 =
|
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:
|
1897
|
+
* Document-method: Zstdlib::inflate
|
1884
1898
|
*
|
1885
1899
|
* call-seq:
|
1886
|
-
*
|
1887
|
-
*
|
1900
|
+
* Zstdlib.inflate(string)
|
1901
|
+
* Zstdlib::Inflate.inflate(string)
|
1888
1902
|
*
|
1889
|
-
* Decompresses +string+. Raises a
|
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 =
|
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
|
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:
|
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:
|
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
|
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
|
1977
|
-
* decompress. Set the dictionary by
|
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 =
|
1994
|
+
* inflater = Zstdlib::Inflate.new
|
1981
1995
|
*
|
1982
1996
|
* begin
|
1983
1997
|
* out = inflater.inflate compressed
|
1984
|
-
* rescue
|
1998
|
+
* rescue Zstdlib::NeedDict
|
1985
1999
|
* # ensure the dictionary matches the stream's required dictionary
|
1986
|
-
* raise unless inflater.adler ==
|
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
|
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
|
2032
|
-
* returns the
|
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:
|
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
|
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("
|
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) { /*
|
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:
|
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 ==
|
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 =
|
2573
|
+
gz->level = ZSTD_maxCLevel();
|
2560
2574
|
}
|
2561
2575
|
else {
|
2562
|
-
gz->level =
|
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:
|
2965
|
+
* Document-class: Zstdlib::GzipFile
|
2952
2966
|
*
|
2953
|
-
*
|
2967
|
+
* Zstdlib::GzipFile is an abstract class for handling a gzip formatted
|
2954
2968
|
* compressed file. The operations are defined in the subclasses,
|
2955
|
-
*
|
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 (
|
2976
|
+
* - ::open (Zstdlib::GzipReader::open and Zstdlib::GzipWriter::open)
|
2963
2977
|
* - #close
|
2964
2978
|
* - #closed?
|
2965
2979
|
* - #comment
|
2966
|
-
* - comment= (
|
2980
|
+
* - comment= (Zstdlib::GzipWriter#comment=)
|
2967
2981
|
* - #crc
|
2968
|
-
* - eof? (
|
2982
|
+
* - eof? (Zstdlib::GzipReader#eof?)
|
2969
2983
|
* - #finish
|
2970
2984
|
* - #level
|
2971
|
-
* - lineno (
|
2972
|
-
* - lineno= (
|
2985
|
+
* - lineno (Zstdlib::GzipReader#lineno)
|
2986
|
+
* - lineno= (Zstdlib::GzipReader#lineno=)
|
2973
2987
|
* - #mtime
|
2974
|
-
* - mtime= (
|
2988
|
+
* - mtime= (Zstdlib::GzipWriter#mtime=)
|
2975
2989
|
* - #orig_name
|
2976
|
-
* - 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
|
2984
|
-
* or
|
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:
|
3057
|
+
* Document-method: Zstdlib::GzipFile.wrap
|
3044
3058
|
*
|
3045
3059
|
* call-seq:
|
3046
|
-
*
|
3047
|
-
*
|
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
|
-
*
|
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:
|
3078
|
+
* Document-method: Zstdlib::GzipFile.open
|
3065
3079
|
*
|
3066
|
-
* See
|
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:
|
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:
|
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:
|
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:
|
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:
|
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:
|
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:
|
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:
|
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:
|
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:
|
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:
|
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:
|
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:
|
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:
|
3312
|
+
* Document-method: Zstdlib::GzipFile#finish
|
3299
3313
|
*
|
3300
|
-
* Closes the GzipFile object. Unlike
|
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:
|
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:
|
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:
|
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:
|
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:
|
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:
|
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:
|
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:
|
3453
|
+
* Document-class: Zstdlib::GzipWriter
|
3440
3454
|
*
|
3441
|
-
*
|
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
|
-
*
|
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 =
|
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
|
-
*
|
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
|
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:
|
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
|
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
|
-
*
|
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
|
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
|
3542
|
-
* +flush+ is omitted. It is no use giving 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:
|
3642
|
+
* Document-class: Zstdlib::GzipReader
|
3629
3643
|
*
|
3630
|
-
*
|
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
|
-
*
|
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 =
|
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
|
3646
|
-
* in IO, but they raise
|
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>
|
3665
|
-
* <tt>
|
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
|
3669
|
-
*
|
3670
|
-
* - When
|
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
|
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:
|
3700
|
+
* Document-method: Zstdlib::GzipReader.open
|
3687
3701
|
*
|
3688
|
-
* call-seq:
|
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
|
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:
|
3715
|
+
* Document-method: Zstdlib::GzipReader.new
|
3702
3716
|
*
|
3703
3717
|
* call-seq:
|
3704
|
-
*
|
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
|
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:
|
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:
|
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:
|
3788
|
+
* Document-method: Zstdlib::GzipReader#read
|
3775
3789
|
*
|
3776
|
-
* See
|
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:
|
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:
|
3842
|
+
* Document-method: Zstdlib::GzipReader#getc
|
3829
3843
|
*
|
3830
|
-
* See
|
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:
|
3855
|
+
* Document-method: Zstdlib::GzipReader#readchar
|
3842
3856
|
*
|
3843
|
-
* See
|
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:
|
3871
|
+
* Document-method: Zstdlib::GzipReader#getbyte
|
3858
3872
|
*
|
3859
|
-
* See
|
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:
|
3889
|
+
* Document-method: Zstdlib::GzipReader#readbyte
|
3876
3890
|
*
|
3877
|
-
* See
|
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:
|
3905
|
+
* Document-method: Zstdlib::GzipReader#each_char
|
3892
3906
|
*
|
3893
|
-
* See
|
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:
|
3923
|
+
* Document-method: Zstdlib::GzipReader#each_byte
|
3910
3924
|
*
|
3911
|
-
* See
|
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:
|
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("
|
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:
|
3955
|
+
* Document-method: Zstdlib::GzipReader#ungetc
|
3942
3956
|
*
|
3943
|
-
* See
|
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:
|
3977
|
+
* Document-method: Zstdlib::GzipReader#ungetbyte
|
3964
3978
|
*
|
3965
|
-
* See
|
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:
|
4177
|
+
* Document-method: Zstdlib::GzipReader#gets
|
4164
4178
|
*
|
4165
|
-
* See
|
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:
|
4193
|
+
* Document-method: Zstdlib::GzipReader#readline
|
4180
4194
|
*
|
4181
|
-
* See
|
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:
|
4209
|
+
* Document-method: Zstdlib::GzipReader#each
|
4196
4210
|
*
|
4197
|
-
* See
|
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:
|
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("
|
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:
|
4241
|
+
* Document-method: Zstdlib::GzipReader#readlines
|
4228
4242
|
*
|
4229
|
-
* See
|
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:
|
4257
|
+
* Document-method: Zstdlib::GzipReader#external_encoding
|
4244
4258
|
*
|
4245
|
-
* See
|
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
|
-
*
|
4291
|
+
* Zstdlib.gzip(src, level: nil, strategy: nil) -> String
|
4278
4292
|
*
|
4279
4293
|
* Gzip the given +string+. Valid values of level are
|
4280
|
-
*
|
4281
|
-
*
|
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 =
|
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
|
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
|
-
*
|
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 =
|
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
|
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
|
-
|
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("
|
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
|
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
|
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
|
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
|
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(
|
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(
|
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
|
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:
|
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
|
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
|
-
* -
|
4742
|
-
* -
|
4743
|
-
* -
|
4744
|
-
* -
|
4745
|
-
* -
|
4746
|
-
* -
|
4747
|
-
* -
|
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:
|
4768
|
+
* Document-class: Zstdlib::StreamEnd
|
4753
4769
|
*
|
4754
|
-
* Subclass of
|
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:
|
4779
|
+
* Document-class: Zstdlib::NeedDict
|
4764
4780
|
*
|
4765
|
-
* Subclass of
|
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
|
4786
|
+
* Used by Zstdlib::Inflate.inflate and <tt>Zstdlib.inflate</tt>
|
4771
4787
|
*/
|
4772
4788
|
|
4773
4789
|
/*
|
4774
|
-
* Document-class:
|
4790
|
+
* Document-class: Zstdlib::VersionError
|
4775
4791
|
*
|
4776
|
-
* Subclass of
|
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:
|
4801
|
+
* Document-class: Zstdlib::MemError
|
4786
4802
|
*
|
4787
|
-
* Subclass of
|
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:
|
4811
|
+
* Document-class: Zstdlib::StreamError
|
4796
4812
|
*
|
4797
|
-
* Subclass of
|
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:
|
4821
|
+
* Document-class: Zstdlib::BufError
|
4806
4822
|
*
|
4807
|
-
* Subclass of
|
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:
|
4830
|
+
* Document-class: Zstdlib::DataError
|
4815
4831
|
*
|
4816
|
-
* Subclass of
|
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:
|
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:
|
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:
|
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:
|
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.
|