[
https://issues.apache.org/jira/browse/GROOVY-6996?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=15855974#comment-15855974
]
Andres Almiray commented on GROOVY-6996:
----------------------------------------
It appears the problem is related to scoping of method arguments. The following
script works as expected
{code}
class Outer {
interface Inner {
}
static with_default_args(args = 'default args') {
def my_args = args
def inner = new Inner() {
def arguments = my_args
}
println inner.arguments
}
static main(args) {
with_default_args()
with_default_args('jfokus')
}
}
{code}
prints the following
{code}
default args
jfokus
{code}
Notice the usage of a local variable to grab a reference to the method args. If
the variable is removed and the method arguments are accessed directly then we
get an MPE
{code}
groovy> class Outer {
groovy> interface Inner {
groovy> }
groovy>
groovy> static with_default_args(args = 'default args') {
groovy> def inner = new Inner() {
groovy> def arguments = args
groovy> }
groovy> println inner.arguments
groovy> }
groovy> static main(args) {
groovy> with_default_args()
groovy> with_default_args('jfokus')
groovy> }
groovy> }
Exception thrown
groovy.lang.MissingPropertyException: No such property: args for class: Outer
at Outer$1.propertyMissing(ConsoleScript26)
at Outer$1.<init>(ConsoleScript26)
at Outer.with_default_args(ConsoleScript26:6)
at Outer.with_default_args(ConsoleScript26)
at Outer.main(ConsoleScript26:13)
{code}
Tested with Groovy 2.4.8
> Anonymous class field initialized with an enclosing argument results in
> MissingPropertyException
> ------------------------------------------------------------------------------------------------
>
> Key: GROOVY-6996
> URL: https://issues.apache.org/jira/browse/GROOVY-6996
> Project: Groovy
> Issue Type: Bug
> Affects Versions: 2.3.3, 2.3.4, 2.3.5, 2.3.6, 2.4.1
> Environment: Oracle JDK 1.7.0_60 @ Mavericks
> Reporter: Bastian Helfert
> Priority: Minor
> Attachments: MissingPropertyExceptionBug.groovy
>
>
> Since Groovy 2.3.3 initializing a field of an anonymous class with an
> enclosing argument results in a MissingPropertyException:
> Code:
> {code}
> class MissingPropertyExceptionBug {
> interface SomeType {
> }
> static main(args) {
> new SomeType() {
> def arguments = args
> }
> }
> }
> {code}
> ...results in:
> {code}
> Exception in thread "main" groovy.lang.MissingPropertyException: No such
> property: args for class: MissingPropertyExceptionBug
> at
> groovy.lang.MetaClassImpl.invokeStaticMissingProperty(MetaClassImpl.java:996)
> at groovy.lang.MetaClassImpl.getProperty(MetaClassImpl.java:1851)
> at groovy.lang.MetaClassImpl.getProperty(MetaClassImpl.java:1827)
> at groovy.lang.MetaClassImpl.getProperty(MetaClassImpl.java:3690)
> at
> org.codehaus.groovy.runtime.InvokerHelper.getProperty(InvokerHelper.java:171)
> at
> org.codehaus.groovy.runtime.ScriptBytecodeAdapter.getProperty(ScriptBytecodeAdapter.java:452)
> at
> MissingPropertyExceptionBug$1.propertyMissing(MissingPropertyExceptionBug.groovy)
> at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
> at
> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
> at
> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
> at java.lang.reflect.Method.invoke(Method.java:606)
> at
> org.codehaus.groovy.reflection.CachedMethod.invoke(CachedMethod.java:90)
> at
> groovy.lang.MetaClassImpl.invokeMissingProperty(MetaClassImpl.java:874)
> at groovy.lang.MetaClassImpl$12.getProperty(MetaClassImpl.java:2018)
> at
> org.codehaus.groovy.runtime.callsite.GetEffectivePogoPropertySite.getProperty(GetEffectivePogoPropertySite.java:82)
> at
> org.codehaus.groovy.runtime.callsite.AbstractCallSite.callGroovyObjectGetProperty(AbstractCallSite.java:231)
> at
> MissingPropertyExceptionBug$1.<init>(MissingPropertyExceptionBug.groovy)
> at
> MissingPropertyExceptionBug.main(MissingPropertyExceptionBug.groovy:7)
> at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
> at
> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
> at
> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
> at java.lang.reflect.Method.invoke(Method.java:606)
> at com.intellij.rt.execution.application.AppMain.main(AppMain.java:134)
> {code}
> Workaround:
> Use a top-level class instead.
--
This message was sent by Atlassian JIRA
(v6.3.15#6346)