/[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 802 by dpavlin, Thu Feb 15 22:43:03 2007 UTC revision 824 by dpavlin, Fri May 18 20:27:21 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( lc(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 38  if ( rec('230') ) { Line 69  if ( rec('230') ) {
69    
70    
71  marc('035','6',  marc('035','6',
72  join_with(' ',  join_with('',
73  #               config('input normalize path'),  #               config('input normalize path'),
74  #               config('name'),  #               config('name'),
75                  config(),                  config(),
# 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 110  marc_repeatable_subfield('041','a', Line 142  marc_repeatable_subfield('041','a',
142    
143    
144  ### 080  ### 080
145  # 675 podpolja c, d ... - što s njima ???  # 675 podpolja b, c, d ... - što s njima ???
146    
147  marc('080','a',  marc('080','a',
148          rec('675','a')          rec('675','a')
# Line 130  marc('084','a', Line 162  marc('084','a',
162  ### 100  ### 100
163  # I1 = 0 ako je pseudonim (ima 700a, nema 700b)  # I1 = 0 ako je pseudonim (ima 700a, nema 700b)
164    
165  marc_indicators('100', 1, ' ');  if ( rec('700','a') && ! rec('700','b') ) {
166            marc_indicators('100', 0, ' ');
167    } else {
168            marc_indicators('100', 1, ' ');
169    }
170    
171  marc('100','a',  marc('100','a',
172          join_with(', ',          join_with(', ',
173                  rec('700', 'a'),                  rec('700', 'a'),
# Line 171  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/^Der /) ||
229          ( rec('200','a') =~ m/^The /) ) {          ( rec('200','a') =~ m/^The /) ) {
230                  marc_indicators('245', 1, 4);                  marc_indicators('245', $i1, 4);
231    }
232    
233    if (    ( rec('200','a') =~ m/^A /) && ( rec(101) =~ m/ENG/ ) ) {
234                    marc_indicators('245', $i1, 2);
235  }  }
236    
237  if (    ( rec('200','a') =~ m/^A /) && ( rec(101) =~ m/ENG/ ) )  if (    ( rec('200','a') =~ m/^An /) && ( rec(101) =~ m/ENG/ ) ) {
238          {                  marc_indicators('245', $i1, 2);
                 marc_indicators('245', 1, 2);  
239  }  }
240    
241  ### 245  ### 245
242  # redoslijed polja  # redoslijed polja važan
243    # podpolja i interpunkcije pripremljeni u modify
244    
245  #_debug(3);  #_debug(3);
246    
247  marc_compose('245',  marc_compose('245',
248          'a', suffix(          'a', suffix(
249                  rec('200','b') ? '. '   :                  ( ! rec('200','p') && ( rec('200','f') || rec('200','c') ) ) ? ' / ' :  
250                  rec('200','k') ? ' ; '  :                  ( rec('200','p') && rec('200','c') ) ? ' : '  :
251                  rec('200','d') ? ' = '  :                          '',
252                  rec('200','e') ? ' : '  :                          rec('200','a'),
                 rec('200','f') ? ' / '  :  
                                  '.',  
                         rec('200','a')  
253          ),          ),
 #       'h', rec('200','b'),  
254          'b', suffix(          'b', suffix(
255                  ( rec('200','k') && rec('200','f') ) ? ' / ' :                  ( rec('200','p') && rec('200','f') ) ? ' / ' :
256                                       ' ',                  ( rec('200','p') && rec('200','c') ) ? '. '  :
257                          join_with(' ; ',                          '',
258                                  rec('200','k'),                          rec('200','p'),
                         ),  
259          ),          ),
260          'b', suffix(          'c', suffix(
261                  ( rec('200','d') && rec('200','f') ) ? ' / ' :                  ( rec('200','f') && rec('200','c') ) ? '. ' :
262                                                         ' ',                          '',
263                                  rec('200','d'),                          rec('200','f'),
         ),  
         'b', suffix(  
                 ( rec('200','e') && rec('200','f') ) ? ' / ' :  
                                                        ' ',  
                         join_with(' : ',  
                                 rec('200','e'),  
                         ),  
264          ),          ),
265            '+', rec('200','c'),
266    );
267    
268          'c', rec('200','f'),  #_debug(0);
269    
270  # append to last subfield  #marc_compose('245',
271          '+', prefix('. ',  #       'a', suffix(
272                  rec('200','c')  #               rec('200','b') ? '. '   :
273          ),  #               rec('200','k') ? ' ; '  :
274  );  #               rec('200','d') ? ' = '  :
275    #               rec('200','e') ? ' : '  :
276    #               rec('200','f') ? ' / '  :
277    #                                '.',
278    #                       rec('200','a')
279    #       ),
280    ##      'h', rec('200','b'),
281    #       'b', suffix(
282    #               ( rec('200','k') && rec('200','f') ) ? ' / ' :
283    #                                    ' ',
284    #                       join_with(' ; ',
285    #                               rec('200','k'),
286    #                       ),
287    #       ),
288    #       'b', suffix(
289    #               ( rec('200','d') && rec('200','f') ) ? ' / ' :
290    #                                                      ' ',
291    #                               rec('200','d'),
292    #       ),
293    #       'b', suffix(
294    #               ( rec('200','e') && rec('200','f') ) ? ' / ' :
295    #                                                      ' ',
296    #                       join_with(' : ',
297    #                               rec('200','e'),
298    #                       ),
299    #       ),
300    #       'c', rec('200','f'),
301    ### append to last subfield
302    #       '+', prefix('. ',
303    #               rec('200','c')
304    #       ),
305    #);
306    
307    
308    
 #_debug(0);  
309    
310    
311  ### 250  ### 250
312    
313  marc('250','a',  marc_compose('250',
314          suffix(          'a',suffix(
315                  rec('205','f') ? ' / ' :                  rec('205','f') ? ' / ' :
316                                   ' '.                          ' ',
317                          rec('205','a')                          rec('205','a')
318          )          ),
319            'b', rec('205','f'),
320  );  );
321    
322  marc('250','b',  #marc('250','b',
323          rec('205','f')  #       rec('205','f')
324  );  #);
325    
326    
327  ### 260  ### 260
# Line 274  marc('300','b', Line 347  marc('300','b',
347          suffix(          suffix(
348                  ( rec('215','c') && rec('215','d') ) ? ' ; ' :                  ( rec('215','c') && rec('215','d') ) ? ' ; ' :
349                  ( rec('215','c') && rec('215','e') ) ? ' + ' :                  ( rec('215','c') && rec('215','e') ) ? ' + ' :
350                                                                  ' ',                                                         ' ',
351                          rec('215','c')                          rec('215','c')
352          )          )
353  );  );
# Line 297  marc('300','e', Line 370  marc('300','e',
370    
371  marc_indicators('440', ' ', '0');  marc_indicators('440', ' ', '0');
372    
373  marc('440','a',  if (    ( rec('225','a') =~ m/^Die /) ||
374          join_with(' : ',          ( rec('225','a') =~ m/^Das /) ||
375                  rec('225','a'),          ( rec('225','a') =~ m/^The /) ) {
376                  join_with(' / ',                  marc_indicators('440', ' ', 4);
377                          rec('225','e'),  }
378                          rec('225','f')  
379                  )  if (    ( rec('225','a') =~ m/^A /) && ( rec(101) =~ m/ENG/ ) ) {
380          )                  marc_indicators('440', ' ', 2);
381  ) ;  }
382    
383    if (    ( rec('225','a') =~ m/^An /) && ( rec(101) =~ m/ENG/ ) ) {
384                    marc_indicators('440', ' ', 2);
385    }
386    
387    #_debug(3);
388    
389    marc('440',
390            'a', suffix( rec('225','f'),
391                            rec('225','a'),
392            ),
393    );
394    
395    #       join_with(' / ',
396    #               join_with(' ',
397    #                       rec('225','a'),
398    #                       rec('225','p'),
399    #               ),
400    #                       rec('225','f')
401    #       ),
402    
403    #_debug(0);
404    
405  marc('440','n',  marc('440','n',
406          rec('225','h')          rec('225','h')
# Line 316  marc('440','p', Line 411  marc('440','p',
411  );  );
412    
413  marc('440','v',  marc('440','v',
414          join_with(', ',          rec('225','v'),
                 rec('225','v'),  
                 rec('225','w')  
         ),  
415  );  );
416    
417  marc('440','x',  marc('440','x',
418          rec('225','x')          rec('225','x')
419  );  );
420    
 marc('440','a',  
         rec('225','b'),  
 );  
   
421    
422  ### 490  ### 490
423  #  #
# Line 338  marc('440','a', Line 426  marc('440','a',
426  #);  #);
427    
428    
429  ### 500  ### 50x
430    
431  marc('500','a',  marc('500','a',
432          rec('300')          rec('300')
# Line 382  if ( config() =~ m/ffps/ || config() =~ Line 470  if ( config() =~ m/ffps/ || config() =~
470  );  );
471  }  }
472    
473    if ( config() =~ m/ffan/ ) {
474            marc_indicators('505', '0', ' ');
475            marc('505','a',
476                    regex('s/[<>]//g',
477                            rec('330')
478                    )      
479    );
480    }
481    
482    
483    
484  ## napomene uz konverziju polja 330:  ## napomene uz konverziju polja 330:
# Line 400  if ( config() =~ m/ffps/ ) { Line 497  if ( config() =~ m/ffps/ ) {
497          );          );
498  }  }
499    
500  # FFTU 330 - ???  ### 526 - STUDY PROGRAM INFORMATION NOTE
501  if ( config() =~ m/fftu/ ) {  
502          marc('520','a',  marc_indicators('526', 8, ' ');
                 rec('330')  
         );  
 }  
503    
504    marc('526','a',
505            rec('996')
506    );
507    
508  ### 538  ### 538 - zahtjevi sustava
509    
510  marc('538','a',  marc('538','a',
511          rec('337','a')          rec('337','a')
# Line 549  marc_indicators('740', 0, ' '); Line 646  marc_indicators('740', 0, ' ');
646  #       rec('200','c')  #       rec('200','c')
647  # );  # );
648    
649   marc('740','a',  marc('740','a',
650          rec('200','k')          rec('200','k')
651   );  );
652    
653  # } else {  # } else {
654    
# Line 563  marc_indicators('740', 0, ' '); Line 660  marc_indicators('740', 0, ' ');
660    
661  ### generiranje zapisa o nakladničkoj cjelini i povezivanje podređenog zapisa s nadređenim  ### generiranje zapisa o nakladničkoj cjelini i povezivanje podređenog zapisa s nadređenim
662    
663    if (
664            rec('225','a')  # da li je nakladnicka cjelina?
665    ) {
666    
667    my $series_key =
668    join_with('',
669            rec('225','a'),
670            rec('210','a'),
671            rec('210','b'),
672    );
673    
674    my $series = get( $series_key );
675    
676    if ($series) {
677            warn "nije novi";
678    } else {
679    
680    
681    $series = join_with('',
682            config(),
683            'LS',
684            rec('000')
685    );
686    
687    set( $series_key => $series );
688    
689    }
690    }
691    
692  my $series_key = join_with('',  my $series_key = join_with('',
693          rec('225','a'),          rec('225','a'),
# Line 577  if ($series_key) { Line 702  if ($series_key) {
702          marc('760','w',          marc('760','w',
703                  get( $series_key )                  get( $series_key )
704          );          );
   
705  }  }
   
706  ### testing  ### testing
707  #  #
708  # my $dup_key = join_with('',  # my $dup_key = join_with('',
# Line 601  if ($series_key) { Line 724  if ($series_key) {
724  #  #
725    
726    
727    ## 852 - lokacija
728    
729  ##################################  marc_indicators('852', 4, ' ');
 ##                              ##  
 ## pomoćni ispisi - privremeno! ##  
 ##                              ##  
 ##################################  
   
 if ( ! rec('464') && rec('200','c') ) {  
         marc('002',  
                 'ima-200c-nema-464'  
         );  
 }  
730    
731  if ( ! rec('464') && rec('200','k') ) {  marc('852','j',
732          marc('003',          join_with(' ',
733                  'ima-200k-nema-464'                  rec('990')
734          );          )
735  }  );
736    
737  if ( ! ( rec('200','c') || rec('200','k') ) && rec('464') ) {  ## 876 - item information - basic bibliographic unit
         marc('004',  
                 'ima-464-nema-200c-ili-200k'  
         );  
 }  
738    
739    marc('876','a',
740            rec('991'),
741    );
742    
743    ## 886 - former marc
744    
745  #_debug(2);  marc_indicators('886', 2, ' ');
746    
747  if ( rec('200') =~ m/prev/ ) {  marc('886','2',
748          marc('005',          'ffmarc'
749                  'prijevod'  );
         );  
 }  
750    
751  #_debug(0);  marc('886','a',
752            '994'
753    );
754    
755    marc('886','b',
756            join_with(''.
757                    '##^a',
758                    join_with('',
759                            prefix('^a',
760                                    rec('994','a'),
761                            ),
762                            prefix('^b',
763                                    rec('994','b')
764                            )
765                    )
766            )
767    );
768    
769    
770  } # polje 200a  } # polje 200a

Legend:
Removed from v.802  
changed lines
  Added in v.824

  ViewVC Help
Powered by ViewVC 1.1.26