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
格式為
-DFOO
或-DFOO=bar
的編譯器定義的 ;-list。也會自動新增由<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,則所有與檢查相關聯的狀態訊息都將被抑制。