nestmates spec open issues

David Holmes david.holmes at oracle.com
Thu Oct 26 03:54:50 UTC 2017


On 26/10/2017 1:11 PM, John Rose wrote:
> On Oct 25, 2017, at 8:07 PM, John Rose <john.r.rose at oracle.com> wrote:
>>
>> On Oct 25, 2017, at 3:33 PM, Remi Forax <forax at univ-mlv.fr <mailto:forax at univ-mlv.fr>> wrote:
>>>
>>> getClasses() throws an exception but getAnnotations() skips unavailable annotations.
>>>
>>> that said, i'm not against throwing in this case.
>>
>> I'm not against throwing either, but I think scrubbing (like annotations)
>> is a little better, because it is more robust about retaining partial results.

Aren't annotations a different situation because annotations are well 
known to potentially not be available at runtime? A missing annotation 
does not necessarily reflect an error in the runtime environment of an 
application. Also AFAIK see from the jdk/java/lang/annotation/Missing/ 
test the throw/no-throw behaviour depends on exactly how the missing 
annotation is used.

>> Partial results are important if you are just asking about one or two
>> classes and don't care about their other nestmates.

How do you know to only ask about "one or two classes"? Sorry I'm not 
understanding the potential usecase here.If you've already identified 
specific classes of interest then you can call getNestHost on them.

> And even if H.getNestMembers() throws because of some missing N1,
> we have to be careful to allow N2.getNestHost() to return H, if we can
> validate that N2 points to H and vice versa.  We don't want the validated
> relation between N2 and H to be collateral damage to a failure of N1.

Absolutely not. The two queries would be completely unrelated in that 
regard.

> (If H goes missing there is nothing we can do with N1 and N2, except
> to assign each to its own 1-nest.  Which is OK with me.)

Then presumably we should do the same at the VM level instead of 
allowing resolution related exceptions to propagate as currently 
proposed? We could just throw IAE as we do if a nest-host validation 
check fails. Though a case can still be made to allow VME's to pass through.

Though I still feel uncomfortable lying about the nest-host. I don't see 
what usecases would be served by doing that. Other than informational 
uses, I can't see a reason to actually identify the nest-host which 
would not be impacted by lying about that identity. The only truly 
useful query is for nestmate access and that doesn't need to expose the 
identity of the nest-host and conservatively rejects access if anything 
goes wrong.

Bottom line for my personal preferences:

- hasNestMateAccess: never throws, always returns true or false
- getNestHost(): throw if the host isn't there or else a membership 
validation check fails
- getNestMembers(): throw if any nest member isn't there or a membership 
validation check fails

Cheers,
David


More information about the valhalla-spec-observers mailing list