阅读 1474

使用Xcode调试lldb

此方法对于调试swift、lldb、clang等工具都适用。

  1. 安装 Xcode

  • AppStore 下载最新 Xcode,然后 Terminal 中执行下面命令
sudo xcodebuild -license accept
复制代码
  1. 安装必要的命令行工具

brew install cmake ninja sccache ccache
复制代码
  • 这里如果不使用sccache和ccache则可以不安装
  • 安装之后确认一下版本
    • cmake --version: 3.18.1 or higher for macOS
  • 还需要安装python,这里比较复杂,需要确保本地有python3环境
  1. 代码拉取

这里需要创建一个单独的目录用于存放相关代码。

这里可能会比较缓慢,会把llvm等必要源码全部拉取下来。

说明:这里一定要拉swift源码,直接编译苹果fork的llvm工程里面的lldb会失败

mkdir swift-project && cd swift-project

git clone -b main git@github.com:apple/swift.git

./swift/utils/update-checkout --clone-with-ssh
复制代码
  1. 编译工程

这里会同时编译swift llvm lldb等多个工程,非常缓慢,约等待一个多小时,可能还会报错

./swift/utils/build-script --skip-build-benchmarks \

  --skip-ios --skip-watchos --skip-tvos \

  --swift-darwin-supported-archs "$(uname -m)" \

  --release-debuginfo --lldb
复制代码

这一步如果要开scache则可以执行

sccache --start-server

./swift/utils/build-script --skip-build-benchmarks \

  --skip-ios --skip-watchos --skip-tvos \

  --swift-darwin-supported-archs "$(uname -m)" \

  --release-debuginfo --lldb --sccache
复制代码
  1. 调试

使用xcode随便创建一个空白的工程

把lldb源码拖进来,源码在swift-project/llvm-project/lldb直接往里拖即可

修改scheme,把调试启动的二进制指向编译的lldb产物,swift-project/build/Ninja-RelWithDebInfoAssert/lldb-macos-xxx/bin/lldb,这里xxx与本机架构有关,比如x86_64,arm64等

搜索driver.cpp然后打开文件,在main函数前面打个断点,然后run即可

问题

  1. python报错

执行./swift/utils/build-script时,如果报python相关的错误,请确认执行时python环境。

python --version
python3 --version
复制代码

如果第一个返回2.x的版本,可以修改swift/utils/build-script开头,改成python3环境

#!/usr/bin/env python3
复制代码
  1. 不能跳转

当前情况是使用cmake和ninja构建的源码,不是xcode构建的源码,因此在xcode里面不能跳转,只能打断点。

文章分类
iOS
文章标签