Imported Upstream version 0.06
This commit is contained in:
		
							
								
								
									
										244
									
								
								lib/Archive/SevenZip/API/ArchiveZip.pm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										244
									
								
								lib/Archive/SevenZip/API/ArchiveZip.pm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,244 @@ | ||||
| package Archive::SevenZip::API::ArchiveZip; | ||||
| use strict; | ||||
| use Carp qw(croak); | ||||
| use Encode qw( decode encode ); | ||||
| use File::Basename qw(dirname basename); | ||||
| use File::Copy; | ||||
| use Archive::SevenZip 'AZ_OK'; | ||||
|  | ||||
| use vars qw($VERSION); | ||||
| $VERSION= '0.06'; | ||||
|  | ||||
| sub new { | ||||
|     my( $class, %options )= @_; | ||||
|     $options{ sevenZip } = Archive::SevenZip->new(); | ||||
|     bless \%options => $class; | ||||
| }; | ||||
|  | ||||
| sub sevenZip { $_[0]->{sevenZip} } | ||||
|  | ||||
| =head1 NAME | ||||
|  | ||||
| Archive::SevenZip::API::ArchiveZip - Archive::Zip compatibility API | ||||
|  | ||||
| =head1 SYNOPSIS | ||||
|  | ||||
|   my $ar = Archive::SevenZip->archiveZipApi( | ||||
|       find => 1, | ||||
|       archivename => $archivename, | ||||
|       verbose => $verbose, | ||||
|   ); | ||||
|  | ||||
| This module implements just enough of the L<Archive::Zip> | ||||
| API to pass some of the Archive::Zip test files. Ideally you can | ||||
| use this API to enable a script that uses Archive::Zip | ||||
| to also read other archive files supported by 7z. | ||||
|  | ||||
| =cut | ||||
|  | ||||
| sub writeToFileNamed { | ||||
|     my( $self, $targetName )= @_; | ||||
|     copy( $self->sevenZip->{archivename}, $targetName ); | ||||
|     return AZ_OK; | ||||
| } | ||||
|  | ||||
| sub addFileOrDirectory { | ||||
|     my($self, $name, $newName, $compressionLevel) = @_; | ||||
|     $newName = $name | ||||
|         unless defined $newName; | ||||
|     $self->sevenZip->add( | ||||
|         items => [ [$name, $newName] ], | ||||
|         compression => $compressionLevel | ||||
|     ); | ||||
| } | ||||
|  | ||||
| sub addString { | ||||
|     my( $self, $content, $name, %options ) = @_; | ||||
|     $self->sevenZip->add_scalar($name => $content); | ||||
|     $self->memberNamed($name, %options); | ||||
| } | ||||
|  | ||||
| sub addDirectory { | ||||
|     # Create just a directory name | ||||
|     my( $self, $name, $target, %options ) = @_; | ||||
|     $target ||= $name; | ||||
|      | ||||
|     if( ref $name ) { | ||||
|         croak "Hashref API not supported, sorry"; | ||||
|     }; | ||||
|      | ||||
|     $self->sevenZip->add_directory($name, $target, %options); | ||||
|     $self->memberNamed($target, %options); | ||||
| } | ||||
|  | ||||
| sub members { | ||||
|     my( $self ) = @_; | ||||
|     $self->sevenZip->members; | ||||
| } | ||||
|  | ||||
| sub memberNames { | ||||
|     my( $self ) = @_; | ||||
|     map { $_->fileName } $self->sevenZip->members; | ||||
| } | ||||
|  | ||||
| sub membersMatching { | ||||
|     my( $self, $re, %options ) = @_; | ||||
|     grep { $_->fileName =~ /$re/ } $self->sevenZip->members; | ||||
| } | ||||
|  | ||||
| =head2 C<< $ar->numberOfMembers >> | ||||
|  | ||||
|   my $count = $az->numberOfMembers(); | ||||
|  | ||||
| =cut | ||||
|  | ||||
| sub numberOfMembers { | ||||
|     my( $self, %options ) = @_; | ||||
|     my @m = $self->members( %options ); | ||||
|     0+@m | ||||
| } | ||||
|  | ||||
| =head2 C<< $az->memberNamed >> | ||||
|  | ||||
|   my $entry = $az->memberNamed('hello_world.txt'); | ||||
|   print $entry->fileName, "\n"; | ||||
|  | ||||
| =cut | ||||
|  | ||||
| # Archive::Zip API | ||||
| sub memberNamed { | ||||
|     my( $self, $name, %options )= @_; | ||||
|     $self->sevenZip->memberNamed($name, %options ); | ||||
| } | ||||
|  | ||||
| sub extractMember { | ||||
|     my( $self, $name, $target, %options ) = @_; | ||||
|     if( ref $name and $name->can('fileName')) { | ||||
|         $name = $name->fileName; | ||||
|     }; | ||||
|     $self->sevenZip->extractMember( $name, $target, %options ); | ||||
| } | ||||
|  | ||||
| sub removeMember { | ||||
|     my( $self, $name, $target, %options ) = @_; | ||||
|     # Just for the result: | ||||
|     my $res = ref $name ? $name : $self->memberNamed( $name ); | ||||
|      | ||||
|     if( ref $name and $name->can('fileName')) { | ||||
|         $name = $name->fileName; | ||||
|     }; | ||||
|     $self->sevenZip->removeMember( $name, %options ); | ||||
|      | ||||
|     $res | ||||
| } | ||||
|  | ||||
| =head2 C<< $ar->replaceMember >> | ||||
|  | ||||
|   $ar->replaceMember('backup.txt', 'new-backup.txt'); | ||||
|  | ||||
| Replaces the member in the archive. This is just delete then add. | ||||
|  | ||||
| I clearly don't understand the utility of this method. It clearly | ||||
| does not update the content of one file with the content of another | ||||
| file, as the name of the new file can be different. | ||||
|  | ||||
| =cut | ||||
|  | ||||
| # strikingly similar to Archive::Zip API | ||||
| sub replaceMember { | ||||
|     my( $self, $name, $replacement, %_options ) = @_; | ||||
|  | ||||
|     my %options = (%$self, %_options); | ||||
|      | ||||
|     if( $^O =~ /MSWin/ ) { | ||||
|         $name =~ s!/!\\!g; | ||||
|     } | ||||
|      | ||||
|     my $res = $self->removeMember( $name ); | ||||
|     $self->add( $replacement ); | ||||
|      | ||||
|     $res | ||||
| }; | ||||
|  | ||||
|  | ||||
| sub addFile { | ||||
|     my( $self, $name, $target, %options ) = @_; | ||||
|     if( ref $name and $name->can('fileName')) { | ||||
|         $name = $name->fileName; | ||||
|     }; | ||||
|     $target ||= $name; | ||||
|     $self->sevenZip->add( items => [[ $name, $target ]], %options ); | ||||
|     return $self->memberNamed($target, %options); | ||||
| } | ||||
|  | ||||
| sub addMember { | ||||
|     my( $self, $name, $target, %options ) = @_; | ||||
|     if( ref $name and $name->can('fileName')) { | ||||
|         $name = $name->fileName; | ||||
|     }; | ||||
|     $target ||= $name; | ||||
|     $self->sevenZip->add( items => [[ $name, $target ]], %options ); | ||||
|     return $self->memberNamed($target, %options); | ||||
| } | ||||
| { no warnings 'once'; | ||||
| *add = \&addMember; | ||||
| } | ||||
|  | ||||
| sub addTree { | ||||
|     my( $self, $sourceDir, $target, $predicate, %options ) = @_; | ||||
|      | ||||
|     croak "Predicates are not supported, sorry" | ||||
|         if $predicate; | ||||
|          | ||||
|     $target ||= $sourceDir; | ||||
|     croak "Different target for ->addTree not supported, sorry" | ||||
|         if $target ne $sourceDir; | ||||
|          | ||||
|     $self->sevenZip->add( items => [[ $sourceDir, $target ]], recursive => 1, %options ); | ||||
|     return $self->memberNamed($target, %options); | ||||
| } | ||||
| *add = \&addMember; | ||||
|  | ||||
| __END__ | ||||
|  | ||||
| =head1 CAUTION | ||||
|  | ||||
| This module tries to mimic the API of L<Archive::Zip>. | ||||
|  | ||||
| =head2 Differences between Archive::Zip and Archive::SevenZip | ||||
|  | ||||
| =head3 7-Zip does not guarantee the order of entries within an archive | ||||
|  | ||||
| The Archive::Zip test suite assumes that items added later to an | ||||
| archive will appear later in the directory listing. 7-zip makes no | ||||
| such guarantee. | ||||
|  | ||||
| =head1 REPOSITORY | ||||
|  | ||||
| The public repository of this module is  | ||||
| L<http://github.com/Corion/archive-sevenzip>. | ||||
|  | ||||
| =head1 SUPPORT | ||||
|  | ||||
| The public support forum of this module is | ||||
| L<https://perlmonks.org/>. | ||||
|  | ||||
| =head1 BUG TRACKER | ||||
|  | ||||
| Please report bugs in this module via the RT CPAN bug queue at | ||||
| L<https://rt.cpan.org/Public/Dist/Display.html?Name=Archive-SevenZip> | ||||
| or via mail to L<archive-sevenzip-Bugs@rt.cpan.org>. | ||||
|  | ||||
| =head1 AUTHOR | ||||
|  | ||||
| Max Maischein C<corion@cpan.org> | ||||
|  | ||||
| =head1 COPYRIGHT (c) | ||||
|  | ||||
| Copyright 2015-2016 by Max Maischein C<corion@cpan.org>. | ||||
|  | ||||
| =head1 LICENSE | ||||
|  | ||||
| This module is released under the same terms as Perl itself. | ||||
|  | ||||
| =cut | ||||
							
								
								
									
										138
									
								
								lib/Archive/SevenZip/Entry.pm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										138
									
								
								lib/Archive/SevenZip/Entry.pm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,138 @@ | ||||
| package Archive::SevenZip::Entry; | ||||
| use strict; | ||||
|  | ||||
| use Time::Piece; # for strptime | ||||
| use File::Basename (); | ||||
| use Path::Class (); | ||||
|  | ||||
| use vars qw($VERSION); | ||||
| $VERSION= '0.06'; | ||||
|  | ||||
| sub new { | ||||
|     my( $class, %options) = @_; | ||||
|      | ||||
|     bless \%options => $class | ||||
| } | ||||
|  | ||||
| sub archive { | ||||
|     $_[0]->{_Container} | ||||
| } | ||||
|  | ||||
| sub fileName { | ||||
|     my( $self ) = @_; | ||||
|      | ||||
|     my $res = $self->{Path}; | ||||
|      | ||||
|     # Normalize to unixy path names | ||||
|     $res =~ s!\\!/!g; | ||||
|      | ||||
|     # If we're a directory, append the slash: | ||||
|     if( $self->{Folder} eq '+') { | ||||
|         $res .= '/'; | ||||
|     }; | ||||
|      | ||||
|     $res | ||||
| } | ||||
|  | ||||
| # Class::Path API | ||||
| sub basename { | ||||
|     Path::Class::file( $_[0]->{Path} )->basename | ||||
| } | ||||
|  | ||||
| sub components { | ||||
|     my $cp = file( $_[0]->{Path} ); | ||||
|     $cp->components() | ||||
| } | ||||
|  | ||||
| sub lastModFileDateTime { | ||||
|     0 | ||||
| } | ||||
|  | ||||
| sub crc32 { | ||||
|     hex( $_[0]->{CRC} ); | ||||
| } | ||||
|  | ||||
| sub crc32String { | ||||
|     lc $_[0]->{CRC}; | ||||
| } | ||||
|  | ||||
| sub desiredCompressionMethod { | ||||
|     $_[0]->{Method} | ||||
| } | ||||
|  | ||||
| sub uncompressedSize { | ||||
|     $_[0]->{Size} | ||||
| } | ||||
|  | ||||
| sub dir { | ||||
|     # We need to return the appropriate class here | ||||
|     # so that further calls to (like) dir->list | ||||
|     # still work properly | ||||
|     die "->dir Not implemented"; | ||||
| } | ||||
|  | ||||
| sub open { | ||||
|     my( $self, $mode, $permissions )= @_; | ||||
|     $self->archive->openMemberFH( membername => $self->fileName, binmode => $mode ); | ||||
| } | ||||
| { no warnings 'once'; | ||||
| *fh = \&open; # Archive::Zip API | ||||
| } | ||||
|  | ||||
| # Path::Class API | ||||
| sub slurp { | ||||
|     my( $self, %options )= @_; | ||||
|     my $fh = $self->archive->openMemberFH( membername => $self->fileName, binmode => $options{ iomode } ); | ||||
|     local $/; | ||||
|     <$fh> | ||||
| } | ||||
|  | ||||
| # Archive::Zip API | ||||
| #externalFileName() | ||||
|  | ||||
| # Archive::Zip API | ||||
| #fileName() | ||||
|  | ||||
| # Archive::Zip API | ||||
| #lastModFileDateTime() | ||||
|  | ||||
| # Archive::Zip API | ||||
| #lastModTime() | ||||
|  | ||||
| # Archive::Zip API | ||||
| sub extractToFileNamed { | ||||
|     my($self, $target) = @_; | ||||
|     $self->archive->extractMember( $self->fileName, $target ); | ||||
| }; | ||||
|  | ||||
| 1; | ||||
|  | ||||
| =head1 REPOSITORY | ||||
|  | ||||
| The public repository of this module is  | ||||
| L<http://github.com/Corion/archive-sevenzip>. | ||||
|  | ||||
| =head1 SUPPORT | ||||
|  | ||||
| The public support forum of this module is | ||||
| L<https://perlmonks.org/>. | ||||
|  | ||||
| =head1 BUG TRACKER | ||||
|  | ||||
| Please report bugs in this module via the RT CPAN bug queue at | ||||
| L<https://rt.cpan.org/Public/Dist/Display.html?Name=Archive-SevenZip> | ||||
| or via mail to L<archive-sevenzip-Bugs@rt.cpan.org>. | ||||
|  | ||||
| =head1 AUTHOR | ||||
|  | ||||
| Max Maischein C<corion@cpan.org> | ||||
|  | ||||
| =head1 COPYRIGHT (c) | ||||
|  | ||||
| Copyright 2015-2016 by Max Maischein C<corion@cpan.org>. | ||||
|  | ||||
| =head1 LICENSE | ||||
|  | ||||
| This module is released under the same terms as Perl itself. | ||||
|  | ||||
| =cut | ||||
		Reference in New Issue
	
	Block a user