gpt4 book ai didi

gradle - 将 gradle 从 4.4 更新到 5.4 导致 joda-time 依赖问题

转载 作者:行者123 更新时间:2023-12-02 10:45:01 24 4
gpt4 key购买 nike

嗨,我已经将一个项目从 4.4 迁移到了 gradle 版本 5.4。从此gradlew build返回错误如下。
....ConvTable.java:6: error: package org.joda.time does not exist
import org.joda.time.DateTime;
...ConvetService.java:5: error: package org.joda.time does not exist
import org.joda.time.DateTime;
...ConvetService.java:34: error: cannot find symbol
ConvTableP getLastCononTableDate(String fromCurrency, String toCurrency, DateTime dateTimeZone) throws IOException;
symbol: class DateTime
location: interface ConvetService
Note: Some input files use or override a deprecated API.
Note: Recompile with -Xlint:deprecation for details
* What went wrong:
Execution failed for task ':cur-api:compileJava'

gradle 文件如下所示。它是一个更大的子项目

apply plugin: "j-library" 
apply plugin: "m-publish"

group = "com.t.cur"

sourceCompatibility = JavaVersion.VERSION_1_7
targetCompatibility = JavaVersion.VERSION_1_7

publishing { publications { mavenJava(MavenPublication) { } }

repositories {
maven { url "${mv_repo_url}" } }
}

dependencies {
implementation "com.t.com:x-core:1.0.0"
implementation "commons-lang:commons-lang:2.6"
}

最佳答案

我的猜测是,作为升级的一部分,您更改了 compile implementation 的配置.与新配置的区别之一是依赖项不会作为编译类路径的一部分暴露给消费项目。这个想法是您放入 implementation 的依赖项是特定于实现的,不应“泄漏”到消费项目上。当使用增量编译时,这会加快构建速度,因为仅当公共(public) API 更改而不是内部实现时,才会重新编译依赖类。还有一个案例可以在项目之间提供更松散的耦合,尽管这有点主观。 implementation依赖关系仍将是 runtimeClasspath 中的一部分并已解决。虽然配置。

所以(假设这是原因的根本问题),依赖 x-core用于提供 Joda 作为编译的传递依赖。但情况已不再如此。

有两种方法可以修复它。如果您使用 Joda 作为 x-core 的公共(public) API 的一部分,您需要使用 api 声明它配置而不是 implementation (如果您还没有,请使用 java-library 插件)。这将使 Joda 成为依赖项目的编译类路径的一部分。

另一方面,如果这个子项目恰好也使用了 Joda,但与 x-core 完全无关。 ,您也应该在此处将其声明为依赖项(使用与以前相同的规则作为 implementationapi)。

关于gradle - 将 gradle 从 4.4 更新到 5.4 导致 joda-time 依赖问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59101639/

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