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

Eric Milles commented on GROOVY-10651:
--------------------------------------

There is at least on place in StaticTypeCheckingSupport that can be changed to 
overcome this difference.  When dealing with "node.eachWithIndex \{ ... \}" the 
param types are inferred, with the first coming from "TN".

https://github.com/apache/groovy/blob/4fc7c5d290725b7120ee3466d81da2ce94e770d3/src/main/java/org/codehaus/groovy/transform/stc/StaticTypeCheckingSupport.java#L1757

{{superClass}} comes as {{Iterable<TN> -> Iterable<T>}} and the expectation is 
to transform it to {{Iterable<TreeNode<?>>}} but the spec comes empty.

> STC: closure parameter type inference for raw type that is iterable over type 
> parameter
> ---------------------------------------------------------------------------------------
>
>                 Key: GROOVY-10651
>                 URL: https://issues.apache.org/jira/browse/GROOVY-10651
>             Project: Groovy
>          Issue Type: Bug
>          Components: Static Type Checker
>    Affects Versions: 2.5.17, 3.0.11, 4.0.3
>            Reporter: Eric Milles
>            Assignee: Eric Milles
>            Priority: Major
>
> Consider the following:
> {code:java}
> abstract class TreeNode<TN extends TreeNode<?>> implements Iterable<TN> {
>   @Override
>   Iterator<TN> iterator() {
>   }
> }
> {code}
> {code:groovy}
> void proc(TreeNode node) {
>   node.eachWithIndex { child, index ->
>     proc(child) // Cannot find matching method #proc(java.lang.Object)
>   }
> }
> {code}



--
This message was sent by Atlassian Jira
(v8.20.7#820007)

Reply via email to