CheckCXXSourceCompiles

檢查 C++ 原始碼是否可以建置。

check_cxx_source_compiles
check_cxx_source_compiles(<code> <resultVar>
                          [FAIL_REGEX <regex1> [<regex2>...]])

檢查 <code> 中提供的原始碼是否可以建置。結果會儲存在 <resultVar> 指定的內部快取變數中,成功為布林值 true,失敗為布林值 false

如果提供了 FAIL_REGEX,則失敗的判斷方式是檢查編譯器輸出中是否有任何內容與指定的正規表示式匹配。

在內部,使用 try_compile() 來編譯原始碼。如果 CMAKE_TRY_COMPILE_TARGET_TYPE 設定為 EXECUTABLE (預設值),則原始碼會編譯並連結為可執行程式。如果設定為 STATIC_LIBRARY,則只會編譯原始碼,不會連結。無論哪種情況,所有函式都必須照常宣告。

另請參閱 check_source_compiles(),以取得更通用的命令語法。

另請參閱 check_source_runs() 來執行編譯後的原始碼。

編譯和連結命令可以透過在呼叫 check_cxx_source_compiles() 之前設定下列任何變數來影響:

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