此方法对于调试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