1. 程式人生 > >Mac下CMakeLists.txt檔案的使用快速入門(一)

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

: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

待續。。。