CheckCXXSourceRuns

检查一次给定的 C++ 代码是否可以编译和链接成可执行文件,以及随后是否可以运行。

check_cxx_source_runs
check_cxx_source_runs(<code> <resultVar>)

检查一次在 <code> 中提供的代码是否可以构建、链接成可执行文件,然后运行。 <code> 至少必须包含一个 main() 函数。

结果存储在由 <resultVar> 指定的内部缓存变量中。构建和运行成功由布尔值 true 指示。构建或运行失败由布尔值 false 指示,例如空字符串或错误消息。

另请参见 check_source_runs(),以了解更通用的命令语法。

在调用 check_cxx_source_runs() 之前,可以通过设置以下任何变量来影响编译和链接命令

CMAKE_REQUIRED_FLAGS

传递给编译器的附加标志字符串。字符串必须以空格分隔——;-list 将不起作用。 CMAKE_<LANG>_FLAGS 的内容及其关联配置特定变量将在 CMAKE_REQUIRED_FLAGS 的内容之前自动添加到编译器命令中。

CMAKE_REQUIRED_DEFINITIONS

;-list 编译器定义,形式为 -DFOO-DFOO=bar。还将自动添加由 <resultVar> 指定名称的定义。

CMAKE_REQUIRED_INCLUDES

;-list 要传递给编译器的标头搜索路径。这些将是唯一使用的标头搜索路径——INCLUDE_DIRECTORIES 目录属性的内容将被忽略。

CMAKE_REQUIRED_LINK_OPTIONS

在 3.14 版本中添加。

;-list 要添加到链接命令的选项(有关详细信息,请参见 try_compile())。

CMAKE_REQUIRED_LIBRARIES

;-list 要添加到链接命令的库。这些库可以是系统库的名称,也可以是 导入的目标(有关详细信息,请参见 try_compile())。

CMAKE_REQUIRED_LINK_DIRECTORIES

3.31 版本中添加。

传递给链接器的一条库搜索路径的 ;-list(有关详细信息,请参阅 try_compile())。

CMAKE_REQUIRED_QUIET

3.1 版本中添加。

如果此变量评估为布尔真值,则与该检查关联的所有状态消息都将被抑制。