CMakeLists.txt学习笔记二
背景
对CMake常用命令的一个系统性的学习和记录。
指定cmake的最小版本
1 | cmake_minimum_required(VERSION 2.8) |
这行命令是可选的,我们可以不写这句话,但在有些情况下,如果 CMakeLists.txt 文件中使用了一些高版本 cmake 特有的一些命令的时候,就需要加上这样一行,提醒用户升级到该版本之后再执行cmake。
设置项目名称
1 | project(exampleProject) |
这个命令不是强制性的,但最好都加上。它会引入两个变量 exampleProject_BINARY_DIR 和 exampleProject_SOURCE_DIR,同时,cmake 自动定义了两个等价的变量 PROJECT_BINARY_DIR 和 PROJECT_SOURCE_DIR。还会创建PROJECT_NAME
${PROJECT_SOURCE_DIR}:本CMakeLists.txt所在的文件夹路径
${PROJECT_NAME}:本CMakeLists.txt的project名称
如果代码需要支持C++11,就直接加上这句
1 | SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++0x") |
添加编译选项
1 | add_definitions(编译选项) |
比如,如果想要生成的可执行文件拥有符号表,可以gdb调试,就直接加上这句
1 | add_definitions("-Wall -g") |
如果需要fpermissive选项
1 | ADD_DEFINITIONS("-fpermissive") |
设置变量,下面的代码都可以用到
1 | 给文件名/路径名或其他字符串起别名,用${变量}获取变量内容 |
list追加或删除变量的值
1 | set(SRC_LIST main.cpp) |
打印消息
1 | message(消息) |
编译子文件夹的CMakeLists.txt
1 | add_subdirectory(子文件夹名称) |
获取路径下所有的.cpp/.c/.cc文件,并赋值给变量中
1 | aux_source_directory(路径 变量) |
设置.h头文件的路径
1 | include_directories(路径) |
指定库文件路径
1 | link_directories(路径) |
设置编译最终结果类型
1 | 生成可执行文件 |
对add_library或add_executable生成的文件进行链接操作
1 | target_link_libraries(库文件名称/可执行文件名称 链接的库文件名称) |
安装操作
1 | 将生成的执行程序/库文件/头文件等,安装到指定路径下 |
搜索所有的cpp文件
1 | aux_source_directory(dir VAR) |
自定义搜索规则
1 | file(GLOB SRC_LIST "*.cpp" "protocol/*.cpp") |
查找指定的库文件
1 | find_library(VAR name path)查找到指定的预编译库,并将它的路径存储在变量中。 |
if…elseif…else…endif
1 | 逻辑判断和比较: |
while…endwhile循环
1 | while(condition) |
foreach…endforeach循环
1 | foreach(loop_var RANGE start stop [step]) |
预定义变量
1 | PROJECT_SOURCE_DIR:工程的根目录 |
读写环境变量
1 | 使用环境变量 |
系统信息
1 | CMAKE_MAJOR_VERSION:cmake 主版本号,比如 3.4.1 中的 3 |
主要开关选项
1 | BUILD_SHARED_LIBS:这个开关用来控制默认的库编译方式,如果不进行设置,使用 add_library 又没有指定库类型的情况下,默认编译生成的库都是静态库。如果 set(BUILD_SHARED_LIBS ON) 后,默认生成的为动态库 |
参考链接
https://blog.csdn.net/AgingMoon/article/details/123307248
//几乎全部摘抄自此链接