您可以在支持Gradle的IDE中打开此示例。

用于开发 Gradle 插件的复合构建

此示例演示了用于开发 Gradle 插件的复合构建,与消费者构建结合使用。

该插件可能位于同一仓库中(仅由该构建使用),也可能位于不同的仓库中(由许多其他构建使用)。

这消除了对特殊 buildSrc 项目的需求,并使原型插件变得更加容易。

构建脚本依赖项被替换

在复合构建中,在 plugins { } 块或 buildscript classpath 配置中声明的依赖项与其它依赖项的替换方式相同。在此示例中,构建声明了插件“org.sample.greeting”,并且此依赖项由 greeting-plugin 包含的构建替换。

无需将 greeting-plugin 项目发布到仓库,即可使用本地开发的“org.sample.greeting”插件构建项目。

> gradle --include-build ../greeting-plugin greeting
[composite-build] Configuring build: /home/user/gradle/sample/compositeBuilds/plugin-dev/greeting-plugin
:greeting-plugin:compileJava
:greeting-plugin:pluginDescriptors
:greeting-plugin:processResources
:greeting-plugin:classes
:greeting-plugin:jar
:my-greeting-app:greeting
Hi Bob!!!

插件更改可以测试

此示例可用于演示 Gradle 插件的开发生命周期。编辑文件 greeting-plugin/src/main/java/org/sample/GreetingTask.java 以更改问候语,并重新执行消费者构建

> gradle --include-build ../greeting-plugin greeting
[composite-build] Configuring build: /home/user/gradle/sample/compositeBuilds/plugin-dev/greeting-plugin
:greeting-plugin:compileJava
:greeting-plugin:pluginDescriptors
:greeting-plugin:processResources
:greeting-plugin:classes
:greeting-plugin:jar
:my-greeting-app:greeting
G'day Bob!!!