Android自动化构建之使用Gradle下载与处理文件
一般情况下,我们的项目构建并不需要再去导入其他文件。但如果自己项目正在维护一个自己的library module,而这个library内又维护着大量会经常更新的SO库,SO库文件很小倒无所谓,但是SO库又多又大时,直接将SO库放入Git中,一个版本更新下来,Git库估计就要炸掉了。而此时,我们利用Gradle的task来执行下载与导入即可解决这一尴尬。
Gradle下载插件
Gradle原生并不支持文件下载,使用Gradle命令执行文件下载则需要安装Gradle插件:Gradle Download Task。
插件的安装必须在项目根目录下的build.gradle文件中配置(版本最好参考官方说明):
plugins {
id "de.undercouch.download" version "3.2.0"
}
配置文件删除task
既然涉及到文件更新,那么针对项目情况,显然需要删除旧的文件,示例:
task cleanFile(type: Delete) {
// 清除SO库文件
delete 'library/src/main/jniLibs'
// 清除文件
delete new File('library/src/main/jniLibs/my.so')
}
拆分Gradle文件
在根项目或者Module的build.gradle中做配置,会导致Gradle又臭又长又不便于阅读,一修改还需要不停刷新,因此个人推荐,将比较集中的功能,提取到另一个gradle文件,apply到build.gradle中;再将需要经常修改,而跟处理逻辑毫无关联的字段提取到另一个properties文件之中,便于修改与配置。
示例:
build.gradle文件:
apply from: "update.gradle"
update.gradle文件:
// 读取update.properties文件
Properties psUpdate = new Properties()
psUpdate.load(project.file("update.properties").newDataInputStream())
def filename = psCore.getProperty("filename")
def filepath = psCore.getProperty("filepath")
task cleanFile(type: Delete) {
delete new File(filepath, filename)
}
update.properties文件
# 文件名
filename=my.so
# 文件路径
filepath=library\\src\\main\\jniLibs
注意: update.properties文件中的路径是双反斜杠
配置下载
参照官方指出的方案即可,并无难处。比较复杂的下载方案参考官方文档,以下是取自官方的简单示例:
import de.undercouch.gradle.tasks.download.Download
task downloadFile(type: Download) {
src 'http://www.example.com/index.html'
dest buildDir
}
在Android Studio上使用此方案时,存在一个大坑。如果使用该方案,那么必须写在build.gradle文件之中,而不能写在拆分出来用于apply的gradle文件之中,如果写在其中,会在import处报错,可能是第三方文件导入的不能再次导包吧。于是在我们的方案中就只能选择第二方案:
task downloadFile << {
download {
src 'http://www.example.com/index.html'
dest buildDir
}
}
注意: 在使用插件以前,必须先apply:
apply plugin: 'de.undercouch.download'