X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=templates%2Fhooks--pre-commit;h=43d3b6ef4a0e515cdc8d9874a81029d4d9425f64;hb=d37fd03222ad6b38aa6e237f5f191238c0544850;hp=4bb6803b105505fd89b24a17403e8210c42c06be;hpb=181dc776956b4d265891ac70514ed214e4b7564a;p=git.git diff --git a/templates/hooks--pre-commit b/templates/hooks--pre-commit index 4bb6803b..43d3b6ef 100644 --- a/templates/hooks--pre-commit +++ b/templates/hooks--pre-commit @@ -10,8 +10,16 @@ # This is slightly modified from Andrew Morton's Perfect Patch. # Lines you introduce should not have trailing whitespace. # Also check for an indentation that has SP before a TAB. + +if git-rev-parse --verify HEAD 2>/dev/null +then + git-diff-index -p -M --cached HEAD +else + # NEEDSWORK: we should produce a diff with an empty tree here + # if we want to do the same verification for the initial import. + : +fi | perl -e ' - my $fh; my $found_bad = 0; my $filename; my $reported_filename = ""; @@ -31,8 +39,7 @@ perl -e ' print STDERR "* $why (line $lineno)\n"; print STDERR "$filename:$lineno:$line\n"; } - open $fh, "-|", qw(git-diff-index -p -M --cached HEAD); - while (<$fh>) { + while (<>) { if (m|^diff --git a/(.*) b/\1$|) { $filename = $1; next;