HEX

Warning: set_time_limit() [function.set-time-limit]: Cannot set time limit - prohibited by configuration in /home/u547966/brikov.ru/www/wp-content/plugins/admin-menu-editor/menu-editor.php on line 745
Server: Apache
System: Linux 4.19.0-0.bpo.9-amd64 x86_64 at red40
User: u547966 (5490)
PHP: 5.3.29-mh2
Disabled: syslog, dl, popen, proc_open, proc_nice, proc_get_status, proc_close, proc_terminate, posix_mkfifo, chown, chgrp, accelerator_reset, opcache_reset, accelerator_get_status, opcache_get_status, pcntl_alarm, pcntl_fork, pcntl_waitpid, pcntl_wait, pcntl_wifexited, pcntl_wifstopped, pcntl_wifsignaled, pcntl_wifcontinued, pcntl_wexitstatus, pcntl_wtermsig, pcntl_wstopsig, pcntl_signal, pcntl_signal_dispatch, pcntl_get_last_error, pcntl_strerror, pcntl_sigprocmask, pcntl_sigwaitinfo, pcntl_sigtimedwait, pcntl_exec, pcntl_getpriority, pcntl_setpriority
Upload Files
File: //usr/share/doc/libipc-run-perl/examples/abuse/blocking_debug_with_sub_coprocess
#!/usr/bin/perl -w

## Submitted by Blair Zajac <blair@orcaware.com>

## Tests blocking when piping though a &sub coprocess.
## Fixed, now in test suite.

$| = 1;

use strict;
use Carp;
use Symbol;
use IPC::Run                  0.44 qw(start);

print "My pid is $$\n";

my $out_fd = gensym;
open($out_fd, ">ZZZ.test") or
  die "$0: open: $!\n";

my $queue = '';

my @commands = ([['cat', '-'], \$queue, '|'], 
                [['cat'],  '|'], 
                [\&double, '>', $out_fd]); 

my $harness = start 'debug' => 10, map { @$_ } @commands;
$harness or
  die "$0: harness\n";

close($out_fd) or
  die "$0: cannot close: $!\n";

for (1..100) {
  $queue .= rand(100) . "\n";
  $harness->pump;
}
$harness->finish or
  die "$0: finish\n";

exit 0;

sub double {
  while (<STDIN>) {
    s/\s+$//;
    print "$_ $_\n";
  }
}