gpt4 book ai didi

java - 如何在处理注释时写入 Gradle 日志记录?

转载 作者:搜寻专家 更新时间:2023-10-30 23:02:53 25 4
gpt4 key购买 nike

我有一个 javax.annotation.processing.Processor 用来生成源文件。这一切都很好,但我想在构建期间将一些调试消息写到控制台。我可以使用注释 Messeger 类,但这不允许我使用 Gradle 日志记录。我想要的是通过 Gradle 日志选项控制输出,所以 gradle -d ... 写入调试消息,gradle -i ... 信息消息等。

有什么方法可以从我的 Java bean 处理类中获取 Gradle 记录器?

我读过 Gradle logging doco ,并尝试使用 SLF4J 日志记录,但这只是将我的消息写入标准输出,Gradle 将其拾取为 QUIET:

private static final Logger log = LoggerFactory.getLogger("org.gradle.example");

messeger.printMessage(Diagnostic.Kind.NOTE, "BeanProcessor: processing " + classElem);
log.debug("===debug=== BeanProcessor: processClass {}", classElem);
log.error("===error=== BeanProcessor: processClass {}", classElem);

21:28:22.211 [QUIET] [system.out] 21:28:22.208 [main] DEBUG com.example.beans.BeanProcessor - ===debug=== BeanProcessor: processClass com.example.beans.MyBean
21:28:22.212 [QUIET] [system.out] 21:28:22.212 [main] ERROR com.example.beans.BeanProcessor - ===error=== BeanProcessor: processClass com.example.beans.MyBean
21:28:22.216 [ERROR] [system.err] Note: BeanProcessor: processing com.example.beans.MyBean

此外,我得到的记录器是 ch.qos.logback.classic.Logger - Gradle doco 提到:“Logger ... 扩展了 SLF4J Logger 接口(interface)并添加了一些Gradle 特定的方法”,所以我希望看到一些 Gradle 特定的日志记录类。

Gradle 配置符合 Annotation processor in Gradle outputs source files to build/classes making javadoc fail. How to fix it?

谢谢,

最佳答案

一个可能有用的技巧:

您可以创建一个所有编译任务都依赖的新自定义 gradle 任务,它根据是否将 -i、-d 等传递给 gradle 来设置系统环境变量(也许读取 logging.captureStandardOutput 的值就可以了)技巧)。

然后在注释处理器启动时读取该环境变量,并使用它有条件地写入标准输出。

关于java - 如何在处理注释时写入 Gradle 日志记录?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29470860/

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