diff options
author | Eric Wong <e@80x24.org> | 2019-01-30 02:32:29 +0000 |
---|---|---|
committer | Eric Wong <e@80x24.org> | 2019-01-30 02:32:29 +0000 |
commit | df7ee53f43ad5624f512b2ba0b53df9a76b41937 (patch) | |
tree | 22f29366b2dc6123ec28168eb7c528c70648f627 /lib | |
parent | 8b473d081c3eaccce2efd8458e663ae355eae7b3 (diff) | |
download | public-inbox-df7ee53f43ad5624f512b2ba0b53df9a76b41937.tar.gz |
"git apply" will warn about whitespace with the full path of the patch, which will expose the $TMPDIR environment to users over HTTP(S). This change breaks compatibility with git pre-1.8.5, again; but that was released in late-2013; so hopefully everybody is on newer versions.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/PublicInbox/SolverGit.pm | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/lib/PublicInbox/SolverGit.pm b/lib/PublicInbox/SolverGit.pm index 24d9da2f..891cde20 100644 --- a/lib/PublicInbox/SolverGit.pm +++ b/lib/PublicInbox/SolverGit.pm @@ -389,8 +389,8 @@ sub do_git_apply ($) { my $patches = $self->{patches}; # we need --ignore-whitespace because some patches are CRLF - my @cmd = qw(git apply --cached --ignore-whitespace - --whitespace=warn --verbose); + my @cmd = (qw(git -C), $dn, qw(apply --cached --ignore-whitespace + --whitespace=warn --verbose)); my $len = length(join(' ', @cmd)); my $total = $self->{tot}; my $di; # keep track of the last one for "git ls-files" @@ -400,8 +400,7 @@ sub do_git_apply ($) { $di = shift @$patches; dbg($self, "\napplying [$i/$total] " . di_url($self, $di) . "\n" . join('', @{$di->{hdr_lines}})); - my $pn = $total + 1 - $i; - my $path = "$dn/$pn"; + my $path = $total + 1 - $i; $len += length($path) + 1; push @cmd, $path; } while (@$patches && $len < $ARG_SIZE_MAX); |