0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Gradle自定义插件介绍2

jf_78858299 来源:小余的自习室 作者:小余的自习室 2023-03-30 11:17 次阅读

步骤4.创建插件实现的任务:上传版本信息

class UploadTask extends DefaultTask{
    String url = 'http://127.0.0.1/api/v3/upload/version'
    @TaskAction
    void upload(){
        //1.获取版本信息
        def version = getCurrentVersion()
        //2.发送版本信息
        def response = sendAndReceive(version)
        //3.处理响应:将版本信息以及响应写入到本地文件中
//        checkResponse(response)

    }
    //1.获取版本信息
    def getCurrentVersion(){
        def name = project.extensions.versionInfo.versionName
        def code = project.extensions.versionInfo.versionCode
        def info = project.extensions.versionInfo.versionUpdateInfo
        println "name:$name code:$code info:$info"
        return new VersionInfo(versionName: name,
                     versionCode: code,
                     versionUpdateInfo: info)
    }
    //2.发送版本信息
    void sendAndReceive(VersionInfo version){
        OkHttpClient client = new OkHttpClient()
        FormBody body = new FormBody.Builder()
                .add('versionName',version.versionName)
                .add('versionCode',""+version.versionCode)
                .add('versionUpdateInfo',version.versionUpdateInfo)
                .build()
        Request.Builder builder = new Request.Builder()
                .url(url)
                .post(body)

        def call1 = client.newCall(builder.build())
        call1.enqueue(new Callback() {
            @Override
            void onFailure(@NotNull Call call, @NotNull IOException e) {
                println "push version fail:reason:"+e.message
            }

            @Override
            void onResponse(@NotNull Call call, @NotNull Response response) throws IOException {
                checkResponse(response);
            }
        })
    }
    //3.处理响应:将版本信息以及响应写入到本地文件中
    void  checkResponse(response){
        println "response:"+new String(response.body().bytes())

    }
}

记住,在需要执行的方法上面添加TaskAction注解:在我们任务执行的时候就会执行到这个方法。

步骤5.将插件扩展和插件任务集成到Project生命周期中

@Override
void apply(Project project) {
    println "begin:now this is a ${project.name} 's upload plugin"
    //1.在插件中引入extensions中的字段,就是我们Project中配置的扩展字段
    project.extensions.create(EXTENSIVE,VersionInfo.class)
    //2.创建待处理的Task
    project.tasks.create(TASK_NAME,UploadTask.class)
    //3.将uploadTask任务挂架到Project的生命周期中
    def build = project.tasks.getByName('clean')
    def uploadTask = project.tasks.getByName(TASK_NAME)
    //这里使用dependsOn强依赖任务关系
    build.dependsOn(uploadTask)
}

步骤6.插件发布

笔者为了测试,将jar包只发布在本地,测试使用。

使用如下方式发布:

gradlePlugin {
    plugins {
        modularPlugin {
                id = 'com.yuhb.upload'
                implementationClass = 'com.yuhb.upload.UploadVersionPlugin'
        }
    }
}

这个配置在build后自动生成resources文件:这个插件扩展配置是引入的:java-gradle-plugin中。

图片

resources文件自动生成.png

当然也可以直接在resources文件夹中上手动写入该文件

在插件的build.gradle实现下面的逻辑:

uploadArchives {
    repositories {
            mavenDeployer {
                    repository(url:uri('D:/maven_local'))
                    pom.groupId = 'com.yuhb.upload'
                    pom.artifactId = 'uploader'
                    pom.version = '1.0.0'
            }
    }
}

在命令行执行:

./gradlew :uploadversion:uploadArchives

然后去本地文件夹下面看看是否上传成功:

图片

本地文件成功.png

这里要说明下:

一般情况下都会将自定义插件发布到maven私服或者中央仓库,才可以供其他项目使用

关于如何发布到maven私服,可以查看这篇文章

后期也会出一期文章教大家如何将数据发布到中央仓库

步骤7.插件引入

  • 步骤1 :在工程的根build.gradle文件中引入:
buildscript {
        repositories {
                ...
                maven {
                        url uri('D:/maven_local')
                }
        }
        dependencies {
                ...
                classpath 'com.yuhb.upload:upload:1.0.0'
        }
}

说明:

com.yuhb.upload:uploader:1.0.0格式:

引入字段 发布字段
com.yuhb.upload pom.groupId
uploader pom.artifactId
1.0.0 pom.version
  • 步骤2 :在子Project中引入插件:
apply plugin: 'com.yuhb.upload'
  • 步骤3 :配置extensive插件扩展:
versionInfo {
    versionName = '1.0.0'
    versionCode = 1
    versionUpdateInfo = '当前是第一个版本:初始apk'
}

这个versionInfo扩展是怎么来的呢?

我们看下之前我们配置插件的时候,使用了:

EXTENSIVE = 'versionInfo'
project.extensions.create(EXTENSIVE,VersionInfo.class)

在插件中引入extensions中的字段,就是我们Project中配置的扩展字段:

versionInfo {
    versionName = '1.0.0'
    versionCode = 1
    versionUpdateInfo = '当前是第一个版本:初始apk'
}

就是这里,如果外部配置了versionInfo的扩展字段,就会通过project.extensions获取到,并将数据写入project.extensionsversionInfo属性中:之后就可以使用project.extensionsversionInfo属性访问外部传入的配置数据:

def name = project.extensions.versionInfo.versionName
def code = project.extensions.versionInfo.versionCode
def info = project.extensions.versionInfo.versionUpdateInfo
  • 步骤4 :运行rootbuild 任务查看编译信息:
./gradlew build
结果:
> Task :app:uploadTask
name:1.0.0 code:1 info:当前是第一个版本:初始apk

这里运行build可以执行插件中的任务是因为前面笔者将插件Task挂接到了build任务之前:

挂接代码

//3.将uploadTask任务挂架到Project的生命周期中
def build = project.tasks.getByName('build')
def uploadTask = project.tasks.getByName(TASK_NAME)
//这里使用dependsOn强依赖任务关系
build.dependsOn(uploadTask)

项目Demo完整代码已经上传Github:

https://github.com/ByteYuhb/a_gradle_plugin_sample

5.总结

本文主要针对我们自定义插件定义以及优势做了一些说明,且使用一个实战项目对自定义插件制作,发布,引入流程做了一个详细的讲解

,Gradle插件部分还有Gradle的上传流程和AGP插件讲解没有讲,后面都会陆续推出。

参考资料

  • Gradle自定义插件

    _官网文档

  • Using Gradle Plugins _ Gradle 官方文档

  • Gradle 系列(2)手把手带你自定义 Gradle 插件_胡飞洋

好了,本文就讲解到这里了。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • project
    +关注

    关注

    0

    文章

    35

    浏览量

    13197
  • 插件
    +关注

    关注

    0

    文章

    313

    浏览量

    22205
  • gradle
    +关注

    关注

    0

    文章

    26

    浏览量

    663
收藏 人收藏

    评论

    相关推荐

    Android端自定义铃声 MobPush对安卓端自定义铃声的教程

    如何为APP推送设置独特的通知铃声呢?本次带来的是MobPush对安卓端自定义铃声的教程,快来看看吧~
    的头像 发表于 10-21 15:34 821次阅读
    Android端<b class='flag-5'>自定义</b>铃声 MobPush对安卓端<b class='flag-5'>自定义</b>铃声的教程

    OpenHarmony自定义组件介绍

    (param); } } } 要完全理解上面的示例,需要了解自定义组件的以下概念定义,本文将在后面的小节中介绍: ● 自定义组件的基本结构 ● 成员函数/变量 ●
    发表于 09-25 15:36

    在Protel中自定义Title Block的方法

    详细介绍了在Protel中自定义Title Block的方法
    发表于 05-24 11:42 0次下载
    在Protel中<b class='flag-5'>自定义</b>Title Block的方法

    1602自定义字符

    1602液晶能够显示自定义字符,能够根据读者的具体情况显示自定义字符。
    发表于 01-20 15:43 1次下载

    如何在LabVIEW中实现自定义控件

    本文档的主要内容详细介绍的是如何在LabVIEW中实现自定义控件。
    发表于 01-14 17:17 48次下载
    如何在LabVIEW中实现<b class='flag-5'>自定义</b>控件

    占位面积很小的自定义进度指示器progressbutton

    概述 1、描述:progressbutton是占位面积很小的自定义进度指示器。默认实现提供了一个pin进度按钮。 2、实现功能: a.自定义圆形进度条。 b.实现根据Slider滑动更新自定义进度条
    发表于 03-18 14:45 3次下载

    OpenHarmony自定义组件CircleProgress

    组件介绍 本示例是OpenHarmony自定义组件CircleProgress。 用于定义一个带文字的圆形进度条。 调用方法
    发表于 03-23 14:06 4次下载
    OpenHarmony<b class='flag-5'>自定义</b>组件CircleProgress

    自定义进度指示器progressbutton

    概述 1、描述:progressbutton是占位面积很小的自定义进度指示器。默认实现提供了一个pin进度按钮。 2、实现功能:a.自定义圆形进度条。 b.实现根据Slider滑动更新自定义进度条
    发表于 03-24 14:26 1次下载

    自定义视图组件教程案例

    自定义组件 1.自定义组件-particles(粒子效果) 2.自定义组件- pulse(脉冲button效果) 3.自定义组件-progress(progress效果) 4.
    发表于 04-08 10:48 14次下载

    ArkUI如何自定义弹窗(eTS)

    自定义弹窗其实也是比较简单的,通过CustomDialogController类就可以显示自定义弹窗。
    的头像 发表于 08-31 08:24 1453次阅读

    Gradle自定义插件介绍1

    首先来讲下`Gradle`和`Gradle插件`有啥区别? > `Gradle`是一套构建工具,其内部构建过程主要是以`Project`组成一个树形的生态系统,整个构建流程有自己
    的头像 发表于 03-30 11:17 708次阅读
    <b class='flag-5'>Gradle</b><b class='flag-5'>自定义</b><b class='flag-5'>插件</b><b class='flag-5'>介绍</b>1

    labview自定义控件

    labview自定义精美控件
    发表于 05-15 16:46 9次下载

    自定义算子开发

    一个完整的自定义算子应用过程包括注册算子、算子实现、含自定义算子模型转换和运行含自定义op模型四个阶段。在大多数情况下,您的模型应该可以通过使用hb_mapper工具完成转换并顺利部署到地平线芯片上……
    的头像 发表于 04-07 16:11 1918次阅读
    <b class='flag-5'>自定义</b>算子开发

    labview超快自定义控件制作和普通自定义控件制作

    labview超快自定义控件制作和普通自定义控件制作
    发表于 08-21 10:32 5次下载

    博途用户自定义库的使用

    中经常使用的函数/函数块/数据类型等存放到自定义库中,方便自己使用及与别人共享。博途具有很强的库管理功能,包括:库版本管理,库的更新及清扫等等。本系列文章我将给大家介绍项目库、全局库、库的更新/清扫等功能,今天这篇文章,我们先来介绍
    的头像 发表于 12-25 10:08 308次阅读
    博途用户<b class='flag-5'>自定义</b>库的使用