熟悉 CMake(二)—— 以一個實例說明 CMakeLists txt 文件的編寫
阿新 • • 發佈:2018-12-27
語法 項目構建工具 易懂 支持 list rec prope span 信息
原文請見 cmake使用總結(轉)—工程主目錄CMakeList文件編寫
在 Linux 下進行開發很多人選擇編寫 makefile 文件進行項目環境搭建,而makefile 文件依賴關系復雜,工作量很大。采用自動化的項目構建工具 CMake 可以將程序員從復雜的 makefile 文件中解脫出來。CMake
- 根據內置的規則和語法來自動生成相關的 makefile 文件進行編譯,
- 同時還支持靜態庫和動態庫的構建
具體cmake的介紹和詳細語法還是參考官方文檔(http://www.cmake.org/)。
使用 cmake 很簡單,只需要執行 cmake, make 兩個命令即可,考慮如下的項目結構。
假設當前的項目代碼在 src 目錄。 src 下有如下子目錄(subdirectory):
- server —– 存放項目的主功能類文件
- utility —– 存放項目要用到相關庫文件,便已成為庫文件存放到子目錄lib 中
- lib —– 存放utility 生成的庫
- bin —– 存放association 生成的二進制文件
- build —– 編譯目錄,存放編譯生成的中間文件
cmake 要求工程主目錄和所有存放源代碼子目錄下都要編寫CMakeLists.txt 文件,註意大小寫.
-
(1)src/CMakeLists.txt 文件如下:
CMAKE_MINIMUM_REQUIRED(VERSION 2.8
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
-
(2)子目錄 Utility 下的 CMakeLists.txt 文件如下
SET(SOURCE_FILES ConfigParser.cpp StrUtility.cpp) # 設置變量,表示所有的源文件 INCLUDE_DIRECTORIES(/usr/local/include ${PROJET_SOURCE_DIR}/utility) # 相關頭文件的目錄 LINK_DIRECTORIES(/usr/local/lib) # 相關庫文件的目錄 ADD_LIBRARY(association ${SOURCE_FILES}) # 生成靜態鏈接庫libassociation.a TARGET_LINK_LIBRARY(association core) # 依賴的庫文件 SET_TARGET_PROPERTIES(utility PROPERTIES # 表示生成的執行文件所在路徑 RUNTIME_OUTPUT_DIRECTORY> "${PROJECT_SOURCE_DIR}/lib")
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
再分享一下我老師大神的人工智能教程吧。零基礎!通俗易懂!風趣幽默!還帶黃段子!希望你也加入到我們人工智能的隊伍中來!https://www.cnblogs.com/captainbed
熟悉 CMake(二)—— 以一個實例說明 CMakeLists txt 文件的編寫