首先要了解安卓编译原理:
安卓编译在原先安卓6.0纯MakeFile编译的传统流程前,8.0版本新增了四个步骤:
1.Soong的自举(bootstrap)。这个步骤会编译Soong的核心组件。
2.收集Android.bp并生成out/soong/build.ninja文件。
3.收集Android.mk并生成out/build-.ninja与out/combined-.ninja文件。
4.执行Ninja文件,进行编译。这个combined-*.ninja文件,就是真正的执行入口。
可以发现:在开发过程中,开发者最经常使用的mm、mma等单模块编译功能,就会执行上面所有步骤、极其耗时。而实际上在不改变Android.bp和Android.mk编译脚本文件时,我们是不需要执行前三步的、只需要执行第四步,因此针对安卓编译流程,我们开发了一个ninja的脚本,能直接执行第四步,以此节省大量编译耗时。
整编项目后,在不改变Android.bp和Android.mk编译脚本文件时,将我们的ninja编译脚本放在服务器bin目录下、配置环境变量后可以使用ninja指令进行模块单编译,极大提升编译速度、缩短时间成本,一些需要长时间编译的模块,编译时间缩短甚至达到90%。
为了方便使用ninja编译,写了一个ninja脚本,放到任意路径,然后配置环境变量。
例如:~/samba/code/ninja
在.bashrc添加环境变量
exportPATH=$PATH:/home/shu5_zhang/samba/code。
再编写ninja文件:
#!/bin/bash
ninja(){
ninja_bin="$ANDROID_BUILD_TOP/prebuilts/build-tools/linux-x86/bin/ninja"
#ninja_build_file="$ANDROID_BUILD_TOP/out/build-$TARGET_PRODUCT.ninja"
ninja_build_file="$ANDROID_BUILD_TOP/out/combined-$TARGET_PRODUCT.ninja"
if [! -f $ninja_build_file]
then
echo "can't find ninja buildfile $ninja_build_file"
exit -1
fi
if [! -f $ninja_bin]
then
echo "can't find ninja binary $ninja_bin"
exit -1
fi
$ninja_bin -f $ninja_build_file $1
}
#usage:ninja
ninja$*
使用mmm单编libsurfaceflinger.so需要12分钟,使用ninja后只需要1分钟,时间缩短率达到91.7%。
ninja脚本编译和平台无关,所有项目都可以使用ninja脚本编译,而且与模块类型无关,ninja编译kernel、framework、service都是一样的,只不过把make指令换成ninja使用,操作简便、效果明显!