问题描述
构建水晶项目时no-codegen
选项的目的是什么?
我有相当大的代码库,在没有这个选项的情况下构建时,可能需要长达 20 秒的时间来构建。当我使用 no-codegen
选项时,它将构建时间减少到 6 秒。但我不明白当包含该选项时是否可以调试可执行文件(目前我在使用 --debug
标志构建时使用 LLDB 进行调试)?
解决方法
简而言之,它允许检查一切正常,但不会生成二进制文件。
总的来说,Crystal 编译器有四个主要阶段:
- 类型检查和宏扩展
- 代码生成到 LLVM
- 优化(通过 LLVM)
- 二进制生成(通过 LLVM)
每个过程都需要一些时间。在第一阶段,编译器只检查所有类型并扩展程序中的宏。在第二阶段,丢弃死代码,进行一些其他特定于语言的优化,并将程序生成为 LLVM。在第四阶段(仅使用 --release
),Crystal 调用 LLVM 对生成的代码进行许多优化。在最后一个阶段,LLVM 创建特定于平台的二进制文件。
在您的情况下,进行类型检查需要 6 秒,完成所有其他阶段需要约 14 秒(但需要 3 个)。
,--no-codegen
表示不生成代码。它不会产生任何二进制文件。
这个标志的目的是检查程序的有效性,而不是实际构建它。当您无论如何都无法执行结果时,这很有用,然后可以跳过二进制生成。例如,这用于 Crystal 存储库中的代码示例:它们使用 --no-codegen
在 CI 中构建只是为了检查代码是否有效,但验证它们的执行超出了自动化测试的范围。