strange ClassFormatError with indy
Douglas Simon
doug.simon at oracle.com
Thu Aug 30 06:59:41 PDT 2012
Is is something to do with the fact that <init> methods always have a void return type?
On Aug 30, 2012, at 3:35 PM, Remi Forax <forax at univ-mlv.fr> wrote:
> The JVMS says the name must be a method name,
> http://docs.oracle.com/javase/specs/jvms/se7/html/jvms-5.html#jvms-5.1
>
> A symbolic reference to a call site specifier is derived from a CONSTANT_InvokeDynamic_info structure (§4.4.10) in the binary representation of a class or interface. Such a reference gives:
> • a symbolic reference to a method handle, which will serve as a bootstrap method for an invokedynamic instruction (§invokedynamic);
>
> • a sequence of symbolic references (to classes, method types, and method handles), string literals, and runtime constants (i.e. primitive numeric values), which will serve as static arguments to a bootstrap method;
>
> • a method name and method descriptor.
>
>
> so "<init>" should be possible, but I don't think the EG discuss this corner case.
>
> Rémi
>
> On 08/30/2012 03:19 PM, Jochen Theodorou wrote:
>> Hi all,
>>
>> I originally wrote that to the asm list, but nobody seems to know there.
>> Anyway, for my generated bytecode the verifier complains with this message:
>>
>> java.lang.ClassFormatError: Method "<init>" in class test has illegal
>> signature "(Ljava/lang/Class;Ljava/util/Map;)Ljava/lang/Object;"
>>
>> Now... there is not a single <init> method of that signature in the
>> class test. What is new though (before it worked) is this indy call:
>>
>>
>>> INVOKEDYNAMIC <init>(Ljava/lang/Class;Ljava/util/Map;)Ljava/lang/Object; [
>>> // handle kind 0x6 : INVOKESTATIC
>>> org/codehaus/groovy/vmplugin/v7/IndyInterface.bootstrap((Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;)
>>> // arguments: none
>>>
>> And this call has the signature the verifier complains about. Is this an
>> illegal invokedynamic call?
>>
>> bye blackdrag
>>
>>
>
> _______________________________________________
> mlvm-dev mailing list
> mlvm-dev at openjdk.java.net
> http://mail.openjdk.java.net/mailman/listinfo/mlvm-dev
More information about the mlvm-dev
mailing list