编译工具:CMake(七) | cmake 常用变量和常用环境变量
- [cmake 变量引用方式](#cmake 变量引用方式)
- [cmake 自定义变量的方式](#cmake 自定义变量的方式)
- [cmake 常用变量总结](#cmake 常用变量总结)
cmake 变量引用方式
cmake使用${}
进行变量的引用。
在 IF
等语句中,是直接使用变量名而不通过${}
取值
cmake 自定义变量的方式
主要有两种方式:
- 隐式定义
- 显式定义
隐式定义的例子:就是 PROJECT
指令,他会隐式的定义<projectname>_BINARY_DIR
和<projectname>_SOURCE_DIR
两个变
量。
显式定义的例子:使用 SET 指令,就可以构建一个自定义变量了。
cmake 常用变量总结
c
CMAKE_BINARY_DIR
PROJECT_BINARY_DIR
<projectname>_BINARY_DIR
这三个变量指代的内容是一致的,如果是 in source 编译 ,指得就是工程顶层目录,如果是 out-of-source 编译,指的是工程编译发生的目录。PROJECT_BINARY_DIR 跟其他指令稍有区别。
c
CMAKE_SOURCE_DIR
PROJECT_SOURCE_DIR
<projectname>_SOURCE_DIR
这三个变量指代的内容是一致的,不论采用何种编译方式,都是工程顶层目录。也就是在 in source 编译时,他跟 CMAKE_BINARY_DIR
等变量一致。
PROJECT_SOURCE_DIR
跟其他指令稍有区别,现在,你可以理解为他们是一致的。
CMAKE_CURRENT_SOURCE_DIR
指的是当前处理的 CMakeLists.txt 所在的路径,比如上面我们提到的 src 子目录。
c
CMAKE_CURRRENT_BINARY_DIR
如果是 in-source 编译,它跟 CMAKE_CURRENT_SOURCE_DIR
一致,如果是 out-of-source 编译,他指的是 target 编译目录。
使用我们上面提到的 ADD_SUBDIRECTORY(src bin)
可以更改这个变量的值。
使用 SET(EXECUTABLE_OUTPUT_PATH <新路径>)
并不会对这个变量造成影响,它仅仅修改了最终目标文件存放的路径。
c
CMAKE_CURRENT_LIST_FILE
输出调用这个变量的 CMakeLists.txt 的完整路径
c
CMAKE_CURRENT_LIST_LINE
输出这个变量所在的行
c
CMAKE_MODULE_PATH
这个变量用来定义自己的 cmake 模块所在的路径。如果你的工程比较复杂,有可能会自己编写一些 cmake 模块,这些 cmake 模块是随你的工程发布的,为了让 cmake 在处理CMakeLists.txt 时找到这些模块,你需要通过 SET 指令,将自己的 cmake 模块路径设置一下。比如SET(CMAKE_MODULE_PATH ${PROJECT_SOURCE_DIR}/cmake)
这时候你就可以通过 INCLUDE 指令来调用自己的模块了。
c
EXECUTABLE_OUTPUT_PATH 和 LIBRARY_OUTPUT_PATH
分别用来重新定义最终结果的存放目录,前面我们已经提到了这两个变量。
c
PROJECT_NAME
返回通过 PROJECT 指令定义的项目名称。