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 2023/04/30 15:59:00 UTC
[jira] [Resolved] (GROOVY-11012) Wrong type is inferred when calling method defined in the parent class
[ https://issues.apache.org/jira/browse/GROOVY-11012?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
Eric Milles resolved GROOVY-11012.
----------------------------------
Resolution: Fixed
https://github.com/apache/groovy/commit/b94ce492a5d7ff2b79182d585c588e77519a34a8
> Wrong type is inferred when calling method defined in the parent class
> ----------------------------------------------------------------------
>
> Key: GROOVY-11012
> URL: https://issues.apache.org/jira/browse/GROOVY-11012
> Project: Groovy
> Issue Type: Bug
> Components: Static Type Checker
> Reporter: Thodoris Sotiropoulos
> Assignee: Eric Milles
> Priority: Minor
> Labels: traits
>
> I have the following program
> {code}
> interface Bar<V> {
> default V get(Object x, Object y) { return null; }
> }
> class Foo<V> implements Bar<V> {
> static <V> Foo<V> create() { return null; }
> }
> class Main {
> static final void test() {
> Number x = Foo.<Number>create().get(null, null);
> }
> }
> {code}
> h3. Actual behavior
> {code}
> org.codehaus.groovy.control.MultipleCompilationErrorsException: startup failed:
> test.groovy: 11: [Static type checking] - Cannot assign value of type java.lang.Object to variable of type java.lang.Number
> @ line 11, column 16.
> Number x = Foo.<Number>create().get(null, null);
> ^
> 1 error
> {code}
> h3. Expected behavior
> Compile successfully
> h3. Notes
> Tested against master (commit: 5bcd83e0fde722971f97d479f1a4d6da6cd4aa5f)
> Test cased adapt from the following program that uses the Guava lib
> {code}
> import com.google.common.collect.HashBasedTable;
> class Main {
> static final void test() {
> Number x = HashBasedTable.<Number, Number, Number>create().get(null, null);
> }
> }
> {code}
--
This message was sent by Atlassian Jira
(v8.20.10#820010)