[ 
https://issues.apache.org/jira/browse/TAP5-2588?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=16674518#comment-16674518
 ] 

Andrew Fowler commented on TAP5-2588:
-------------------------------------

[~bobharner], I noticed you updated the {{--add-modules}} to make JAXB & Common 
Annotations work for JDK 9+, but it will only be valid for compiling in 9–10 
since [those 2 modules are removed from JDK 
11+|https://www.oracle.com/technetwork/java/javase/11-relnote-issues-5012449.html#JDK-8190378].
 Instead, going forward, I think Tapestry will need explicit dependencies on:
 * {{javax.annotation:javax.annotation-api}}
 * {{javax.xml.bind:jaxb-api}}
 * {{org.glassfish.jaxb:jaxb-runtime}}

It would be also safe to use this for JDK 9–10 instead of the {{--add-modules 
java.xml.ws.annotation,java.xml.bind}}, at the cost of an extra <2MB of 
dependencies.

 

ASM 7 will support Java 11 bytecode, but going past Java 9 is going to take 
substantial effort – e.g., {{tapestry-javadoc}} will need a revamp to use the 
rewritten Doclet API (the new one got added in 9, and the old one is gone from 
10). I suggest Tapestry gets at least one JDK 9 release, just to get it out 
sooner.

> Does not work with Java 9
> -------------------------
>
>                 Key: TAP5-2588
>                 URL: https://issues.apache.org/jira/browse/TAP5-2588
>             Project: Tapestry 5
>          Issue Type: Bug
>          Components: plastic
>    Affects Versions: 5.4.3
>            Reporter: Jochen Kemnade
>            Assignee: Bob Harner
>            Priority: Critical
>         Attachments: 
> 0001-TAP5-2588-Upgrade-ASM-6.x-7.0.1-for-Java-11-support.patch
>
>
> You cannot use Tapestry with Java 9 because of an outdated ASM version in 
> plastic (5.0.4). AFAICT, we'll need to upgrade to 6.0. My attempt do do so 
> results in a {{ClassCastException}} in 
> {{org.apache.tapestry5.plastic.ArrayAttributeAnnotations.explicit values for 
> array attributes}}.
> {noformat}
> java.lang.ClassCastException: [I cannot be cast to 
> java.base/[Ljava.lang.Object;
>       at 
> org.apache.tapestry5.internal.plastic.AbstractAnnotationBuilder$2.visitEnd(AbstractAnnotationBuilder.java:134)
>       at 
> org.apache.tapestry5.internal.plastic.asm.tree.AnnotationNode.accept(AnnotationNode.java:284)
>       at 
> org.apache.tapestry5.internal.plastic.asm.tree.AnnotationNode.accept(AnnotationNode.java:251)
>       at 
> org.apache.tapestry5.internal.plastic.PlasticClassPool.createAnnotation(PlasticClassPool.java:307)
>       at 
> org.apache.tapestry5.internal.plastic.PlasticClassPool$4.buildAnnotation(PlasticClassPool.java:286)
>       at 
> org.apache.tapestry5.internal.plastic.PlasticClassPool$4.getAnnotation(PlasticClassPool.java:270)
>       at 
> org.apache.tapestry5.internal.plastic.DelegatingAnnotationAccess.getAnnotation(DelegatingAnnotationAccess.java:42)
>       at 
> org.apache.tapestry5.internal.plastic.PlasticClassImpl.getAnnotation(PlasticClassImpl.java:342)
>       at org.apache.tapestry5.plastic.ArrayAttributeAnnotations.explicit 
> values for array attributes(ArrayAttributeAnnotations.groovy:27)
> {noformat}
> The {{AbstractAnnotationBuilder}} subclass tries to cast an {{int[]}} to an 
> {{Object[]}}.



--
This message was sent by Atlassian JIRA
(v7.6.3#76005)

Reply via email to