Question

This Question is about getting the gcc compiler to warn when you make a typo and initialize a variable with itself.

      int f()
      {
        int i = i;
        return i;
      }

It turns out you need the -Winit-self flag in addition to -Wuninitialized:

-Winit-self (C, C++, Objective-C and Objective-C++ only) Warn about uninitialized variables which are initialized with themselves. Note this option can only be used with the -Wuninitialized option, which in turn only works with -O1 and above.

My question is: Why is this not the default behavior for -Wuninitialized? What is the use case where you want to warn about uninitialized variables, but not self-initialized ones, which are just as troublesome?

Was it helpful?

Solution

It looks like this bug report Warn about member variables initialized with itself has an explanation for this (emphasis mine):

I agree with Andrew, the a(a) mistake should always warn, it should be independent of -Winit-self, which exists so that -Wuninitialized doesn't warn about the common (but questionable) practice of self-initializing automatic variables to silence warnings.

It it probably called a questionable practice since it is undefined behavior in C++ to self initialize an automatic variable and the bug report is a C++ bug report.

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top