/usr/share/doc/libarchive-zip-perl/examples/selfex.pl is in libarchive-zip-perl 1.30-6.
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 | #!/usr/bin/perl -w
#
# Shows one way to write a self-extracting archive file.
# This is not intended for production use, and it always extracts to a
# subdirectory with a fixed name.
# Plus, it requires Perl and A::Z to be installed first.
#
# In general, you want to provide a stub that is platform-specific.
# You can use 'unzipsfx' that it provided with the Info-Zip unzip program.
# Get this from http://www.info-zip.org .
#
# $Revision: 1.6 $
#
use strict;
use Archive::Zip;
use IO::File;
# Make a self-extracting Zip file.
die "usage: $0 sfxname file [...]\n" unless @ARGV > 1;
my $outputName = shift();
my $zip = Archive::Zip->new();
foreach my $file (@ARGV)
{
$zip->addFileOrDirectory($file);
}
my $fh = IO::File->new( $outputName, O_CREAT | O_WRONLY | O_TRUNC, 0777 )
or die "Can't open $outputName\: $!\n";
binmode($fh);
# add self-extracting Perl code
while (<DATA>)
{
$fh->print($_)
}
$zip->writeToFileHandle($fh);
$fh->close();
# below the __DATA__ line is the extraction stub:
__DATA__
#!/usr/bin/perl
# Self-extracting Zip file extraction stub
# Copyright (C) 2002 Ned Konz
use Archive::Zip qw(:ERROR_CODES);
use IO::File;
use File::Spec;
my $dir = 'extracted';
my $zip = Archive::Zip->new();
my $fh = IO::File->new($0) or die "Can't open $0\: $!\n";
die "Zip read error\n" unless $zip->readFromFileHandle($fh) == AZ_OK;
(mkdir($dir, 0777) or die "Can't create directory $dir\: $!\n") unless -d $dir;
for my $member ( $zip->members )
{
$member->extractToFileNamed( File::Spec->catfile($dir,$member->fileName) );
}
__DATA__
|