在用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:Switch between shared and static libraries
三、命令
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
待續。。。