You are viewing a plain text version of this content. The canonical link for it is here.
Posted to notifications@groovy.apache.org by "Eric Milles (Jira)" <ji...@apache.org> on 2021/12/12 16:35:00 UTC

[jira] [Commented] (GROOVY-5502) If/else branch does not always infer the variable type

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

Eric Milles commented on GROOVY-5502:
-------------------------------------

This kind of tracking was implemented in Groovy Development Tools for Eclipse back in 2020.  When a branch (if-else in this case) is reached, the assignments in both are collected and if a variable is assigned in both branches, the previous type can be discarded.  See {{updateVariableSoft}} and {{bubbleUpdates}}.

https://github.com/groovy/groovy-eclipse/blob/bc05754a9f4f2ae8986fb1ec9dfd78d8ae3bca19/base/org.eclipse.jdt.groovy.core/src/org/eclipse/jdt/groovy/search/TypeInferencingVisitorWithRequestor.java#L1314

https://github.com/groovy/groovy-eclipse/commit/48e9a464d56eebe1b42fe7ae07c2468413e44847

> If/else branch does not always infer the variable type
> ------------------------------------------------------
>
>                 Key: GROOVY-5502
>                 URL: https://issues.apache.org/jira/browse/GROOVY-5502
>             Project: Groovy
>          Issue Type: Improvement
>          Components: Static Type Checker
>            Reporter: Ariel Morelli Andres
>            Priority: Minor
>
> Suppose we have the following code:
> {code}
> class A {
>   void m() {  
>   }
> }
> class B extends A {
> }
> class C extends A {
> }
> @groovy.transform.TypeChecked
> class Test {
>    void m() {
>       def var = new Object()   //If instead I put just "def var" it works as spected
>       if (true) {
>         var = new B()
>       }
>       else {
>         var = new C()
>       }
>       var.m()                  //fails here
>    }
> }
> {code}
> In this case, after the if/else structure we can infer that var is instanceOf A.
> But, the initialization seems to confuse the type inference.
> [Static type checking] - Cannot find matching method java.lang.Object#mA()
>  at line: 23, column: 7
> If instead of {code}def var = new Object(){code} we put just {code}def var{code}, then the inference works fine.



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