uawdijnntqw1x1x1
IP : 216.73.216.155
Hostname : vm5018.vps.agava.net
Kernel : Linux vm5018.vps.agava.net 3.10.0-1127.8.2.vz7.151.14 #1 SMP Tue Jun 9 12:58:54 MSK 2020 x86_64
Disable Function : None :)
OS : Linux
PATH:
/
var
/
..
/
usr
/
share
/
..
/
share
/
perl5
/
Algorithm
/
..
/
Dpkg
/
Compression.pm
/
/
# Copyright © 2010 Raphaël Hertzog <hertzog@debian.org> # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program. If not, see <http://www.gnu.org/licenses/>. package Dpkg::Compression; use strict; use warnings; our $VERSION = "1.00"; use Dpkg::ErrorHandling; use Dpkg::Gettext; use base qw(Exporter); our @EXPORT = qw($compression_re_file_ext compression_get_list compression_is_supported compression_get_property compression_guess_from_filename compression_get_default compression_set_default compression_get_default_level compression_set_default_level compression_is_valid_level); =encoding utf8 =head1 NAME Dpkg::Compression - simple database of available compression methods =head1 DESCRIPTION This modules provides a few public funcions and a public regex to interact with the set of supported compression methods. =head1 EXPORTED VARIABLES =over 4 =cut my $COMP = { "gzip" => { "file_ext" => "gz", "comp_prog" => [ "gzip", "--no-name", "--rsyncable" ], "decomp_prog" => [ "gunzip" ], }, "bzip2" => { "file_ext" => "bz2", "comp_prog" => [ "bzip2" ], "decomp_prog" => [ "bunzip2" ], }, "lzma" => { "file_ext" => "lzma", "comp_prog" => [ 'xz', '--format=lzma' ], "decomp_prog" => [ 'unxz', '--format=lzma' ], }, "xz" => { "file_ext" => "xz", "comp_prog" => [ "xz" ], "decomp_prog" => [ "unxz" ], }, }; our $default_compression = "gzip"; our $default_compression_level = 9; =item $compression_re_file_ext A regex that matches a file extension of a file compressed with one of the supported compression methods. =back =cut my $regex = join "|", map { $_->{"file_ext"} } values %$COMP; our $compression_re_file_ext = qr/(?:$regex)/; =head1 EXPORTED FUNCTIONS =over 4 =item my @list = compression_get_list() Returns a list of supported compression methods (sorted alphabetically). =cut sub compression_get_list { return sort keys %$COMP; } =item compression_is_supported($comp) Returns a boolean indicating whether the give compression method is known and supported. =cut sub compression_is_supported { return exists $COMP->{$_[0]}; } =item compression_get_property($comp, $property) Returns the requested property of the compression method. Returns undef if either the property or the compression method doesn't exist. Valid properties currently include "file_ext" for the file extension, "comp_prog" for the name of the compression program and "decomp_prog" for the name of the decompression program. =cut sub compression_get_property { my ($comp, $property) = @_; return undef unless compression_is_supported($comp); return $COMP->{$comp}{$property} if exists $COMP->{$comp}{$property}; return undef; } =item compression_guess_from_filename($filename) Returns the compression method that is likely used on the indicated filename based on its file extension. =cut sub compression_guess_from_filename { my $filename = shift; foreach my $comp (compression_get_list()) { my $ext = compression_get_property($comp, "file_ext"); if ($filename =~ /^(.*)\.\Q$ext\E$/) { return $comp; } } return undef; } =item my $comp = compression_get_default() Return the default compression method. It's "gzip" unless C<compression_set_default> has been used to change it. =item compression_set_default($comp) Change the default compression method. Errors out if the given compression method is not supported. =cut sub compression_get_default { return $default_compression; } sub compression_set_default { my ($method) = @_; error(_g("%s is not a supported compression"), $method) unless compression_is_supported($method); $default_compression = $method; } =item my $level = compression_get_default_level() Return the default compression level used when compressing data. It's "9" unless C<compression_set_default_level> has been used to change it. =item compression_set_default_level($level) Change the default compression level. Errors out if the level is not valid (see C<compression_is_valid_level>). either a number between 1 and 9 or "fast" or "best". =cut sub compression_get_default_level { return $default_compression_level; } sub compression_set_default_level { my ($level) = @_; error(_g("%s is not a compression level"), $level) unless compression_is_valid_level($level); $default_compression_level = $level; } =item compression_is_valid_level($level) Returns a boolean indicating whether $level is a valid compression level (it must be either a number between 1 and 9 or "fast" or "best") =cut sub compression_is_valid_level { my ($level) = @_; return $level =~ /^([1-9]|fast|best)$/; } =back =head1 AUTHOR Raphaël Hertzog <hertzog@debian.org>. =cut 1;
/var/../usr/share/../share/perl5/Algorithm/../Dpkg/Compression.pm