/usr/share/perl5/Catmandu/Importer/MARC/ALEPHSEQ.pm is in libcatmandu-marc-perl 0.214-1.
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 | =head1 NAME
Catmandu::Importer::MARC::ALEPHSEQ - Package that imports Ex Libris' Aleph sequential MARC records
=head1 SYNOPSIS
# From the command line
$ catmandu convert MARC --type ALEPHSEQ --fix "marc_map('245a','title')" < /foo/usm01.txt
# From perl
use Catmandu;
# import records from file
my $importer = Catmandu->importer('MARC',file => '/foo/usm01.txt' , type => 'ALEPHSEQ');
my $fixer = Catmandu->fixer("marc_map('245a','title')");
$importer->each(sub {
my $item = shift;
...
});
# or using the fixer
$fixer->fix($importer)->each(sub {
my $item = shift;
printf "title: %s\n" , $item->{title};
});
=head1 METHODS
=head2 new(file => $file , fh => $fh)
Parse a file or a filehandle into a L<Catmandu::Iterable>.
=head1 INHERTED METHODS
=head2 count
=head2 each(&callback)
=head2 ...
Every Catmandu::Importer is a Catmandu::Iterable all its methods are inherited.
=cut
package Catmandu::Importer::MARC::ALEPHSEQ;
use Catmandu::Sane;
use Moo;
with 'Catmandu::Importer';
sub generator {
my $self = shift;
sub {
state $fh = $self->fh;
state $prev_id;
state $record = [];
while(<$fh>) {
chop;
next unless (length $_ >= 18);
my ($sysid,$s1,$tag,$ind1,$ind2,$s2,$char,$s3,$data) = unpack("A9A1A3A1A1A1A1A1U0A*",$_);
unless ($tag =~ m{^[0-9A-Z]+}o) {
warn "skipping $sysid $tag unknown tag";
next;
}
unless ($ind1 =~ m{^[A-Za-z0-9-]$}o) {
$ind1 = " ";
}
unless ($ind2 =~ m{^[A-Za-z0-9-]$}o) {
$ind2 = " ";
}
unless (utf8::decode($data)) {
warn "skipping $sysid $tag unknown data";
next;
}
if ($tag eq 'LDR') {
$data =~ s/\^/ /g;
}
my @parts = ('_' , split(/\$\$(.)/, $data) );
# All control-fields contain an underscore field containing the data
# all other fields not.
unless ($tag =~ /^FMT|LDR|00.$/o) {
shift @parts;
shift @parts;
}
# If we have an empty subfield at the end, then we need to add a implicit empty value
push(@parts,'') unless int(@parts) % 2 == 0;
if (@$record > 0 && $tag eq 'FMT') {
my $result = { _id => $prev_id , record => [ @$record ] };
$record = [[$tag, $ind1, $ind2, @parts]];
$prev_id = $sysid;
return $result;
}
push @$record, [$tag, $ind1, $ind2, @parts];
$prev_id = $sysid;
}
if (@$record > 0) {
my $result = { _id => $prev_id , record => [ @$record ] };
$record = [];
return $result;
}
else {
return;
}
};
}
1;
|