Application.mk 文件语法规范
介绍:
-------------
这篇问档的读者应该读过docs/OVERVIEW.TXT和docs/ANDROID-MK.TXT
总览:
---------
每个Application.mk必须放置在顶层apps目录下子目录下,例如:
$NDK/apps/
这里,
Application.mk其实是一个小的GNU Makefile片段,必须定义一些变量:
APP_MODULES
(由Android.mk文件描述),
这是用空格分割的模块名字列表,这个模块名字与在Android.mk文件中LOCAL_MODULE定义是一样的。
APP_PROJECT_PATH
APK生成器所知道的位置。
APP_OPTIM
这个变量是可选的,可以定义成两个值'release' or 'debug'. 用于修改编译程序模块时的优化层级。
'release'模式是默认的,会产生高优化的文件,’debug’模式会生成不优化的文件,使得调试更容易进行。
主意,调试’release’和’debug’文件都是可能的,但是'release'版在调试节提高的信息很少,一些变量被优化输出,无法检查,代码被重排序,使得跟踪代码很困难,堆栈追踪也不可靠,等等…
APP_CFLAGS
一套编译器选项,在编译模块中的C代码时选用。这可能用于根据应用程序来改变模块的生成,以代替修改Android.mk文件本身。
IMPORTANT WARNING: +++++++++++++++++++++++++++++++++++++++++++++++++++
+
+ All paths in these flags should be relative to the top-level NDK
+ directory. For example, if you have the following setup:
+
+
sources/foo/Android.mk
+
sources/bar/Android.mk
+
+ To specify in foo/Android.mk that you want to add the path to the
+ 'bar' sources during compilation, you should use:
+
+
APP_CFLAGS += -Isources/bar
+
+ Or alternatively:
+
+
APP_CFLAGS += -I$(LOCAL_PATH)/../bar
+
+ Using '-I../bar' will *NOT* work since it will be equivalent to
+ '-I$NDK_ROOT/../bar' instead.
+
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
所有在这些编译选项中的路径都是相对于
NDK顶层目录的。例如,如果你有下面的设置:
+
sources/foo/Android.mk
+
sources/bar/Android.mk
bar的路径,你应该用
+
+
APP_CFLAGS += -Isources/bar
+
+
APP_CFLAGS += -I$(LOCAL_PATH)/../bar
使用'-I../bar'没有用,因为它等价于:
+ '-I$NDK_ROOT/../bar'
APP_CXXFLAGS
与APP_CFLAGS相同,用于C++代码APP_CPPFLAGS
Same as APP_CFLAGS but will be passed to both C and C++ sources
一个普通的Application.mk文件像下面这样:
-------------- cut here -------------------------
APP_MODULES
:=
APP_PROJECT_PATH :=
-------------- cut here -------------------------