Android.mk文件解析
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE := native-interface
LOCAL_SRC_FILES := video.c \
adpcm.c \
audio.c \
sip.c \
network.c \
circular_queue.c \
native_interface.c
LOCAL_SHARED_LIBRARIES := libosip \
libexosip \
libavcodec \
libavutil \
libswscale
# LOCAL_SHARED_LIBRARIES := libavcodec \
# libavutil \
# libswscale
#须要链接的系统默认库
LOCAL_LDLIBS += -llog
LOCAL_LDLIBS += -lOpenSLES
LOCAL_LDLIBS += -landroid
include $(BUILD_SHARED_LIBRARY)
#加入外部导入库文件夹
$(call import-add-path, $(LOCAL_PATH))
#加入到入库
$(call import-module, libffmpeg)
$(call import-module, libosip)
$(call import-module, libexosip)</span></span>
$(CLEAR_VARS)開始,到include $(BUILD_SHARED_LIBRARY)结束
$(call my-dir) 设置LOCAL_PATH变量;my-dir为宏函数,由编译系统提供
$(call:获取当前目录路径。
my-dir)$(call:获取指定文件夹下的全部 Java 文件。
all-java-files-under, <src>)$(call:获取指定文件夹下的全部 C 语言文件。
all-c-files-under, <src>)$(call:获取指定文件夹下的全部 AIDL 文件。
all-Iaidl-files-under, <src>)$(call:获取指定文件夹下的全部 Make 文件。
all-makefiles-under, <folder>)$(call:获取 Build 输出的目标目录路径。
intermediates-dir-for, <class>, <app_name>, <host or target>, <common?> )
3、$(call <function>)
GNU Make‘功能’宏。必须通过使用'$(call <function>)'来求值,他们返回文本化的信息。
1)my-dir
返回当前Android.mk所在的文件夹路径,相对于NDK编译系统的顶层。这是实用的,在Android.mk文件的开头如此定义:
LOCAL_PATH := $(call my-dir)
2)all-subdir-makefiles
返回一个位于当前'my-dir'路径的子文件夹列表。比如,看以下的文件夹层次:
sources/foo/Android.mk
sources/foo/lib1/Android.mk
sources/foo/lib2/Android.mk
假设sources/foo/Android.mk包括一行:
include $(call all-subdir-makefiles)
那么它就会自己主动包括sources/foo/lib1/Android.mk 和sources/foo/lib2/Android.mk
这项功能用于向编译系统提供深层次嵌套的代码文件夹层次。注意。在默认情况下。NDK将会仅仅搜索在sources/*/Android.mk中的文件。
3)this-makefile
返回当前Makefile的路径(即这个函数调用的地方)
4)parent-makefile
返回调用树中父Makefile路径。
即包括当前Makefile的Makefile路径。
5)grand-parent-makefile
$(CLEAR_VARS)
CLEAR_VARS定义在/build/core/clear_vars.mk中,用以清除很多LOCAL变量。由于这些变量往往都是全局的,故须要对其进行清除;
- LOCAL_SRC_FILES :当前模块包括的全部源码文件。
- LOCAL_MODULE :当前模块的名称,这个名称应当是唯一的,模块间的依赖关系就是通过这个名称来引用的。
- LOCAL_C_INCLUDES :C 或 C++ 语言须要的头文件的路径。
- LOCAL_STATIC_LIBRARIES :当前模块在静态链接时须要的库的名称。
- LOCAL_SHARED_LIBRARIES:当前模块在执行时依赖的动态库的名称。
- LOCAL_CFLAGS :提供给 C/C++ 编译器的额外编译參数。
(LOCAL_CFLAGS-D 添加全局宏定义。
LOCAL_CFLAGS := -DUSE_JSC 相当于在全部源文件里添加一个#define USE_JSC
LOCAL_CFLAGS := -DUSE_COPY_BIT=1 相当于在全部源文件里添加一个#define USE_COPY_BIT 1) - LOCAL_JAVA_LIBRARIES :当前模块依赖的 Java 共享库。
- LOCAL_STATIC_JAVA_LIBRARIES:当前模块依赖的 Java 静态库。
- LOCAL_PACKAGE_NAME :当前 APK 应用的名称。
- LOCAL_CERTIFICATE :签署当前应用的证书名称。
- LOCAL_MODULE_TAGS :当前模块所包括的标签,一个模块能够包括多个标签。
标签的值可能是 debug, eng, user,development 或者 optional。当中,optional 是默认标签。标签是提供给编译类型使用的。不同的编译类型会安装包括不同标签的模块,关于编译类型的说明如表
7 所看到的:
LOCAL_SRC_FILES变量必须包括将要编译打包进模块中的C或C++源码文件。注意。你不用在这里列出头文件和包括文件。由于编译系统将会自己主动为你找出依赖型的文件。只列出直接传递给编译器的源码文件就好。
$(BUILD_SHARED_LIBRARY)表示该编译模块希望生成的文件状态。
BUILD_SHARED_LIBRARY是编译系统提供的变量。指向一个GNU Makefile脚本(应该就是在build/core文件夹下的shared_library.mk),负责收集自从上次调用'include
$(CLEAR_VARS)'以来,定义在LOCAL_XXX变量中的全部信息,而且决定编译什么,怎样正确地去做。
并依据其规则生成静态库。
类似的BUILD_XXX变量还有:
- BUILD_SHARED_LIBRARY
- BUILD_STATIC_LIBRARY
- BUILD_EXECUTABLE
- BUILD_PACKAGE
- BUILD_JAVA_LIBRARY等
- TARGET_ROOT_OUT:表示根文件系统。
- TARGET_OUT:表示system文件系统。
- TARGET_OUT_DATA:表示data文件系统。
使用方法如:
LOCAL_MODULE_PATH:=$(TARGET_ROOT_OUT)
Android.mk文件解析的更多相关文章
- Android编译系统(Android.mk文件详解)
[Android-NDK(Native Development Kit) docs文档] NDK提供了一系列的工具,帮助开发者快速开发C(或C++)的动态库,并能自动将so和java应用一起打包成a ...
- Android.mk 文件语法详解
0. Android.mk简介: Android.mk文件用来告知NDK Build 系统关于Source的信息. Android.mk将是GNU Makefile的一部分,且将被Build Syst ...
- Android.mk 文件语法详解 转:http://blog.sina.com.cn/s/blog_602f8770010148ce.html
0. Android.mk简介: Android.mk文件用来告知NDK Build 系统关于Source的信息. Android.mk将是GNU Makefile的一部分,且将被Build Syst ...
- Android.mk文件语法规范 原文
序言:------------- 此文档旨在描述Android.mk文件的语法,Android.mk文件为Android NDK(原生开发)描述了你C/C++源文件.为了明白下面的内容,你必须已经阅读 ...
- Android NDK开发之Android.mk文件
Android NDK开发指南---Android.mk文件 博客分类: Android NDK开发指南 Android.mk文件语法详述 介绍: ------------ 这篇文档是用来描述你的 ...
- 【转】Android.mk文件语法规范(Android.mk File)
原文网址:http://blog.csdn.net/smfwuxiao/article/details/8530742 1.Android.mk文件概述 Android.mk文件用来告诉NDK编译系统 ...
- Android.mk文件语法规范及使用模板
Android.mk文件语法详述 介绍:------------这篇文档是用来描述你的C或C++源文件中Android.mk编译文件的语法的,为了理解她们我们需要您先看完docs/OVERVIEW.h ...
- Android JNI的Android.mk文件语法详解
Android.mk简介: Android.mk文件用来告知NDK Build 系统关于Source的信息. Android.mk将是GNU Makefile的一部分,且将被Build System解 ...
- Android.mk文件简单分析
Android.mk文件简单分析 一个Android.mk文件用来向编译系统描写叙述须要编译的源码.详细来说:该文件是GNUMakefile的一小部分.会被编译系统解析一次或多次. 能够在每个Andr ...
随机推荐
- 【C++】朝花夕拾——表达式树
表达式树: 叶子是操作数,其余结点为操作符,是二叉树的其中一种应用 ====================我是分割线====================== 一棵表达式树如下图: 若是对它做中序 ...
- leetcode_650. 2 Keys Keyboard_dp
https://leetcode.com/problems/2-keys-keyboard/ 初始一个A,两种操作,复制当前所有A,粘贴,问得到n个A最少需要多少步操作. class Solution ...
- redis 其他特性
1.消息订阅与发布 subscribe my1 订阅频道 psubscribe my1* 批量订阅频道,订阅以my1开头的所有频道 publish my1 hello 在指定频道中发布消息,返回值为接 ...
- struts2 针对类型转换出错的处理
在类型转换出错时,需要在页面上显示友好提示: 类型转换出错时,会抛出一个运行时异常,程序会根据建立的属性文件,显示相应的错误提示. 实现方法: 1)新建局部属性文件或者全局属性文件 局部属性文件:放置 ...
- fabric的安装
https://blog.csdn.net/lepton126/article/details/79148027
- vue工程化
很多人在玩完了官方文档的小例子之后,又不知道如何下手了.所以我这边帮大家把断层补上.大家首先要把vue的基本语法都熟悉了,然后再来这边学习. 有了前面webpack的铺垫,我们直接从vue的工程化开始 ...
- 关于Maven项目的pom.xml中的依赖或插件失效的解决方法
1.请将<dependency>标签包含的依赖从<dependencyManagement>中拿出来,单独放在<dependencies>标签里面.2.请将< ...
- No-3.算数运算符
01. 算数运算符 算数运算符是 运算符的一种 是完成基本的算术运算使用的符号,用来处理四则运算 运算符 描述 实例 + 加 10 + 20 = 30 - 减 10 - 20 = -10 * 乘 1 ...
- 第3节 hive高级用法:13、hive的函数
4.2.Hive参数配置方式 Hive参数大全: https://cwiki.apache.org/confluence/display/Hive/Configuration+Properties 开 ...
- http和socket
大多数情况下都是使用Http协议做网络通信的,少数情况下,如扣扣之类的即时通讯,就是用Socket建立长链接 Http一般都是短连接的,即客户端和服务端通讯一次后,服务端就关闭连接 Socket是长连 ...