The warnings
module allows to regularly build a package with more
GCC warnings than the default warnings emitted by GCC. It is often used
indirectly through the manywarnings
module
(see manywarnings).
It provides the following functionality:
CFLAGS
variable at configuration time.
CFLAGS
does not work in general, because it may
break autoconfiguration.)
configure
with an option such as
--enable-gcc-warnings.
To use this module, you need the following:
gl_WARN_ADD([-Wall], [WARN_CFLAGS]) gl_WARN_ADD([-Wpointer-arith], [WARN_CFLAGS])
WARN_CFLAGS
, use it in the
definition of AM_CFLAGS
, like this:
AM_CFLAGS = $(WARN_CFLAGS)
Note that the AM_CFLAGS
is used in combination with CFLAGS
and before CFLAGS
in build rules emitted by Automake. This allows
the user to provide CFLAGS
that override the WARN_CFLAGS
.
‘gl_WARN_ADD([-Werror])’ is intended for developers, and should be avoided in contexts where it would affect ordinary installation builds. The warnings emitted by GCC depend, to some extent, on the contents of the system header files, on the size and signedness of built-in types, etc. Use of ‘-Werror’ would cause frustration to all users on platforms that the maintainer has not tested before the release. It is better if ‘-Werror’ is off by default, and is enabled only by developers. For example, ‘-Werror’ could affect ‘make distcheck’ or ‘configure --enable-gcc-warnings’ as mentioned above.