[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Koha-cvs] koha/C4 Biblio.pm
From: |
Joshua Ferraro |
Subject: |
[Koha-cvs] koha/C4 Biblio.pm |
Date: |
Wed, 22 Feb 2006 01:02:39 +0000 |
CVSROOT: /sources/koha
Module name: koha
Branch:
Changes by: Joshua Ferraro <address@hidden> 06/02/22 01:02:39
Modified files:
C4 : Biblio.pm
Log message:
Replacing all calls to zebra_update with calls to
z3950_extended_services. More work coming, but it's
working now.
CVSWeb URLs:
http://cvs.savannah.gnu.org/viewcvs/koha/koha/C4/Biblio.pm.diff?tr1=1.144&tr2=1.145&r1=text&r2=text
Patches:
Index: koha/C4/Biblio.pm
diff -u koha/C4/Biblio.pm:1.144 koha/C4/Biblio.pm:1.145
--- koha/C4/Biblio.pm:1.144 Mon Feb 20 14:22:38 2006
+++ koha/C4/Biblio.pm Wed Feb 22 01:02:39 2006
@@ -30,7 +30,8 @@
use vars qw($VERSION @ISA @EXPORT);
# set the version for version checking
-$VERSION = 0.01;
+$VERSION = do { my @v = '$Revision: 1.145 $' =~ /\d+/g;
+ shift(@v) . "." . join("_", map {sprintf "%03d", $_ } @v); };
@ISA = qw(Exporter);
@@ -156,7 +157,7 @@
# unlink($filename);
my $Zconn;
my $xmlrecord;
-# warn "zebra_create : $biblionumber =".$record->as_formatted;
+ warn "zebra_create : $biblionumber =".$record->as_formatted;
eval {
$xmlrecord=$record->as_xml();
};
@@ -237,7 +238,8 @@
}
if ($record) {
- $Zpackage->option(record => $record);
+ my $xmlrecord = marc2xml($record);
+ $Zpackage->option(record => $xmlrecord);
if ($serviceOptions->{'syntax'}) {
$Zpackage->option(syntax => $serviceOptions->{'syntax'});
}
@@ -253,6 +255,30 @@
$Zpackage->destroy();
}
+sub marc2xml {
+ my ($record) = @_;
+ my $xmlrecord;
+ eval {
+ $xmlrecord=$record->as_xml();
+ };
+ if ($@){
+ warn "ERROR badly formatted marc record";
+ warn "Skipping record";
+ }
+ return $xmlrecord;
+}
+sub set_service_options {
+ my ($option) = @_;
+ my $serviceOptions;
+ if ($option eq 'update') {
+ $serviceOptions->{ 'action' } = 'specialUpdate';
+ $serviceOptions->{ 'syntax' } = 'xml'; #zebra doesn't support
others
+ }
+
+ return $serviceOptions;
+}
+
+
=head2 @tagslib = &MARCgettagslib($dbh,1|0,$frameworkcode);
=over 4
@@ -1223,7 +1249,11 @@
$biblioitem->{bnotes},
$biblioitem->{size}, $biblioitem->{place}, $biblioitem->{marc},
$biblioitem->{marcxml},
$biblioitem->{biblioitemnumber});
my $record = MARC::File::USMARC::decode($biblioitem->{marc});
- zebra_create($biblioitem->{biblionumber}, $record);
+
+ my $Zconn = C4::Context->Zconn or die "unable to set Zconn";
+
z3950_extended_services($Zconn,'update',set_service_options('update'),$record);
+
+
# warn "MOD : $biblioitem->{biblioitemnumber} = ".$biblioitem->{marc};
} # sub modbibitem
@@ -1287,7 +1317,9 @@
$biblioitem->{marcxml},
);
$dbh->do("unlock tables");
- zebra_create($biblioitem->{biblionumber}, $record);
+ my $Zconn = C4::Context->Zconn or die "unable to set Zconn";
+
z3950_extended_services($Zconn,'update',set_service_options('update'),$record);
+ #zebra_create($biblioitem->{biblionumber}, $record);
return ($biblioitemnumber);
}
@@ -1431,7 +1463,9 @@
if ( defined $sth->errstr ) {
$error .= $sth->errstr;
}
- zebra_create($item->{biblionumber},$record);
+ my $Zconn = C4::Context->Zconn or die "unable to set Zconn";
+
z3950_extended_services($Zconn,'update',set_service_options('update'),$record);
+ #zebra_create($item->{biblionumber},$record);
$dbh->do('unlock tables');
return ( $itemnumber, $error );
}
@@ -1518,7 +1552,9 @@
# save the record into biblioitem
$sth=$dbh->prepare("update biblioitems set marc=?,marcxml=? where
biblionumber=? and biblioitemnumber=?");
$sth->execute($record->as_usmarc(),$record->as_xml(),$item->{biblionumber},$item->{biblioitemnumber});
- zebra_create($item->biblionumber,$record);
+ my $Zconn = C4::Context->Zconn or die "unable to set Zconn";
+
z3950_extended_services($Zconn,'update',set_service_options('update'),$record);
+ #zebra_create($item->biblionumber,$record);
if ( defined $sth->errstr ) {
$error .= $sth->errstr;
}
@@ -3012,8 +3048,13 @@
=cut
-# $Id: Biblio.pm,v 1.144 2006/02/20 14:22:38 kados Exp $
+# $Id: Biblio.pm,v 1.145 2006/02/22 01:02:39 kados Exp $
# $Log: Biblio.pm,v $
+# Revision 1.145 2006/02/22 01:02:39 kados
+# Replacing all calls to zebra_update with calls to
+# z3950_extended_services. More work coming, but it's
+# working now.
+#
# Revision 1.144 2006/02/20 14:22:38 kados
# typo
#
- [Koha-cvs] koha/C4 Biblio.pm, paul poulain, 2006/02/13
- [Koha-cvs] koha/C4 Biblio.pm, Chris Cormack, 2006/02/14
- [Koha-cvs] koha/C4 Biblio.pm, Joshua Ferraro, 2006/02/14
- [Koha-cvs] koha/C4 Biblio.pm, Chris Cormack, 2006/02/16
- [Koha-cvs] koha/C4 Biblio.pm, Joshua Ferraro, 2006/02/16
- [Koha-cvs] koha/C4 Biblio.pm, Joshua Ferraro, 2006/02/20
- [Koha-cvs] koha/C4 Biblio.pm, Joshua Ferraro, 2006/02/20
- [Koha-cvs] koha/C4 Biblio.pm,
Joshua Ferraro <=
- [Koha-cvs] koha/C4 Biblio.pm, Joshua Ferraro, 2006/02/25
- [Koha-cvs] koha/C4 Biblio.pm, Joshua Ferraro, 2006/02/25
- [Koha-cvs] koha/C4 Biblio.pm, Joshua Ferraro, 2006/02/25
- [Koha-cvs] koha/C4 Biblio.pm, Joshua Ferraro, 2006/02/25
- [Koha-cvs] koha/C4 Biblio.pm, Joshua Ferraro, 2006/02/25
- [Koha-cvs] koha/C4 Biblio.pm, Joshua Ferraro, 2006/02/25
- [Koha-cvs] koha/C4 Biblio.pm, Joshua Ferraro, 2006/02/25
- [Koha-cvs] koha/C4 Biblio.pm, Joshua Ferraro, 2006/02/25
- [Koha-cvs] koha/C4 Biblio.pm, Joshua Ferraro, 2006/02/25
- [Koha-cvs] koha/C4 Biblio.pm, Joshua Ferraro, 2006/02/26