nospawnify some of the commands
[spider.git] / cmd / show / registered.pl
index 593ef0f50ba1d313864019ec4af53f8f90df9dd5..b3f345d96317186b9d58e4ae56d08fc61a375a37 100644 (file)
@@ -8,33 +8,65 @@
 #
 #
 
-my ($self, $line) = @_;
-return (1, $self->msg('e5')) unless $self->priv >= 9;
+sub handle
+{
+       my ($self, $line) = @_;
+       return (1, $self->msg('e5')) unless $self->priv >= 9;
 
-my @out;
+       my @out;
 
-use DB_File;
+       use DB_File;
 
-if ($line) {
-       $line =~ s/[^\w\-\/]+//g;
-       $line = "^\U\Q$line";
+       if ($line) {
+               $line =~ s/[^\w\-\/]+//g;
+               $line = "^\U\Q$line";
+       }
+
+       if ($self->{_nospawn}) {
+               @out = generate($self, $line);
+       } else {
+               @out = $self->spawn_cmd("show/registered $line", sub { return (generate($self, $line)); });
+       }
+
+       return (1, @out);
 }
 
-my ($action, $count, $key, $data) = (0,0,0,0);
-eval qq{for (\$action = DXUser::R_FIRST, \$count = 0; !\$DXUser::dbm->seq(\$key, \$data, \$action); \$action = DXUser::R_NEXT) {
+sub generate
+{
+       my $self = shift;
+       my $line = shift;
+       my @out;
+       my @val;
+                                                       
+
+       my ($action, $count, $key, $data) = (0,0,0,0);
+       eval qq{for (\$action = DXUser::R_FIRST, \$count = 0; !\$DXUser::dbm->seq(\$key, \$data, \$action); \$action = DXUser::R_NEXT) {
        if (\$data =~ m{registered}) {                                  
                if (!\$line || (\$line && \$key =~ /^$line/)) {
-                       my \$u = DXUser->get_current(\$key);
+                       my \$u = DXUser::get_current(\$key);
                        if (\$u && \$u->registered) {
-                               push \@out, \$key;
+                               push \@val, \$key;
                                ++\$count;
                        }
                }
        }
 } };
+       my @l;
+       foreach my $call (@val) {
+               if (@l >= 5) {
+                       push @out, sprintf "%-12s %-12s %-12s %-12s %-12s", @l;
+                       @l = ();
+               }
+               push @l, $call;
+       }
+       if (@l) {
+               push @l, "" while @l < 5;
+               push @out, sprintf "%-12s %-12s %-12s %-12s %-12s", @l;
+       }
 
-push @out, $@ if $@;
-
-return (1, @out, $self->msg('rec', $count));
-
+       push @out, $@ if $@;
+       push @out, , $self->msg('rec', $count);
+       return @out;
+       
+}