X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=lib%2FNet%2FZ3950%2FZOOM.pm;h=11f8b2924391c2c3afa7ffa6cdae9eb5349ae485;hb=150f46f520c95d48bc52eacae074639b1718a8fc;hp=57a24f65f62c8e6b37afaeadfb3c72972af64bfd;hpb=c82a9a55d35fd1386af5671dbeda0b373d7a68c5;p=ZOOM-Perl-moved-to-github.git diff --git a/lib/Net/Z3950/ZOOM.pm b/lib/Net/Z3950/ZOOM.pm index 57a24f6..11f8b29 100644 --- a/lib/Net/Z3950/ZOOM.pm +++ b/lib/Net/Z3950/ZOOM.pm @@ -1,16 +1,24 @@ -# $Id: ZOOM.pm,v 1.7 2006-01-04 17:23:43 mike Exp $ - package Net::Z3950::ZOOM; use 5.008; use strict; use warnings; -our $VERSION = '1.02'; +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 < 0x020132 && ! -f "/tmp/ignore-ZOOM-YAZ-version-mismatch") { + warn <<__EOT__; +*** WARNING! +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__ +} # The only thing this module does is define the following constants, # which MUST BE KEPT SYNCHRONISED with the definitions in @@ -30,6 +38,8 @@ sub ERROR_UNSUPPORTED_QUERY { 10009 } sub ERROR_INVALID_QUERY { 10010 } sub ERROR_CQL_PARSE { 10011 } sub ERROR_CQL_TRANSFORM { 10012 } +sub ERROR_CCL_CONFIG { 10013 } +sub ERROR_CCL_PARSE { 10014 } # Event types, as returned from connection_last_event() sub EVENT_NONE { 0 } @@ -42,6 +52,22 @@ sub EVENT_SEND_APDU { 6 } sub EVENT_RECV_APDU { 7 } sub EVENT_RECV_RECORD { 8 } sub EVENT_RECV_SEARCH { 9 } +sub EVENT_END { 10 } # In YAZ 2.1.17 and later + +# CCL error-codes, which are in a different space from the ZOOM errors +sub CCL_ERR_OK { 0 } +sub CCL_ERR_TERM_EXPECTED { 1 } +sub CCL_ERR_RP_EXPECTED { 2 } +sub CCL_ERR_SETNAME_EXPECTED { 3 } +sub CCL_ERR_OP_EXPECTED { 4 } +sub CCL_ERR_BAD_RP { 5 } +sub CCL_ERR_UNKNOWN_QUAL { 6 } +sub CCL_ERR_DOUBLE_QUAL { 7 } +sub CCL_ERR_EQ_EXPECTED { 8 } +sub CCL_ERR_BAD_RELATION { 9 } +sub CCL_ERR_TRUNC_NOT_LEFT { 10 } +sub CCL_ERR_TRUNC_NOT_BOTH { 11 } +sub CCL_ERR_TRUNC_NOT_RIGHT { 12 } =head1 NAME @@ -70,6 +96,82 @@ to document it. If you really, really, really want to use it, then it pretty much follows the API described in the ZOOM-C documentation at http://www.indexdata.dk/yaz/doc/zoom.tkl +The only additional (non-ZOOM-C) function provided by this module is +C, which takes as its argument an event code such as +C, and returns a corresponding +short string. + +=cut + +sub event_str { + my($code) = @_; + + if ($code == EVENT_NONE) { + return "none"; + } elsif ($code == EVENT_CONNECT) { + return "connect"; + } elsif ($code == EVENT_SEND_DATA) { + return "send data"; + } elsif ($code == EVENT_RECV_DATA) { + return "receive data"; + } elsif ($code == EVENT_TIMEOUT) { + return "timeout"; + } elsif ($code == EVENT_UNKNOWN) { + return "unknown"; + } elsif ($code == EVENT_SEND_APDU) { + return "send apdu"; + } elsif ($code == EVENT_RECV_APDU) { + return "receive apdu"; + } elsif ($code == EVENT_RECV_RECORD) { + return "receive record"; + } elsif ($code == EVENT_RECV_SEARCH) { + return "receive search"; + } elsif ($code == EVENT_END) { + return "end"; + } + 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. @@ -80,7 +182,7 @@ Mike Taylor, Emike@indexdata.comE =head1 COPYRIGHT AND LICENCE -Copyright (C) 2005 by Index Data. +Copyright (C) 2005-2014 by Index Data. This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.8.4 or,