X-Git-Url: http://git.indexdata.com/?p=irspy-moved-to-github.git;a=blobdiff_plain;f=web%2Fhtdocs%2Fdetails%2Ffull.mc;h=19f74a29c1abf855cd47554a97da6f03859ea836;hp=6df895b141877d20e95d3ef9c2f2747091888853;hb=5ffcdb88057319217d93ee6a3a5d8dfa4187c6f3;hpb=36c12cb0cb7d526124927b0b19e0171dfa68042f diff --git a/web/htdocs/details/full.mc b/web/htdocs/details/full.mc index 6df895b..19f74a2 100644 --- a/web/htdocs/details/full.mc +++ b/web/htdocs/details/full.mc @@ -1,9 +1,9 @@ -%# $Id: full.mc,v 1.20 2006-12-18 15:37:06 mike Exp $ +%# $Id: full.mc,v 1.26 2007-04-26 14:00:33 mike Exp $ <%args> $id <%perl> -my $conn = new ZOOM::Connection("localhost:3313/IR-Explain---1"); +my $conn = new ZOOM::Connection("localhost:8018/IR-Explain---1"); $conn->option(elementSetName => "zeerex"); my $qid = $id; $qid =~ s/"/\\"/g; @@ -25,10 +25,8 @@ if ($n == 0) { [ Port => "e:serverInfo/e:port" ], [ "Database Name" => "e:serverInfo/e:database" ], [ "Type of Library" => "i:status/i:libraryType" ], - [ "Username (if needed)" => - "e:serverInfo/e:authentication/e:user" ], - [ "Password (if needed)" => - "e:serverInfo/e:authentication/e:password" ], +# [ "Username (if needed)" => "e:serverInfo/e:authentication/e:user" ], +# [ "Password (if needed)" => "e:serverInfo/e:authentication/e:password" ], [ "Server ID" => 'i:status/i:serverImplementationId/@value' ], [ "Server Name" => 'i:status/i:serverImplementationName/@value' ], [ "Server Version" => 'i:status/i:serverImplementationVersion/@value' ], @@ -45,7 +43,7 @@ if ($n == 0) { [ "Implementation ID" => "i:status/i:implementationId" ], [ "Implementation Name" => "i:status/i:implementationName" ], [ "Implementation Version" => "i:status/i:implementationVersion" ], - [ "Reliability" => \&calc_reliability, $xc ], + [ "Reliability/reliability" => \&calc_reliability, $xc ], [ "Services" => \&calc_init_options, $xc ], [ "Bib-1 Use attributes" => \&calc_ap, $xc, "bib-1" ], [ "Dan-1 Use attributes" => \&calc_ap, $xc, "dan-1" ], @@ -54,8 +52,9 @@ if ($n == 0) { [ "Record syntaxes" => \&calc_recsyn, $xc ], [ "Explain" => \&calc_explain, $xc ], ); + my $title = $xc->find("e:databaseInfo/e:title"); -

<% xml_encode($xc->find("e:databaseInfo/e:title"), "") %>

+

<% xml_encode($title, "") %>

<%perl> foreach my $ref (@fields) { @@ -69,12 +68,25 @@ if ($n == 0) { if ($data) { - +% $caption =~ s/\/(.*)//; +% my $help = $1; + % } % }
<% xml_encode($caption) %><% xml_encode($caption) %><% + !defined $help ? "" : $m->comp("/help/link.mc", help =>"info/$help") + %> <% xml_encode($data) %>
+

+ ">Search this target. +

% } <%perl> @@ -107,28 +119,23 @@ sub calc_init_options { sub calc_ap { my($xc, $set) = @_; - my $expr = 'e:indexInfo/e:index/e:map/e:attr[ - @set = "'.$set.'" and @type = "1"]'; - my @bib1nodes = $xc->findnodes($expr); - my $nbib1 = @bib1nodes; - return "[none]" if $nbib1 == 0; + my @aps = list_ap($xc, $set); + my $n = @aps; + return "[none]" if $n == 0; my $res = ""; my($first, $last); - @bib1nodes = sort { $a->findvalue(".") <=> $b->findvalue(".") } @bib1nodes; - foreach my $node (@bib1nodes) { - my $ap .= $node->findvalue("."); + foreach my $ap (@aps) { if (!defined $first) { - $first = $ap; - } elsif (!defined $last || $last == $ap-1) { - $last = $ap; + $first = $last = $ap; + } elsif ($ap == $last+1) { + $last++; } else { # Got a complete range $res .= ", " if $res ne ""; $res .= "$first"; - $res .= "-$last" if defined $last; - $first = $ap; - $last = undef; + $res .= "-$last" if $last > $first; + $first = $last = $ap; } } @@ -136,10 +143,19 @@ sub calc_ap { if (defined $first) { $res .= ", " if $res ne ""; $res .= "$first"; - $res .= "-$last" if defined $last; + $res .= "-$last" if $last > $first; } - return "$nbib1 access points: $res"; + return "$n access points: $res"; +} + +sub list_ap { + my($xc, $set) = @_; + + my $expr = 'e:indexInfo/e:index[@search = "true"]/e:map/e:attr[ + @set = "'.$set.'" and @type = "1"]'; + my @nodes = $xc->findnodes($expr); + return sort { $a <=> $b } map { $_->findvalue(".") } @nodes; } sub calc_boolean { @@ -162,10 +178,11 @@ sub calc_nrs { } sub calc_recsyn { - my($xc) = @_; + my($xc, $sep) = @_; + $sep = ", " if !defined $sep; my @nodes = $xc->findnodes('e:recordInfo/e:recordSyntax'); - my $res = join(", ", map { $_->findvalue('@name') } @nodes); + my $res = join($sep, map { $_->findvalue('@name') } @nodes); $res = "[none]" if $res eq ""; return $res; } @@ -178,5 +195,4 @@ sub calc_explain { $res = "[none]" if $res eq ""; return $res; } -