[Bug c++/19199] [3.3/3.4/4.0 Regression] Wrong warning about returning a reference to a temporary
amylaar at gcc dot gnu dot org
gcc-bugzilla@gcc.gnu.org
Wed Jan 26 18:02:00 GMT 2005
------- Additional Comments From amylaar at gcc dot gnu dot org 2005-01-26 18:02 -------
Is the folowing the same bug?
extern void abort (void);
int i0 = 999;
int *const p = &i0;
int const *const &
foo ()
{
return p;
}
int
main ()
{
int i = *foo ();
if (i != i0)
abort ();
return 0;
}
This warns, and fails at -O1. At -O0 the code is also wrong, but it passes
because the assignment to the stack temporary happens, and the stack is not
scribbled over.
If I make the creation of a const * const & temporary explicit, the warning
is not emitted, but the code is still wrong in the same way:
extern void abort (void);
int i0 = 999;
int *const p = &i0;
int const *const &
foo ()
{
int const *const &p0 = p;
return p0;
}
int
main ()
{
int i = *foo ();
if (i != i0)
abort ();
return 0;
}
If I define p instead with
int const *const p = &i0;
no bogus temporary is generated.
--
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=19199
More information about the Gcc-bugs
mailing list