+<%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);
+}
+
+</%perl>