gpt4 book ai didi

java - Maven:代码生成前的部分编译

转载 作者:搜寻专家 更新时间:2023-10-31 19:57:55 25 4
gpt4 key购买 nike

tl;dr-edition: 我有一个编译,我知道它会失败,但我想要在我的 target/classes 中仍可编译的类子集编译后的文件夹。我配置了<failOnError>false</failOnError> , 但没有生成类,甚至没有生成独立于除 Object 之外的任何其他类的虚拟类.是否有一些配置可以实现此目的?


我有一个基于 maven 的项目,其工作流程基本上包括以下(相关)目标:

  • ...
  • init-compile

    代码生成器(下方)使用基于反射的配置,因此,在第一遍中,我想尝试尽可能多地编译项目,以免在那里抛出 ClassNotFoundExceptions。本次编译配置<failOnError>false</failOnError>以便构建继续。

    不幸的是(你可以称之为设计缺陷),配置用于代码生成(指定 OWL 文件和命名空间以打包映射)和运行时,因此它还包含代码不需要的其他元素生成器,但仍被读取,因此需要在类路径上才能成功。

  • generate-model

    在此步骤中,一些模型类是从 OWL-Ontology 生成的,创建的代码使项目的其余部分完全可编译。

  • default-compile

    现在,显然应该编译其余的类

  • save-model

    现在,本体中的实例被读取并序列化为运行时的文件

  • ...

旁注:生成和保存模型都使用 maven-exec-plugin ,但我真诚地认为这根本不重要。

问题:

当我使用 mvn -e -U clean package source:jar javadoc:jar install:install 运行构建时, 它在 generate-model 期间失败目标与我试图避免的错误。 target/classes是空的,所以编译器似乎没有吐出它可以/应该能够处理的类的子集。有办法实现吗?

我有两个我都不喜欢的解决方法:

  • 在将其解析为 Java 对象之前编辑配置文件“AST”,以便仅解析与代码生成器相关的部分(需要调整我有权访问但应被我的项目视为不可变的代码);
  • 并配置init-compile目标是仅包含所需的类(太不灵活,因为 POM 应该/可能是 future 使用相同模型的应用程序的模板)。

如果您能想出另一种方法来解决我的问题(您可以从我的描述中看到),我也很乐意听取他们的意见!

最佳答案

首先,让我重述一下您的问题,以确保我正确理解了它。

  • 你有一组类,其函数在编译后的形式是配置代码生成器和运行时。 (的一个子集这些与代码生成器有关,但生成会失败除非存在完整的配置。所以我们可以把它当作尽管整个配置都是必要的。)

  • 然后您将拥有一组将作为源生成的类代码。这些有一个生成时间,也许是一个编译时间,和一个对配置类的运行时依赖性。

  • 最后,您有一些其他具有编译时依赖性的代码在生成的类上,以及对两者的运行时依赖生成的类和配置类。

  • 但是,您的配置类对生成的类或其他代码没有任何编译时依赖性。您没有明确说明这一点,但我假设是这样,否则您会遇到循环依赖问题。

这是我的建议:将项目划分为多模块(“ react 器”)项目。您当前的项目将是 reactor 项目的一个模块。创建一个名为“config”或类似名称的新模块,并将您的配置类移入其中。让主模块依赖于它。

如果您不喜欢多模块项目,您可以通过声明编译插件的额外执行来实现相同的目的,绑定(bind)到生成源阶段。 (你没有说,但我假设你在这个阶段进行代码生成。如果你在 POM 中的代码生成器插件之前声明编译插件,Maven 将以相同的顺序执行它们。)你会使用编译插件的“include”过滤器只编译配置类。为此,您需要将配置类与所有其他类放在一个单独的包中,无论如何这是一个很好的做法。

关于java - Maven:代码生成前的部分编译,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7665815/

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