fixed sh/node
[spider.git] / cmd / show / node.pl
index 37db1dc8d1e21f77a4773af97f575c1fbd58a484..9b6938a60db6489ec1d2166d8486def5cda98cc5 100644 (file)
@@ -19,10 +19,19 @@ return (1, $self->msg('e5')) unless $self->priv >= 1;
 
 my @call = map {uc $_} split /\s+/, $line; 
 my @out;
+my $count;
 
 # search thru the user for nodes
 unless (@call) {
-       @call = sort map { my $ref; (($ref = DXUser->get_current($_)) && $ref->sort ne 'U') ? $_ : () } DXUser::get_all_calls;
+       use DB_File;
+       
+       my ($action, $key, $data);
+       for ($action = R_FIRST, $count = 0; !$DXUser::dbm->seq($key, $data, $action); $action = R_NEXT) {
+               if ($data =~ m{sort => '[ACRSX]'}) {
+                   push @call, $key;
+                       ++$count;
+               }
+       } 
 }
 
 my $call;
@@ -34,6 +43,7 @@ foreach $call (@call) {
        my $pcall = sprintf "%-11s", $call;
        push @out, $self->msg('snode1') unless @out > 0;
        if ($uref) {
+               $sort = "Unknwn";
                $sort = "Spider" if $uref->is_spider;
                $sort = "AK1A  " if $uref->is_ak1a;
                $sort = "Clx   " if $uref->is_clx;
@@ -53,14 +63,15 @@ foreach $call (@call) {
        }
        
        my ($major, $minor, $subs) = unpack("AAA*", $ver) if $ver;
-       if ($sort eq 'Spider') {
+       if ($uref->is_spider) {
                push @out, $self->msg('snode2', $pcall, $sort, "$ver  ");
        } else {
                push @out, $self->msg('snode2', $pcall, $sort, $ver ? "$major\-$minor.$subs" : "      ");
        }
+    ++$count;
 }
 
-return (1, @out);
+return (1, @out, $self->msg('rec', $count));