cmake (2)build方面的指令
生活随笔
收集整理的這篇文章主要介紹了
cmake (2)build方面的指令
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1.
add_exectuable 告訴工程生成一個可執行文件
add_library 則告訴生成一個庫文件,構建動態庫和靜態庫
eg.
#生成應用程序 hello ADD_EXECUTABLE(hello ${SRC_LIST})eg.
project(helloso) set(LIB_SRC hello.c) add_library(${PROJECT_NAME} SHARED ${LIB_SRC})//動態庫1.1 參數也可以使用分號來進行分割
eg.
ADD_EXECUTABLE(t1 main.c t1.c)可以寫成 ADD_EXECUTABLE(t1 main.c;t1.c)1.2 ADD_LIBRARY
ADD_LIBRARY(libname [SHARED|STATIC|MODULE][EXCLUDE_FROM_ALL] source1 source2 … sourceN)
不需要寫全 libhello.so,只需要填寫 hello 即可,cmake 系統會自動生成libhello.X的類型有三種:
- SHARED,動態庫
- STATIC,靜態庫
- MODULE,在使用 dyld 的系統有效,如果不支持 dyld,則被當作 SHARED 對待。
- EXCLUDE_FROM_ALL 參數的意思是這個庫不會被默認構建,除非有其他的組件依賴或者手
工構建。
eg.
#構建一個 libhello_static.a 的靜態庫了 ADD_LIBRARY(hello_static STATIC ${LIBHELLO_SRC})1.3 SET
引號SET(SRC_LIST “func.c”)
忽略掉 source 列表中的源文件后綴
#cmake 會自動的在本目錄查找 main.c 或者 main.cpp
ADD_EXECUTABLE(t1 main)
1.4 動態庫版本號
SET_TARGET_PROPERTIES(hello PROPERTIES VERSION 1.2 SOVERSION 1)
VERSION 指代動態庫版本,SOVERSION 指代 API 版本。
eg.
在 build/lib 目錄會生成: libhello.so.1.2 libhello.so.1->libhello.so.1.2 libhello.so ->libhello.so.1總結
以上是生活随笔為你收集整理的cmake (2)build方面的指令的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: cmake (2)指令说明
- 下一篇: cmake (2)其他指令