Swift进阶(一)--- 源码编译

编译环境

  • 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-checkoutclone 编译 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相关的文件夹里面会出现如下四个文件夹

image.png

第四步:使用 VSCode 来调试 Swift

首先我们需要安装一个插件CodeLLDB

image_0.png

紧接着配置 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 到你想要查看的文件夹。
如下:

image_4.png

在当前文件加下执行如下指令:
swiftc -emit-sil main.swift | xcrun swift-demangle >> ./main.sil && code main.sil

image_5.png

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指令来查看

你可能感兴趣的:(Swift进阶(一)--- 源码编译)