X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;ds=sidebyside;f=lib%2FNet%2FZ3950%2FZOOM.pm;h=2b1796499de9648ef9d7071fc3311eb189cef57f;hb=bd9655f57c044d15ff28da78ceb2f2f100ea5b84;hp=44291f1e079cb0031a0664799996181325d77944;hpb=3b893df75010fbba350be5bde66ca973b7826bd7;p=ZOOM-Perl-moved-to-github.git diff --git a/lib/Net/Z3950/ZOOM.pm b/lib/Net/Z3950/ZOOM.pm index 44291f1..2b17964 100644 --- a/lib/Net/Z3950/ZOOM.pm +++ b/lib/Net/Z3950/ZOOM.pm @@ -1,22 +1,20 @@ -# $Id: ZOOM.pm,v 1.27 2006-09-25 11:32:22 mike Exp $ - package Net::Z3950::ZOOM; use 5.008; use strict; use warnings; -our $VERSION = '1.12'; +our $VERSION = '1.29'; require XSLoader; XSLoader::load('Net::Z3950::ZOOM', $VERSION); my($vs, $ss) = ("x" x 100, "x" x 100); # allocate space for these strings my $version = Net::Z3950::ZOOM::yaz_version($vs, $ss); -if ($version < 0x020115 && ! -f "/tmp/ignore-ZOOM-YAZ-version-mismatch") { +if ($version < 0x020132 && ! -f "/tmp/ignore-ZOOM-YAZ-version-mismatch") { warn <<__EOT__; *** WARNING! -ZOOM-Perl requires at least version 2.1.21 of YAZ, but is currently +ZOOM-Perl requires at least version 2.1.50 of YAZ, but is currently running against only version $vs (sys-string '$ss'). Some things may not work. __EOT__ @@ -134,6 +132,46 @@ sub event_str { return "impossible event " . $code; } + +# Switch API variant depending on $type. This works because the +# get_string() and get_binary() functions have different returns +# types, one of which is implemented as a NUL-terminated string and +# the other as a pointer-and-length structure. +# +# Some Z39.50 servers, when asked for an OPAC-format record in the +# case where no circulation information is available, will return a +# USMARC record rather than an OPAC record containing only a +# bibliographic part. This non-OPAC records is not recognised by the +# underlying record_get() code in ZOOM-C, which ends up returning a +# null pointer. To make life a little less painful when dealing with +# such servers until ZOOM-C is fixed, this code recognises the +# wrong-record-syntax case and returns the XML for the bibliographic +# part anyway. +# +sub record_get { + my($rec, $type) = @_; + + my $simpletype = $type; + $simpletype =~ s/;.*//; + if (grep { $type eq $_ } qw(database syntax schema)) { + return record_get_string($rec, $type); + } else { + my $val = record_get_binary($rec, $type); + if ($simpletype eq "opac" && !defined $val) { + my $newtype = $type; + if ($newtype !~ s/.*?;/xml;/) { + $newtype = "xml"; + } + $val = record_get_binary($rec, $newtype); + $val = ("\n \n" . $val . + " \n"); + + } + return $val; + } +} + + =head1 SEE ALSO The C module, included in the same distribution as this one.