CheckOBJCSourceCompiles¶
於 3.16 版本新增。
檢查 Objective-C 原始碼是否可建置一次。
- check_objc_source_compiles¶
check_objc_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_objc_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,則會隱藏與檢查相關的所有狀態訊息。