NAME
Gzip::Libdeflate - Libdeflate compression library
SYNOPSIS
use Gzip::Libdeflate;
my $gl = Gzip::Libdeflate->new (level => 12);
my $out = $gl->compress ("ABCDEFG" x 2);
print length ($out), "\n";
my $rt = $gl->decompress ($out);
print "$rt\n";
produces output
29
ABCDEFGABCDEFG
(This example is included as synopsis.pl in the distribution.)
VERSION
This documents version 0.08_02 of Gzip-Libdeflate corresponding to git commit 6e54636e4d0150477721ea96eaa04da8aad55d7a released on Mon Aug 5 06:54:05 2024 +0900. This distribution also includes libdeflate version 1.21.
DESCRIPTION
This module provides an interface to libdeflate. Libdeflate is a newly-written compression library which offers the same deflate
form of compression as zlib, as used in gzip, libpng and many similar utilities. This distribution includes libdeflate within itself, so it is not necessary to have that on your system.
INSTALLATION
An ISO C99 compiler is required. For example Gcc (Gnu Compiler Collection) version 4.9 or later, or Clang version 3.9 or later, are required. This restriction is imposed by libdeflate.
METHODS
compress
my $comp_thing = $gl->compress ($thing);
Compress input $thing
using whatever compression level and type you have specified for $gl
in "new".
compress_file
my $out = $gl->compress_file (%options);
File to compressed scalar:
my $out = $gl->compress_file (in => $file);
File to compressed file:
$gl->compress_file (in => $file, out => "$file.gz");
Scalar to compressed file:
$gl->compress_file (from => $uncompressed, out => "$file.gz");
This is a convenience method which uses "File::Slurper" to read and write the binary files.
For the opposite operation, see "decompress_file".
This method was added in version 0.03 of the module.
decompress
my $thing = $gl->decompress ($dthing);
Decompress $comp_thing
into $thing
. If you have chosen the zlib
or deflate
options in "new", you also need to specify the expected size of $thing
.
my $thing = $gl->decompress ($dthing, 1000);
In the gzip
format, the size is stored within the data itself, so it doesn't need to be specified.
decompress_file
my $out = $gl->decompress_file (%options);
Compressed file to scalar:
my $out = $gl->decompress_file (in => $file);
Compressed file to file:
$gl->decompress_file (in => "$file.gz", out => $file);
Compressed scalar to file:
$gl->decompress_file (from => $compressed, out => $file);
If using zlib
or deflate
compression, a numerical size must also be specified.
$gl->decompress_file (in => $zlib_file, out => $file, size => 9999);
This is a convenience method which uses "File::Slurper" to read and write the binary files.
For the opposite operation, see "compress_file".
This method was added in version 0.03 of the module.
get_level
my $level = $gl->get_level ();
Retrieve the level of compression as a number.
This method was added in version 0.03 of the module.
get_type
my $type = $gl->get_type ();
Retrieve the type of compression from an object as a string, either deflate
, gzip
(the default), or zlib
.
This method was added in version 0.03 of the module.
new
my $gl = Gzip::Libdeflate->new (%options);
Possible options are
- level
-
my $gl = Gzip::Libdeflate->new (level => 9);
A numerical argument of compression level from 1 (fast and poor compression) to 12 (slow and good compression). If you do not specify it, the default is 6. These correspond to the compression levels of zlib, but with extra compression levels 10-12 also added. See "About libdeflate" for details.
As with zlib, there is also a "zero compression" option of level 0 which just puts the input into the gzip format without compressing it at all.
- type
-
my $gl = Gzip::Libdeflate->new (type => 'deflate');
Change the type of compression. The default is type
gzip
but you can also choosedeflate
andzlib
. These are all the same thing up to headers.
ERROR HANDLING
Errors are handled by warning and then returning an undefined value.
DEPENDENCIES
- File::Slurper
-
File::Slurper is used by "compress_file" and "decompress_file" to read and write binary data.
SEE ALSO
About libdeflate
Libdeflate is a new library which offers the same form of deflate compression as offered by zlib
. From its README:
libdeflate is a library for fast, whole-buffer DEFLATE-based compression and decompression.
See the Libdeflate github repository for full information.
CPAN modules
AUTHOR
Ben Bullock, <benkasminbullock@gmail.com>
COPYRIGHT & LICENCE
This package and associated files are copyright (C) 2021-2024 Ben Bullock.
You can use, copy, modify and redistribute this package and associated files under the Perl Artistic Licence or the GNU General Public Licence.
Libdeflate's copyright and licence are as follows.
Copyright 2016 Eric Biggers Copyright 2024 Google LLC
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.