简体中文 | English
Wink是AndroidStudio的一个快速构建插件。Wink的目标是建立一个易于使用和易于维护的Android快速构建插件。我们与其他快速构建插件的区别在于,我们的快速构建过程完全使用Gradle和Java语言实现,支持快速编译java文件、kotlin文件和资源变化。
在Android开发过程中,应用程序的构建速度直接影响到开发者一天的工作效率。对于已经维护了几年的大型安卓项目来说,一行代码的改变有可能需要10分钟以上的时间来编译。虽然Instant Run可以带来一些优化,但优化结果仍然是分钟级的,Wink就是为了解决这个问题而产生的,对于简单的代码修改,编译速度提高到秒级。基于Gradle和Groovy,我们对java、kotlin和资源文件的编译过程进行了优化,并将整个过程交给Gradle的Task系统,不使用其他脚本语言,这不仅保证了项目代码的可读性和易用性,也大大提高了代码的可维护性。
- 支持Java变更
- 支持kotlin变更
- Gradle mutil模块支持
- 支持资源变更
- 从[wink_studio_plugin.zip]下载插件(https://s.momocdn.com/s1/u/geajgghjh/Wink-2.1.2.zip)
- 打开AndroidStudio
- 将Wink.zip拖到AndroidStudio
- 重新启动AndroidStudio
-
当你安装插件成功后。在你打开一个项目后,你可以看到wink按钮,就像这个屏幕截图。
-
点击wink按钮,你可以看到这样的对话框。选择项目根目录的build.gradle文件和主应用程序build.gradle文件。通过点击安装按钮自动改变gradle文件。
-
再次点击wink按钮,开始编译,你可以如下窗口看到相关日志
在项目根路径的 build.gradle
中加入当前最新的插件地址和版本号如下:
classpath 'com.immomo.wink:plugin:0.3.27'
在主工程 app
中的 build.gradle
应用该插件(只需在主 app 工程中应用插件即可,无需每个 module 都应用):
apply plugin: 'com.immomo.wink.plugin'
配置需要检测变更的白名单目录,可以更最大程度提高编译速度(这里表示我们只关心 hanisdk
该 module 的文件变更,若有多个 module 则用逗号分隔):
winkOptions {
moduleWhitelist = [ "hanisdk" ]
logLevel = 4 // 日志等级;4为普通,0打开所有日志
}
当配置完成后,同步项目,在执行 wink
之前需要先完整用 AS->Run
或者 assembleDebug
完整运行一遍项目,保证电脑端和手机端代码一致。
添加 winnk-compiler (读取注解与文件的依赖关系)即可,目前 annotationProcessor 依赖 kotlin 环境
kapt 依赖:
kapt "com.immomo.wink:compiler-hook:0.3.23"
apt 依赖:
annotationProcessor "com.immomo.wink:compiler-hook:0.3.23"
针对不同的注解,需要在项目的 .idea
目录下创建 wink_annotation_whitelist.txt
文件来标识需要处理的注解类型(用回车
区分,每行一个注解类)
例如:处理 ARouter 的 Route 注解 -> 从类文件 中找到完整路径为com.alibaba.android.arouter.facade.annotation.Route
ARouter 和平台的 AppConfig 注解的 wink_annotation_whitelist.txt
文件内容如下
com.alibaba.android.arouter.facade.annotation.Route
com.immomo.annotations.appconfig.appconfigv1.AppConfigV1
为了更方便的使用,可以直接用插件,拖进studio即可安装: https://s.momocdn.com/s1/u/geajgghjh/Wink-2.1.2.zip 点击即可执行
执行 Task winkInitWithShell
./gradlew winkInitWithShell
然后正常进行代码的修改,在Terminal中执行:
./wink.sh
执行成功后会重启App变更生效!
PS:用脚本执行能规避Gradle初始化的耗时,在陌陌App中体现的效果是增量一次的耗时由10s降低到3s
需要确保在终端执行 ./gradlew installDebug
可以正常运行,否则在未执行全量包时,执行 ./gradlew wink
或 ./wink.sh
会报错。
如果出现异常,可以尝试配置 JAVA_HONE
路径与 AndroidStudio JDK location
路径一致。
- 支持配置指定注解
- 支持编译 ARouter 注解
- 支持同时连接多个设备运行
- 支持raw格式资源文件
- 执行由Gradle Task变更为脚本,执行效率由10s降低到3s
- 由此而来整个执行体系变更,增加winkIni初始化流程
- Litebuild重命名为Wink
- 梳理日志,增加了日志颜色更美观了
- 执行错误抛assert出来,不再错误的跑完全程
- fix 新增资源找不到id
Copyright (c) 2021 纳斯达克:MOMO
特此允许任何获得本软件及相关文档文件("软件")副本的人免费进行交易。
本软件和相关文档文件("软件")的副本,可以不受限制地处理本软件。
本软件,包括但不限于以下权利
使用、复制、修改、合并、出版、分发、分许可和/或销售本软件的副本,并允许其使用本软件。
软件的副本,并允许接受软件的人这样做。
在符合下列条件的情况下,允许接受软件的人这样做。
上述版权声明和本许可声明应包括在
上述版权声明和本许可声明应包括在本软件的所有副本或实质部分中。
本软件 "按原样 "提供,不提供任何形式的明示或暗示的保证。
暗示的,包括但不限于适销性的保证。
对某一特定目的的适用性和不侵权的保证。在任何情况下
作者或版权持有人在任何情况下都不对任何索赔、损害或其他责任负责。
责任,无论是在合同、侵权行为或其他方面的诉讼中,由以下原因引起。
引起的,或与本软件有关的,或与本软件的使用或其他交易有关的任何索赔、损害赔偿或其他责任,作者或版权持有人均不承担任何责任。
本软件。