]> git.saurik.com Git - wxWidgets.git/blobdiff - build/buildbot/tools/check.sh
Correct making the newly inserted menu item owner drawn in some cases.
[wxWidgets.git] / build / buildbot / tools / check.sh
index 0a734558d1808ab748d3dbab9b846081cd738d03..32ce7ebaa5379434ef80691659ccaec42e892ff6 100755 (executable)
@@ -1,16 +1,15 @@
 #!/bin/sh
 #############################################################################
 # Name:        check.sh
-# Purpose:     Check embedded xslt
+# Purpose:     Offline checker for the buildbot configuration files
 # Author:      Mike Wetherell
-# RCS-ID:      $Id$
 # Copyright:   (c) 2007 Mike Wetherell
-# Licence:     wxWidgets licence
+# Licence:     wxWindows licence
 #############################################################################
 
 usage() {
     echo "Usage: $0 [options] FILE..."
-    echo "Check embedded xslt"
+    echo "Offline checker for the buildbot configuration files"
     echo
     echo "Options:"
     echo "  -g      generate xslt"
@@ -26,6 +25,14 @@ badopt() {
     exit 1
 }
 
+progcheck() {
+    prog="$1"
+    $prog --version >/dev/null 2>&1 || {
+        echo "$0: requires $prog, not found" >&2
+        exit 1
+    }
+}
+
 GENERATE=1
 PREPROCESS=2
 VALIDATE=3
@@ -52,6 +59,12 @@ if [ $# -eq 0 ]; then
     usage
 fi
 
+XSLTPROC=xsltproc
+XMLLINT=xmllint
+
+progcheck $XSLTPROC
+progcheck $XMLLINT
+
 DIR="`dirname $0`"
 WORKDIR="${TMPDIR:-/tmp}/wx.$$"
 mkdir "$WORKDIR" || exit
@@ -62,6 +75,24 @@ PREP="$WORKDIR/PREP"
 STDERR="$WORKDIR/STDERR"
 ERR=0
 
+# Filter to show lines of genertated XSLT when they are mentioned.
+showxslt() {
+    awk '{
+            print;
+            if (sub(/.*generated XSLT line */, "") && sub(/[^0-9].*/, ""))
+            {
+                system("sed -ne "$0"p '$XSLT'");
+            }
+         }'
+}
+
+# Test it works as old version of awk don't have sub or system functions.
+if showxslt </dev/null 2>/dev/null; then
+    SHOWXSLT=showxslt
+else
+    SHOWXSLT=cat
+fi
+
 # Change the names of the temporary files in an error message to something
 # to something more informative
 errout()
@@ -71,14 +102,7 @@ errout()
     if [ -s "$STDERR" ]; then
         sed "s|file ${WORKPAT}|${WORKPAT}|g;\
              s|${WORKPAT}/XSLT|generated XSLT|g;\
-             s|${WORKPAT}/PREP|$NAME (preprocessed)|g" "$STDERR" |
-        awk '{
-                print;
-                if (sub(/.*generated XSLT line */, "") && sub(/[^0-9].*/, ""))
-                {
-                    system("sed -ne "$0"p '$XSLT'");
-                }
-             }'
+             s|${WORKPAT}/PREP|$NAME (preprocessed)|g" "$STDERR" | $SHOWXSLT
     fi
 }
 
@@ -91,7 +115,7 @@ generate()
 {
     INPUT="$1"
 
-    if xsltproc --xinclude -o "$XSLT" $DIR/embedded.xsl "$INPUT" 2>"$STDERR" &&
+    if $XSLTPROC --xinclude -o "$XSLT" $DIR/embedded.xsl "$INPUT" 2>"$STDERR" &&
        test \! -s "$STDERR"
     then
         if [ $MODE -eq $GENERATE ]; then
@@ -110,7 +134,7 @@ preprocess()
         return 0
     fi
 
-    if xsltproc --xinclude -o "$PREP" "$XSLT" "$INPUT" 2>"$STDERR" &&
+    if $XSLTPROC --xinclude -o "$PREP" "$XSLT" "$INPUT" 2>"$STDERR" &&
        test \! -s "$STDERR"
     then
         if [ $MODE -eq $PREPROCESS ]; then
@@ -120,7 +144,7 @@ preprocess()
         return 1
     fi
 }
-        
+
 validate()
 {
     NAME="$1"
@@ -129,7 +153,7 @@ validate()
         return 0
     fi
 
-    if xmllint --noout --schema $DIR/bot.xsd "$PREP" 2>"$STDERR"
+    if $XMLLINT --noout --schema $DIR/bot.xsd "$PREP" 2>"$STDERR"
     then
         errout "$NAME"
     else
@@ -149,7 +173,7 @@ while [ $# -gt 0 ]; do
         errout "$NAME" >&2
         ERR=1
     }
-            
+
     rm -f "$XSLT" "$PREP" "$STDERR"
 
     shift