patch pour le champ 100 AddAuthority.
authorHenri-Damien LAURENT <henridamien@koha-fr.org>
Tue, 6 Nov 2007 17:55:44 +0000 (11:55 -0600)
committerJoshua Ferraro <jmf@liblime.com>
Wed, 7 Nov 2007 14:20:51 +0000 (08:20 -0600)
Signed-off-by: Chris Cormack <crc@liblime.com>
Signed-off-by: Joshua Ferraro <jmf@liblime.com>
C4/AuthoritiesMarc.pm

index 1a727bb..632bdb2 100644 (file)
@@ -516,30 +516,24 @@ sub AddAuthority {
     $sth->execute($authid,$authtypecode,$record->as_usmarc,$record->as_xml_record($format));
     $sth->finish;
   }else{
-  ##Insert the recordID in MARC record 
-    unless ($record->field('001') && $record->field('001')->data() eq $authid){
-        $record->delete_field($record->field('001'));
-        $record->insert_fields_ordered(MARC::Field->new('001',$authid));
-    }
-    # check for field 100 in UNIMARC
-    if (($format eq "UNIMARCAUTH") && !$record->subfield('100','a')) {
-        $record->leader("     nx  j22             ");
-        my $date=POSIX::strftime("%Y%m%d",localtime);    
-        if ($record->field('100')){
-            $record->field('100')->update('a'=>$date."afrey50      ba0");
-        } else {      
-            $record->append_fields(
-            MARC::Field->new('100',' ',' '
-                ,'a'=>$date."afrey50      ba0")
-            );
-        }
-    }
-    # field 152 contains authtypecode (unused field in MARC21, correct place in UNIMARC)
-    $record->add_fields('152','','','b'=>$authtypecode) unless ($record->field('152'));
-    $dbh->do("lock tables auth_header WRITE");
-    my $sth=$dbh->prepare("update auth_header set marc=?,marcxml=? where authid=?");
-    $sth->execute($record->as_usmarc,$record->as_xml_record($format),$authid);
-    $sth->finish;
+      $record->add_fields('001',$authid) unless ($record->field('001'));
+      if (($format eq "UNIMARCAUTH") && (!$record->subfield('100','a')){
+            $record->leader("     nx  j22             ");
+            my $date=POSIX::strftime("%Y%m%d",localtime);    
+            if ($record->field('100')){
+              $record->field('100')->update('a'=>$date."afrey50      ba0");
+            } else {      
+              $record->append_fields(
+                MARC::Field->new('100',' ',' '
+                  ,'a'=>$date."afrey50      ba0")
+              );
+            }      
+      }    
+      $record->add_fields('152','','','b'=>$authtypecode) unless ($record->field('152'));
+      $dbh->do("lock tables auth_header WRITE");
+      my $sth=$dbh->prepare("update auth_header set marc=?,marcxml=? where authid=?");
+      $sth->execute($record->as_usmarc,$record->as_xml_record($format),$authid);
+      $sth->finish;
   }
   $dbh->do("unlock tables");
   ModZebra($authid,'specialUpdate',"authorityserver",$record);