编译环境
- Xcode 12.2
- Python 2.7.16
- ninja 1.10.1
编译步骤
第一步:clone swift 源码
git clone --branch swift-5.2.4-RELEASE https://github/apple/swift.git
swift 根据编译时的官方版本来做。
https://github.com/apple/swift
第二步:update-checkout
注意:这一步很关键,需要保证网络环境的稳定,必要时需要科学上网
确保你当前是在 swift-source
目录下,然后执行如下命令:
./swift/utils/update-checkout --tag swift-5.2.4-RELEASE --clone
这一步非常重要,因为update-checkout
会 clone
编译 swift 的相关的库,不然后面在编译 swift 源码的过程中一定会失败。
第三步:编译
这里我们使用 ninja
,来进行编译。
请检查是否已经安装ninja,并保证版本不要太旧,如果没有安装,请用下面的命令安装
brew instal ninja
以上确认完成之后,执行以下命令进行编译:
./swift/utils/build-script -r --debug-swift-stdlib --lldb
该步骤耗时过长,请耐心等待
第三步遇到的错误大概率是环境的问题,可以尝试: ①重装cmake,②重装ninja
如果遇到关于XcodeTools的相关问题可以尝试执行下面命令:
sudo rm -rf /Library/Developer/CommandLineTools
sudo xcode-select -s /Applications/Xcode.app
执行完之后从新编译。
编译成功之后再 swift-source/build
下面的 Ninja相关的文件夹里面会出现如下四个文件夹
第四步:使用 VSCode 来调试 Swift
首先我们需要安装一个插件CodeLLDB
紧接着配置 JSON 文件
image_1.png
注意 program 文件路径要和你编译的文件路径相同
${workspaceFolder}/build/Ninja-RelWithDebInfoAssert+stdlib-DebugAssert/swift-macosx-x86_64/bin/swift
配置完JSON之后,Run一下工程后如下:
image_2.png
会出现一个端点,过掉端点之后如下:
image_3.png
此时源码编译的所有装备工作都完成了,下面我们生成SIL文件,通过SIL文件来探索Swift的执行过程
生成SIL文件
show in finder
到你想要查看的文件夹。
如下:
在当前文件加下执行如下指令:
swiftc -emit-sil main.swift | xcrun swift-demangle >> ./main.sil && code main.sil
。
xcrun swift-demangle
用于还原混淆的代码
code main.sil
用于打开main.sil文件(这里是自定义的指令)可以用以下方式设定:
$ open .zshrc
alias code='/Applications/Visual\ Studio\ Code.app/Contents/Resources/app/bin/code'
$ source .zshrc
更多的swiftc 的操作指令,可以使用swiftc -h
指令来查看
网友评论