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/13 16:26:00 UTC

[jira] [Resolved] (GROOVY-11011) SC: array instanceof guard and length or subscript

     [ https://issues.apache.org/jira/browse/GROOVY-11011?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Eric Milles resolved GROOVY-11011.
----------------------------------
    Resolution: Fixed

https://github.com/apache/groovy/commit/cdc57551a7cce33ec7031b40753f25c869dcf0cc

> SC: array instanceof guard and length or subscript
> --------------------------------------------------
>
>                 Key: GROOVY-11011
>                 URL: https://issues.apache.org/jira/browse/GROOVY-11011
>             Project: Groovy
>          Issue Type: Bug
>          Components: Static compilation
>            Reporter: Eric Milles
>            Assignee: Eric Milles
>            Priority: Major
>              Labels: ClassFormatError
>
> Consider the following:
> {code:groovy}
> @groovy.transform.CompileStatic
> class FileTreeBuilder {
>     def methodMissing(String name, Object args) {
>         if (args instanceof Object[] && args.length == 1) {
>             def arg = args[0]
>             if (arg instanceof Closure) {
>                 dir(name, arg)
>             } else if (arg instanceof CharSequence) {
>                 file(name, arg.toString())
>             } else if (arg instanceof byte[]) {
>                 file(name, arg)
>             } else if (arg instanceof File) {
>                 file(name, arg)
>             }
>         }
>     }
> }
> {code}
> STC gives no errors for this, but there are 2 class format issues.  "args.length" is reporting bad type on operand stack and "if (arg instanceof CharSequence)" and subsequent guards are reporting improper class name "Ljava/lang/Object;" on the operand stack.



--
This message was sent by Atlassian Jira
(v8.20.10#820010)