/PluginDemo

A demo for test publish lib/plugin to Jitpack/Jforg

Primary LanguageJava

Release

PluginDemo

A demo for test publish lib/plugin to Jitpack

Gradle语法

如果要学习gradle相关的东西,请查看Gradle for Android

Gradle插件开发

Gradle插件是使用Groovy进行开发的,而Groovy其实是可以兼容Java的。Android Studio其实除了开发Android App外,完全可以胜任开发Gradle插件这一工作,下面来讲讲具体如何开发。

  • 首先,新建一个Android项目。
  • 之后,新建一个Android Module项目,类型选择Android Library。
  • 将新建的Module中除了build.gradle文件外的其余文件全都删除,然后删除build.gradle文件中的所有内容。
  • 在新建的module中新建目录结构src.main.groovy,这时候groovy文件夹会被Android识别为groovy源码目录。除了在main目录下新建groovy目录外,你还要在main目录下新建resources目录,同理resources目录会被自动识别为资源文件夹。在groovy目录下新建项目包(com.xinayida.plugin),就像Java包那样。resources目录下新建文件夹META-INF,META-INF文件夹下新建gradle-plugins文件夹。这样,就完成了gradle 插件的项目的整体搭建,之后就是小细节了。

目前,项目的结构是这样的: 打开Module下的build.gradle文件,输入

apply plugin: 'groovy'

dependencies {
    compile gradleApi()
    compile localGroovy()
}

repositories {
    mavenCentral()
}

下面我们在刚才的包中添加一个文件,命名为PluginImpl.groovy,注意有groovy后缀,然后在里面输入(注意包名替换为你自己的包名)。

package com.xinayida.plugin

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

public class PluginImpl implements Plugin<Project> {
    void apply(Project project) {
        project.task('testTask') << {
            println "Hello gradle plugin"
        }
    }
}

然后在resources/META-INF/gradle-plugins目录下新建一个properties文件,注意该文件的命名就是你之后使用插件的名字,这里命名为plugin.test.properties,在里面输入

implementation-class=com.xinayida.plugin.PluginImpl

ps:注意包名需要替换为你自己的包名。

这样就完成了最简单的一个gradle插件,里面有一个叫testTask的Task,执行该task后会输出一段文字,就像当初我们输出HelloWorld一样。

发布到Jitpack

之前的参考文章中是将库发布到Jcenter中,但是经过注册使用后发现https://bintray.com 只有30天的试用期,而且不翻墙的话打开速度很慢。 而Jitpack的话使用起来更加方便,基本上在Github上创建项目后,简单配置一下就可以发布使用了。官网发布教程请戳这里

发布

  1. 在主工程的build.gradle中添加:
buildscript {
  dependencies {
  classpath 'com.github.dcendents:android-maven-gradle-plugin:1.5' // Add this line
  1. 在library/build.gradle中添加:
    apply plugin: 'com.github.dcendents.android-maven'
    
    group='com.github.YourUsername'
    
  2. 在Github上创建一个release或添加一个tag

检查

检查在你的工程目录里是否有Gradle wrapper,如果没有的话可以用命令行gradle wrapper来创建。同时,也要看一下生成的gradle-wrapper.jar文件是否被.gitignore规则忽略掉。

测试: 做好这些修改之后,退回到工程根目录,用命令行运行Gradle wrapper: ./gradlew install 这个指令会将你的库安装到本地的maven repository($HOME/.m2/repository)中。加入安装成功,并且你已经增加了一个GitHub release,那么在jitpack.io就已经部署成功了。 重要: 请在这里检查与你的Gradle版本相匹配的android-maven版本.你的gradle版本是在gradle/wrapper/gradle-wrapper.properties文件中指定的。

安装

1.在build文件中加入JitPack库

	allprojects {
		repositories {
			...
			maven { url "https://jitpack.io" }
		}
	}

2.加入依赖库

    dependencies {
            compile 'com.github.User:Repo:Tag'
        }

例如:

    dependencies {
        classpath 'com.github.xinayida:PluginDemo:v0.0.1'
    }

如果Github上没有Release,可以使用short commit hash 或者 'anyBranch-SNAPSHOT' 的方式来作为version字段

如果发布的库是一个插件的话,需要在app/build.gradle中加入 apply plugin: 'pluginname' eg. apply plugin: 'plugin.test' 这个名字就是之前在创建插件工程时,esources/META-INF/gradle-plugins目录下的properties文件名

增加示例

如果在你的代码库中增加了一个例子应用,它就要依赖你的库。这就要在你的app/build.gradle文件中加入:

dependencies {
    compile project(':library')
}

‘library'即是你发布的库模块的名字

其他

默认情况下android-maven插件会将你的库编译成一个'aar'文件.如果你想生成一个'jar'文件的话,可以参考这个例子工程中的library/build.gradle文件

参考文章

如何使用Android Studio开发Gradle插件