此方法对于调试swift、lldb、clang等工具都适用。
-
安装 Xcode
- AppStore 下载最新 Xcode,然后 Terminal 中执行下面命令
sudo xcodebuild -license accept
复制代码
-
安装必要的命令行工具
brew install cmake ninja sccache ccache
复制代码
- 这里如果不使用sccache和ccache则可以不安装
- 安装之后确认一下版本
cmake --version: 3.18.1 or higher for macOS
- 还需要安装python,这里比较复杂,需要确保本地有python3环境
-
代码拉取
这里需要创建一个单独的目录用于存放相关代码。
这里可能会比较缓慢,会把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
复制代码
-
编译工程
这里会同时编译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
复制代码
-
调试
使用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即可

问题
-
python报错
执行./swift/utils/build-script时,如果报python相关的错误,请确认执行时python环境。
python --version
python3 --version
复制代码
如果第一个返回2.x的版本,可以修改swift/utils/build-script开头,改成python3环境
#!/usr/bin/env python3
复制代码
-
不能跳转
当前情况是使用cmake和ninja构建的源码,不是xcode构建的源码,因此在xcode里面不能跳转,只能打断点。
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END






















![[桜井宁宁]COS和泉纱雾超可爱写真福利集-一一网](https://www.proyy.com/skycj/data/images/2020-12-13/4d3cf227a85d7e79f5d6b4efb6bde3e8.jpg)

![[桜井宁宁] 爆乳奶牛少女cos写真-一一网](https://www.proyy.com/skycj/data/images/2020-12-13/d40483e126fcf567894e89c65eaca655.jpg)