Updated JEP: nestmates
David Holmes
david.holmes at oracle.com
Thu Apr 13 21:57:59 UTC 2017
On 14/04/2017 7:50 AM, Brian Goetz wrote:
>> The second part most certainly is necessary as a nest-top does not
>> itself have a nest-top!
>
> I would think we'd consider a nest-top as its own nest-top. That way,
> every nest has a top, which acts as a canonical element for that nest.
From an implementation perspective certainly that simplifies
nest-membership checks. but do you want that in the spec? Do you want
javac to generate a self-referential MemberOfNest attribute? If you want
this then the definitions need a rewrite. This is not where we are today.
>> It is not an optimization! You are either a nest-top (and so have a
>> NestMembers attribute) or you are a nested type and so have a
>> MemberOfNest attribute. (Of course you can be neither.)
>
> Similarly, I'd think that every class that has neither a NestMembers or
> MemberOfNest attribute constitutes a nest of one.
Sure logically you can consider it that way. Not sure it has any real
affect on anything.
> Taken together, now:
> - Every class belongs to exactly one nest;
> - Every nest has a canonical, consistent nest-top (every member of the
> nest agrees on the nest top)
Yes.
> This will become relevant when we extend this to support
> Lookup.defineClass with a private lookup, which has the effect of
> injecting a new class into an existing nest. If every class is already
> in a nest, this injection is simplified.
I don't really see how it makes a difference, but you presumably have
something in mind here.
Thanks,
David
More information about the valhalla-dev
mailing list