Android Makefile 编写总结

来源:互联网 发布:篮球火 知乎 编辑:程序博客网 时间:2024/06/03 20:19

摘自:http://www.ibm.com/developerworks/cn/opensource/os-cn-android-build/


一、Android.mk 编写:

Android.mk 文件通常以以下两行代码作为开头:

 LOCAL_PATH := $(call my-dir)

 include $(CLEAR_VARS)

这两行代码的作用是:

1.     设置当前模块的编译路径为当前文件夹路径。

2.     清理(可能由其他模块设置过的)编译环境中用到的变量。

 

为了方便模块的编译,Build 系统设置了很多的编译环境变量。要编译一个模块,只要在编译之前根据需要设置这些变量然后执行编译即可。它们包括:

  • LOCAL_SRC_FILES:当前模块包含的所有源代码文件。
  • LOCAL_MODULE:当前模块的名称,这个名称应当是唯一的,模块间的依赖关系就是通过这个名称来引用的。
  • LOCAL_C_INCLUDES:C 或 C++ 语言需要的头文件的路径。
  • LOCAL_STATIC_LIBRARIES:当前模块在静态链接时需要的库的名称。
  • LOCAL_SHARED_LIBRARIES:当前模块在运行时依赖的动态库的名称。
  • LOCAL_CFLAGS:提供给 C/C++ 编译器的额外编译参数。
  • 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 所示:


7. 编译类型的说明

名称

说明

eng

默认类型,该编译类型适用于开发阶段。
当选择这种类型时,编译结果将:

  • 安装包含 eng, debug, user,development 标签的模块
  • 安装所有没有标签的非 APK 模块
  • 安装所有产品定义文件中指定的 APK 模块

user

该编译类型适合用于最终发布阶段。
当选择这种类型时,编译结果将:

  • 安装所有带有 user 标签的模块
  • 安装所有没有标签的非 APK 模块
  • 安装所有产品定义文件中指定的 APK 模块,APK 模块的标签将被忽略

userdebug

该编译类型适合用于 debug 阶段。
该类型和 user 一样,除了:

  • 会安装包含 debug 标签的模块
  • 编译出的系统具有 root 访问权限

 

 

 

表 3 中的文件已经定义好了各种类型模块的编译方式。所以要执行编译,只需要引入表 3 中对应的 Make 文件即可(通过常量的方式)。例如,要编译一个 APK 文件,只需要在 Android.mk 文件中,加入include$(BUILD_PACKAGE)

 

  • BUILD_HOST_STATIC_LIBRARY
  • BUILD_HOST_SHARED_LIBRARY
  • BUILD_STATIC_LIBRARY
  • BUILD_SHARED_LIBRARY
  • BUILD_EXECUTABLE
  • BUILD_HOST_EXECUTABLE
  • BUILD_PACKAGE
  • BUILD_PREBUILT
  • BUILD_MULTI_PREBUILT
  • BUILD_HOST_PREBUILT
  • BUILD_JAVA_LIBRARY
  • BUILD_STATIC_JAVA_LIBRARY
  • BUILD_HOST_JAVA_LIBRARY

 

 

除此以外,Build 系统中还定义了一些便捷的函数以便在 Android.mk 中使用,包括:

  • $(call my-dir):获取当前文件夹路径。
  • $(call all-java-files-under, <src>):获取指定目录下的所有 Java 文件。
  • $(call all-c-files-under, <src>):获取指定目录下的所有 C 语言文件。
  • $(call all-Iaidl-files-under, <src>) :获取指定目录下的所有 AIDL 文件。
  • $(call all-makefiles-under, <folder>):获取指定目录下的所有 Make 文件。
  • $(call intermediates-dir-for, <class>, <app_name>, <host or target>, <common?> ):获取 Build 输出的目标文件夹路径。

 

清单 2 和清单 3 分别是编译 APK 文件和编译 Java 静态库的 Make 文件示例:


清单 2. 编译一个 APK 文件

                                  

  LOCAL_PATH := $(call my-dir)

  include $(CLEAR_VARS)

  # 获取所有子目录中的 Java 文件

  LOCAL_SRC_FILES := $(call all-subdir-java-files)                    

  # 当前模块依赖的静态 Java 库,如果有多个以空格分隔

  LOCAL_STATIC_JAVA_LIBRARIES := static-library

  # 当前模块的名称

  LOCAL_PACKAGE_NAME := LocalPackage

  # 编译 APK 文件

  include $(BUILD_PACKAGE)

                         



清单 3. 编译一个 Java 的静态库

                                  

  LOCAL_PATH := $(call my-dir)

  include $(CLEAR_VARS)

  

  # 获取所有子目录中的 Java 文件

  LOCAL_SRC_FILES := $(call all-subdir-java-files)

  

  # 当前模块依赖的动态 Java 库名称

  LOCAL_JAVA_LIBRARIES := android.test.runner

  

  # 当前模块的名称

  LOCAL_MODULE := sample

  

  # 将当前模块编译成一个静态的 Java 库

  include $(BUILD_STATIC_JAVA_LIBRARY)

 


0 0
原创粉丝点击