Merge branch 'release-0.6.5'
[olsrd.git] / gcc-warnings
old mode 100644 (file)
new mode 100755 (executable)
index 0e034e9..9bf8079
@@ -3,7 +3,6 @@
 # We expect warning options for gcc as arguments and return the ones which are
 # accepted by the given gcc.
 #
-# $Id: gcc-warnings,v 1.7 2007/12/06 18:17:35 bernd67 Exp $
 
 set -ue
 #set -vx
@@ -20,7 +19,7 @@ for param; do
 done
 
 testcompile() {
-    $CC $OPTS -x c - 2>&1 <<- EOF
+    $CC $OPTS -x c -o /dev/null - 2>&1 <<- EOF
        int main(void) {
            return 0;
        }
@@ -33,14 +32,24 @@ parsetest() {
         *:\ unrecognized\ *option\ \"*)
             opt="${error#*\"}"
             opt="${opt%\"*}"
-            OPTS="${OPTS//$opt}"
             ;;
         *:\ unrecognized\ *option\ \`*)
             opt="${error#*\`}"
             opt="${opt%\'*}"
-            OPTS="${OPTS//$opt}"
+            ;;
+        *) continue
             ;;
        esac
+       # if we come here, we have in $opt the option to remove. and
+       # we remove all instances. And we save agoinst leading "-"
+       NEW_OPTS=""
+       for o in $OPTS; do
+           case "$o" in
+               $opt) : echo "Removed $o" >&2;;
+               *)    NEW_OPTS="$NEW_OPTS $o";;
+           esac
+       done
+       OPTS="$NEW_OPTS"
     done
     echo $OPTS
 }