Hi Christian, thanks for the patch. I use git under Windows and also run often into these problems, because I have to (but don't like to) use come compilers under Windows. I usually comment the two bad_lines() in the pre-commit-hook out by hand: "trailing whitespace" and "indent SP followed by TAB", because i.e. Visual Studio writes some files out, which trigger these checks. Can't we get rid of these checks? CU, Alf On 6/24/08, Christian Holtje <docwhat@xxxxxxxxx> wrote: > When commit files that use DOS style CRLF end-of-lines, the pre-commit > hook would raise an error. When combined with the fact that the hooks > get activated by default on windows, it makes life difficult for > people working with DOS files. > > This patch causes the pre-commit hook to deal with crlf files > correctly. > > Signed-off-by: Christian Höltje <docwhat@xxxxxxxxx> > --- > t/t7503-template-hook--pre-commit.sh | 75 +++++++++++++++++++++++++ > +++++++++ > templates/hooks--pre-commit | 10 ++++- > 2 files changed, 83 insertions(+), 2 deletions(-) > create mode 100755 t/t7503-template-hook--pre-commit.sh > > diff --git a/t/t7503-template-hook--pre-commit.sh b/t/t7503-template- > hook--pre-commit.sh > new file mode 100755 > index 0000000..8f0c3c9 > --- /dev/null > +++ b/t/t7503-template-hook--pre-commit.sh > @@ -0,0 +1,75 @@ > +#!/bin/sh > +# > +# Copyright (c) 2008 Christian Höltje > +# > + > +test_description='t7503 templates-hooks--pre-commit > + > +This test verifies that the pre-commit hook shipped with > +git by default works correctly. > +' > + > +. ./test-lib.sh > + > +test_expect_success 'verify that autocrlf is unset' ' > + if git config core.autocrlf > + then > + false > + else > + test $? -eq 1 > + fi > +' > + > +test_expect_success 'lf without hook' ' > + > + echo "foo" > lf.txt && > + git add lf.txt && > + git commit -m "lf without hook" lf.txt > + > +' > + > +test_expect_success 'crlf without hook' ' > + > + echo "foo\r" > crlf.txt && > + git add crlf.txt && > + git commit -m "crlf without hook" crlf.txt > + > +' > + > +# Set up the pre-commit hook. > +HOOKDIR="$(git rev-parse --git-dir)/hooks" > +mkdir -p "${HOOKDIR}" > +cp -r "${HOOKDIR}-disabled/pre-commit" "${HOOKDIR}/pre-commit" > +chmod +x "${HOOKDIR}/pre-commit" > + > +test_expect_success 'lf with hook' ' > + > + echo "bar" >> lf.txt && > + git add lf.txt && > + git commit -m "lf with hook" lf.txt > + > +' > +test_expect_success 'crlf with hook' ' > + > + echo "bar\r" >> crlf.txt && > + git add crlf.txt && > + git commit -m "crlf with hook" crlf.txt > + > +' > + > +test_expect_success 'lf with hook white-space failure' ' > + > + echo "bar " >> lf.txt && > + git add lf.txt && > + ! git commit -m "lf with hook" lf.txt > + > +' > +test_expect_success 'crlf with hook white-space failure' ' > + > + echo "bar \r" >> crlf.txt && > + git add crlf.txt && > + ! git commit -m "crlf with hook" crlf.txt > + > +' > + > +test_done > diff --git a/templates/hooks--pre-commit b/templates/hooks--pre-commit > index b25dce6..335ca09 100644 > --- a/templates/hooks--pre-commit > +++ b/templates/hooks--pre-commit > @@ -55,8 +55,14 @@ perl -e ' > if (s/^\+//) { > $lineno++; > chomp; > - if (/\s$/) { > - bad_line("trailing whitespace", $_); > + if (/\r$/) { > + if (/\s\r$/) { > + bad_line("trailing whitespace", $_); > + } > + } else { > + if (/\s$/) { > + bad_line("trailing whitespace", $_); > + } > } > if (/^\s* \t/) { > bad_line("indent SP followed by a TAB", $_); > -- > 1.5.5.4 > > > -- > To unsubscribe from this list: 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 > -- To unsubscribe from this list: 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