Re: warning that warns about iso compliant code

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Burlen Loring wrote:
Hi all, can anyone comment on this warning? I think that it might loosely be classified as a "bug" in the compiler because it warns both about the correct code and the incorrect code. There is more detail below. Given the fact that I have almost zero formal cs training, I would like to get some comments from the more experienced guys, if possible thanks. Burlen

for code such as:

int main()
{
int nToProcess=0;
for (int i=0; i<nToProcess; ++i)
  {
  int nComp=0;
  for (int i=0; i<nComp; ++i)
    {
    int j=i;
    }
    int q=i;
  }
return 0;
}

I have the following warnings:

testNetsted.cpp: In function ‘int main()’:
testNetsted.cpp:11: warning: name lookup of ‘i’ changed
testNetsted.cpp:4: warning: matches this ‘i’ under ISO standard rules
testNetsted.cpp:7: warning: matches this ‘i’ under old rules

To me it seems the compiler should not warn about code that follows the
ISO standard rules. However, it would be nice if the compiler warned about the case that didn't follow the standard. I personally like to hide the outer variables because it documents the fact that a particular loop does not use that variable. Am I just being silly and I should use different index variable name for all of my nested loops,even when there are no dependencies?

Also as a non-cs type, I appreciate the warning about such error-prone code, regardless of whether it follows the standard (which a majority of such code does not, in my experience).

[Index of Archives]     [Linux C Programming]     [Linux Kernel]     [eCos]     [Fedora Development]     [Fedora Announce]     [Autoconf]     [The DWARVES Debugging Tools]     [Yosemite Campsites]     [Yosemite News]     [Linux GCC]

  Powered by Linux