+case "$cc" in
+*g++*)
+ # Extra paranoia in case people have bad canned ccflags:
+ # bad in the sense that the flags are accepted by g++,
+ # but then whined about.
+ #
+ # -Werror=d-a-s option is valid for g++, by definition,
+ # but we remove it just for cleanliness and shorter command lines.
+ for f in -Wdeclaration-after-statement \
+ -Werror=declaration-after-statement \
+ -Wc++-compat \
+ -std=c89
+ do
+ case "$ccflags$warn" in
+ *"$f"*)
+ echo "cflags.SH: Removing $f because of g++."
+ ccflags=`echo $ccflags|sed 's/$f/ /'`
+ warn=`echo $warn|sed 's/$f/ /'`
+ ;;
+ esac
+ done
+ ;;
+esac
+
+for f in -Wdeclaration-after-statement -Werror=declaration-after-statement
+do
+ case "$cppflags" in
+ *"$f"*)
+ echo "cflags.SH: Removing $f from cppflags."
+ cppflags=`echo $cppflags|sed 's/$f/ /'` ;;
+ esac
+done
+
+# If usethreads and clang, add -Wthread-safety for clang 3.6 or later.
+# gccversion is defined also for clang, because compat, use that for matching.
+# Apple overwrites clang version with XCode version, see hints/darwin.sh
+# for the gory details. Aggressively forward-proofing.
+case "$usethreads" in
+define)
+case "$gccversion" in
+*" Clang 3."[56789]*|*" Clang "[456]*|*"Apple LLVM 6.1"*|*"Apple LLVM "[789]*)
+ for f in -Wthread-safety
+ do
+ case " $warn " in
+ *" $f "*) ;; # Skip if already there.
+ *)
+ echo "cflags.SH: Adding $f because usethreads and clang and gccversion '$gccversion'"
+ warn="$warn $f"
+ ;;
+ esac
+ done
+;;
+esac
+;;
+esac
+
+echo "cflags.SH: cc = $cc"
+echo "cflags.SH: ccflags = $ccflags"
+echo "cflags.SH: stdflags = $stdflags"
+echo "cflags.SH: optimize = $optimize"
+echo "cflags.SH: warn = $warn"
+