我想用 org 类型的对象替换类型为
,以便我可以将其与 Logback 一起正确使用。org.apache.commons.logging.Log
的自动注入(inject)的 log
对象。 slf4j.Logger
因此我需要创建一个 ...Transformer
类(用 Java 编写)——这是我在“grails-user”邮件列表上从 Graeme Rocher 那里得到的。我还知道我必须将这个 ...Transformer
类打包到一个插件中,并使其成为一个 *.jar 存档,我可以将其加载到 lib/
文件夹中的插件。但是我想我在这里做错了什么,因为我有这个类(class),还有一个 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 插件有一些经验并且可以给我一些建议?有目前为止我还没有看到的很好的教程吗?
请告诉我;)
最佳答案
因此,经过一些研究、浏览并最终询问 Grails 邮件列表(查看邮件列表存档:http://grails.1312388.n4.nabble.com/Grails-user-f1312389.html,我找到了解决方案。
我的目标是创建一个 Globals ASTTransformation,注入(inject)一个 org.slf4j.Logger
对象而不是通常的 org.apache.commons.logging。在没有注释的情况下将
对象记录到每个 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
as
Grails scans for classes that are annotated with @AstTransformer in this package. (Graeme Rocher)
并将其与 META-INF/
文件夹中的 MANIFEST.MF
文件一起打包到 JAR 中。正如 Graeme Rocher 所述,不需要包含所有内容的 META-INF/services
目录:
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 compile
和 grails package-plugin
。
如果你想像我一样替换log
实现,你应该排除grails-logging
和grails-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/