cmake变量整理

CMake常用变量与使用技巧详解

1. cmake常用变量及使用方法

1.1. 简介

1.2. cmake 变量引用的方式

前面我们已经提到了,使用${}进行变量的引用。在 if 等语句中,是直接使用变量名而不通过${}取值

1.3. cmake 自定义变量的方式

主要有隐式定义和显式定义两种,一个隐式定义的例子,就是 PROJECT 指令,他会隐式的定义<projectname>_BINARY_DIR<projectname>_SOURCE_DIR 两个变量。
显式定义的例子使用 SET 指令,就可以构建一个自定义变量了。
比如:SET(HELLO_SRC main.SOURCE_PATH),就可以通过 ${HELLO_SRC} 来引用这个自定义变量了.

1.4. cmake 常用变量

  1. CMAKE_BINARY_DIR  PROJECT_BINARY_DIR <projectname>_BINARY_DIR

    这三个变量指代的内容是一致的,如果是 in source 编译,指得就是工程顶层目录,如果是 out-of-source 编译,指的是工程编译发生的目录。PROJECT_BINARY_DIR 跟其他指令稍有区别,现在,你可以理解为他们是一致的。

  2. CMAKE_SOURCE_DIR PROJECT_SOURCE_DIR <projectname>_SOURCE_DIR

    这三个变量指代的内容是一致的,不论采用何种编译方式,都是工程顶层目录。也就是在 in source 编译时,他跟 CMAKE_BINARY_DIR 等变量一致。PROJECT_SOURCE_DIR 跟其他指令稍有区别,现在,你可以理解为他们是一致的。

  3. CMAKE_CURRENT_SOURCE_DIR

    指的是当前处理的 CMakeLists.txt 所在的路径,比如上面我们提到的 src 子目录。

  4. CMAKE_CURRRENT_BINARY_DIR

    如果是 in-source 编译,它跟 CMAKE_CURRENT_SOURCE_DIR 一致,如果是 out-of-source 编译,他指的是 target 编译目录。
    使用 ADD_SUBDIRECTORY(src bin) 可以更改这个变量的值。
    使用 SET(EXECUTABLE_OUTPUT_PATH <新路径>)并不会对这个变量造成影响,它仅仅修改了最终目标文件存放的路径。

  5. CMAKE_CURRENT_LIST_FILE

    输出调用这个变量的 CMakeLists.txt 的完整路径

  6. CMAKE_CURRENT_LIST_LINE

    输出这个变量所在的行

  7. CMAKE_MODULE_PATH

    这个变量用来定义自己的 cmake 模块所在的路径。如果你的工程比较复杂,有可能会自己编写一些 cmake 模块,这些 cmake 模块是随你的工程发布的,为了让 cmake 在处理 CMakeLists.txt 时找到这些模块,你需要通过 SET 指令,将自己的 cmake 模块路径设置一下。
    比如:
    SET(CMAKE_MODULE_PATH ${PROJECT_SOURCE_DIR}/cmake)
    这时候你就可以通过 INCLUDE 指令来调用自己的模块了。

  8. EXECUTABLE_OUTPUT_PATHLIBRARY_OUTPUT_PATH

    分别用来重新定义最终结果的存放目录。

  9. PROJECT_NAME

    返回通过 PROJECT 指令定义的项目名称。

  10. CMAKE_INCLUDE_CURRENT_DIR

    自动添加 CMAKE_CURRENT_BINARY_DIR 和 CMAKE_CURRENT_SOURCE_DIR 到当前处理的 CMakeLists.txt。相当于在每个 CMakeLists.txt 加入:
    INCLUDE_DIRECTORIES(${CMAKE_CURRENT_BINARY_DIR} ${CMAKE_CURRENT_SOURCE_DIR}),默认是OFF

  11. CMAKE_INCLUDE_DIRECTORIES_PROJECT_BEFORE

    将工程提供的头文件目录始终至于系统头文件目录的前面,当你定义的头文件确实跟系统发生冲突时可以提供一些帮助。

  12. CMAKE_INCLUDE_PATHCMAKE_LIBRARY_PATH

    CMAKE_LIBRARY_PATH,用分号分隔的目录列表,指定find_library()命令的搜索路径。默认情况下它是空的,它是由项目设置的。参见CMAKE_SYSTEM_LIBRARY_PATH和CMAKE_PREFIX_PATH。
    CMAKE_INCLUDE_PATH,用分号分隔的目录列表,其中指定find_file()和find_path()命令的搜索路径。默认情况下它是空的,它是由项目设置的。参见CMAKE_SYSTEM_INCLUDE_PATH和CMAKE_PREFIX_PATH。

1.5. cmake 调用环境变量的方式

使用$ENV{NAME}指令就可以调用系统的环境变量了。
比如:MESSAGE(STATUS “HOME dir: $ENV{HOME}”)

设置环境变量的方式是:
SET(ENV{变量名} 值)

1.6. 系统信息

  1. CMAKE_MAJOR_VERSION,CMAKE 主版本号,比如 2.4.6 中的 2
  2. CMAKE_MINOR_VERSION,CMAKE 次版本号,比如 2.4.6 中的 4
  3. CMAKE_PATCH_VERSION,CMAKE 补丁等级,比如 2.4.6 中的 6
  4. CMAKE_SYSTEM,系统名称,比如 Linux-2.6.22
  5. CMAKE_SYSTEM_NAME,不包含版本的系统名,比如 Linux
  6. CMAKE_SYSTEM_VERSION,系统版本,比如 2.6.22
  7. CMAKE_SYSTEM_PROCESSOR,处理器名称,比如 i686.
  8. UNIX,在所有的类 UNIX 平台为 TRUE,包括 OS X 和 cygwin
  9. WIN32,在所有的 win32 平台为 TRUE,包括 cygwin

1.7. 主要的开关选项

  1. CMAKE_ALLOW_LOOSE_LOOP_CONSTRUCTS
    用来控制 IF ELSE 语句的书写方式
  2. BUILD_SHARED_LIBS
    这个开关用来控制默认的库编译方式,如果不进行设置,使用 ADD_LIBRARY 并没有指定库类型的情况下,默认编译生成的库都是静态库。
    如果 SET(BUILD_SHARED_LIBS ON)后,默认生成的为动态库。
  3. CMAKE_C_FLAGS
    设置 C 编译选项,也可以通过指令 ADD_DEFINITIONS()添加。
  4. CMAKE_CXX_FLAGS
    设置 C++编译选项,也可以通过指令 ADD_DEFINITIONS()添加。

1.8. 参考资料

  1. cmake 常用变量和常用环境变量查表手册
<think>好的,我现在需要帮助用户在Ubuntu系统中设置CMake的环境变量。首先,我得回忆一下用户提供的引用内容,看看里面有没有相关的信息。用户提供了五个引用,其中引用[1]、[3]、[4]、[5]提到了CMake的安装和环境变量配置。 引用[1]和[4]提到使用apt-get安装CMakecmake-qt-gui,但这种方法安装的版本可能较低。如果需要更高版本,可能需要通过源码安装。引用[3]讨论了源码安装CMake的好处,但没有具体步骤。引用[5]则给出了通过修改.bashrc文件来设置环境变量的例子,比如使用cat命令将环境文件追加到.bashrc,并执行source命令使其生效。 接下来,我需要整理在Ubuntu中设置环境变量的常见方法。通常,环境变量可以设置在~/.bashrc、~/.profile、/etc/profile等文件中,或者通过export命令临时设置。对于CMake来说,如果用户是源码安装的,可能需要将CMake的安装路径添加到PATH变量中,这样系统就能找到cmake命令。 例如,如果用户将CMake安装在/usr/local/cmake-3.25.1目录下,那么需要将bin目录添加到PATH。具体步骤可能包括编辑~/.bashrc文件,添加一行类似export PATH=/usr/local/cmake-3.25.1/bin:$PATH,然后运行source ~/.bashrc使更改生效。引用[5]中的例子使用了类似的方法,所以应该适用。 另外,用户可能还需要设置其他环境变量,如CMAKE_PREFIX_PATH,这取决于他们的项目需求。比如,当项目依赖某些库时,可能需要指定这些库的路径,帮助CMake找到它们。 需要注意不同安装方式的环境变量配置差异。如果用户通过apt-get安装,CMake可能已经自动添加到PATH中,无需手动设置。但如果是源码安装,手动添加是必要的。引用[1]和[4]提到通过apt安装的版本可能较低,所以如果用户安装的是更高版本的源码,这部分配置就很重要。 另外,引用[2]提到环境变量设置无效的问题,可能需要检查文件是否正确修改,或者是否需要重新登录或source文件。这也是需要注意的地方,避免用户设置后不生效。 总结步骤应该是:确定安装方式(apt或源码),找到CMake的安装路径,编辑相应的配置文件(如.bashrc),添加PATH,然后应用更改。同时,提醒用户验证是否生效,通过cmake --version查看版本。 可能还需要考虑是否需要设置其他变量,如CMAKE_MODULE_PATH等,但用户的问题主要关注环境变量设置,可能只需要PATH即可。需要保持回答简洁,覆盖主要方法,并引用提供的资料作为支持。</think>在Ubuntu系统中配置CMake环境变量,可通过以下步骤实现: ### 方法1:通过`~/.bashrc`文件永久设置 1. **确定CMake安装路径** 若通过源码安装(如路径为`/usr/local/cmake-3.25.1`),其可执行文件通常在`bin`目录下。 若通过apt安装(如`sudo apt-get install cmake`),路径通常为`/usr/bin/cmake`,此时无需额外配置环境变量。 2. **编辑`.bashrc`文件** 打开终端,输入: ```bash nano ~/.bashrc ``` 在文件末尾添加: ```bash export PATH="/usr/local/cmake-3.25.1/bin:$PATH" ``` 保存后执行: ```bash source ~/.bashrc ``` 此操作将CMake路径加入当前用户的`PATH`变量[^3][^5]。 --- ### 方法2:临时设置环境变量 在终端中直接运行: ```bash export PATH="/usr/local/cmake-3.25.1/bin:$PATH" ``` 此方式仅在当前终端会话有效[^2]。 --- ### 方法3:全局配置(系统级) 编辑`/etc/environment`文件,添加路径: ```bash sudo nano /etc/environment ``` 修改为: ``` PATH="/usr/local/cmake-3.25.1/bin:$PATH" ``` 需重启系统生效。 --- ### 验证配置 运行命令检查版本: ```bash cmake --version ``` 若显示指定版本(如3.25.1),则配置成功。 --- ### 特殊场景:自定义变量 若需设置`CMAKE_PREFIX_PATH`(例如指定依赖库路径): ```bash export CMAKE_PREFIX_PATH="/opt/my_libs:$CMAKE_PREFIX_PATH" ``` 可将其写入`.bashrc`实现永久生效[^5]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值