[GCC-XML]"__thread" now a reserved word in gcc 3.3
Brad King
brad.king at kitware.com
Thu, 04 Mar 2004 17:30:35 -0500
Dan Halbert wrote:
> Hi, I am using gccxml in conjunction with Boost.Python's pyste tool.
>
> I was using gccxml-0.4.2, but wanted to switch to 0.6.0 because of the
> support for exception specifiers.
>
> We are using gcc 3.2.2 on a RH7.3 system. As of gcc 3.3, "__thread"
> has become a reserved word. This causes problems with my RH7.3
> /usr/include/pthread.h, which happens to use "__thread" as an ordinary
> variable name.
>
> I #include <pthread.h> in the code I run through gccxml.
> Without patching my pthread.h, is it possible to get gccxml-0.6.0
> not to treat "__thread" as a reserved word? I thought it could
> imitate the behavior of previous compilers, but perhaps this is
> an exception.
>
> I have tried rebuilding gccxml-0.6.0 from scratch, using my gcc 3.2.2
> as its basis. But the problem persists.
I have seen this problem when simulating 2.95 and 2.96 versions of GCC,
but this is the first time I've seen it for GCC 3.3. Since the conflict
is with pthread.h, the problem could conceivably occur for any compiler.
Since parsing other compiler's headers is a general problem for GCC-XML,
there is a general solution. The Support directory in the source tree
contains a set of patched headers from various supported compilers.
These fixed headers are found by GCC-XML's preprocessor before those on
the system.
There is a directory called GCC_XML/Support/GCC/2.95 in the GCC-XML
source tree. Copy the file pthread.h from that directory to
GCC_XML/Support/GCC/3.3. This should add the pthread.h fixes to the
simulation of the GCC 3.3 compiler. Let me know if this fixes your
problem and I'll commit the fix upstream.
Thanks,
-Brad