Mac下CMakeLists.txt檔案的使用快速入門(一)
在用Cmake編譯檔案,發現需要自己動手寫CMakeLists.txt檔案,簡單研究了下,記錄如下:
一、介紹
CMake是一種跨平臺編譯工具,比make更為高階,使用起來要方便得多。CMake主要是編寫CMakeLists.txt檔案,然後用cmake命令將CMakeLists.txt檔案轉化為make所需要的makefile檔案,最後用make命令編譯原始碼生成可執行程式或共享庫。
二、語法
1. #註釋
2. 變數:使用set命令顯式定義及賦值,在非if語句中,使用${}引用,if中直接使用變數名引用;後續的set命令會清理變數原來的值;
3. command (args ...) 命令不分大小寫,引數使用空格分隔,使用雙引號引起引數中空格
4. set(var a;b;c) <=> set(var a b c) 定義變數var並賦值為a;b;c這樣一個string list
5. Add_executable(${var}) <=> Add_executable(a b c) 變數使用${xxx}引用
6. 條件語句:if(var) else()/elseif() … endif(var),非運算的話使用NOT,即:if(NOT var)
7. 迴圈語句
Set(VAR a b c)
Foreach(f ${VAR}) …Endforeach(f)
8. 迴圈語句
WHILE() … ENDWHILE()
二、內部變數
CMAKE_C_COMPILER:指定C編譯器
CMAKE_CXX_COMPILER:
CMAKE_C_FLAGS:編譯C檔案時的選項,如-g;也可以通過add_definitions新增編譯選項
EXECUTABLE_OUTPUT_PATH:可執行檔案的存放路徑
LIBRARY_OUTPUT_PATH:庫檔案路徑
CMAKE_BUILD_TYPE::build 型別(Debug, Release, ...),CMAKE_BUILD_TYPE=Debug
BUILD_SHARED_LIBS
三、命令
project (HELLO) #指定專案名稱,生成的VC專案的名稱;
>>使用${HELLO_SOURCE_DIR}表示專案根目錄
include_directories:指定標頭檔案的搜尋路徑,相當於指定gcc的-I引數
>> include_directories (${HELLO_SOURCE_DIR}/Hello) #增加Hello為include目錄
link_directories:動態連結庫或靜態連結庫的搜尋路徑,相當於gcc的-L引數
>> link_directories (${HELLO_BINARY_DIR}/Hello) #增加Hello為link目錄
add_subdirectory:包含子目錄
>> add_subdirectory (Hello)
add_executable:編譯可執行程式,指定編譯,好像也可以新增.o檔案
>> add_executable (helloDemo demo.cxx demo_b.cxx) #將cxx編譯成可執行檔案——
add_definitions:新增編譯引數
>> add_definitions(-DDEBUG)將在gcc命令列新增DEBUG巨集定義;
>> add_definitions( “-Wall -ansi –pedantic –g”)
target_link_libraries:新增連結庫,相同於指定-l引數
>> target_link_libraries(demo Hello) #將可執行檔案與Hello連線成最終檔案demo
add_library:
>> add_library(Hello hello.cxx) #將hello.cxx編譯成靜態庫如libHello.a
add_custom_target:
message( status|fatal_error, “message”):
set_target_properties( ... ): lots of properties... OUTPUT_NAME, VERSION, ....
link_libraries( lib1 lib2 ...): All targets link with the same set of libs
待續。。。