make several show/* cmds non-blocking
[spider.git] / cmd / show / isolate.pl
index daa77f42eb01be26fe65c8d454aaa01025d77167..979bf0d3021645d03b77bce0934cef78bcb32f28 100644 (file)
@@ -15,17 +15,40 @@ my @out;
 
 use DB_File;
 
-my ($action, $count, $key, $data) = (0,0,0,0);
-for ($action = DXUser::R_FIRST, $count=0; !$DXUser::dbm->seq($key, $data, $action); $action = DXUser::R_NEXT) {
-       if ($data =~ m{isolate}) {
-               my $u = DXUser::get_current($key);
-               if ($u && $u->isolate) {
-                       push @out, $key;
-                       ++$count;
-               }
-       }
-} 
-
-return (1, @out, $self->msg('rec', $count));
+@out = $self->spawn_cmd(sub {
+                                                       my @out;
+                                                       my @val;
+                                                       
+                                                       my ($action, $count, $key, $data) = (0,0,0,0);
+
+                                                       for ($action = DXUser::R_FIRST, $count=0; !$DXUser::dbm->seq($key, $data, $action); $action = DXUser::R_NEXT) {
+                                                               if ($data =~ m{isolate}) {
+                                                                       my $u = DXUser::get_current($key);
+                                                                       if ($u && $u->isolate) {
+                                                                               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, , $self->msg('rec', $count);
+                                                       return @out;
+                                               });
+
+
+return (1, @out);