X-Git-Url: http://git.indexdata.com/?p=irspy-moved-to-github.git;a=blobdiff_plain;f=lib%2FZOOM%2FIRSpy%2FStats.pm;h=c7780f4b17b0ec798d235abbdd0dfb1f4be57702;hp=f79545c897ba4cf8c03fdda9fd252e6246a64c2a;hb=c3ce1a514156d9b69e789cd329ec5d3a78b5a152;hpb=625af60b1b44a55271071b44139ac262f6c1547c diff --git a/lib/ZOOM/IRSpy/Stats.pm b/lib/ZOOM/IRSpy/Stats.pm index f79545c..c7780f4 100644 --- a/lib/ZOOM/IRSpy/Stats.pm +++ b/lib/ZOOM/IRSpy/Stats.pm @@ -1,4 +1,4 @@ -# $Id: Stats.pm,v 1.4 2006-12-15 17:24:59 mike Exp $ +# $Id: Stats.pm,v 1.5 2006-12-18 15:34:27 mike Exp $ package ZOOM::IRSpy::Stats; @@ -82,6 +82,7 @@ sub new { my $n = $rs->size(); my $this = bless { + host => $conn->option("host"), conn => $conn, query => $query, rs => $rs, @@ -116,12 +117,16 @@ sub _gather_stats { # Explain support foreach my $node ($xc->findnodes('i:status/i:explain[@ok="1"]/@category')) { - print $node; $this->{explain}->{$node->findvalue(".")}++; } # Z39.50 Protocol Services Support - ### Requires XSLT fix + foreach my $node ($xc->findnodes('e:configInfo/e:supports')) { + my $supports = $node->findvalue('@type'); + if ($node->findvalue(".") && $supports =~ s/^z3950_//) { + $this->{z3950_init_opt}->{$supports}++; + } + } # Z39.50 Server Atlas ### TODO -- awkward, should be considered an enhancement @@ -179,6 +184,14 @@ sub print { $key, $hr->{$key}, 100*$hr->{$key}/$this->{n}); } + print "\nZ39.50 PROTOCOL SERVICES SUPPORT\n"; + $hr = $this->{z3950_init_opt}; + foreach my $key (sort { $hr->{$b} <=> $hr->{$a} + || $a cmp $b } keys %$hr) { + print sprintf("%-26s%5d (%d%%)\n", + $key, $hr->{$key}, 100*$hr->{$key}/$this->{n}); + } + print "\nTOP-LEVEL DOMAINS\n"; $hr = $this->{domains}; foreach my $key (sort { $hr->{$b} <=> $hr->{$a}