Grails 2.1.1 - 如何使用AstTransformer开发插件?

时间:2012-12-11 21:58:06

标签: java grails grails-plugin abstract-syntax-tree grails-2.0

我想用类型为log的对象替换自动注入的org.apache.commons.logging.Log对象,类型为org.slf4j.Logger,以便我可以正确使用它与Logback。

因此,我需要创建一个...Transformer类(用Java编写) - 这是我从Graeme Rocher那里得到的#34; grails-user"邮件列表。我也知道我必须在插件中打包这个...Transformer类并使其成为* .jar存档,我可以在插件的lib/文件夹中加载它。但我想我在这里做错了,因为我有这个类,还有一个META-INF文件夹,其中包含MANIFEST.MF文件以及另一个文件夹services,其中包含以下内容文件org.codehaus.groovy.transform.ASTTransformation只包含一个字符串:...Transformer类的规范名称。

现在,如果我尝试grails clean一切都很好,但如果我尝试运行grails package-plugin,控制台会出现java.lang.ClassNotFoundException

从Stacktrace剪辑:

| Packaging Grails application...

| Error Fatal error during compilation org.codehaus.groovy.control.MultipleCompilationErrorsException: startup failed:

Could not instantiate global transform class my.package.ast.LoggingTransformation specified at jar:file:/C:/Source/MyGrailsAST/lib/replace-logging-logback-ast.jar!/META-INF/services/org.codehaus.groovy.transform.ASTTransformation  because of exception java.lang.ClassNotFoundException: my.package.ast.LoggingTransformation

1 error

org.codehaus.groovy.control.MultipleCompilationErrorsException: startup failed:

Could not instantiate global transform class my.package.ast.LoggingTransformation specified at jar:file:/C:/Source/MyGrailsAST/lib/replace-logging-logback-ast.jar!/META-INF/services/org.codehaus.groovy.transform.ASTTransformation  because of exception java.lang.ClassNotFoundException: my.package.ast.LoggingTransformation

有没有人对使用AstTransformer处理的Grails插件有一些经验,可以给我一些建议吗?那里有一个很好的教程,到目前为止我还没有看到过吗?

请让我知道;)

1 个答案:

答案 0 :(得分:1)

所以,经过一些研究,浏览并最终询问Grails邮件列表(请参阅邮件列表档案:http://grails.1312388.n4.nabble.com/Grails-user-f1312389.html我找到了解决方案。

我的目标是创建一个 Globals ASTTransformation ,将org.slf4j.Logger对象而不是通常的org.apache.commons.logging.Log对象注入到没有注释的每个Artefact类中。

所以,以下是步骤:

我创建了类似于https://github.com/grails/grails-core/blob/master/grails-logging/src/main/groovy/org/codehaus/groovy/grails/compiler/logging/LoggingTransformer.java的Java类,但是我自己实现了org.slf4j.Logger对象。将Java.class放在以下包中是至关重要的:org.codehaus.groovy.grails.compiler

  

Grails扫描在此包中使用@AstTransformer注释的类。 ( Graeme Rocher

并将其与MANIFEST.MF文件夹中的META-INF/文件一起打包到JAR中。不需要META-INF/services目录及其所有内容,因为 Graeme Rocher 声明:

  

你不需要META-INF /服务的东西,我会删除它,因为它可能使问题复杂化。

所以,我猜这个陈述与我的具体问题更相关,因为我的插件中只有一个@AstTransformer类,但这只是猜测。我没有搜索关于这个主题的进一步信息。 也许其他一些需要这个的开发人员可以做一些研究并在这个帖子中分享他的解决方案......

应将JAR导入插件并放在lib/目录下。在此之后,您应该能够grails cleangrails compilegrails package-plugin

如果要像我一样替换log实现,则应从指定项目的类路径中排除grails-logginggrails-plugin-log4j JAR。这是在BuildConfig.groovy文件中完成的:

inherits("global") {
  excludes "grails-plugin-log4j", "grails-logging"
}

现在安装你的插件grails install-plugin \path\to\plugin.zip,并且everthing应该按预期工作。

希望这会有所帮助......