]> Sergey Matveev's repositories - public-inbox.git/commitdiff
solvergit: do not show full path names to "git apply"
authorEric Wong <e@80x24.org>
Wed, 30 Jan 2019 02:32:29 +0000 (02:32 +0000)
committerEric Wong <e@80x24.org>
Wed, 30 Jan 2019 02:32:29 +0000 (02:32 +0000)
"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.

lib/PublicInbox/SolverGit.pm

index 24d9da2f42b14ff8a89344321dba2e5daa1c7d00..891cde2087dbf55f6e6f738752c105f4dd94e027 100644 (file)
@@ -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);