X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=web%2Fhtdocs%2Fdetails%2Ffull.mc;h=a152a74e35ca3f2bd50d645c1a964ef3f21fa5db;hb=22758a77f0c1cb3f41357468be56cd6b9207baff;hp=49690a72bccd34eb0e8cc4d7362bb4762a80ea99;hpb=133fa8ece58e75a4cf2ed020f945dfbee9e8d0f4;p=irspy-moved-to-github.git
diff --git a/web/htdocs/details/full.mc b/web/htdocs/details/full.mc
index 49690a7..a152a74 100644
--- a/web/htdocs/details/full.mc
+++ b/web/htdocs/details/full.mc
@@ -1,4 +1,4 @@
-%# $Id: full.mc,v 1.6 2006-11-06 11:41:03 mike Exp $
+%# $Id: full.mc,v 1.11 2006-11-06 17:34:58 mike Exp $
<%args>
$id
%args>
@@ -43,11 +43,12 @@ if ($n == 0) {
[ "Implementation ID" => "i:status/i:implementationId" ],
[ "Implementation Name" => "i:status/i:implementationName" ],
[ "Implementation Version" => "i:status/i:implementationVersion" ],
- [ "Reliability" => sub { "### 97%" } ],
- [ "Services" => sub { "### search, present, delSet, concurrentOperations, namedResultSets" } ],
- [ "Bib-1 Use attributes" => sub { "### 4-5, 7-8, 12, 21, 31, 54, 58, 63, 1003-1005, 1009, 1011-1012, 1016, 1031" } ],
- [ "Operators" => sub { "### and, or, not" } ],
- [ "Record syntaxes" => sub { "### SUTRS, USmarc, Danmarc" } ],
+ [ "Reliability" => \&calc_reliability, $xc ],
+ [ "Services" => sub { "### IRSpy does not yet check for search, present, delSet, concurrentOperations, namedResultSets, etc. and store the information is a usable form." } ],
+ [ "Bib-1 Use attributes" => \&calc_ap, $xc, "bib-1" ],
+ [ "Dan-1 Use attributes" => \&calc_ap, $xc, "dan-1" ],
+ [ "Operators" => \&calc_boolean, $xc ],
+ [ "Record syntaxes" => \&calc_recsyn, $xc ],
[ "Explain" => sub { "### CategoryList, TargetInfo, DatabaseInfo, RecordSyntaxInfo, AttributeSetInfo, AttributeDetails" } ],
);
%perl>
@@ -55,10 +56,10 @@ if ($n == 0) {
<%perl>
foreach my $ref (@fields) {
- my($caption, $xpath, %attrs) = @$ref;
+ my($caption, $xpath, @args) = @$ref;
my $data;
if (ref $xpath && ref($xpath) eq "CODE") {
- $data = &$xpath();
+ $data = &$xpath(@args);
} else {
$data = $xc->find($xpath);
}
@@ -72,3 +73,72 @@ if ($n == 0) {
% }
% }
+<%perl>
+
+sub calc_reliability {
+ my($xc) = @_;
+
+ my @allpings = $xc->findnodes("i:status/i:probe");
+ my $nall = @allpings;
+ return "[untested]" if $nall == 0;
+ my @okpings = $xc->findnodes('i:status/i:probe[@ok = "1"]');
+ my $nok = @okpings;
+ return "$nok/$nall = " . int(100*$nok/$nall) . "%";
+}
+
+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 $res = "";
+ my($first, $last);
+ @bib1nodes = sort { $a->findvalue(".") <=> $b->findvalue(".") } @bib1nodes;
+ foreach my $node (@bib1nodes) {
+ my $ap .= $node->findvalue(".");
+ if (!defined $first) {
+ $first = $ap;
+ } elsif (!defined $last || $last == $ap-1) {
+ $last = $ap;
+ } else {
+ # Got a complete range
+ $res .= ", " if $res ne "";
+ $res .= "$first";
+ $res .= "-$last" if defined $last;
+ $first = $ap;
+ $last = undef;
+ }
+ }
+
+ # Leftovers
+ if (defined $first) {
+ $res .= ", " if $res ne "";
+ $res .= "$first";
+ $res .= "-$last" if defined $last;
+ }
+
+ return "$nbib1 access points: $res";
+}
+
+sub calc_boolean {
+ my($xc) = @_;
+
+ ### Note that we are currently interrogating an IRSpy extension.
+ # The standard ZeeRex record should be extended with a
+ # "supports" type for this.
+ my @nodes = $xc->findnodes('i:status/i:boolean[@ok = "1"]');
+ return join(", ", map { $_->findvalue('@operator') } @nodes);
+}
+
+sub calc_recsyn {
+ my($xc) = @_;
+
+ my @nodes = $xc->findnodes('e:recordInfo/e:recordSyntax');
+ return join(", ", map { $_->findvalue('@name') } @nodes);
+}
+
+%perl>