水晶构建上无代码生成选项的目的?

问题描述

构建水晶项目时no-codegen选项的目的是什么?

我有相当大的代码库,在没有这个选项的情况下构建时,可能需要长达 20 秒的时间来构建。当我使用 no-codegen 选项时,它将构建时间减少到 6 秒。但我不明白当包含该选项时是否可以调试可执行文件目前我在使用 --debug 标志构建时使用 LLDB 进行调试)?

解决方法

简而言之,它允许检查一切正常,但不会生成二进制文件。

总的来说,Crystal 编译器有四个主要阶段:

  1. 类型检查和宏扩展
  2. 代码生成到 LLVM
  3. 优化(通过 LLVM)
  4. 二进制生成(通过 LLVM)

每个过程都需要一些时间。在第一阶段,编译器只检查所有类型并扩展程序中的宏。在第二阶段,丢弃死代码,进行一些其他特定于语言的优化,并将程序生成为 LLVM。在第四阶段(仅使用 --release),Crystal 调用 LLVM 对生成的代码进行许多优化。在最后一个阶段,LLVM 创建特定于平台的二进制文件。

在您的情况下,进行类型检查需要 6 秒,完成所有其他阶段需要约 14 秒(但需要 3 个)。

,

--no-codegen 表示不生成代码。它不会产生任何二进制文件。

这个标志的目的是检查程序的有效性,而不是实际构建它。当您无论如何都无法执行结果时,这很有用,然后可以跳过二进制生成。例如,这用于 Crystal 存储库中的代码示例:它们使用 --no-codegen 在 CI 中构建只是为了检查代码是否有效,但验证它们的执行超出了自动化测试的范围。