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,則所有與檢查相關的狀態訊息將會被抑制。