Updated JEP: nestmates
John Rose
john.r.rose at oracle.com
Fri Apr 14 20:26:37 UTC 2017
On Apr 13, 2017, at 3:05 PM, forax at univ-mlv.fr wrote:
>
> It seems we are all on the same page but some of us talk about the spec and other about the implementation.
>
> From the spec point of view, i agree with Brian,
> "Every class belongs to exactly one nest",
> - if there is a MemberOfNest attribute, it defines the nest,
> - if there is a NestMembers attribute, it defines the nest-top,
> - if there is no attribute, it defines its own nest.
> and "Every nest has a canonical, consistent nest-top".
Confirmed. So the attributes are precursor relations which
should not be confused with the final product entity, a nest.
By "implementation" you mean the same thing as I mean
when I say "precursor relations".
(The product entity can be represented unambiguously
by a Class, the nest-top of the nest. This is what leads
to confusion, because that's not exactly the same thing
as the class which contains the NestMembers attribute,
nor does it *ever* contain the MemberOfNest attribute,
despite being a member of the nest of which it is the top,
nor is it *ever* in the NestMembers list, despite being
a member of that same nest.)
This tricky language is another reason to settle on a reflective
API sooner rather than later, so we have a rigorous notation
for this stuff. Should it be the precursors or the emergent
Nest entity? If the latter, should there be a Class.Nest
type or should we take a gamble and use a Class object
to represent the Nest of which it is the nest-top?
— John
More information about the valhalla-dev
mailing list