/[webpac2]/trunk/conf/normalize/ff-libri.pl
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /trunk/conf/normalize/ff-libri.pl

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 807 by dpavlin, Sun Apr 1 12:26:25 2007 UTC revision 816 by dpavlin, Thu Apr 5 21:48:41 2007 UTC
# Line 29  if ( rec('230') ) { Line 29  if ( rec('230') ) {
29    
30  ### 001 - Voyager  ### 001 - Voyager
31    
32    ### 007
33    
34    marc_fixed('007',00,'ta');
35    
36  ### 008  ### 008
37    
38    if ( rec('994','c') ) {
39            marc_fixed('008','00',
40                    regex('s/^\d\d//',
41                            rec('994','c')
42                    ),
43            );
44    } else {
45            marc_fixed('008', 00,
46                    '000101'
47            );
48    }
49    
50    #warn( dump(
51    #       regex('s/^\d\d//',
52    #               rec('994','c')
53    #       ),
54    #)
55    #);
56    
57    ## FIXME treba velika slova pretvoriti u mala
58    
59    marc_fixed('008','35',
60            first( rec('101') )
61    );
62    
63    
64    
65  ### 035$6  ### 035$6
66  # Privemeno koristimo 035$6 umjesto 035$9, zato što marclint prijavljuje 9 kao grešku.  # Privemeno koristimo 035$6 umjesto 035$9, zato što marclint prijavljuje 9 kao grešku.
67  # marc 035a - System Number - NSK zapisuje Voyagerov ID (001) - kako?  # marc 035a - System Number - NSK zapisuje Voyagerov ID (001) - kako?
# Line 80  marc('040','e', Line 111  marc('040','e',
111  ### 041 indikatori  ### 041 indikatori
112  # pretpostavke o indikatorima:  # pretpostavke o indikatorima:
113  #  #
114  # 1. Ako postoji polje 300 i prvo pojavljivanje tog polja sadrži /Prijevod/ , i1 = 1  # 1. Ako postoji polje 300 i ono sadrži /Prijevod/ ili /Izv. stv. nasl./, i1 = 1
115  # (Da li je napomena uvijek pisana?)  # (Da li je napomena uvijek pisana?)
116  #  #
117  # 2. Podatak o prevodiocu u 200g. Problem: različiti oblici riječi, različiti jezici.  # 2. Podatak o prevodiocu u 200g. Problem: različiti oblici riječi, različiti jezici.
# Line 89  marc('040','e', Line 120  marc('040','e',
120  # (ako postoje zagrade pr. 94(=411.16) onda su to pomoćne oznake)  # (ako postoje zagrade pr. 94(=411.16) onda su to pomoćne oznake)
121  # pr. 821.111-2=163.42 je prijevod engleske drame na HR.  # pr. 821.111-2=163.42 je prijevod engleske drame na HR.
122  # to ima samo za književna djela, eseje....  # to ima samo za književna djela, eseje....
123    # ????
124    
125    
126  #if ( rec('675') =~ m/\d=\d/ ) {  #if ( rec('675') =~ m/\d=\d/ ) {
127  if ( first(rec('300')) =~ m/Prijevod/ || first(rec('300')) =~ m/Izv. stv. nasl./ ) {  if ( grep( m/Prijevod/, rec('300')) || grep( m/Izv. stv. nasl./, rec('300') ) ) {
128          marc_indicators('041', 1, ' ');          marc_indicators('041', 1, ' ');
129  } else {  } else {
130          marc_indicators('041', 0, ' ');          marc_indicators('041', 0, ' ');
# Line 176  marc('110','c', Line 208  marc('110','c',
208    
209    
210  ### 245 indikatori  ### 245 indikatori
211  # i1 = 1 za sve zapise  # i1 = 0 za anonimne publikacije, i1 = 1 ako postoji 700 ili 710
212  # i2 = pretpostavlja se na temelju člana na početku naslova i jezika  # i2 = pretpostavlja se na temelju člana na početku naslova i jezika
213  # treba nadopuniti i dati podatke na verifikaciju knjižničarima  # treba nadopuniti i dati podatke na verifikaciju knjižničarima
214    
215  marc_indicators('245', 1, 0);  my $i1;
216    
217    if ( rec('700') || rec('710') ) {
218            $i1 = 1;
219    
220    } else {
221            $i1 = 0;
222    }
223            
224    marc_indicators('245', $i1, 0);
225    
226  if (    ( rec('200','a') =~ m/^Die /) ||  if (    ( rec('200','a') =~ m/^Die /) ||
227          ( rec('200','a') =~ m/^Das /) ||          ( rec('200','a') =~ m/^Das /) ||
228          ( rec('200','a') =~ m/^The /) ) {          ( rec('200','a') =~ m/^The /) ) {
229                  marc_indicators('245', 1, 4);                  marc_indicators('245', $i1, 4);
230  }  }
231    
232  if (    ( rec('200','a') =~ m/^A /) && ( rec(101) =~ m/ENG/ ) ) {  if (    ( rec('200','a') =~ m/^A /) && ( rec(101) =~ m/ENG/ ) ) {
233                  marc_indicators('245', 1, 2);                  marc_indicators('245', $i1, 2);
234  }  }
235    
236  if (    ( rec('200','a') =~ m/^An /) && ( rec(101) =~ m/ENG/ ) ) {  if (    ( rec('200','a') =~ m/^An /) && ( rec(101) =~ m/ENG/ ) ) {
237                  marc_indicators('245', 1, 2);                  marc_indicators('245', $i1, 2);
238  }  }
239    
240  ### 245  ### 245
241  # redoslijed polja  # redoslijed polja važan
242    # podpolja i interpunkcije pripremljeni u modify
243    
244  #_debug(3);  #_debug(3);
245    
246  marc_compose('245',  marc_compose('245',
247          'a', suffix(          'a', suffix(
248                  rec('200','b') ? '. '   :                  ( ! rec('200','b') && ( rec('200','f') || rec('200','c') ) ) ? ' / ' : ' ',
249                  rec('200','k') ? ' ; '  :                          rec('200','a'),
                 rec('200','d') ? ' = '  :  
                 rec('200','e') ? ' : '  :  
                 rec('200','f') ? ' / '  :  
                                  '.',  
                         rec('200','a')  
250          ),          ),
 #       'h', rec('200','b'),  
251          'b', suffix(          'b', suffix(
252                  ( rec('200','k') && rec('200','f') ) ? ' / ' :                  ( rec('200','b') && rec('200','f') ) ? ' / ' :
253                                       ' ',                  ( rec('200','b') && rec('200','c') ) ? '. '  :
254                          join_with(' ; ',                          ' ',
255                                  rec('200','k'),                          rec('200','b'),
                         ),  
         ),  
         'b', suffix(  
                 ( rec('200','d') && rec('200','f') ) ? ' / ' :  
                                                        ' ',  
                                 rec('200','d'),  
256          ),          ),
257          'b', suffix(          'c', suffix(
258                  ( rec('200','e') && rec('200','f') ) ? ' / ' :                  ( rec('200','f') && rec('200','c') ) ? '. ' :
259                                                         ' ',                          ' ',
260                          join_with(' : ',                          rec('200','f'),
                                 rec('200','e'),  
                         ),  
261          ),          ),
262            '+', rec('200','c'),
263    );
264    
265          'c', rec('200','f'),  #_debug(0);
266    
267  # append to last subfield  #marc_compose('245',
268          '+', prefix('. ',  #       'a', suffix(
269                  rec('200','c')  #               rec('200','b') ? '. '   :
270          ),  #               rec('200','k') ? ' ; '  :
271  );  #               rec('200','d') ? ' = '  :
272    #               rec('200','e') ? ' : '  :
273    #               rec('200','f') ? ' / '  :
274    #                                '.',
275    #                       rec('200','a')
276    #       ),
277    ##      'h', rec('200','b'),
278    #       'b', suffix(
279    #               ( rec('200','k') && rec('200','f') ) ? ' / ' :
280    #                                    ' ',
281    #                       join_with(' ; ',
282    #                               rec('200','k'),
283    #                       ),
284    #       ),
285    #       'b', suffix(
286    #               ( rec('200','d') && rec('200','f') ) ? ' / ' :
287    #                                                      ' ',
288    #                               rec('200','d'),
289    #       ),
290    #       'b', suffix(
291    #               ( rec('200','e') && rec('200','f') ) ? ' / ' :
292    #                                                      ' ',
293    #                       join_with(' : ',
294    #                               rec('200','e'),
295    #                       ),
296    #       ),
297    #       'c', rec('200','f'),
298    ### append to last subfield
299    #       '+', prefix('. ',
300    #               rec('200','c')
301    #       ),
302    #);
303    
304    
305    
 #_debug(0);  
306    
307    
308  ### 250  ### 250
# Line 282  marc('300','b', Line 343  marc('300','b',
343          suffix(          suffix(
344                  ( rec('215','c') && rec('215','d') ) ? ' ; ' :                  ( rec('215','c') && rec('215','d') ) ? ' ; ' :
345                  ( rec('215','c') && rec('215','e') ) ? ' + ' :                  ( rec('215','c') && rec('215','e') ) ? ' + ' :
346                                                                  ' ',                                                         ' ',
347                          rec('215','c')                          rec('215','c')
348          )          )
349  );  );
# Line 305  marc('300','e', Line 366  marc('300','e',
366    
367  marc_indicators('440', ' ', '0');  marc_indicators('440', ' ', '0');
368    
369    if (    ( rec('225','a') =~ m/^Die /) ||
370            ( rec('225','a') =~ m/^Das /) ||
371            ( rec('225','a') =~ m/^The /) ) {
372                    marc_indicators('440', ' ', 4);
373    }
374    
375    if (    ( rec('225','a') =~ m/^A /) && ( rec(101) =~ m/ENG/ ) ) {
376                    marc_indicators('440', ' ', 2);
377    }
378    
379    if (    ( rec('225','a') =~ m/^An /) && ( rec(101) =~ m/ENG/ ) ) {
380                    marc_indicators('440', ' ', 2);
381    }
382    
383  marc('440','a',  marc('440','a',
384          join_with(' : ',          rec('225','a'),
385                  rec('225','a'),  );
                 join_with(' / ',  
                         rec('225','e'),  
                         rec('225','f')  
                 )  
         )  
 ) ;  
386    
387  marc('440','n',  marc('440','n',
388          rec('225','h')          rec('225','h')
# Line 324  marc('440','p', Line 393  marc('440','p',
393  );  );
394    
395  marc('440','v',  marc('440','v',
396          join_with(', ',          rec('225','v'),
                 rec('225','v'),  
                 rec('225','w')  
         ),  
397  );  );
398    
399  marc('440','x',  marc('440','x',
400          rec('225','x')          rec('225','x')
401  );  );
402    
 marc('440','a',  
         rec('225','b'),  
 );  
   
403    
404  ### 490  ### 490
405  #  #
# Line 346  marc('440','a', Line 408  marc('440','a',
408  #);  #);
409    
410    
411  ### 500  ### 50x
412    
413  marc('500','a',  marc('500','a',
414          rec('300')          rec('300')
# Line 390  if ( config() =~ m/ffps/ || config() =~ Line 452  if ( config() =~ m/ffps/ || config() =~
452  );  );
453  }  }
454    
455    if ( config() =~ m/ffan/ ) {
456            marc_indicators('505', '0', ' ');
457            marc('505','a',
458                    regex('s/[<>]//g',
459                            rec('330')
460                    )      
461    );
462    }
463    
464    
465    
466  ## napomene uz konverziju polja 330:  ## napomene uz konverziju polja 330:
# Line 408  if ( config() =~ m/ffps/ ) { Line 479  if ( config() =~ m/ffps/ ) {
479          );          );
480  }  }
481    
482  # FFTU 330 - ???  ### 526 - STUDY PROGRAM INFORMATION NOTE
 if ( config() =~ m/fftu/ ) {  
         marc('520','a',  
                 rec('330')  
         );  
 }  
483    
484    marc_indicators('526', 8, ' ');
485    
486    marc('526','a',
487            rec('996')
488    );
489    
490  ### 538  ### 538 - zahtjevi sustava
491    
492  marc('538','a',  marc('538','a',
493          rec('337','a')          rec('337','a')
# Line 608  if ($series_key) { Line 679  if ($series_key) {
679  #  #
680    
681    
682    ## 852 - lokacija
683    
684  ##################################  marc_indicators('852', 4, ' ');
 ##                              ##  
 ## pomoćni ispisi - privremeno! ##  
 ##                              ##  
 ##################################  
   
 if ( ! rec('464') && rec('200','c') ) {  
         marc('002',  
                 'ima-200c-nema-464'  
         );  
 }  
685    
686  if ( ! rec('464') && rec('200','k') ) {  marc('852','j',
687          marc('003',          join_with(' ',
688                  'ima-200k-nema-464'                  rec('990')
689          );          )
690  }  );
691    
692  if ( ! ( rec('200','c') || rec('200','k') ) && rec('464') ) {  ## 876 - item information - basic bibliographic unit
         marc('004',  
                 'ima-464-nema-200c-ili-200k'  
         );  
 }  
693    
694    marc('876','a',
695            rec('991'),
696    );
697    
698    ## 886 - former marc
699    
700  #_debug(2);  marc_indicators('886', 2, ' ');
701    
702  if ( rec('200') =~ m/prev/ ) {  marc('886','2',
703          marc('005',          'ffmarc'
704                  'prijevod'  );
         );  
 }  
705    
706  #_debug(0);  marc('886','a',
707            '994'
708    );
709    
710    marc('886','b',
711            join_with(''.
712                    '##^a',
713                    join_with('',
714                            prefix('^a',
715                                    rec('994','a'),
716                            ),
717                            prefix('^b',
718                                    rec('994','b')
719                            )
720                    )
721            )
722    );
723    
724    
725  } # polje 200a  } # polje 200a

Legend:
Removed from v.807  
changed lines
  Added in v.816

  ViewVC Help
Powered by ViewVC 1.1.26