本文介绍了Gradle 4.10+的一个有趣的功能,称为源依赖项:
https://blog.gradle.org/introducing-source-dependencies
它允许使用Git(例如GitHub)源代码存储库来建立依赖关系。但是似乎它仅支持Gradle项目作为源依赖项。是否可以使用Maven项目?如果可以,请显示示例。
当我尝试在Maven项目中使用此功能时,无论如何,Gradle都会尝试在其中找到build.gradle
文件(使用--info
选项运行Gradle时会看到该文件),并失败,并显示以下错误消息:
Git repository at https://github.com/something/something.git did not contain a project publishing the specified dependency.
答案 0 :(得分:0)
...是:“否”。
在后台,源代码依赖关系是复合构建。这些需要是Gradle项目,因为外部项目已与主项目合并。
...是:“是,但很难”。
您链接到的同一博客文章中实际上提到了该问题(强调我的意思):
源依赖性使这些用例更易于实现。 Gradle会自动检查出正确的依赖版本,并确保在需要时生成二进制文件。运行构建的所有地方都会这样做。 检出的项目甚至不需要现有的Gradle构建。 This example显示了通过插件注入Gradle构建,Gradle构建消耗了两个没有构建系统的源依赖项。注入的配置可以执行常规Gradle插件可以执行的任何操作,例如包装现有的CMake或Maven构建。
因为听起来不是在源依赖项中的Maven和Gradle项目之间建立桥梁不是世界上最大的事情,所以我给了一个机会。除了传递依赖之外,我也可以使用。基本上,您将需要做上面链接的示例中显示的操作,但是您无需构建本机库,而是调用Maven(例如,使用Gradle的Maven插件)。
但是,我最终得到的脚本非常复杂,我建议您自己构建Maven项目,将其部署到本地Maven存储库,然后将该存储库添加到Gradle项目中。
好的,这就是实际的操作方法。该功能的文献资料很少,似乎主要针对本机项目(例如C ++或Swift)。
使用已应用Java插件的普通Gradle项目。我在一个空文件夹中执行了“ gradle init”。假设在这个项目中,您依赖于一个名为``的库,以后您希望将其包含为源依赖项:
// [root]/build.gradle
dependencies {
implementation 'org.example:my-maven-project:1.1'
}
请注意,此处必须定义的版本号必须与存储库中的Git标签匹配。这是将签出的代码修订版。
然后在设置文件中,为其定义源依赖项映射:
// [root]/settings.gradle
rootProject.name = 'my-project'
includeBuild('plugins') // [1]
sourceControl {
gitRepository("https://github.com/jitpack/maven-simple") { // [2]
producesModule("org.example:my-maven-project") // [3]
plugins {
id "external-maven-build" // [4]
}
}
}
plugins
的Gradle项目,稍后将对其进行解释。external-maven-build
项目中定义的名为plugins
的自定义设置插件,稍后将对其进行解释。在根项目中,我们定义了一个新的Gradle项目。同样,您可以使用gradle init
将其初始化为Groovy(或任何您喜欢的项目)项目。删除所有生成的源和测试。
// [root]/plugins/settings.gradle
// Empty, but used to mark this as a stand-alone project (and not part of a multi-build)
// [root]/plugins/build.gradle
plugins {
id 'groovy'
id 'java-gradle-plugin' // [1]
}
repositories {
gradlePluginPortal() // [2]
}
dependencies {
implementation "gradle.plugin.com.github.dkorotych.gradle.maven.exec:gradle-maven-exec-plugin:2.2.1" // [3]
}
gradlePlugin {
plugins {
"external-maven-build" { // [4]
id = "external-maven-build"
implementationClass = "org.example.ExternalMavenBuilder"
}
}
}
现在出现了有趣的东西。我选择在Groovy中进行此操作,但是可以使用任何受支持的JVM语言进行此操作。
插件结构与其他Gradle插件一样。要注意的一件事是它是一个设置插件,而您通常使用Project插件。之所以需要这样做,是因为我们基本上是在运行时定义Gradle项目的,而这需要在初始化阶段中完成。
// [root]/plugins/src/main/groovy/org/example/ExternalMavenBuilder.groovy
package org.example
import com.github.dkorotych.gradle.maven.exec.MavenExec
import org.gradle.api.Plugin
import org.gradle.api.artifacts.ConfigurablePublishArtifact
import org.gradle.api.initialization.Settings
class ExternalMavenBuilder implements Plugin<Settings> {
void apply(Settings settings) {
settings.with {
rootProject.name = 'my-maven-project' // [1]
gradle.rootProject {
group = "org.example" //[2]
pluginManager.apply("base") // [3]
pluginManager.apply("com.github.dkorotych.gradle-maven-exec") // [4]
def mavenBuild = tasks.register("mavenBuild", MavenExec) {
goals('clean', 'package') // [5]
}
artifacts.add("default", file("$projectDir/target/maven-simple-0.2-SNAPSHOT.jar")) { ConfigurablePublishArtifact a ->
a.builtBy(mavenBuild) // [6]
}
}
}
}
}
请注意,它不会对传递依赖项进行建模,并且由于缺少输入和输出,它永远不会是最新的。
这是我花了几个小时才玩完的。我认为可以将其概括为发布到Gradle门户的通用插件。但是我认为我已经准备太多了。如果有人想从这里继续,那么我很幸运:)