X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/3347f618eb68c3bd8176cd8a9162424da79f55aa..069358b7ccf8a82eb4d809c25ebe5a3db9db67cd:/misc/scripts/svn/hooks/pre-commit diff --git a/misc/scripts/svn/hooks/pre-commit b/misc/scripts/svn/hooks/pre-commit index 5dabb3cea7..85a3641d69 100755 --- a/misc/scripts/svn/hooks/pre-commit +++ b/misc/scripts/svn/hooks/pre-commit @@ -5,34 +5,76 @@ TXN="$2" SVNLOOK=/usr/bin/svnlook -svn_cat() { - $SVNLOOK cat "$REPOS" -t "$TXN" $1 +svnl() { + cmd=$1 + shift + $SVNLOOK $cmd "$REPOS" -t "$TXN" $* } -all_changed_files=`$SVNLOOK changed "$REPOS" -t "$TXN" | \ +rc=0 + +# exclude all third-party files from consideration, we don't want to do any +# checks for them +# +# Also don't impose any constraints on commits to previous 2.x branches. +all_changed_files=`svnl changed | \ grep "^[AU]" | \ - sed 's/^....//'` + sed 's/^....//' | \ + egrep -v "branches/WX_2_" | \ + egrep -v "src/(tiff|regex|jpeg|stc/scintilla)" | \ + egrep -v "_wrap.cpp" | \ + egrep -v "wxPython/.*/docs/.*\.html$"` -changed_sources=`echo $all_changed_files | \ - egrep "\.(cpp|h|py)$" | \ - egrep -v "src/(tiff|regex|jpeg|stc/scintilla)"` +# analyze the changed files to find all non-binary and all source files +for f in $all_changed_files; do + mimetype=`svnl proplist -v $f | + fgrep "svn:mime-type" | + sed 's/^ svn:mime-type : //'` + case $mimetype in + ''|text/*) + ;; -rc=0 + *) + continue + ;; + esac + + changed_text_files="$changed_text_files $f" -set -e + case $f in + *.cpp|*.h|*.py) + changed_sources="$changed_sources $f" + ;; + esac +done for f in $changed_sources; do - if svn_cat $f | fgrep -q ' '; then + if svnl cat $f | fgrep -q ' '; then echo "Please remove TABs from $f before committing." >&2 rc=1 fi + + case $f in + */wx/chartype.h) + # This file defines _T() for compatibility so don't check it. + ;; + + *) + if svnl cat $f | fgrep -qw '_T'; then + echo "Please use wxT() instead of _T() in $f." >&2 + rc=1 + fi + ;; + esac done -for f in $all_changed_files; do - if ! svn_cat $f | iconv -f utf8 -t WCHAR_T > /dev/null; then +for f in $changed_text_files; do + if ! svnl cat $f | iconv -f utf8 -t WCHAR_T > /dev/null; then echo "File $f doesn't use UTF-8, please convert it before committing." >&2 + echo "(or set svn:mime-type property correctly if the file is binary)." >&2 rc=1 fi done exit $rc +