Create your gradle plugin

本文详细介绍了一种自定义Gradle插件的方法,通过实际案例——Android应用版本号自增插件,展示了从创建插件到集成使用的全过程。涵盖了插件的结构、核心代码实现、配置及测试等关键步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Gradle

reuse your gradle plugin

文章转自 http://stanho.top/2017/03/19/gradle_plugin/

什么是 gradle plugin

gradle 插件指我们的build.gradle文件中的: apply plugin: ‘your_plugin’,自定义的plugin能够完成我们想要的功能,在不同的project中进行快捷的引用。

编写一个gradle plugin。

作为示例,这里编写一个Android中 常用的versionCode自增插件,目的在于我们打包的时候版本自增。

新建插件包目录结构及文件

目录
Android工程主目录下新建插件包,即 Project的 build.gradle同级目录下新建 autoaddversioncode包.
settings.gradle中增加依赖Module。

include ':app','autoaddversioncode'

上面的方法和 new Module是一个性质,区别在于上面的方法可以创建空目录,不会生成多余的结构,如果new Module需要删除多余的目录结构。

最终结构图如下:

autoaddversioncode
            |
            +------ src
            |         |
            |         +-----main
            |                 |
            |                 +------ groovy
            |                 |          |
            |                 |          +---- com.stan.addversioncode
            |                 |                                 |
            |                 |                                 +------ AddGradle.groovy
            |                 |                                 |
            |                 |                                 +------ AddManifest.groovy
            |                 |                                 |
            |                 |                                 +------ AddVersionCode.groovy
            |                 |                                 |
            |                 |                                 +------ VersionFile.groovy
            |                 |
            |                 +--------- resources
            |                                |
            |                                +------ META-INF.gradle-plugins
            |                                                 |
            |                                                 +----- addversioncode.properties
            +-------- build.gradle
groovy and properties

com.stan.addversioncode内是插件的实现代码,properties是插件入口定义。

VersionFile类,用于在app;build.gradle目录下定义extention 类,获取外部参数

package com.stan.addversioncode;

public class VersionFile {
    def desFile = "gradle";
}

AddGradle类,实现build.gradle内的versionCode自增逻辑

package com.stan.addversioncode

import org.gradle.api.DefaultTask
import org.gradle.api.tasks.TaskAction
import java.util.regex.Pattern


public class AddGradle extends DefaultTask{
    @TaskAction
    addGradleFile () {
        try {
            def buildFile = project.file("build.gradle")
            def buildText = buildFile.getText()
            println("project buildText : ${buildText}")
            def matcher = Pattern.compile("versionCode (\\d+)").matcher(buildText)
            matcher.find()
            def versionCode = Integer.parseInt(matcher.group(1))
            def newBuildText = matcher.replaceAll("versionCode " + ++versionCode)
            buildFile.write(newBuildText)
        }catch (Exception e){
            e.printStackTrace()
            println("<----- exception ----->")
        }
    }
}

AddVersionCode 插件入口

package com.stan.addversioncode

import org.gradle.api.Plugin
import org.gradle.api.Project

public class AddVersionCode implements Plugin<Project> {
    @Override
    void apply(Project project) {
        project.extensions.create("versionFile",VersionFile)
        project.task("startAddGradle",type:AddGradle)
        //使用 hello task 测试。
        project.task("hello",dependsOn: 'startAddGradle')<<{ task ->
            if (task.name == "hello") {
                if (project.versionFile.desFile == "gradle") {
                    println("this is gradle")
                }else if (project.versionFile.desFile == "manifest"){
                    println("this is manifest")
                }else if (project.versionFile.desFile == "all"){
                    println("this is all")
                }
            }
        }
        //正常情况下应该是
        project.tasks.whenTaskAdded{task->
             if (task.name == "generateReleaseBuildConfig") {
                            if (project.versionFile.desFile == "gradle") {
                                task.dependsOn 'startAddGradle'//需要依赖实例
                            }else if (project.versionFile.desFile == "manifest"){
                                task.dependsOn AddManifest
                            }else if (project.versionFile.desFile == "all"){
                                task.dependsOn AddGradle,AddManifest
                            }
        }

    }
}

然后 在addversioncode.properties 中定义插件入口类

implementation-class = com.stan.addversioncode.AddVersionCode
最后 插件目录下的 build.gradle 文件内部定义插件信息
apply plugin: 'groovy'
apply plugin: 'maven'

dependencies {
    compile gradleApi()
    compile localGroovy()
}

repositories {
    mavenCentral()
}

group = 'com.stan.auto.plugin'
version='1.0.13'
uploadArchives{
    repositories{
        mavenDeployer{
            repository(url:uri('../repo')) //本地仓库
        }
    }
}

至此插件就已经完成了,现在rebuild工程右边就会出现如下结构图点击upload uploadArchives上传版本到本地仓库

Test gradle plugin

最后当然是测试了。app:build.gradle中引用插件

apply plugin: 'com.android.application'
apply plugin: 'addversioncode'

buildscript{
    repositories{
        maven{
            url uri('../repo')
        }
    }
    dependencies{
        classpath 'com.stan.auto.plugin:autoaddversioncode:1.0.13'
    }
}

versionFile{
   desFile  = 'gradle'
}

android {
    ......
}

以上示例会在Gradle projects 包目录下的和 upload 同级的 Other下生成 hello task,点击hello运行,会自增 :app 下的 build.gralde中的versionCode,插件功能完成。

至此插件编辑完成,现在只需要上传到binary仓库就可以分享该插件了。上传参考下面的文章。

参考文章

如何使用Android Studio开发Gradle插件
自定义Gradle插件

源码

源码地址

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值