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

Christopher Smith commented on GROOVY-10546:
--------------------------------------------

It seems there was a forum where planning for this update happened. I'm on
groovy-dev, but I didn't see the conversation; is there another place where
these discussions are focused?




-- 
Christopher Smith


> Regression: Indy compiler in 4.0 uses wrong key for map lookup
> --------------------------------------------------------------
>
>                 Key: GROOVY-10546
>                 URL: https://issues.apache.org/jira/browse/GROOVY-10546
>             Project: Groovy
>          Issue Type: Bug
>          Components: Compiler
>            Reporter: Christopher Smith
>            Priority: Critical
>         Attachments: closure.javap.txt, image-2022-03-25-10-37-24-960.png, 
> screenshot-1.png
>
>
> I have a Gremlin pipeline that returns a complex object as a nested map.
> {code}
> private static final String LABEL_INV = 'invitation-1234'
> g./...
>   .select(LABEL_INV, LABEL_OTHER)
>   .next()
>   .with {] invitation: process(it[LABEL_INV]) ]}
> {code}
> This was working correctly in Groovy 3. In Groovy 4, however, the map lookup 
> is passed {{null}} instead of the value in the constant. The query builder 
> correctly passes the constant value, and the map contained in {{it}} has the 
> constant as a key as expected. However, {{DefaultGroovyMethods#getAt(Map, 
> Object)}} is passed the {{it}} map as self but {{null}} for the key.
> I am a complete noob at InvokeDynamic, but _perhaps_ this seems to be a 
> sequencing issue where indy binds the value for {{key}} in bootstrap before 
> actually initializing it?



--
This message was sent by Atlassian Jira
(v8.20.1#820001)

Reply via email to