背景:
创建Android的公共库,但Android Studio默认的导入库的方式会将整个库的文件拷贝到项目目录下,也就是说这个库不再是公共的了,这样显然不行,修改公共库需要到每个目录下分别修改,太麻烦了,或者使用git+ 服务器同步一次,那也很麻烦。
需要找一种不把库复制到项目目录下进行依赖的方式。
简书上转载的:
实例
在ProjectB中如何使用ProjectA的模块moduleLib ?
D:/ProjectA/
- moduleLib/
- build.gradle
- build.gradle
- settings.gradle
D:/ProjectB/
- app/
- build.gradle
- build.gradle
- settings.gradle
方法一
1.在ProjectB/settings.gradle下,导入ProjectA的模块moduleLib
include ':moduleLib'
project(':moduleLib').projectDir = new File(settingsDir, '../ProjectA/moduleLib') // settingsDir是指settings.gradle文件目录
// project(':moduleLib').projectDir = new File('D:/ProjectA/moduleLib') // 绝对路径
2.在ProjectB/app/build.gradle下,添加依赖
dependencies {
compile project(':moduleLib')
}
注: ..代表settingsDir目录的上一级目录
网上大多使用这种方式,上面这篇写得很好,易懂,自己用起来能行
代码管理
如此组织项目,会不会影响 git 项目管理呢?
git 是根据目录进行代码管理的,只受文件实际目录中的 git 控制,这种组织方式并没有实际移动代码的位置,因此并没有改变代码所属的仓库。在依赖者项目中对 commonlib module 中的代码进行修改的时候,改动只会被记录到 commonlib module 所属的 lib 项目中。
在Android Studio中:
如果在依赖者项目中做 commit,并且改动涉及到两个项目,会自动生成两个提交,commit mesage 相同,但会将文件改动记录分别提交到其所属的项目中。
如果在依赖者项目中 push 代码,只会 push 依赖者项目本身已 commit 的改动,commonlib module 的改动需要单独去其所属的 lib 项目中 push。