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)

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

友情链接更多精彩内容