~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to m4/pandora_warnings.m4

  • Committer: Lee Bieber
  • Date: 2010-10-27 18:28:56 UTC
  • mfrom: (1883.1.3 build)
  • Revision ID: kalebral@gmail.com-20101027182856-q3wqtbv1t4egkjsk
Merge Andrew - fix bug 667360: --defaults-file not processed before paths read           
Merge Andrew - fix bug 656577: Importing SQL script results in silent failure    
Merge Andrew - fix bug 667053: drizzledump minor output cleanup needed

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
dnl  Copyright (C) 2009 Sun Microsystems, Inc.
2
 
dnl This file is free software; Sun Microsystems, Inc.
 
1
dnl  Copyright (C) 2009 Sun Microsystems
 
2
dnl This file is free software; Sun Microsystems
3
3
dnl gives unlimited permission to copy and/or distribute it,
4
4
dnl with or without modifications, as long as this notice is preserved.
5
5
 
34
34
          [ac_cv_warnings_as_errors=yes],
35
35
          [ac_cv_warnings_as_errors=no]))
36
36
 
37
 
  AC_ARG_ENABLE([gcc-profile-mode],
38
 
      [AS_HELP_STRING([--enable-gcc-profile-mode],
39
 
         [Toggle gcc profile mode @<:@default=off@:>@])],
40
 
      [ac_gcc_profile_mode="$enableval"],
41
 
      [ac_gcc_profile_mode="no"])
42
 
 
43
37
  AC_ARG_ENABLE([profiling],
44
38
      [AS_HELP_STRING([--enable-profiling],
45
39
         [Toggle profiling @<:@default=off@:>@])],
93
87
            F_DIAGNOSTICS_SHOW_OPTION="-fdiagnostics-show-option"
94
88
          ])
95
89
 
96
 
    AC_CACHE_CHECK([whether it is safe to use -floop-parallelize-all],
97
 
      [ac_cv_safe_to_use_floop_parallelize_all_],
98
 
      [save_CFLAGS="$CFLAGS"
99
 
       CFLAGS="-floop-parallelize-all ${AM_CFLAGS} ${CFLAGS}"
100
 
       AC_COMPILE_IFELSE(
101
 
         [AC_LANG_PROGRAM([],[])],
102
 
         [ac_cv_safe_to_use_floop_parallelize_all_=yes],
103
 
         [ac_cv_safe_to_use_floop_parallelize_all_=no])
104
 
       CFLAGS="$save_CFLAGS"])
105
 
 
106
 
    AS_IF([test "$ac_cv_safe_to_use_floop_parallelize_all_" = "yes"],
107
 
          [
108
 
            F_LOOP_PARALLELIZE_ALL="-floop-parallelize-all"
109
 
          ])
 
90
    AC_CACHE_CHECK([whether it is safe to use -Wformat],
 
91
      [ac_cv_safe_to_use_wformat_],
 
92
      [save_CFLAGS="$CFLAGS"
 
93
       dnl Use -Werror here instead of ${W_FAIL} so that we don't spew
 
94
       dnl conversion warnings to all the tarball folks
 
95
       CFLAGS="-Wconversion -Werror -pedantic ${AM_CFLAGS} ${CFLAGS}"
 
96
       AC_COMPILE_IFELSE(
 
97
         [AC_LANG_PROGRAM([[
 
98
#include <stdio.h>
 
99
#include <stdint.h>
 
100
#include <inttypes.h>
 
101
void foo(bool a)
 
102
{
 
103
  uint64_t test_u= 0;
 
104
  printf("This is a %" PRIu64 "test\n", test_u);
 
105
}
 
106
         ]],[[
 
107
foo(0);
 
108
         ]])],
 
109
         [ac_cv_safe_to_use_wformat_=yes],
 
110
         [ac_cv_safe_to_use_wformat_=no])
 
111
       CFLAGS="$save_CFLAGS"])
 
112
    AS_IF([test "$ac_cv_safe_to_use_wformat_" = "yes"],[
 
113
      W_FORMAT="-Wformat"
 
114
      W_FORMAT_2="-Wformat=2"
 
115
      NO_FORMAT="-Wno-format"
 
116
      ],[
 
117
      W_FORMAT="-Wno-format"
 
118
      W_FORMAT_2="-Wno-format"
 
119
      NO_FORMAT="-Wno-format"
 
120
    ])
 
121
 
 
122
 
 
123
 
 
124
    AC_CACHE_CHECK([whether it is safe to use -Wconversion],
 
125
      [ac_cv_safe_to_use_wconversion_],
 
126
      [save_CFLAGS="$CFLAGS"
 
127
       dnl Use -Werror here instead of ${W_FAIL} so that we don't spew
 
128
       dnl conversion warnings to all the tarball folks
 
129
       CFLAGS="-Wconversion -Werror -pedantic ${AM_CFLAGS} ${CFLAGS}"
 
130
       AC_COMPILE_IFELSE(
 
131
         [AC_LANG_PROGRAM([[
 
132
#include <stdbool.h>
 
133
void foo(bool a)
 
134
{
 
135
  (void)a;
 
136
}
 
137
         ]],[[
 
138
foo(0);
 
139
         ]])],
 
140
         [ac_cv_safe_to_use_wconversion_=yes],
 
141
         [ac_cv_safe_to_use_wconversion_=no])
 
142
       CFLAGS="$save_CFLAGS"])
 
143
 
 
144
    AS_IF([test "$ac_cv_safe_to_use_wconversion_" = "yes"],
 
145
      [W_CONVERSION="-Wconversion"
 
146
      AC_CACHE_CHECK([whether it is safe to use -Wconversion with htons],
 
147
        [ac_cv_safe_to_use_Wconversion_],
 
148
        [save_CFLAGS="$CFLAGS"
 
149
         dnl Use -Werror here instead of ${W_FAIL} so that we don't spew
 
150
         dnl conversion warnings to all the tarball folks
 
151
         CFLAGS="-Wconversion -Werror -pedantic ${AM_CFLAGS} ${CFLAGS}"
 
152
         AC_COMPILE_IFELSE(
 
153
           [AC_LANG_PROGRAM(
 
154
             [[
 
155
#include <netinet/in.h>
 
156
             ]],[[
 
157
uint16_t x= htons(80);
 
158
             ]])],
 
159
           [ac_cv_safe_to_use_Wconversion_=yes],
 
160
           [ac_cv_safe_to_use_Wconversion_=no])
 
161
         CFLAGS="$save_CFLAGS"])
 
162
 
 
163
      AS_IF([test "$ac_cv_safe_to_use_Wconversion_" = "no"],
 
164
            [NO_CONVERSION="-Wno-conversion"])
 
165
    ])
110
166
 
111
167
    NO_STRICT_ALIASING="-fno-strict-aliasing -Wno-strict-aliasing"
112
168
    NO_SHADOW="-Wno-shadow"
113
169
 
114
170
    AS_IF([test "$INTELCC" = "yes"],[
115
171
      m4_if(PW_LESS_WARNINGS,[no],[
116
 
        BASE_WARNINGS="-w1 -Werror -Wcheck -Wp64 -Woverloaded-virtual -Wcast-qual -diag-disable 188"
 
172
        BASE_WARNINGS="-w1 -Werror -Wcheck ${W_FORMAT} -Wp64 -Woverloaded-virtual -Wcast-qual -diag-disable 188"
117
173
      ],[
118
174
        dnl 2203 is like old-style-cast
119
175
        dnl 1684 is like strict-aliasing
120
176
        dnl 188 is about using enums as bitfields
121
177
        dnl 1683 is a warning about _EXPLICIT_ casting, which we want
122
 
        BASE_WARNINGS="-w1 -Werror -Wcheck -Wp64 -Woverloaded-virtual -Wcast-qual -diag-disable 188,981,2259,2203,1683,1684"
 
178
        BASE_WARNINGS="-w1 -Werror -Wcheck ${W_FORMAT} -Wp64 -Woverloaded-virtual -Wcast-qual -diag-disable 188,981,2259,2203,1683,1684"
123
179
      ])
124
180
      CC_WARNINGS="${BASE_WARNINGS}"
125
181
      CXX_WARNINGS="${BASE_WARNINGS}"
127
183
      
128
184
    ],[
129
185
      m4_if(PW_LESS_WARNINGS,[no],[
130
 
        BASE_WARNINGS_FULL="${W_CONVERSION} -Wstrict-aliasing"
 
186
        BASE_WARNINGS_FULL="${W_FORMAT_2} ${W_CONVERSION} -Wstrict-aliasing"
131
187
        CC_WARNINGS_FULL="-Wswitch-default -Wswitch-enum -Wwrite-strings"
132
188
        CXX_WARNINGS_FULL="-Weffc++ -Wold-style-cast"
133
189
        NO_OLD_STYLE_CAST="-Wno-old-style-cast"
134
190
        NO_EFF_CXX="-Wno-effc++"
135
191
      ],[
136
 
        BASE_WARNINGS_FULL="${NO_STRICT_ALIASING}"
 
192
        BASE_WARNINGS_FULL="${W_FORMAT_2} ${NO_STRICT_ALIASING}"
137
193
      ])
138
194
 
139
195
      AS_IF([test "${ac_cv_assert}" = "no"],
153
209
        [ac_cv_safe_to_use_Wextra_=no])
154
210
      CFLAGS="$save_CFLAGS"])
155
211
 
156
 
      BASE_WARNINGS="${W_FAIL} -pedantic -Wall -Wundef -Wshadow ${NO_UNUSED} ${F_DIAGNOSTICS_SHOW_OPTION} ${F_LOOP_PARALLELIZE_ALL} ${BASE_WARNINGS_FULL}"
 
212
      BASE_WARNINGS="${W_FAIL} -pedantic -Wall -Wundef -Wshadow ${NO_UNUSED} ${F_DIAGNOSTICS_SHOW_OPTION} ${BASE_WARNINGS_FULL}"
157
213
      AS_IF([test "$ac_cv_safe_to_use_Wextra_" = "yes"],
158
214
            [BASE_WARNINGS="${BASE_WARNINGS} -Wextra"],
159
215
            [BASE_WARNINGS="${BASE_WARNINGS} -W"])
160
216
  
161
 
      AC_CACHE_CHECK([whether it is safe to use -Wformat],
162
 
        [ac_cv_safe_to_use_wformat_],
163
 
        [save_CFLAGS="$CFLAGS"
164
 
         dnl Use -Werror here instead of ${W_FAIL} so that we don't spew
165
 
         dnl conversion warnings to all the tarball folks
166
 
         CFLAGS="-Wformat -Werror -pedantic ${AM_CFLAGS} ${CFLAGS}"
167
 
         AC_COMPILE_IFELSE(
168
 
           [AC_LANG_PROGRAM([[
169
 
#include <stdio.h>
170
 
#include <stdint.h>
171
 
#include <inttypes.h>
172
 
void foo();
173
 
void foo()
174
 
{
175
 
  uint64_t test_u= 0;
176
 
  printf("This is a %" PRIu64 "test\n", test_u);
177
 
}
178
 
           ]],[[
179
 
foo();
180
 
           ]])],
181
 
           [ac_cv_safe_to_use_wformat_=yes],
182
 
           [ac_cv_safe_to_use_wformat_=no])
183
 
         CFLAGS="$save_CFLAGS"])
184
 
      AS_IF([test "$ac_cv_safe_to_use_wformat_" = "yes"],[
185
 
        BASE_WARNINGS="${BASE_WARNINGS} -Wformat -Wno-format-nonliteral -Wno-format-security"
186
 
        BASE_WARNINGS_FULL="${BASE_WARNINGS_FULL} -Wformat=2 -Wno-format-nonliteral -Wno-format-security"
187
 
        ],[
188
 
        BASE_WARNINGS="${BASE_WARNINGS} -Wno-format"
189
 
        BASE_WARNINGS_FULL="${BASE_WARNINGS_FULL} -Wno-format"
190
 
      ])
191
 
 
192
 
 
193
 
 
194
 
      AC_CACHE_CHECK([whether it is safe to use -Wconversion],
195
 
        [ac_cv_safe_to_use_wconversion_],
196
 
        [save_CFLAGS="$CFLAGS"
197
 
         dnl Use -Werror here instead of ${W_FAIL} so that we don't spew
198
 
         dnl conversion warnings to all the tarball folks
199
 
         CFLAGS="-Wconversion -Werror -pedantic ${AM_CFLAGS} ${CFLAGS}"
200
 
         AC_COMPILE_IFELSE(
201
 
           [AC_LANG_PROGRAM([[
202
 
#include <stdbool.h>
203
 
void foo(bool a)
204
 
{
205
 
  (void)a;
206
 
}
207
 
           ]],[[
208
 
foo(0);
209
 
           ]])],
210
 
           [ac_cv_safe_to_use_wconversion_=yes],
211
 
           [ac_cv_safe_to_use_wconversion_=no])
212
 
         CFLAGS="$save_CFLAGS"])
213
 
  
214
 
      AS_IF([test "$ac_cv_safe_to_use_wconversion_" = "yes"],
215
 
        [W_CONVERSION="-Wconversion"
216
 
        AC_CACHE_CHECK([whether it is safe to use -Wconversion with htons],
217
 
          [ac_cv_safe_to_use_Wconversion_],
218
 
          [save_CFLAGS="$CFLAGS"
219
 
           dnl Use -Werror here instead of ${W_FAIL} so that we don't spew
220
 
           dnl conversion warnings to all the tarball folks
221
 
           CFLAGS="-Wconversion -Werror -pedantic ${AM_CFLAGS} ${CFLAGS}"
222
 
           AC_COMPILE_IFELSE(
223
 
             [AC_LANG_PROGRAM(
224
 
               [[
225
 
#include <netinet/in.h>
226
 
               ]],[[
227
 
uint16_t x= htons(80);
228
 
               ]])],
229
 
             [ac_cv_safe_to_use_Wconversion_=yes],
230
 
             [ac_cv_safe_to_use_Wconversion_=no])
231
 
           CFLAGS="$save_CFLAGS"])
232
 
  
233
 
        AS_IF([test "$ac_cv_safe_to_use_Wconversion_" = "no"],
234
 
              [NO_CONVERSION="-Wno-conversion"])
235
 
      ])
236
 
 
237
217
      CC_WARNINGS="${BASE_WARNINGS} -Wstrict-prototypes -Wmissing-prototypes -Wredundant-decls -Wmissing-declarations -Wcast-align ${CC_WARNINGS_FULL}"
238
218
      CXX_WARNINGS="${BASE_WARNINGS} -Woverloaded-virtual -Wnon-virtual-dtor -Wctor-dtor-privacy -Wno-long-long ${CXX_WARNINGS_FULL}"
239
219
 
256
236
      AS_IF([test "$ac_cv_safe_to_use_Wmissing_declarations_" = "yes"],
257
237
            [CXX_WARNINGS="${CXX_WARNINGS} -Wmissing-declarations"])
258
238
  
259
 
      AC_CACHE_CHECK([whether it is safe to use -Wframe-larger-than],
260
 
        [ac_cv_safe_to_use_Wframe_larger_than_],
261
 
        [AC_LANG_PUSH(C++)
262
 
         save_CXXFLAGS="$CXXFLAGS"
263
 
         CXXFLAGS="-Werror -pedantic -Wframe-larger-than=32768 ${AM_CXXFLAGS}"
264
 
         AC_COMPILE_IFELSE([
265
 
           AC_LANG_PROGRAM(
266
 
           [[
267
 
#include <stdio.h>
268
 
           ]], [[]])
269
 
        ],
270
 
        [ac_cv_safe_to_use_Wframe_larger_than_=yes],
271
 
        [ac_cv_safe_to_use_Wframe_larger_than_=no])
272
 
        CXXFLAGS="$save_CXXFLAGS"
273
 
        AC_LANG_POP()
274
 
      ])
275
 
      AS_IF([test "$ac_cv_safe_to_use_Wframe_larger_than_" = "yes"],
276
 
            [CXX_WARNINGS="${CXX_WARNINGS} -Wframe-larger-than=32768"])
277
 
  
278
239
      AC_CACHE_CHECK([whether it is safe to use -Wlogical-op],
279
240
        [ac_cv_safe_to_use_Wlogical_op_],
280
241
        [save_CFLAGS="$CFLAGS"
371
332
      dnl TODO: Figure out a better way to deal with this:
372
333
      PROTOSKIP_WARNINGS="-Wno-effc++ -Wno-shadow -Wno-missing-braces ${NO_ATTRIBUTES}"
373
334
      NO_WERROR="-Wno-error"
374
 
      PERMISSIVE_WARNINGS="-Wno-error -Wno-unused-function -fpermissive"
375
 
      PERMISSIVE_C_WARNINGS="-Wno-error -Wno-redundant-decls"
 
335
      INNOBASE_SKIP_WARNINGS="-Wno-shadow -Wno-cast-align"
376
336
      AS_IF([test "$host_vendor" = "apple"],[
377
337
        BOOSTSKIP_WARNINGS="-Wno-uninitialized"
378
338
      ])
406
366
 
407
367
 
408
368
    m4_if(PW_LESS_WARNINGS, [no],[
409
 
      CC_WARNINGS_FULL="-erroff=E_STATEMENT_NOT_REACHED,E_INTEGER_OVERFLOW_DETECTED${W_PASTE_RESULT}"
 
369
      CC_WARNINGS_FULL="-erroff=E_INTEGER_OVERFLOW_DETECTED${W_PASTE_RESULT}"
410
370
      CXX_WARNINGS_FULL="-erroff=inllargeuse"
411
371
    ],[
412
 
      CC_WARNINGS_FULL="-erroff=E_ATTRIBUTE_NOT_VAR,E_STATEMENT_NOT_REACHED"
 
372
      CC_WARNINGS_FULL="-erroff=E_ATTRIBUTE_NOT_VAR"
413
373
      CXX_WARNINGS_FULL="-erroff=attrskipunsup,doubunder,reftotemp,inllargeuse,truncwarn1,signextwarn,inllargeint"
414
374
    ])
415
375
 
417
377
    CXX_WARNINGS="+w +w2 -xwe -xport64 -errtags=yes ${CXX_WARNINGS_FULL} ${W_FAIL}"
418
378
    PROTOSKIP_WARNINGS="-erroff=attrskipunsup,doubunder,reftotemp,wbadinitl,identexpected,inllargeuse,truncwarn1,signextwarn,partinit,notused,badargtype2w,wbadinit"
419
379
    BOOSTSKIP_WARNINGS="-erroff=attrskipunsup,doubunder,reftotemp,inllargeuse,truncwarn1,signextwarn,inllargeint,hidef,wvarhidenmem"
420
 
    PERMISSIVE_WARNINGS="-erroff=attrskipunsup,doubunder,reftotemp,inllargeuse,truncwarn1,signextwarn,inllargeint,hidef,wvarhidenmem,notused,badargtype2w,wunreachable"
421
 
    INNOBASE_SKIP_WARNINGS="-erroff=attrskipunsup,doubunder,reftotemp,wbadinitl,identexpected,inllargeuse,truncwarn1,signextwarn,partinit,notused,badargtype2w,wbadinit,wunreachable"
422
380
    NO_UNREACHED="-erroff=E_STATEMENT_NOT_REACHED"
423
381
    NO_WERROR="-errwarn=%none"
424
382
 
432
390
  AC_SUBST(NO_EFF_CXX)
433
391
  AC_SUBST(NO_OLD_STYLE_CAST)
434
392
  AC_SUBST(PROTOSKIP_WARNINGS)
 
393
  AC_SUBST(BOOSTSKIP_WARNINGS)
435
394
  AC_SUBST(INNOBASE_SKIP_WARNINGS)
436
 
  AC_SUBST(BOOSTSKIP_WARNINGS)
437
 
  AC_SUBST(PERMISSIVE_WARNINGS)
438
 
  AC_SUBST(PERMISSIVE_C_WARNINGS)
439
395
  AC_SUBST(NO_WERROR)
440
396
  AC_SUBST([GCOV_LIBS])
441
397