otool源码调试

otool是苹果开源的项目,它主要用于查看mach-o文件的内容。动态调试otool有助于我们查看苹果是如何读取mach-o文件,并如何关联其中的内容的(比如类的信息和实例方法信息如何关联上)。这从一定程度上帮助我们了解mach-o各种segmentsection之间的关系。

1.下载源码

需要注意的是,苹果的源码无法编译通过,为了节省时间,需要使用github上已经可以编译的代码cctools-port

$ git clone https://github.com/tpoechtrager/cctools-port.git
$ cd cctools-port/cctools
$ ./configure

以上,会在各级目录生成Makefile文件,在使用Makefile之前,我们需要处理,否则最终是无法打断点的。

2.Makefile增加和删除编译器参数

进入cctools-port/cctools,修改目录下Makefile文件,查找CFLAGS标志的定义处:

...
CC = clang
CCAS = clang
CCASFLAGS = -O3 -isystem /usr/local/include -isystem /usr/pkg/include  -DLD64_VERSION_NUM=530
CFLAGS = -isystem /usr/local/include -isystem /usr/pkg/include  -DLD64_VERSION_NUM=530 -g -Wall
CPP = clang -E
CPPFLAGS = 
CXX = clang++
CXXABI_LIB = -lc++abi
CXXCPP = clang++ -E
CXXFLAGS = -std=c++0x -isystem /usr/local/include -isystem /usr/pkg/include -stdlib=libc++  -DLD64_VERSION_NUM=530  -fblocks -g -Wall
CYGPATH_W = echo
...

CFLAGSCXXFLAGS中的-O3删除,并在这两个变量的尾部追加-g -Wall

进入cctools-port/cctools/otool,对该目录下的Makefile做同样的修改。

现在,进入cctools-port/cctools,执行make指令即可。

去除-O3是因为我们不需要优化,否则断点过程中变量的值可能会出现奇怪的现象;-g -Wall是开启生成debug信息,并且输出所有警告。

3. Xcode中进行调试

在上面两个步骤中,如果没有错误的话,应该已经在各级目录生成了对应的可执行文件了,比如cctools-port/cctools/otool目录下应该包含了otool可执行文件。此时,我们需要动态调试它。

  1. 新建Xcode项目,选择类型为External Build System,项目可以放在任意地方。这里假设项目名为TEST
  2. 关闭Xcode项目,找到该项目物理地址,将TEST.xcodeproj拖入到cctools-port/cctools/中;
  3. 打开TEST.xcodeproj,选择Edit Scheme->Info,修改其中的executable为目录cctools-port/cctools/otool下的otool可执行文件;
  4. 在Xcode项目中右键添加文件Add files to "TEST" ...,将cctools-port/cctools/整个添加进来。

以上步骤结束后,现在可以运行项目了,在main.c中打断点,则可以动态调试otool源码了。

4.代码高亮及代码提示

此时虽然可以断点,但是没有代码高亮及代码提示以及代码跳转功能。

解决方法为新增Target,类型为Command Line Tool,名字随意。假设这里名字为TEST_COM

TEST_COMBuild Phases中,在Compile Sources中点击+,在搜索框中输入*.c,选中任意一个文件,按CMD + A全选,添加。

CMD + B编译TEST_COM,即使出错也不用理会。

现在,在切换回TEST,就可以有代码高亮和代码提示了。

大部分有代码高亮,小部分变量和函数还是没法解决,但是已经不影响整个流程了。

你可能感兴趣的:(otool源码调试)