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

Daniel Sun commented on GROOVY-9611:
------------------------------------

We wish you could provide a simple runnable script to reproduce the issue.

> Reflexive access to class attributes broken in Groovy 3
> -------------------------------------------------------
>
>                 Key: GROOVY-9611
>                 URL: https://issues.apache.org/jira/browse/GROOVY-9611
>             Project: Groovy
>          Issue Type: Bug
>    Affects Versions: 3.0.4
>         Environment: macOs Catalina, openjdk 13.0.2 2020-01-14, Groovy 3.0.4
>            Reporter: Gildas Morvan
>            Priority: Major
>
> Since Groovy 3, the reflexive access to Groovy class attributes from Java is 
> broken.
>  
> The [following 
> code|[https://github.com/gildasmorvan/similar2logo/blob/master/similar2logo-examples/src/main/groovy/fr/univ_artois/lgi2a/similar2logo/examples/boids/GroovyBoidsSimulation.groovy]]
>  which works fine with groovy 2.5.* raises this exception:
>  
> {{}}
>  
> {code:java}
> juin 30, 2020 9:01:33 AM 
> fr.univ_artois.lgi2a.similar.extendedkernel.libs.web.view.SimilarHtmlGenerator
>  renderParameter
> WARNING: The parameter public double 
> fr.univ_artois.lgi2a.similar2logo.examples.boids.GroovyBoidsSimulation$1.minInitialSpeed
>  cannot be found
> java.lang.IllegalAccessException: class 
> fr.univ_artois.lgi2a.similar.extendedkernel.libs.web.view.SimilarHtmlGenerator
>  cannot access a member of class 
> fr.univ_artois.lgi2a.similar2logo.examples.boids.GroovyBoidsSimulation$1 with 
> modifiers "public"
>  at 
> java.base/jdk.internal.reflect.Reflection.newIllegalAccessException(Reflection.java:376)
>  at 
> java.base/java.lang.reflect.AccessibleObject.checkAccess(AccessibleObject.java:642)
>  at java.base/java.lang.reflect.Field.checkAccess(Field.java:1075)
>  at java.base/java.lang.reflect.Field.get(Field.java:416)
>  at 
> fr.univ_artois.lgi2a.similar.extendedkernel.libs.web.view.SimilarHtmlGenerator.renderParameter(SimilarHtmlGenerator.java:290)
>  at 
> fr.univ_artois.lgi2a.similar.extendedkernel.libs.web.view.SimilarHtmlGenerator.lambda$renderParameters$4(SimilarHtmlGenerator.java:243)
>  at 
> java.base/java.util.stream.ReferencePipeline$3$1.accept(ReferencePipeline.java:195)
>  at 
> java.base/java.util.Spliterators$ArraySpliterator.forEachRemaining(Spliterators.java:948)
>  at 
> java.base/java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:484)
>  at 
> java.base/java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:474)
>  at 
> java.base/java.util.stream.ForEachOps$ForEachOp.evaluateSequential(ForEachOps.java:150)
>  at 
> java.base/java.util.stream.ForEachOps$ForEachOp$OfRef.evaluateSequential(ForEachOps.java:173)
>  at 
> java.base/java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234)
>  at 
> java.base/java.util.stream.ReferencePipeline.forEach(ReferencePipeline.java:497)
>  at j2html.tags.ContainerTag.with(ContainerTag.java:100)
>  at j2html.TagCreator.each(TagCreator.java:108)
>  at 
> fr.univ_artois.lgi2a.similar.extendedkernel.libs.web.view.SimilarHtmlGenerator.renderParameters(SimilarHtmlGenerator.java:243)
>  at 
> fr.univ_artois.lgi2a.similar.extendedkernel.libs.web.view.SimilarHtmlGenerator.renderView(SimilarHtmlGenerator.java:166)
>  at 
> fr.univ_artois.lgi2a.similar.extendedkernel.libs.web.view.SimilarHttpServer.lambda$initServer$0(SimilarHttpServer.java:112)
>  at spark.RouteImpl$1.handle(RouteImpl.java:72)
>  at spark.http.matching.Routes.execute(Routes.java:61)
>  at spark.http.matching.MatcherFilter.doFilter(MatcherFilter.java:134)
>  at spark.embeddedserver.jetty.JettyHandler.doHandle(JettyHandler.java:50)
>  at 
> org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:1671)
>  at 
> org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:144)
>  at org.eclipse.jetty.server.handler.HandlerList.handle(HandlerList.java:61)
>  at 
> org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:132)
>  at org.eclipse.jetty.server.Server.handle(Server.java:505)
>  at org.eclipse.jetty.server.HttpChannel.handle(HttpChannel.java:370)
>  at 
> org.eclipse.jetty.server.HttpConnection.onFillable(HttpConnection.java:267)
>  at 
> org.eclipse.jetty.io.AbstractConnection$ReadCallback.succeeded(AbstractConnection.java:305)
>  at org.eclipse.jetty.io.FillInterest.fillable(FillInterest.java:103)
>  at org.eclipse.jetty.io.ChannelEndPoint$2.run(ChannelEndPoint.java:117)
>  at 
> org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:698)
>  at 
> org.eclipse.jetty.util.thread.QueuedThreadPool$Runner.run(QueuedThreadPool.java:804)
>  at java.base/java.lang.Thread.run(Thread.java:830)
> {code}
>  
>  



--
This message was sent by Atlassian Jira
(v8.3.4#803005)

Reply via email to