diff options
Diffstat (limited to 'configure.in')
-rw-r--r-- | configure.in | 32 |
1 files changed, 22 insertions, 10 deletions
diff --git a/configure.in b/configure.in index 73b92995ba..db5ff50db5 100644 --- a/configure.in +++ b/configure.in @@ -387,19 +387,31 @@ AC_SUBST(CHDIR) dnl } dnl compiler section { -if test "$GCC:${warnflags+set}:no" = yes::no; then +AC_DEFUN(RUBY_TRY_CFLAGS, [ save_CFLAGS="$CFLAGS" - for wflag in -Wextra -Wno-unused-parameter -Wno-parentheses -Wpointer-arith -Wwrite-strings \ + CFLAGS="[$]CFLAGS $1" + AC_MSG_CHECKING([whether ]$1[ is accepted]) + AC_COMPILE_IFELSE([AC_LANG_PROGRAM([])], + [$2 + AC_MSG_RESULT(yes)], + [$3 + AC_MSG_RESULT(no)]) + CFLAGS="$save_CFLAGS" + save_CFLAGS= +]) + +if test "$GCC:${warnflags+set}:no" = yes::no; then + for wflag in -Wno-unused-parameter -Wno-parentheses -Wpointer-arith -Wwrite-strings \ -Wno-missing-field-initializers -Wshorten-64-to-32; do - CFLAGS="$CFLAGS $wflag" - AC_MSG_CHECKING([whether $wflag is accepted]) - AC_COMPILE_IFELSE([AC_LANG_PROGRAM([])], - [warnflags="${warnflags+$warnflags }$wflag" - AC_MSG_RESULT(yes)], - [AC_MSG_RESULT(no)]) + RUBY_TRY_CFLAGS($wflag, [warnflags="${warnflags+$warnflags }$wflag"]) done - CFLAGS="$save_CFLAGS" - unset save_CFLAGS + case " $warnflags " in + when(*" -Wno-missing-field-initializers "*) + wflag=-Wextra;; + when(*) + wflag=-Wall;; + esac + RUBY_TRY_CFLAGS($wflag, [warnflags="$wflag${warnflags+ $warnflags}"]) fi test -z "${ac_env_CFLAGS_set}" -a -n "${cflags+set}" && eval CFLAGS="\"$cflags $ARCH_FLAG\"" |