]> git.saurik.com Git - wxWidgets.git/blobdiff - misc/scripts/svn/hooks/pre-commit
avoiding double define warnings on osx
[wxWidgets.git] / misc / scripts / svn / hooks / pre-commit
index 5dabb3cea79ce22843599564bfc552774e3e9de3..d683f16317bf8081e520d52f6c5c81a808846636 100755 (executable)
@@ -5,32 +5,56 @@ TXN="$2"
 
 SVNLOOK=/usr/bin/svnlook
 
 
 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" | \
-                    grep "^[AU]" | \
-                    sed 's/^....//'`
+set -e
+rc=0
 
 
-changed_sources=`echo $all_changed_files | \
-                    egrep "\.(cpp|h|py)$" | \
+# exclude all third-party files from consideration, we don't want to do any
+# checks for them
+all_changed_files=`svnl changed | \
+                    grep "^[AU]" | \
+                    sed 's/^....//' | \
                     egrep -v "src/(tiff|regex|jpeg|stc/scintilla)"`
 
                     egrep -v "src/(tiff|regex|jpeg|stc/scintilla)"`
 
-rc=0
-
-set -e
+# 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/*)
+            ;;
+
+        *)
+            continue
+            ;;
+    esac
+
+    changed_text_files="$changed_text_files $f"
+
+    case $f in
+        *.cpp|*.h|*.py)
+            changed_sources="$changed_sources $f"
+            ;;
+    esac
+done
 
 for f in $changed_sources; do
 
 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
 done
 
          echo "Please remove TABs from $f before committing." >&2
          rc=1
      fi
 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 ! svncat $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 "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
         rc=1
     fi
 done