/usr/share/perl5/Cache/CacheUtils.pm is in libcache-cache-perl 1.08-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 | ######################################################################
# $Id: CacheUtils.pm,v 1.39 2003/04/15 14:46:19 dclinton Exp $
# Copyright (C) 2001-2003 DeWitt Clinton All Rights Reserved
#
# Software distributed under the License is distributed on an "AS
# IS" basis, WITHOUT WARRANTY OF ANY KIND, either expressed or
# implied. See the License for the specific language governing
# rights and limitations under the License.
######################################################################
package Cache::CacheUtils;
use strict;
use vars qw( @ISA @EXPORT_OK );
use Cache::Cache;
use Error;
use Exporter;
use File::Spec;
use Storable qw( nfreeze thaw dclone );
@ISA = qw( Exporter );
@EXPORT_OK = qw( Assert_Defined
Build_Path
Clone_Data
Freeze_Data
Static_Params
Thaw_Data );
# throw an Exception if the Assertion fails
sub Assert_Defined
{
if ( not defined $_[0] )
{
my ( $package, $filename, $line ) = caller( );
throw Error::Simple( "Assert_Defined failed: $package line $line\n" );
}
}
# Take a list of directory components and create a valid path
sub Build_Path
{
my ( @p_elements ) = @_;
# TODO: add this to Untaint_Path or something
# ( $p_unique_key !~ m|[0-9][a-f][A-F]| ) or
# throw Error::Simple( "key '$p_unique_key' contains illegal characters'" );
if ( grep ( /\.\./, @p_elements ) )
{
throw Error::Simple( "Illegal path characters '..'" );
}
return File::Spec->catfile( @p_elements );
}
# use Storable to clone an object
sub Clone_Data
{
my ( $p_object ) = @_;
return defined $p_object ? dclone( $p_object ) : undef;
}
# use Storable to freeze an object
sub Freeze_Data
{
my ( $p_object ) = @_;
return defined $p_object ? nfreeze( $p_object ) : undef;
}
# Take a parameter list and automatically shift it such that if
# the method was called as a static method, then $self will be
# undefined. This allows the use to write
#
# sub Static_Method
# {
# my ( $parameter ) = Static_Params( @_ );
# }
#
# and not worry about whether it is called as:
#
# Class->Static_Method( $param );
#
# or
#
# Class::Static_Method( $param );
sub Static_Params
{
my $type = ref $_[0];
if ( $type and ( $type !~ /^(SCALAR|ARRAY|HASH|CODE|REF|GLOB|LVALUE)$/ ) )
{
shift( @_ );
}
return @_;
}
# use Storable to thaw an object
sub Thaw_Data
{
my ( $p_frozen_object ) = @_;
return defined $p_frozen_object ? thaw( $p_frozen_object ) : undef;
}
1;
__END__
=pod
=head1 NAME
Cache::CacheUtils -- miscellaneous utility routines
=head1 DESCRIPTION
The CacheUtils package is a collection of static methods that provide
functionality useful to many different classes.
=head1 AUTHOR
Original author: DeWitt Clinton <dewitt@unto.net>
Last author: $Author: dclinton $
Copyright (C) 2001-2003 DeWitt Clinton
=cut
|