gpt4 book ai didi

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

转载 作者:塔克拉玛干 更新时间:2023-11-02 20:10:53 26 4
gpt4 key购买 nike

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

因此我需要创建一个 ...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 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 一切都应该按预期工作。

希望这有助于...

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

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com