Final nestmates spec
David Holmes
david.holmes at oracle.com
Mon Dec 18 22:03:03 UTC 2017
On 19/12/2017 7:28 AM, Dan Smith wrote:
>> On Dec 15, 2017, at 9:41 PM, David Holmes <David.Holmes at oracle.com> wrote:
>>
>>> A good litmus test: should the result contain the current class or not? If it does, you're giving clients a polished list of actual nest members. If it does not, you're just repeating to clients what the attribute says.
>>
>> The result should of course contain the current class - if it is the nest host it is always returned as the zeroeth element.
>
>> getNetsMembers() doesn't mean "read the Nestmember attribute of this class", it means " get all the nest members of the nest in which this class is a member".
>
> Okay, then my argument is that the result of 'getNestMembers' is a semantically meaningful set of classes, not just a view of the attribute contents. And under that interpretation, anomalous entries should either be silently filtered out or trigger an error.
>
> As a user, I think I'd view the method as "go find me all the classes in this nest; you may use 'NestMembers' as a hint for your search".
>
>> That conflicts with what John suggested.
>
> Sorry, John, I'd prefer different behavior. :-)
>
> Specifically:
>> Given the action on 4 (just let it hit the fan), I suggest that we should
>> also let self, outsider, and duplicate entries show through on reflection.
>
> The proposed treatment of a nonexistent class (4) is to report an error. That's fine, and maybe it makes sense to report an error in some or all of the cases. (I wouldn't object to silently ignoring the nonexistent class, though. Depends on what we think users want when a nest member class is missing—which, as we've discovered, is not uncommon.)
>
> But letting things "show through" is, I think, never what the end user will want. They will believe that anything in the array returned by 'getNestMembers' actually *is* a member of the nest.
Given we're only talking about the case where the nesthost is explicitly
listed in NestMembers, or where there are duplicate (correct) entries in
NestMembers, then everything in the returned array _is_ a member of the
nest. The issue is whether we need to condense the array so that it
holds the set of members.
From a purist perspective I'd like it to return the set of members in
the array. But pragmatically I hate to add overhead to every single
correct use of the attribute just to account for the
allowed-for-but-not-expected corner case of there being duplicates.
Thanks,
David
> —Dan
>
More information about the valhalla-spec-experts
mailing list