------- Comment #6 from dodji at gcc dot gnu dot org 2008-07-22 18:25 -------
@jakub: I confirm that doing:
if (!DECL_CONTEXT (decl))
{
DECL_CONTEXT (decl) = current_function_decl;
}
at the beginning of one_static_initialization_or_destruction() allows the
compilation to not crash.
At that point, the name of current_function_decl is effectively
"__static_initialization_and_destruction_0".
I am not sure if setting DECL_CONTEXT (decl) is safe to do, because the
DECL_CONTEXT (decl) being NULL means the variable happened in the global
namespace. Doing DECL_CONTEXT (decl) = current_function_decl makes us loose
that information.
On the other hand, one_static_initialization_or_destruction() is called at the
end of the parsing+semantic analysis phase, so loosing that information might
not be harmful (I am not sure). In which case, this candidate fix might be
enough.
--
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=36767