CheckSourceRuns

新增於 3.19 版本。

檢查給定的原始碼是否可以編譯並連結成可執行檔,並隨後執行。

check_source_runs
check_source_runs(<lang> <code> <resultVar>
                  [SRC_EXT <extension>])

檢查一次在 <code> 中提供的 <lang> 原始碼是否可以被建置、連結為可執行檔,然後執行。<code> 必須包含至少一個 main() 函式,或在 Fortran 中是一個 program

結果會儲存在由 <resultVar> 指定的內部快取變數中。建置和執行成功會以布林值 true 表示。建置或執行失敗則以布林值 false 表示,例如空字串或錯誤訊息。

預設情況下,測試原始碼檔案將會被賦予符合所請求語言的副檔名。SRC_EXT 選項可以用來覆寫此設定,改為使用 .<extension>

<code> 必須包含一個有效的 main 程式。例如:

check_source_runs(C
"#include <stdlib.h>
#include <stdnoreturn.h>
noreturn void f(){ exit(0); }
int main(void) { f(); return 1; }"
HAVE_NORETURN)

check_source_runs(Fortran
"program test
real :: x[*]
call co_sum(x)
end program"
HAVE_COARRAY)

編譯和連結命令可以透過在呼叫 check_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 版本。

如果此變數評估為布林值 true,則所有與檢查相關的狀態訊息將會被抑制。