Android.mk文件用来告知NDK Build 系统关于Source的信息。 Android.mk将是GNU Makefile的一部分,且将被Build System解析一次或多次。
所以,请尽量少的在Android.mk中声明变量,也不要假定任何东西不会在解析过程中定义
学习一个android.mk
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_ALLOW_UNDEFINED_SYMBOLS=false
LOCAL_C_INCLUDES := \
$(LOCAL_PATH)/dvrnet/include \
$(LOCAL_PATH)/dvrnet/src/include \
$(LOCAL_PATH)/dvrnet/common \
$(LOCAL_PATH)/ttxcommon/include
LOCAL_MODULE := ttxstream
LOCAL_STATIC_LIBRARIES := libdvrnet
LOCAL_SRC_FILES := ttxnetstream.cpp ttxstreamwork.cpp
include $(BUILD_SHARED_LIBRARY)
include $(call all-makefiles-under,$(LOCAL_PATH))
LOCAL_PATH := $(call my-dir)
每个Android.mk文件必须以定义LOCAL_PATH为开始。它用于在开发tree中查找源文件。
宏my-dir 则由Build System提供。返回包含Android.mk的目录路径
LOCAL_PATH 是一个变量,其对应的属性即路径是当前路径(my_dir),call作用是得到其完整路径,GNU Make函数宏,必须通过使用'$(call )'来调用,返回值是文本化的信息
注意:‘:=’是赋值的意思;'+='是追加的意思;‘$’表示引用某变量的值
include $(CLEAR_VARS)
CLEAR_VARS 变量由Build System提供。并指向一个指定的GNU Makefile,由它负责清理很多LOCAL_xxx.
例如:LOCAL_MODULE, LOCAL_SRC_FILES, LOCAL_STATIC_LIBRARIES等等。但不清理LOCAL_PATH.
这个清理动作是必须的,因为所有的编译控制文件由同一个GNU Make解析和执行,其变量是全局的。所以清理后才能避免相互影响。
LOCAL_ALLOW_UNDEFINED_SYMBOLS = false
在运行中可能会出现错误,因为库文件找不到依赖的文件就会报错。如何使true 则忽略,true--慎用
LOCAL_C_INCLUDES := \
可选变量,表示要包含的头文件的搜索路径 “ \ ”分行连接符
LOCAL_MODULE = ttxstream
编译后的文件名,这是模块的名字,它必须是唯一的,而且不能包含空格
LOCAL_STATIC_LIBRARIES :=libdvrnet
表示该模块需要使用哪些静态库,以便在编译时进行链接。
LOCAL_SRC_FILE := ttxnetstream.cpp ttxstreamwork.cpp
这是要编译的源代码文件列表。
只要列出要传递给编译器的文件,因为编译系统自动计算依赖。注意源代码文件名称都是相对于 LOCAL_PATH的
include $(BUILD_SHARED_LIBRARY)
编译生成动态库
#include $(call all_subdir_makefiles)
all-subdir-makefiles 是一 个宏定义all-subdir-makefiles $(all-subdir-makefiles)是宏展开替换
说明:其返回一个列表,包含'my-dir'中所有子目录中的Android.mk。 可以实现深层递归编译