[constables] RFR of constants API
Remi Forax
forax at univ-mlv.fr
Mon Jun 4 22:23:40 UTC 2018
Yes, good catch,
in ASM we use a supplementary boolean to say if it's a MethodRef or an InterfaceRef.
Rémi
----- Mail original -----
> De: "Brian Goetz" <brian.goetz at oracle.com>
> À: "Vicente Romero" <vicente.romero at oracle.com>, "amber-spec-experts" <amber-spec-experts at openjdk.java.net>
> Envoyé: Lundi 4 Juin 2018 23:54:01
> Objet: Re: [constables] RFR of constants API
> Robert Field raised the following possible bug in the API of
> MethodHandleDesc.
>
> A Constant_MethodHandle_info has the following contents:
> refKind
> reference to MethodRef or InterfaceMethodRef
> reference to NameAndType
>
> Most of these map directly; we extract refKind from Kind, we extract
> name from name, we extract type descriptor from type. But, it doesn't
> seem like there's a way to express both (refkind=invokespecial,
> Constant_MethodRef_info) and (refkind=invokevirtual,
> Constant_InterfaceMethodRef_info).
>
> One of the inputs to a MHDesc is a Kind enum constant. Currently, they
> map 1:1 with refKind, but it seems to me we need to differentiate
> between INTERFACE_VIRTUAL and INTERFACE_SPECIAL, where in the latter
> case, refKind=special but we use an InterfaceMethodRef?
>
> On 4/27/2018 1:31 PM, Vicente Romero wrote:
>> Hi all,
>>
>> Please review the current proposal of the constants API, which are
>> nominal descriptor types defined in pkg java.lang.invoke.constant. The
>> code can be found at [1]. This API is being developed in the context
>> of JEP 303: Intrinsics for the LDC and INVOKEDYNAMIC Instructions [2]
>>
>> Thanks in advance for your comments,
>> Vicente
>>
>> [1] http://cr.openjdk.java.net/~vromero/constant.api/webrev.00
> > [2] http://openjdk.java.net/jeps/303
More information about the amber-spec-experts
mailing list