git: write proposed attachment to temp file without going via system()

master
Simon McVittie 2016-12-28 19:35:14 +00:00
parent 7f2235478d
commit 4ad4fc33b5
1 changed files with 10 additions and 5 deletions

View File

@ -221,6 +221,11 @@ sub safe_git {
chdir $git_dir_stack[0]
or error("cannot chdir to $git_dir_stack[0]: $!");
}
if ($params{stdout}) {
open(STDOUT, '>&', $params{stdout}) or error("Cannot reopen stdout: $!");
}
exec @{$params{cmdline}} or error("Cannot exec '@{$params{cmdline}}': $!");
}
# In parent.
@ -958,11 +963,11 @@ sub git_parse_changes {
die $@ if $@;
my $fh;
($fh, $path)=File::Temp::tempfile(undef, UNLINK => 1);
my $cmd = "cd $git_dir_stack[0] && ".
"git show $detail->{sha1_to} > '$path'";
if (system($cmd) != 0) {
error("failed writing temp file '$path'.");
}
safe_git(
error_handler => sub { error("failed writing temp file '$path': ".shift."."); },
stdout => $fh,
cmdline => ['git', 'show', $detail->{sha1_to}],
);
}
push @rets, {