美文网首页
CMake获取属性命令get_property简介

CMake获取属性命令get_property简介

作者: Domibaba | 来源:发表于2023-09-16 11:40 被阅读0次

CMake中有很多内置的变量,以CMAKE_开头,本文要介绍的是另外一种“变量”,叫做属性,它与一个范围绑定。当CMake添加一个目录、创建一个目标、创建缓存条目、创建测试、创建安装目录时,也同时会生成与这些范围相关联的属性(范围可以关联多个不同属性)。属性无法通变量的获取方式${}直接得到,需要使用本文介绍的get_propery()命令进行获取。

命令简介

命令格式为:

get_property(<variable>
<GLOBAL |
DIRECTORY [<dir>] |
TARGET <target> |
SOURCE <source>
[DIRECTORY <dir> | TARGET_DIRECTORY <target>] |
INSTALL <file> |
TEST <test> |
CACHE <entry> |
VARIABLE >
PROPERTY <name>
[SET | DEFINED | BRIEF_DOCS | FULL_DOCS])

命令的第一个参数<variable>是存储属性获取的结果,第二个参数表示待获取的属性归属的范围,第三个参数是PROPERTY选项后面跟着属性的名称(可以是CMake默认定义的属性,也可以自定义属性)。

简单的示例

例如,当CMake读取CMakeLists.txt文件启动构建时,会对CMakeLists.txt文件所在的目录,添加一个名为INCLUDE_DIRECTORIES属性,表示在CMake位于当前目录下的头文件搜索目录列表(通过include_directories()命令CMake会为该属性赋值),下面来简单演示下如何获取这个属性。

CMakeLists.txt文件内容:

cmake_minimum_required(VERSION 3.22.1)
project(get_property_test)

get_property(dirs DIRECTORY ${CMAKE_CURRENT_SRC_DIR} PROPERTY INCLUDE_DIRECTORIES)
message("# Get current directory property INCLUDE_DIRECTORIES: ${dirs}")

include_directories(test)
get_property(dirs DIRECTORY ${CMAKE_CURRENT_SRC_DIR} PROPERTY INCLUDE_DIRECTORIES)
message("# Get current directory property INCLUDE_DIRECTORIES after include 'test': ${dirs}")

运行cmake .输出结果:

# Get current directory property INCLUDE_DIRECTORIES: 
# Get current directory property INCLUDE_DIRECTORIES after include 'test': /XXX/test

说明在使用include_directories(test)后,当前目录的属性INCLUDE_DIRECTORIES被修改了,把test目录增加了进去。

参数详解

范围参数

指定的范围必须是如下的选项之一:

  • GLOBAL

    全局范围,后面不需要指定范围名称。使用该选项时,等同于命令get_cmake_property,可以参考get_cmake_property命令介绍。

    获取CMAKE_ROLE全局属性:

    cmake_minimum_required(VERSION 3.22.1)
    project(get_property_test)
    
    get_property(role GLOBAL PROPERTY CMAKE_ROLE)
    message("# Get GLOBAL property CMAKE_ROLE: ${role}")
    

    输出结果

    $ cmake .
    # Get GLOBAL property CMAKE_ROLE: PROJECT
    
  • DIRECTORY

    目录范围,如果选项后不指定目录名称,默认是当前目录。指定的目录可以使绝对路径也可以是相对路径,如果是相对路径,那么是相对于当前的目录路径。该选项等同于命令get_directory_property。

  • TARGET

    获取指定构建目标的属性,等同于命令get_target_property()。

    获取NAME属性

    cmake_minimum_required(VERSION 3.22.1)
    project(get_property_test)
    
    add_executable(hello .)
    get_property(target_name TARGET hello PROPERTY NAME)
    message("# Get target property NAME: ${target_name}")
    

    输出结果

    # Get GLOBAL property CMAKE_ROLE: PROJECT
    
  • SOURCE

    获取指定源文件属性,该参数后面必须跟一个源文件名,默认情况下,源文件的属性会赋值当前源文件所在目录的属性。目录也可以通过选项进行指定。

    • DIRECTORY <dir>:从指定的<dir>目录获取属性,前提是该目录是已经通过add_subdirectory()添加或者是CMake构建的顶层目录。如果是相对路径,则是针对当前目录的相对路径。
    • TARGET_DIRECTORY <target>:从构建目标<target>被创建的目录中获取属性,前提是<target>必须已经存在(通过add_executable或add_libraray创建)
  • INSTALL

    获取指定安装目录的属性。

  • TEST

    获取指定测试的属性。

  • CACHE

    获取缓存条目的属性。

  • VARIABLE

    获取变量的属性。

其他参数选项

  • SET

    如果指定SET选项,则获取的变量,表示的是属性是否被设置过,是一个布尔值。

  • DEFINED

    如果指定DEFINED选项,则获取的变量,表示的是属性是否被定义,是一个布尔值。

  • BRIEF_DOCS或FULL_DOCS

    如果指定了这两个选型,则获取的变量是一个属性文档的字符串。

相关文章

  • cmake 常见命令

    cmake cmake_minimum_required命令语法:cmake_minimum_required(V...

  • CMake项目中集成gtest

    使用cmake的ExternalProject_Add相关命令,实现源码获取、编译、集成到本地项目中的动态集成,不...

  • 编译:CMAKE

    CMAKE 0、CMake CMake中,我们先输入cmake 命令对工程进行分析,生成makefile文件; 然...

  • Libde265Mac&iOS平台源码编译

    Mac平台下编译 1.获取源码 2.安装cmake命令行工具 3.cmake创建工程 -2,3两步具体步骤可参看我...

  • CMake 学习笔记

    引子Make or CMake,What's different?CMake简介[附]CMake常用指令 引子 人...

  • vue多环境打包

    方法1 node属性process.argv 改属性为node执行命令获取到的命令集合 如打包命令为npm bui...

  • 05-命令行参数

    通过os包获取命令行参数 获取方法导入os包然后通过os包的Args属性获取命令行参数package mainim...

  • OpenPose在服务器下配置过程

    OpenPose安装 新版CMake命令 cmake -DOpenCV_CONFIG_FILE=/mnt/sdb/...

  • cmake 简介

    转自http://tzc.is-programmer.com/show/476.html CMake是一个跨平台的...

  • cmake简介

    著名的OpenCV采用了cmake作为工程的编译工具,下面简单介绍一下cmake CMakeLists.txt c...

网友评论

      本文标题:CMake获取属性命令get_property简介

      本文链接:https://www.haomeiwen.com/subject/gaahvdtx.html