Gradle - 插件



插件只不过是一组所有有用的任务,例如编译任务、设置域对象、设置源文件等都由插件处理。将插件应用于项目意味着它允许插件扩展项目的 capabilities。

插件可以做以下事情:

  • 扩展基本的 Gradle 模型(例如,添加可以配置的新 DSL 元素)。

  • 根据转换配置项目(例如,添加新任务或配置合理的默认值)。

  • 应用特定配置(例如,添加组织存储库或强制执行标准)。

插件类型

Gradle 中有两种类型的插件,如下所示:

  • 脚本插件 - 脚本插件是一个额外的构建脚本,它提供了一种声明式的方法来操作构建。这通常在构建中使用。

  • 二进制插件 - 二进制插件是实现插件接口并采用编程方式操作构建的类。二进制插件可以与构建脚本一起存在,与项目层次结构一起存在,或者外部存在于插件 JAR 中。

应用插件

Project.apply() API 方法用于应用特定的插件。您可以多次使用相同的插件。插件有两种类型,一种是脚本插件,另一种是二进制插件。

脚本插件

脚本插件可以从本地文件系统上的脚本或远程位置应用。文件系统位置相对于项目目录,而远程脚本位置指定 HTTP URL。

请查看以下代码片段。它用于将other.gradle插件应用于构建脚本。在build.gradle文件中使用此代码。

apply from: 'other.gradle'

二进制插件

每个插件都由插件 ID 标识。一些核心插件使用短名称来应用插件 ID,而一些社区插件使用完全限定名称作为插件 ID。有时,它允许指定插件的类。

请查看以下代码片段。它显示了如何使用其类型应用 java 插件。在build.gradle文件中使用以下代码。

apply plugin: JavaPlugin

请查看以下代码以使用短名称应用核心插件。在build.gradle文件中使用此代码。

plugins {
   id 'java'
}

请查看以下代码以使用短名称应用社区插件。在build.gradle文件中使用此代码。

plugins {
   id "com.jfrog.bintray" version "0.4.1"
}

编写自定义插件

在创建自定义插件时,您需要编写插件的实现。Gradle 实例化插件并使用 Plugin.apply() 方法调用插件实例。

以下示例包含一个问候插件,它向项目添加了一个 hello 任务。请查看以下代码并在build.gradlebuild.gradle 文件中使用此代码。

apply plugin: GreetingPlugin

class GreetingPlugin implements Plugin<Project> {
   void apply(Project project) {
      project.task('hello') << {
         println "Hello from the GreetingPlugin"
      }
   }
}

使用以下代码执行上述脚本。

C:\> gradle -q hello

输出

这会产生以下输出:

Hello from the GreetingPlugin

从构建中获取输入

大多数插件需要构建脚本的配置支持。Gradle 项目具有关联的 ExtensionContainer 对象,该对象有助于跟踪传递给插件的所有设置和属性。

让我们向项目添加一个简单的扩展对象。在这里,我们向项目添加了一个问候扩展对象,它允许您配置问候语。在build.gradle文件中使用此代码。

apply plugin: GreetingPlugin

greeting.message = 'Hi from Gradle'

class GreetingPlugin implements Plugin<Project> {
   void apply(Project project) {
      // Add the 'greeting' extension object
      project.extensions.create("greeting", GreetingPluginExtension)
		
      // Add a task that uses the configuration
      project.task('hello') << {
         println project.greeting.message
      }
   }
}

class GreetingPluginExtension {
   def String message = 'Hello from GreetingPlugin'
}

使用以下代码执行上述脚本:

C:\> gradle -q hello

输出

运行代码时,您将看到以下输出:

Hi from Gradle

在此示例中,GreetingPlugin 是一个简单的旧 Groovy 对象,带有一个名为 message 的字段。扩展对象使用名称 greeting 添加到插件列表中。然后,此对象作为具有与扩展对象相同名称的项目属性可用。

Gradle 为每个扩展对象添加了一个配置闭包,因此您可以将设置组合在一起。请查看以下代码。在build.gradle文件中使用此代码。

apply plugin: GreetingPlugin

greeting {
   message = 'Hi'
   greeter = 'Gradle'
}

class GreetingPlugin implements Plugin<Project> {
   void apply(Project project) {
      project.extensions.create("greeting", GreetingPluginExtension)
		
      project.task('hello') << {
         println "${project.greeting.message} from ${project.greeting.greeter}"
      }
   }
}

class GreetingPluginExtension {
   String message
   String greeter
}

使用以下代码执行上述脚本。

C:\> gradle -q hello

输出

输出如下所示:

Hello from Gradle

标准 Gradle 插件

Gradle 发行版中包含不同的插件。

语言插件

这些插件为可以在 JVM 中编译和执行的各种语言添加支持。

插件 ID 自动应用 描述
java java-base 向项目添加 Java 编译、测试和捆绑功能。它是许多其他 Gradle 插件的基础。
groovy java,groovy-base 添加对构建 Groovy 项目的支持。
scala java,scala-base 添加对构建 Scala 项目的支持。
antlr Java 添加对使用 Antlr 生成解析器的支持。

孵化语言插件

这些插件为各种语言添加支持。

插件 ID 自动应用 描述
汇编程序 - 向项目添加本机汇编语言功能。
c - 向项目添加 C 源代码编译功能。
cpp - 向项目添加 C++ 源代码编译功能。
objective-c - 向项目添加 Objective-C 源代码编译功能。
objective-cpp - 向项目添加 Objective-C++ 源代码编译功能。
windows-resources - 添加对在本地二进制文件中包含 Windows 资源的支持。
广告