From 7c909bd8b83d8bf0ee1f5615b0df02c7bcb8dba0 Mon Sep 17 00:00:00 2001 From: mike Date: Wed, 14 May 2008 13:29:57 +0000 Subject: [PATCH] Version 1.22 Add record_get() switching function, which chooses between the underlying record_get_string() and record_get_binary() depending on the value of $type. The different APIs of those two XS functions ensure that memory is managed differently. --- lib/Net/Z3950/ZOOM.pm | 35 +++++++++++++++++++++++++++++++++-- 1 file changed, 33 insertions(+), 2 deletions(-) diff --git a/lib/Net/Z3950/ZOOM.pm b/lib/Net/Z3950/ZOOM.pm index 7e9be7f..b8e3fda 100644 --- a/lib/Net/Z3950/ZOOM.pm +++ b/lib/Net/Z3950/ZOOM.pm @@ -1,4 +1,4 @@ -# $Id: ZOOM.pm,v 1.36 2007-10-29 11:52:39 mike Exp $ +# $Id: ZOOM.pm,v 1.37 2008-05-14 13:29:57 mike Exp $ package Net::Z3950::ZOOM; @@ -6,7 +6,7 @@ use 5.008; use strict; use warnings; -our $VERSION = '1.21'; +our $VERSION = '1.22'; require XSLoader; XSLoader::load('Net::Z3950::ZOOM', $VERSION); @@ -134,6 +134,37 @@ 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) = @_; + + if (grep { $type eq $_ } qw(database syntax schema)) { + return record_get_string($rec, $type); + } else { + my $val = record_get_binary($rec, $type); + if ($type eq "opac" && !defined $val) { + $val = record_get_binary($rec, "xml"); + } + return $val; + } +} + + =head1 SEE ALSO The C module, included in the same distribution as this one. -- 1.7.10.4