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

原文 标签 java grails grails-plugin abstract-syntax-tree grails-2.0

我想更换自动注入(inject)的log对象,类型为 org.apache.commons.logging.Log带有 org.slf4j.Logger 类型的对象,这样我就可以在 Logback 中正确使用它。

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

现在,如果我尝试做 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 插件有一些经验吗?可以给我一些建议吗?有没有我至今没见过的好教程?

请告诉我 ;)

最佳答案

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

我的目标是创建一个 全局 ASTTransformation , 注入(inject) 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 scans for classes that are annotated with @AstTransformer in this package. (Graeme Rocher)



并将其与 MANIFEST.MF 一起打包到 JAR 中META-INF/ 中的文件文件夹。一个 META-INF/services正如 Graeme Rocher 所说,不需要包含所有内容的目录:

You do not need the META-INF/services stuff and I would remove it as it is probably complicating matters.



所以,我想这句话与我的具体问题更相关,因为我只有一个 @AstTransformer我的插件中的类,但这只是一个猜测。而且我还没有搜索有关此主题的更多信息。也许这里需要这个的其他一些开发人员可以做一些研究并在这个线程中分享他的解决方案......

应该将 JAR 导入插件并放在 lib/ 下目录。在这之后你应该可以做grails clean , grails 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一切都应该按预期工作。

希望这可以帮助...

关于java - Grails 2.1.1 - 如何使用 AstTransformer 开发插件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13829189/

相关文章:

Grails Spring Security 插件 - 登录表单重定向到 ajaxAuth

java - 当创建 JDialog 并将模式设置为 true 时,我的线程似乎永远锁定?

java - 在Windows XP上自动启动Selenium RC

java - 使用内部框架时,主面板重绘无法正常工作

jquery - 用grails和jquery上传文件

grails - 如何使用 grails jasper 插件使用添加到 JasperReports 3.7.2 的表格组件?

java - 实用方法 - 传递文件还是字符串?

grails - Grails选择将不会显示嵌套类中的字符串

jquery - Jediatable with grails - 如何在更改 Controller 中的字段数据时获取其他参数?

grails - grails jasper插件和jquery插件与 Assets 管道冲突