otool是苹果开源的项目,它主要用于查看mach-o
文件的内容。动态调试otool
有助于我们查看苹果是如何读取mach-o
文件,并如何关联其中的内容的(比如类的信息和实例方法信息如何关联上)。这从一定程度上帮助我们了解mach-o
各种segment
和section
之间的关系。
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
...
将CFLAGS
和CXXFLAGS
中的-O3
删除,并在这两个变量的尾部追加-g -Wall
。
进入cctools-port/cctools/otool
,对该目录下的Makefile
做同样的修改。
现在,进入cctools-port/cctools
,执行make
指令即可。
去除-O3是因为我们不需要优化,否则断点过程中变量的值可能会出现奇怪的现象;-g -Wall是开启生成debug信息,并且输出所有警告。
3. Xcode中进行调试
在上面两个步骤中,如果没有错误的话,应该已经在各级目录生成了对应的可执行文件了,比如cctools-port/cctools/otool
目录下应该包含了otool
可执行文件。此时,我们需要动态调试它。
- 新建Xcode项目,选择类型为
External Build System
,项目可以放在任意地方。这里假设项目名为TEST
; - 关闭Xcode项目,找到该项目物理地址,将
TEST.xcodeproj
拖入到cctools-port/cctools/
中; - 打开
TEST.xcodeproj
,选择Edit Scheme
->Info
,修改其中的executable
为目录cctools-port/cctools/otool
下的otool
可执行文件; - 在Xcode项目中右键添加文件
Add files to "TEST" ...
,将cctools-port/cctools/
整个添加进来。
以上步骤结束后,现在可以运行项目了,在main.c中打断点,则可以动态调试otool
源码了。
4.代码高亮及代码提示
此时虽然可以断点,但是没有代码高亮及代码提示以及代码跳转功能。
解决方法为新增Target
,类型为Command Line Tool
,名字随意。假设这里名字为TEST_COM
。
在TEST_COM
的Build Phases
中,在Compile Sources
中点击+
,在搜索框中输入*.c
,选中任意一个文件,按CMD + A
全选,添加。
CMD + B
编译TEST_COM
,即使出错也不用理会。
现在,在切换回TEST
,就可以有代码高亮和代码提示了。
大部分有代码高亮,小部分变量和函数还是没法解决,但是已经不影响整个流程了。
网友评论