Android.mk文件解析

在源码树中每一个模块的所有文件通常都相应有一个自己的文件夹,在该模块的根目录下有一个名称为“Android.mk” 的文件。编译系统正是以模块为单位进行编译,每个模块都有唯一的模块名,一个模块可以有依赖多个其他模块,模块间的依赖关系就是通过模块名来引用的。也就是说当模块需要依赖一个jar包或者apk时,必须先将jar包或apk定义为一个模块,然后再依赖相应的模块。

对于Android.mk文件,通常都是以下面两行

LOCAL_PATH := $(call my-dir)//设置当编译路径为当前文件夹所在路径include $(CLEAR_VARS)//清空编译环境的变量(由其他模块设置过的变量)

为方便模块编译,编译系统设置了很多的编译环境变量,如下:

LOCAL_SRC_FILES:当前模块包含的所有源码文件;

LOCAL_MODULE:当前模块的名称(具有唯一性);

LOCAL_PACKAGE_NAME:当前APK应用的名称(具有唯一性);

LOCAL_C_INCLUDES:C/C++所需的头文件路径;

LOCAL_STATIC_LIBRARIES:当前模块在静态链接时需要的库名;

LOCAL_SHARED_LIBRARIES:当前模块在运行时依赖的动态库名;

LOCAL_STATIC_JAVA_LIBRARIES:当前模块依赖的Java静态库;

LOCAL_JAVA_LIBRARIES:当前模块依赖的Java共享库;

LOCAL_CERTIFICATE:签署当前应用的证书名称,比如platform。

LOCAL_MODULE_TAGS:当前模块所包含的标签,可以包含多标签,可能值为debgu,eng,user,development或optional(默认值)

针对这些环境变量,编译系统还定义了一些便捷函数,如下:

$(call my-dir):获取当前文件夹路径;

$(call all-java-files-under, ):获取指定目录下的所有Java文件;

$(call all-c-files-under, ):获取指定目录下的所有C文件;

$(call all-Iaidl-files-under, ) :获取指定目录下的所有AIDL文件;

$(call all-makefiles-under, ):获取指定目录下的所有Make文件;

示例:

LOCAL_PATH:= $(call my-dir)
include $(CLEAR_VARS) # 获取所有子目录中的Java文件 
LOCAL_SRC_FILES:= $(call all-subdir-java-files) # 当前模块依赖的动态Java库名称 
LOCAL_JAVA_LIBRARIES:= com.gityuan.lib # 当前模块的名称 
LOCAL_MODULE:= demo # 将当前模块编译成一个静态的Java库
include $(BUILD_STATIC_JAVA_LIBRARY)

你可能感兴趣的:(Android.mk文件解析)