Benjamin, Thanks for looking into this issue. I see what's going on here. It's basically a phase ordering problem. I am trying to determine whether a declaration is a class member when attributes are parsed and handled (in c-common.c), which happens earlier than where the context of a data member is set (which takes place either in finish_static_data_member_decl or finish_member_declaration). Do you know of any way to determine whether a decl is a class member when we are parsing the decl attributes?
Thanks, Le-chun On Tue, Jul 22, 2008 at 12:34 PM, Benjamin Smedberg <[EMAIL PROTECTED]> wrote: > Le-Chun Wu wrote: >> >> Hi, >> >> I haven't heard anything back on my questions. Can any of C++ frontend >> maintainers please shed some light (or comment on my proposed patch)? >> Thanks a lot. >> >> Le-chun >> >> On Fri, Jul 18, 2008 at 10:22 AM, Le-Chun Wu <[EMAIL PROTECTED]> wrote: >>> >>> Hi, >>> >>> In my attribute handlers that handle the new thread-safety attributes >>> (in c-common.c), I need to check if a decl is a class member. How do >>> people do that? My original code was checking if a decl is a >>> FIELD_DECL but that doesn't work for static members. I also tried to >>> use DECL_CONTEXT but it is not set (in the C++ front-end) for data >>> members. (I was able to use DECL_CONTEXT for member functions, >>> though.) Is there any other way that I should use? > > I created a simple testcase for treehydra and it seems that DECL_CONTEXT was > set and correct for all of the following in 4.3.0: > > struct A { > int a; > int f(); > static int sa; > static int sf(); > }; > > Are you saying that you don't see a proper DECL_CONTEXT for "a" and "sa"? > > --BDS >