[cfe-dev] Access specifiers and anonymous unions

John McCall rjmccall at apple.com
Fri Jun 4 14:57:38 PDT 2010


On Jun 1, 2010, at 3:56 AM, Abramo Bagnara wrote:

> Il 31/05/2010 20:42, John McCall ha scritto:
>> 
>> On May 31, 2010, at 7:21 AM, Abramo Bagnara wrote:
>> 
>>> Il 28/05/2010 19:53, John McCall ha scritto:
>>>>> 
>>>>> To represent correctly the above we might decide to have a node for
>>>>> access specifiers at the same level of other decls.
>>>> 
>>>> Yes, I've been wanting something like this for some time.
>>> 
>>> Would it be OK if we derive from Decl a new class modeling syntactic
>>> access specifiers occurring in the list of member specifiers of a C++
>>> class definition?
>>> 
>>> What about the name AccessSpecDecl ?
>> 
>> Decl actually has a lot of space overhead, and if we put these in the decl chain
>> we have to instantiate them, etc.  If we want to be really space-conserving, we
>> could just add an array of little structs to CXXRecordDecl::DefinitionData.
>> On the other hand, that would make them much more difficult to use;  I'm torn.
>> 
>>> Deriving from Decl already provides space for storing the access
>>> specifier (cannot be AS_none) and the corresponding source location.
>>> While at it, should we also provide a source location for the ':' ?
>> 
>> Probably not necessary.
>> 
>>> Am I right if I say that all code visiting CXXRecordDecl as a
>>> declaration context will automatically ignore this new class (which is
>>> actually a good thing)?
>> 
>> Well, if they were Decls, lookup would ignore them because they wouldn't
>> be NamedDecls, but they'd still show up in the lexical decl chain.  That's
>> probably fine.
> 
> I've attached the patch that introduces AccessSpecDecl for your approval.

After some discussion, we decided that the potential memory savings of avoiding
making Decls here was Not Worth It.  We can revisit that decision if shown that
it matters.

Please commit, and thanks for being patient.

John.



More information about the cfe-dev mailing list