This should make adding asciidoc files to Documentation easier. Only complain about conflict markers if we see that we have some combination of '<<<<<<< ', '>>>>>>> ', and '======='. Also add a NO_VERIFY environment check to this hook, in case there's something that we want to force in but still gets tripped by this hook. It'd be a lot more work to add --no-verify flags to all things that could potentially call this hook. Signed-off-by: Eric Wong <normalperson@xxxxxxxx> --- templates/hooks--pre-commit | 32 ++++++++++++++++++++++++++++---- 1 files changed, 28 insertions(+), 4 deletions(-) diff --git a/templates/hooks--pre-commit b/templates/hooks--pre-commit index 723a9ef..1657f96 100644 --- a/templates/hooks--pre-commit +++ b/templates/hooks--pre-commit @@ -1,4 +1,5 @@ #!/bin/sh +test -n "$NO_VERIFY" && exit 0 # # An example hook script to verify what is about to be committed. # Called by git-commit with no arguments. The hook should @@ -24,8 +25,9 @@ perl -e ' my $filename; my $reported_filename = ""; my $lineno; - sub bad_line { - my ($why, $line) = @_; + my $in_unresolved; + my @unresolved; + sub bad_common { if (!$found_bad) { print STDERR "*\n"; print STDERR "* You have some suspicious patch lines:\n"; @@ -36,12 +38,34 @@ perl -e ' print STDERR "* In $filename\n"; $reported_filename = $filename; } + } + sub bad_line { + my ($why, $line) = @_; + bad_common(); print STDERR "* $why (line $lineno)\n"; print STDERR "$filename:$lineno:$line\n"; } + sub show_unresolved { + # if we want even less easily-tripped checks, + # change the "||" to "&&" here. Right now, we can deal with + # the case where somebody removed one of the <{7} or >{7} lines + # but left the other one (as well as ={7}) in there. + if (($unresolved[0]->[0] =~ /^<{7} / || + $unresolved[-1]->[0] =~ /^>{7} /) && + grep { $_->[0] =~ /^={7}$/ } @unresolved) { + bad_common(); + foreach my $l (@unresolved) { + print STDERR "* unresolved merge conflict (line $l->[1])\n"; + print STDERR "$filename:$l->[1]:$l->[0]\n" + } + } + @unresolved = (); + } + while (<>) { if (m|^diff --git a/(.*) b/\1$|) { $filename = $1; + show_unresolved() if @unresolved; next; } if (/^@@ -\S+ \+(\d+)/) { @@ -61,8 +85,8 @@ perl -e ' if (/^\s* /) { bad_line("indent SP followed by a TAB", $_); } - if (/^(?:[<>=]){7}/) { - bad_line("unresolved merge conflict", $_); + if (/^[<>]{7} / || /^={7}$/) { + push @unresolved, [ $_, $lineno ]; } } } -- 1.4.1.rc1.g2faf-dirty - : send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html