Crafting Better Source Code in C++
llewelly@xmission.com
llewelly@xmission.com
Mon Mar 22 04:50:00 GMT 2004
Eljay Love-Jensen <eljay@adobe.com> writes:
> Hi everyone,
>
> #define SOAPBOX
>
> I've been asked this question several times about C++ (in particular,
> GCC's C++), and I thought I'd share my thoughts.
>
> The GCC compiler has a suite of warnings which will point out
> dangerous or suspicious coding practices. By and large, I feel that
> these GCC warnings are indicative of either bad code ("bugs"! ~10% of
> the time), or poor coding practices (~90%).
>
> In either case, I think it is a worthwhile endeavor to use GCC's
> warning facilities to help improve the source code, and improve the
> portability of the source code.
>
> At a minimum, I suggest everyone ALWAYS use these flags:
> -pedantic -Wall -W
As more and more C libraries incorporate C99 features, fewer and fewer
people will be able to use -pedantic with C++ . Many real projects
will need to seperate that code which can be written with strict
conformance from that which requires non standard features, and
use appropriately different compile flags.
While we are at it, however, I suggest another warning flag: -O
:-) . Certain warnings (like 'foo unused', and 'foo may be used
before it is initialized' ) require data-flow analysis, and so are
only enabled with -On, e.g. -Wunitialized.
>
> Other flags are documented here:
> http://gcc.gnu.org/onlinedocs/gcc-3.3.3/gcc/Warning-Options.html
>
> I use almost all the additional flags. Call me ultra-pedantic. I
> wish there was an -WALL switch, to enable all warnings (even the
> annoying ones which I disregard), just so I wouldn't have the creepy
> feeling I've missed one.
[snip]
Compile this program:
#include<iostream>
#include<ostream>
int main()
{
std::cout << "Hello World!" << std::endl;
}
with: g++ -Weffc++ -Wsystem-headers
Alternatively, try building any boost-using C++ with -Weffc++, without
-Wsystem-headers.
Personally, I think the flags not enabled by -W -Wall are only useful
in very rare circumstances.
More information about the Gcc-help
mailing list