2012年1月31日星期二

Mac OS 10.6(Snow Leopard)编译Android源代码

最近在看Android内核剖析(柯元丹著),准备把Android源代码研究一下。做net开发时,就是通过microsoft symbol server取得net framework的源代码加载到debugger调试程序的,这种方式对于框架的学习是最方便不过的。很多时候,我也养成了习惯了随手打开源文件而不是API文档的习惯。Android源代码需要在*nix系统下编译,正好手头有个macbook,于是打算在Mac OS下编译。本文参考了android官网以及部分网友的blog,文中如引用均给已出相应连接。

一.配置环境

   笔记本:Macbook MC207CH/A  2.26GHz Intel Core 2 Duo

   内存:2GB 1067MHz DDR3

   OS : Snow Leopard 10.6

   XCode :  4.0 with ios sdk 4.2 (有问题,后面有解决方案)

   JDK : 1.6 

   Eclipse :  Indigo (Java EE)

二.设置Mac OS 编译环境

   参照官网Setting up a Mac OS X build environment,不再赘述。

   1.特别强调Android源代码必须在大小写敏感的文件系统下编译,而Mac OS默认不是大小写敏感的,因此需要创建一个大小写敏感的磁盘镜像文件。

   具体方法进入应用程序/实用工具/磁盘工具,选择文件->新建->新建空白映像:

     屏幕快照 2012-01-31 下午04.06.38

  2. 使用make 3.81 (revert from make3.82)

      强调在mkdir /Users/Shared/dports后需要使用cd /Users/Shared/dports切换到该文件夹下执行svn co,这里我刚开始没有注意无法安装gmake 3.81

三. 下载Android源代码

   参照官网Downloading the Source Tree

   1. 特别强调在Initializing a Repo client 一节,应该把当前目录设置为前文创建的大小写敏感的文件系统下,比如我把新创建的dmg挂载到/Users/basilwang/android,那么需要执行$cd /Users/basilwang/android  源代码才能放到新创建的这个路径下

      我刚开始没有注意,直接执行了

      $ repo init -u https://android.googlesource.com/platform/manifest

  结果把源代码下载到其他路径下,白白浪费我2个多小时的时间,而后我把下载的文件扔到了回收站了,结果出了一个错误,害的我又花了一些时间排除这个错误(后面详述)

   2. 这里推荐使用Android内核剖析(柯元丹著)一书提供的一段防止下载异常的脚本

   #!/bin/bash
   #FileName get-android.sh
   PATH=./bin:$PATH
   repo init -u https://android.googlesource.com/platform/manifest -b android-2.3.3_r1.1
   repo sync
   while [ $? = 1 ]; do
   echo "================sync failed, re-sync again ====="
   sleep 3
   repo sync
   done

    这里下载的是2.3.3 gingerbread版本

四. 编译Android源代码(Gingerbread)

    Gingerbread的编译还依赖于MacOSX10.5.sdk,但本机是10.6,于是下载Xcode 3.25,安装的时候选择另外的路径比如Developer325,安装完毕后Xcode4和Xcode325共存

    另外修改两个地方

   1 external/qemu/Makefile.android,其中第72行,LEOPARD_SDK:= /Developer/SDKs/MacOSX10.5.sdk,将其修改为:
LEOPARD_SDK:= /Developer325/SDKs/MacOSX10.5.sdk

   2 build/core/combo/HOST_darwin-x86.mk,其中第29行,

sdk_105_root := /Developer/SDKs/MacOSX10.5.sdk 改为

sdk_105_root := /Developer325/SDKs/MacOSX10.5.sdk

   现在可以开始编译源代码

   $make,需要很长时间,我大概用了2个多小时才编译完成

   此处报了两个错误,耽误了我很长时间

   1 执行make后

find: `frameworks/base/frameworks/base/docs/html': No such file or
directory
find: `out/target/common/docs/gen': No such file or directory
find: `frameworks/base/frameworks/base/docs/html': No such file or
directory
find: `out/target/common/docs/gen': No such file or directory
find: `frameworks/base/frameworks/base/docs/html': No such file or
directory
find: `out/target/common/docs/gen': No such file or directory
find: `frameworks/base/frameworks/base/docs/html': No such file or
directory
find: `out/target/common/docs/gen': No such file or directory
find: `frameworks/base/frameworks/base/docs/html': No such file or
directory
find: `out/target/common/docs/gen': No such file or directory

Jean-Baptiste Queru在Error building Gingerbread?回答

Oh, that error reported by "find" is actually a known harmless issue.
We should add it to the documentation.

  2

.Trashes/501/bionic/libc: MODULE.TARGET.STATIC_LIBRARIES.libc_common already defined by bionic/libc.  Stop.

    开始我一直在检查为什么会重复定义(already defined),make clean也不管用,最后发现原来编译时找到了回收站.Trashes我删除过的文件,郁闷,清空回收站就ok.

五.将源代码导入Eclipse

   1. 新建Java Project将路径指向Gingerbread目录, 此处为~/android

   2. 拷贝.classpath

       $sudo cp ~/android/development/ide/eclipse/.classpath   ~/android/.classpath

       $chmod +w  ~/android/.classpath    将.classpath设置为可写

   3. build 出现如下错误

       nopackage

      整理报错信息,集中在com.android.common包中

com.android.common.ArrayListCursor;

com.android.common.speech.LoggingEvents;

com.android.common.Rfc822InputFilter;

com.android.common.Rfc822Validator;

com.android.common.Search;

com.android.common.userhappiness.UserHappinessSignals

     在Java Build Path界面下

     buildpath

    移除出错jar包,并且选择Add JARs 增加out/target/common/obj/JAVA_LIBRARIES/android-common_intermediates/javalib.jar

    buildpath1

   至此编译成功。


Mac OS 10.6(Snow Leopard)编译Android源代码

TAG: