/usr/share/doc/libdevice-cdio-perl/examples/iso3.pl is in libdevice-cdio-perl 0.3.0-3.
This file is owned by root:root, with mode 0o755.
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 | #!/usr/bin/perl -w
# Copyright (C) 2006, 2008 Rocky Bernstein <rocky@cpan.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 3 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/>.
# Simple program to show using Device::Cdio::ISO9660 to extract a file
# from an ISO-9660 image.
#
# If a single argument is given, it is used as the ISO 9660 image to
# use in the extraction. Otherwise a compiled in default ISO 9660
# image name (that comes with the libcdio distribution) will be used.
use strict;
BEGIN {
chdir 'example' if -d 'example';
use lib '../lib';
eval "use blib"; # if we fail keep going - maybe we have installed Cdio
}
use POSIX;
use IO::Handle;
use Device::Cdio;
use Device::Cdio::Device;
use Device::Cdio::ISO9660;
use Device::Cdio::ISO9660::IFS;
use File::Spec;
# The default ISO 9660 image if none given
my $ISO9660_IMAGE_PATH="../data";
my $ISO9660_IMAGE=File::Spec->catfile($ISO9660_IMAGE_PATH, "copying.iso");
# File to extract if none given.
my $local_filename="copying";
my $iso_image_fname = $ISO9660_IMAGE;
if (@ARGV >= 1) {
$iso_image_fname = $ARGV[0];
if (@ARGV >= 2) {
$local_filename = $ARGV[1];
if (@ARGV >= 3) {
print "
usage: $0 [ISO9660-image.ISO [filename]]
Extracts filename from ISO9660-image.ISO.
";
exit 1;
}
}
}
my $iso = Device::Cdio::ISO9660::IFS->new(-source=>$iso_image_fname);
if (!defined($iso)) {
printf "Sorry, couldn't open %s as an ISO-9660 image\n.",
$iso_image_fname;
exit 1;
}
my $statbuf = $iso->stat ($local_filename, 1);
if (!defined($statbuf))
{
printf "Could not get ISO-9660 file information for file %s\n",
$local_filename;
$iso->close();
exit 2;
}
open OUTPUT, ">$local_filename" or
die "Can't open $local_filename for writing: $!";
binmode OUTPUT;
# Copy the blocks from the ISO-9660 filesystem to the local filesystem.
my $blocks = POSIX::ceil($statbuf->{size} / $perlcdio::ISO_BLOCKSIZE);
for (my $i = 0; $i < $blocks; $i++) {
my $lsn = $statbuf->{LSN} + $i;
my $buf = $iso->seek_read ($lsn);
if (!defined($buf)) {
printf "Error reading ISO 9660 file %s at LSN %d\n",
$local_filename, $lsn;
exit 4;
}
syswrite OUTPUT, $buf, $perlcdio::ISO_BLOCKSIZE;
}
OUTPUT->autoflush(1);
# Make sure the file size has the exact same byte size. Without the
# truncate below, the file will a multiple of ISO_BLOCKSIZE.
truncate OUTPUT, $statbuf->{size};
printf "Extraction of file '%s' from %s successful.\n",
$local_filename, $iso_image_fname;
close OUTPUT;
$iso->close();
exit 0;
|