Kung has asked for the wisdom of the Perl Monks concerning the following question:
I have a perl script that:
- reads STDIN line by line and for each line:
- parses the line ( in order to build a list of system commands)
- writes the line to STDOUT
- writes the line out to an output file
- forks a child to run each system command in the list
( the relevant parts of the code are below )
at the completion of this script, I would expect that the input
file would have been written as is to STDOUT and the output file...
howver I find that the output file contains the input file repeated
many times - although it is only written once to STDOUT.
If I take the forking code out ( no pun intended) then I only get
once copy of the input file in the output file.
Whats going on here? and why doesnt it happen with STDOUT?
Thanks Kung
open(MFOUT,">mfout.txt"); while (<STDIN>) { print MFOUT $_; print $_; <SNIP> ... stuff that builds up commands in @commands... ... eg 'perl anotherscript.pl < input' </SNIP> } my %running = (); my $max_jobs = 200; my $job_count = 0; while ( @commands || %running ) { if ( @commands && ($job_count < $max_jobs)) { my $command = shift(@commands); my $pid; if ($pid = fork) { print "Parent Pid $$\n"; $running{$pid} = $command; ++$job_count; } else { die "cannot fork: $!" unless defined $pid; print "Child Pid $$ $command\n"; my $rc = system $command; exit($rc>>8); } } else { my $child_pid = wait(); if (! exists $running{$child_pid}) { warn "Reaped unkown process id $child_pid!!"; } elsif ($?) { my $rc = $? >> 8; warn "Process '$child_pid:$running{$child_pid}' errored with retu +rn code '$ rc'"; } print "command '$running{$child_pid}' completed\n"; delete $running{$child_pid}; --$job_count; } }
Edit: chipmunk 2001-05-16
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re: fork and print..
by chipmunk (Parson) on May 17, 2001 at 18:30 UTC | |
by tye (Sage) on May 17, 2001 at 19:11 UTC | |
|
Re: fork and print..
by jepri (Parson) on May 17, 2001 at 09:00 UTC | |
by Anonymous Monk on May 17, 2001 at 09:31 UTC | |
by Kung (Initiate) on May 17, 2001 at 09:34 UTC | |