K2LL33D SHELL

 Apache/2.4.7 (Ubuntu)
 Linux sman1baleendah 3.13.0-24-generic #46-Ubuntu SMP Thu Apr 10 19:11:08 UTC 2014 x86_64
 uid=33(www-data) gid=33(www-data) groups=33(www-data)
 safemode : OFF
 MySQL: ON | Perl: ON | cURL: OFF | WGet: ON
  >  / usr / share / perl / 5.18.2 / Digest /
server ip : 104.21.89.46

your ip : 172.70.126.3

H O M E


Filename/usr/share/perl/5.18.2/Digest/base.pm
Size1.76 kb
Permissionrw-r--r--
Ownerroot : root
Create time27-Apr-2025 10:10
Last modified21-Nov-2018 01:11
Last accessed06-Jul-2025 09:09
Actionsedit | rename | delete | download (gzip)
Viewtext | code | image
package Digest::base;

use strict;
use vars qw($VERSION);
$VERSION = "1.16";

# subclass is supposed to implement at least these
sub new;
sub clone;
sub add;
sub digest;

sub reset {
my $self = shift;
$self->new(@_); # ugly
}

sub addfile {
my ($self, $handle) = @_;

my $n;
my $buf = "";

while (($n = read($handle, $buf, 4*1024))) {
$self->add($buf);
}
unless (defined $n) {
require Carp;
Carp::croak("Read failed: $!");
}

$self;
}

sub add_bits {
my $self = shift;
my $bits;
my $nbits;
if (@_ == 1) {
my $arg = shift;
$bits = pack("B*", $arg);
$nbits = length($arg);
}
else {
($bits, $nbits) = @_;
}
if (($nbits % 8) != 0) {
require Carp;
Carp::croak("Number of bits must be multiple of 8 for this algorithm");
}
return $self->add(substr($bits, 0, $nbits/8));
}

sub hexdigest {
my $self = shift;
return unpack("H*", $self->digest(@_));
}

sub b64digest {
my $self = shift;
require MIME::Base64;
my $b64 = MIME::Base64::encode($self->digest(@_), "");
$b64 =~ s/=+$//;
return $b64;
}

1;

__END__

=head1 NAME

Digest::base - Digest base class

=head1 SYNOPSIS

package Digest::Foo;
use base 'Digest::base';

=head1 DESCRIPTION

The C<Digest::base> class provide implementations of the methods
C<addfile> and C<add_bits> in terms of C<add>, and of the methods
C<hexdigest> and C<b64digest> in terms of C<digest>.

Digest implementations might want to inherit from this class to get
this implementations of the alternative I<add> and I<digest> methods.
A minimal subclass needs to implement the following methods by itself:

new
clone
add
digest

The arguments and expected behaviour of these methods are described in
L<Digest>.

=head1 SEE ALSO

L<Digest>