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

Eric Milles updated GROOVY-5736:
--------------------------------
    Fix Version/s: 2.5.16

> Log4j, Commons, Slf4j ast transforms are broken in Groovy-Eclipse
> -----------------------------------------------------------------
>
>                 Key: GROOVY-5736
>                 URL: https://issues.apache.org/jira/browse/GROOVY-5736
>             Project: Groovy
>          Issue Type: Bug
>          Components: Compiler
>    Affects Versions: 2.0.4
>            Reporter: Andrew Eisenberg
>            Assignee: Eric Milles
>            Priority: Major
>             Fix For: 2.5.16, 3.0.10, 4.0.0-rc-2
>
>
> Since Groovy-Eclipse moved to using the 2.0.4 compiler, the @Log4j and other 
> log ast transformations are crashing the compiler.  This is because in 
> GROOVY-5574, there was a move to call {{Class.forName()}} in the Log AST 
> transformation.  In Groovy-Eclipse, you cannot use Class.forName since the 
> classpath of the project is not on the classpath of the compiler.
> The workaround is to change 
> {{org.codehaus.groovy.transform.LogASTTransformation.AbstractLoggingStrategy.classNode(String)}}.
>   Instead of throwing a {{GroovyRuntimeException}}, you could simply call and 
> return {{ClassHelper.make(name);}}. 
> I know this adds code that was removed to fix GROOVY-5574, but for 
> Groovy-Eclipse this is safe since {{ClassHelper.make(name);}} will correctly 
> use the project's class path to generate the ClassNode and classloader issues 
> will not happen.
> If you think that this solution is not a good one because of problems that 
> could occur outside of eclipse, then we could talk about a different solution.



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

Reply via email to