8 |
|
|
9 |
my %opts; |
my %opts; |
10 |
|
|
11 |
getopt('dm', \%opts); |
getopts('d:m:q', \%opts); |
12 |
|
|
13 |
die "usage: $0 -d [database_dir] -m [database1,database2] " if (! %opts); |
die "usage: $0 -d [database_dir] -m [database1,database2] " if (! %opts); |
14 |
|
|
41 |
require "./search/config.pm"; |
require "./search/config.pm"; |
42 |
|
|
43 |
#-------------------------------------------------------------------- |
#-------------------------------------------------------------------- |
44 |
|
# read database configuration, store database names |
45 |
|
open(CF,$common::database_cf) || die "$common::database_cf: $!"; |
46 |
|
my %DatabaseDescriptions; |
47 |
|
while(<CF>) { |
48 |
|
chomp; |
49 |
|
if (/^database-name:([^=]+)=(.*)$/) { |
50 |
|
my ($db_name,$db_desc) = ($1,$2); |
51 |
|
$db_desc=~s/^##\w+##//g; |
52 |
|
$DatabaseDescriptions{$db_name}=$db_desc; |
53 |
|
} |
54 |
|
} |
55 |
|
close(CF); |
56 |
|
|
57 |
|
#-------------------------------------------------------------------- |
58 |
# |
# |
59 |
# expand(nr,"space separated string"); |
# expand(nr,"space separated string"); |
60 |
# |
# |
84 |
return $tmp; |
return $tmp; |
85 |
} |
} |
86 |
|
|
87 |
|
sub c_iso_852 { |
88 |
|
my $tmp = $_[0]; |
89 |
|
$tmp =~ tr/ܫꔼȺ̪㍐슂ٝ// if ($tmp); |
90 |
|
return $tmp; |
91 |
|
} |
92 |
|
|
93 |
sub c_852_czs { |
sub c_852_czs { |
94 |
my $tmp = $_[0]; |
my $tmp = $_[0]; |
95 |
$tmp =~ tr//ܫꔼȺ̪㍐슂ٝ/; |
$tmp =~ tr//ܫꔼȺ̪㍐슂ٝ/; |
325 |
my $row = OpenIsis::read( $db, $row_id ); |
my $row = OpenIsis::read( $db, $row_id ); |
326 |
if (my $tmp = $row->{'200'}->[0]) { |
if (my $tmp = $row->{'200'}->[0]) { |
327 |
|
|
|
my $bib = "%MFN $row->{mfn}\n"; |
|
328 |
my $mps = "W $row->{mfn} 14\n"; |
my $mps = "W $row->{mfn} 14\n"; |
329 |
|
|
330 |
my $pcnt = int($row->{mfn} * 100 / $max_rowid); |
my $pcnt = int($row->{mfn} * 100 / $max_rowid); |
331 |
if ($pcnt != $last_pcnt) { |
if ($pcnt != $last_pcnt) { |
332 |
printf MPS ("M %5d / %5d -- %-2d %%\n",$row->{mfn},$max_rowid,$pcnt); |
printf MPS ("M %5d / %5d -- %-2d %%\n",$row->{mfn},$max_rowid,$pcnt) if (! $opts{q}); |
333 |
$last_pcnt = $pcnt; |
$last_pcnt = $pcnt; |
334 |
} |
} |
335 |
|
|
336 |
my $headline; |
my $headline; |
337 |
$headline .= isis_sf($row,'200','a',"'"); |
$headline .= isis_sf($row,'200','a'); |
338 |
$headline .= isis_sf($row,'200','e'," : ","'"); |
$headline .= isis_sf($row,'200','e'," : "); |
339 |
|
$headline .= isis_sf($row,'200','f'," / "); |
340 |
|
$headline .= isis_sf($row,'210','d'," , "); |
341 |
|
|
342 |
|
# remove newlines, compress spaces |
343 |
|
$headline =~ s/[\n\r]//g; |
344 |
|
$headline =~ s/^\s+//g; |
345 |
|
$headline =~ s/\s+$//g; |
346 |
|
|
347 |
# author |
# author |
348 |
$bib .= isis_to_bib($row,'700','%700+','*',2,'<'); |
$bib .= isis_to_bib($row,'700','%700+','ab',undef,'>',', '); |
349 |
$bib .= isis_to_bib($row,'701','%700+','*',2,'<'); |
$bib .= isis_to_bib($row,'701','%700+','ab',undef,'>',', '); |
350 |
$bib .= isis_to_bib($row,'710','%700+','*',2,'<'); |
$bib .= isis_to_bib($row,'701','%700+','cd',undef,'>',', '); |
351 |
$bib .= isis_to_bib($row,'711','%700+','*',2,'<'); |
|
352 |
$bib .= isis_to_bib($row,'503','%700+','*',2,'<'); |
my $tmp = isis_sf($row,'710','abc', '', '', (' : ',', ')); |
353 |
|
$tmp .= isis_sf($row,'710','dfe', ' (', ')', ('', ' ; ',' ; ')); |
354 |
|
$bib .= "%700+ $tmp\n" if ($tmp); |
355 |
|
|
356 |
|
my $tmp = isis_sf($row,'711','abc', '', '', (' : ',', ')); |
357 |
|
$tmp .= isis_sf($row,'711','dfe', ' (', ')', ('', ' ; ',' ; ')); |
358 |
|
$bib .= "%700+ $tmp\n" if ($tmp); |
359 |
|
|
360 |
|
$bib .= isis_to_bib($row,'503','%700+','ab',undef,'>',', '); |
361 |
|
|
362 |
$mps .= isis_to_mps($row,'700',1); |
$mps .= isis_to_mps($row,'700',1); |
363 |
$mps .= isis_to_mps($row,'701',1); |
$mps .= isis_to_mps($row,'701',1); |
426 |
$mps .= isis_to_mps($row,'272',2); |
$mps .= isis_to_mps($row,'272',2); |
427 |
$mps .= isis_to_mps($row,'273',2); |
$mps .= isis_to_mps($row,'273',2); |
428 |
|
|
|
$headline .= isis_sf($row,'700','b'," "); |
|
|
$headline .= isis_sf($row,'700','a'," "); |
|
|
|
|
429 |
# izdavac |
# izdavac |
430 |
$mps .= isis_to_mps($row,'210',3); |
$mps .= isis_to_mps($row,'210',3); |
431 |
$mps .= isis_to_mps($row,'250',3); |
$mps .= isis_to_mps($row,'250',3); |
444 |
if (my $year = isis_sf($row,'210','d')) { |
if (my $year = isis_sf($row,'210','d')) { |
445 |
$year =~ s/^\s*cop\.*\s*//i; |
$year =~ s/^\s*cop\.*\s*//i; |
446 |
$year =~ s/[\[\]]*//g; |
$year =~ s/[\[\]]*//g; |
447 |
|
$year =~ s/[\n\r]//g; # remove cr |
448 |
$mps .= "D ${year}\n" if ($year !~ m/\?/ && $year =~ /\d{4}/); |
$mps .= "D ${year}\n" if ($year !~ m/\?/ && $year =~ /\d{4}/); |
|
$headline .= " ($year)"; |
|
449 |
} |
} |
450 |
|
|
451 |
$mps .= isis_to_mps($row,'215',15); |
$mps .= isis_to_mps($row,'215',15); |
498 |
my $mps=''; |
my $mps=''; |
499 |
while (my $isn=$row->{$isis_id}->[$i]) { |
while (my $isn=$row->{$isis_id}->[$i]) { |
500 |
$isn =~ s/ +//g; # remove spaces |
$isn =~ s/ +//g; # remove spaces |
501 |
|
$isn =~ s/[\n\r]//g; # remove cr |
502 |
$mps .= "W $isn $nr\n"; |
$mps .= "W $isn $nr\n"; |
503 |
if ($isn =~ s/-//g) { |
if ($isn =~ s/-//g) { |
504 |
$mps .= "W $isn $nr\n"; |
$mps .= "W $isn $nr\n"; |
521 |
|
|
522 |
$mps .= isis_to_mps($row,'532',1); |
$mps .= isis_to_mps($row,'532',1); |
523 |
|
|
524 |
$bib .= isis_to_bib($row,'994','%994a','a'); |
$bib .= '%knjiz '.$DatabaseDescriptions{$db_dir}.", ".$row->{mfn}."\n"; |
|
|
|
525 |
# headline |
# headline |
526 |
if ($headline) { |
if ($headline) { |
527 |
$headline .= " [".$row->{mfn}."]"; ## debug MFN! |
$headline .= " <i>(".$DatabaseDescriptions{$db_dir}.", ".$row->{mfn}.")</i>"; ## debug MFN! |
528 |
$headline =~ s/&/∧/g; |
$headline =~ s/&/∧/g; |
529 |
$headline =~ s/</</g; |
$headline =~ s/</</g; |
530 |
$headline =~ s/>/>/g; |
$headline =~ s/>/>/g; |