大家应该都看过微信关于??榛姆窒?a target="_blank" rel="nofollow">《微信Android模块化架构重构实践》,但不知道是否注意到它里面提到的pins工程结构
作者是这样描述的 ------“pins工程能在module之内再次构建完整的多子工程结构,通过project.properties来指定编译依赖关系。通过依赖关系在编译时找到所有的资源和源码路径?!?/b>
仔细推敲这句话的意思,应该能知道它实现的基本原理:通过设置sourceSets指定多个资源、源码等等路径,详见:
https://developer.android.com/studio/build/index.html#sourcesets
另外,project.properties为sourceSets指定路径。
但是,有一个问题需要要知道的是,一个module只能指定一个AndroidManifest文件,怎么办?
解决的方式很简单,依旧在project.properties配置文件中定义manifest的srcFile路径,然后在编译过程中把各个AndroidManifest文件按照约定的方式拼接成一个文件。
接下来就是如何在编译过程中指定sourceSets的资源、源码等等路径,这里就需要用到Gradle的Task以及了解下Gradle打包Android的流程。
这里简单的定义了一个microModuleTask,microModuleHandler方法里面就是在编译的时候要做的一些事情。有人会疑问,为什么在preBuild任务之前也要执行microModuleHandler?
因为Gradle的执行生命周期分为三个阶段:初始化阶段、配置阶段和执行阶段。在配置阶段,会去执行build.gradle脚本,配置project对象,其实也就配置了android对象。通过执行microModuleTask重新配置android对象,其中很重要的一点是生成AndroidManifest文件在build文件夹下。在执行阶段中,可能会执行clean等操作,以至于build文件下生成的AndroidManifest文件会被清理掉,所以需要在preBuild任务之前重新生成。原因就在于我把生成的AndroidManifest文件在build文件夹下。
接下来就是microModuleHandler里面要做什么?
最初:先找到main子工程,解析main所属的配置文件,提取路径,并判断是否有依赖的lib,如果有,再递归下去。接着开始提取各个依赖lib对应AndroidManifest文件中application标签里面的内容,插入到main子工程对应AndroidManifest文件中application标签里。
2017.08.22 更新:使用官方库com.android.tools.build:manifest-merger来作merge操作,详见源码(micro.gradle?/?micro_reference.gradle)
然后指定sourceSets对应的资源路径。
然后就是这样了
到这里MicroModule就差不多了。
另外,通过依赖关系来确定包含哪些子??榈姆绞接胂钟械南钅啃枨笥械悴灰谎?,所以我又做了不通过依赖关系而是增加一个配置属性enable来确定这个子??槭欠褚鴐odule里面。
MicroModule源码及demo,详进:https://github.com/EastWoodYang/MicroModule