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 2020/04/22 14:10:00 UTC

[jira] [Comment Edited] (GROOVY-9517) CompileStatic typeCasting runtime error from Class Array to Class List

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

Eric Milles edited comment on GROOVY-9517 at 4/22/20, 2:09 PM:
---------------------------------------------------------------

I will have a look to see if this is still happening in Groovy 2.5+.  I think this has to do with the {{T[]}} return type of the array sort extension methods.

You can also assign the result of the sort call to a temp. And I don't think you need the "as File[]". You can use {{<=>}} operator in place of {{compareTo}}. And if you are comparing one property in natural order, you can use a variant of sort that just returns that property from the closure.
{code:groovy}
File file = new File('.')
listSortedFiles(file)

@groovy.transform.CompileStatic
void listSortedFiles(File directory) {
  File[] files = directory.listFiles()
  def sorted = files?.sort { it.name }
  for (file in sorted) {
    println file.name
  }
}
{code}


was (Author: emilles):
I will have a look to see if this is still happening in Groovy 2.5+.

You can also assign the result of the sort call to a temp.  And I don't think you need the "as File[]".  You can use {{<=>}} operator in place of {{compareTo}}.  And if you are comparing one property in natural order, you can use a variant of sort that just returns that property from the closure.

{code:groovy}
File file = new File('.')
listSortedFiles(file)

@groovy.transform.CompileStatic
void listSortedFiles(File directory) {
  File[] files = directory.listFiles()
  def sorted = files?.sort { it.name }
  for (file in sorted) {
    println file.name
  }
}
{code}

> CompileStatic typeCasting runtime error from Class Array to Class List
> ----------------------------------------------------------------------
>
>                 Key: GROOVY-9517
>                 URL: https://issues.apache.org/jira/browse/GROOVY-9517
>             Project: Groovy
>          Issue Type: Bug
>          Components: Static compilation
>    Affects Versions: 2.4.0, 2.4.19, 3.0.2, 3.0.3
>         Environment: Java: openjdk version "1.8.0_242"
> OS: OS X Catalina 10.15.3
> Groovy: 2.4.19
>            Reporter: David Estes
>            Assignee: Eric Milles
>            Priority: Major
>              Labels: CompileStatic
>
> After upgrading asset-pipeline-core from groovy 2.0.7 to 2.4.15 then 2.4.19 . A bug was identified with @CompileStatic not properly handling runtime type casting when sorting an Array instead of a List
>  
> Example
>  
> Create File TestFile.groovy
> {code:java}
> import groovy.transform.CompileStaticpublic class TestFile {	
>     static void main(String[] args) {
>         File file = new File('.')
>         TestFile testFile = new TestFile()
>         testFile.listSortedFiles(file)
>     }
>     @CompileStatic
>     void listSortedFiles(File directory) {
>         File[] files = directory.listFiles()
>         files = files?.sort { File a, File b -> a.name.compareTo b.name } as File[]
>         for(File file in files) {
>         }
>     }
> 	
> 		
> }
> {code}
> Then simply run:
> {code:java}
> groovy TestFile.groovy
> {code}
>  
> Exception:
>  
> {code:java}
> Caught: java.lang.ClassCastException: [Ljava.lang.Object; cannot be cast to [Ljava.io.File;
> java.lang.ClassCastException: [Ljava.lang.Object; cannot be cast to [Ljava.io.File;
> 	at TestFile.listSortedFiles(TestFile.groovy:15)
> 	at TestFile$listSortedFiles.call(Unknown Source)
> 	at TestFile.main(TestFile.groovy:8)
> {code}
>  



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