您可以在支持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!!!