class Zlib::Deflate
Overview
A write-only IO
object to compress data in zlib or gzip format.
Instances of this class wrap another IO object. When you write to this instance, it compresses the data and writes it to the underlying IO.
Note: unless created with a block, #close
must be invoked after all
data has been written to a Zlib::Deflate instance.
Example: compress a file
File.open("./file.txt", "r") do |input_file|
File.open("./file.gzip", "w") do |output_file|
Zlib::Deflate.gzip(output_file) do |deflate|
IO.copy(input_file, deflate)
end
end
end
See also: Zlib::Inflate
for decompressing data.
Included Modules
Defined in:
zlib/deflate.crClass Method Summary
-
.gzip(output, sync_close : Bool = false) : self
Creates an instance of Zlib::Deflate for the gzip format.
-
.gzip(output, sync_close : Bool = false, &block)
Creates an instance of Zlib::Deflate for the gzip format, yields it to the given block, and closes it at its end.
-
.new(output : IO, level = LibZ::DEFAULT_COMPRESSION, wbits = LibZ::MAX_BITS, mem_level = LibZ::DEF_MEM_LEVEL, strategy = LibZ::Strategy::DEFAULT_STRATEGY, sync_close : Bool = false)
Creates an instance of Zlib::Deflate.
-
.new(output : IO, level = LibZ::DEFAULT_COMPRESSION, wbits = LibZ::MAX_BITS, mem_level = LibZ::DEF_MEM_LEVEL, strategy = LibZ::Strategy::DEFAULT_STRATEGY, sync_close : Bool = false, &block)
Creates an instance of Zlib::Deflate, yields it to the given block, and closes it at its end.
Instance Method Summary
-
#close
Closes this IO.
-
#closed? : Bool
Returns
true
if this IO is closed. -
#flush
See
IO#flush
. -
#read(slice : Slice(UInt8))
Always raises: this is a write-only IO.
-
#sync_close=(sync_close : Bool)
If
sync_close
is true, closing this IO will close the underlying IO. -
#sync_close? : Bool
If
sync_close
is true, closing this IO will close the underlying IO. -
#write(slice : Slice(UInt8))
See
IO#write
.
Instance methods inherited from module IO
<<(obj) : self
<<,
close
close,
closed?
closed?,
each_byte(&block)each_byte each_byte, each_char(&block)
each_char each_char, each_line(*args, **options)
each_line(*args, **options, &block) each_line, encoding : String encoding, flush flush, gets(limit : Int) : String | Nil
gets(delimiter : Char, limit : Int) : String | Nil
gets(delimiter : Char) : String | Nil
gets : String | Nil
gets(delimiter : String) : String | Nil gets, gets_to_end : String gets_to_end, print(obj) : Nil
print(*objects : _) : Nil print, printf(format_string, *args) : Nil
printf(format_string, args : Array | Tuple) : Nil printf, puts(*objects : _) : Nil
puts : Nil
puts(string : String) : Nil
puts(obj) : Nil puts, read(slice : Slice(UInt8)) read, read_byte : UInt8 | Nil read_byte, read_bytes(type, format : IO::ByteFormat = IO::ByteFormat::SystemEndian) read_bytes, read_char : Char | Nil read_char, read_fully(slice : Slice(UInt8)) read_fully, read_line(*args, **options) : String | Nil read_line, read_utf8(slice : Slice(UInt8)) read_utf8, read_utf8_byte read_utf8_byte, rewind rewind, set_encoding(encoding : String, invalid : Symbol | Nil = nil) set_encoding, skip(bytes_count : Int) : Nil skip, tty? : Bool tty?, write(slice : Slice(UInt8)) : Nil write, write_byte(byte : UInt8) write_byte, write_bytes(object, format : IO::ByteFormat = IO::ByteFormat::SystemEndian) write_bytes, write_utf8(slice : Slice(UInt8)) write_utf8
Class methods inherited from module IO
copy(src, dst, limit : Int)copy(src, dst) copy, pipe(read_blocking = false, write_blocking = false, &block)
pipe(read_blocking = false, write_blocking = false) pipe, select(read_ios, write_ios, error_ios, timeout_sec : LibC::TimeT | Int | Float | Nil)
select(read_ios, write_ios = nil, error_ios = nil) select
Instance methods inherited from module JSON::Builder
json_array(&block)
json_array,
json_object(&block)
json_object
Instance methods inherited from class Reference
==(other)==(other : self) ==, dup dup, hash hash, inspect(io : IO) : Nil inspect, object_id : UInt64 object_id, same?(other : Reference)
same?(other : Nil) same?, to_s(io : IO) : Nil to_s
Instance methods inherited from class Object
!=(other)
!=,
!~(other)
!~,
==(other)
==,
===(other)===(other : YAML::Any)
===(other : JSON::Any) ===, =~(other) =~, class class, crystal_type_id crystal_type_id, dup dup, hash hash, inspect(io : IO)
inspect inspect, itself itself, not_nil! not_nil!, tap(&block) tap, to_json to_json, to_pretty_json(indent : String = " ")
to_pretty_json(io : IO, indent : String = " ") to_pretty_json, to_s
to_s(io : IO) to_s, to_yaml
to_yaml(io : IO) to_yaml, try(&block) try
Class methods inherited from class Object
==(other : Class)
==,
===(other)
===,
cast(other) : self
cast,
clone
clone,
dup
dup,
from_json(string_or_io) : selffrom_json(string_or_io, root : String) : self from_json, from_yaml(string : String) : self from_yaml, hash hash, inspect(io) inspect, name : String name, nilable? nilable?, to_s(io) to_s, |(other : U.class) forall U |
Class Method Detail
Creates an instance of Zlib::Deflate for the gzip format. #close
must be invoked after all data
has written.
Creates an instance of Zlib::Deflate for the gzip format, yields it to the given block, and closes it at its end.
Creates an instance of Zlib::Deflate. #close
must be invoked after all data
has written.
Creates an instance of Zlib::Deflate, yields it to the given block, and closes it at its end.
Instance Method Detail
If sync_close
is true, closing this IO will close the underlying IO.
If sync_close
is true, closing this IO will close the underlying IO.