Commit 9986a6db authored by Byron Jones's avatar Byron Jones

Bug 839095: Fix interdiff failing on mod_perl with "No valid patch files were…

Bug 839095: Fix interdiff failing on mod_perl with "No valid patch files were found in the attachment" r=dkl, a=LpSolit
parent 275eb1b3
...@@ -104,10 +104,19 @@ sub process_interdiff { ...@@ -104,10 +104,19 @@ sub process_interdiff {
# Must hack path so that interdiff will work. # Must hack path so that interdiff will work.
$ENV{'PATH'} = $lc->{diffpath}; $ENV{'PATH'} = $lc->{diffpath};
my ($interdiff_stdout, $interdiff_stderr); my ($pid, $interdiff_stdout, $interdiff_stderr);
$interdiff_stderr = gensym; if ($ENV{MOD_PERL}) {
my $pid = open3(gensym, $interdiff_stdout, $interdiff_stderr, require Apache2::RequestUtil;
$lc->{interdiffbin}, $old_filename, $new_filename); require Apache2::SubProcess;
my $request = Apache2::RequestUtil->request;
(undef, $interdiff_stdout, $interdiff_stderr) = $request->spawn_proc_prog(
$lc->{interdiffbin}, [$old_filename, $new_filename]
);
} else {
$interdiff_stderr = gensym;
my $pid = open3(gensym, $interdiff_stdout, $interdiff_stderr,
$lc->{interdiffbin}, $old_filename, $new_filename);
}
binmode $interdiff_stdout; binmode $interdiff_stdout;
# Check for errors # Check for errors
...@@ -145,7 +154,7 @@ sub process_interdiff { ...@@ -145,7 +154,7 @@ sub process_interdiff {
} }
$reader->iterate_fh($interdiff_stdout, 'interdiff #' . $old_attachment->id . $reader->iterate_fh($interdiff_stdout, 'interdiff #' . $old_attachment->id .
' #' . $new_attachment->id); ' #' . $new_attachment->id);
waitpid($pid, 0); waitpid($pid, 0) if $pid;
$ENV{'PATH'} = ''; $ENV{'PATH'} = '';
# Delete temporary files. # Delete temporary files.
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment