当前位置: 首页 > news >正文

cmake_file(GLOB)详解

文章目录

  • 第二章 CMake基础语法
    • 2.9 file()
      • 2.9.1 file子命令
      • 2.9.2 GLOB/GLOB_RECURSE子命令的使用
      • 2.9.3 写文件 (WRITE / APPEND)
      • 2.9.4读文件 (READ / STRINGS)
      • 2.9.5 复制/重命名/删除(COPY/RENAME/REMOVE)
      • 2.9.6 file部分完整测试代码

本文介绍cmake的file()文件操作函数,该函数功能强大,可以读文件,写文件,复制,删除,重命名等操作。

第二章 CMake基础语法

2.9 file()

file() 是 CMake 中功能最强大的命令之一,用于执行各种文件系统操作(读写、搜索、复制等)。

2.9.1 file子命令

使用file(GLOB|GLOB RECURSE )命令匹配文件列表;
子命令:

GLOB I GLOB_RECURSE : 生成与匹配的文件列表。GLOB 不搜索子目录;GLOB_RECURSE 会递归搜索子目录; WRITE 写入内容到文件中 MAKE DIRECTORY 创建给定的目录及其父目录。 REMOVE 删除给定的文件 COPY_FILE 复制文件 RELATIVE_PATH 计算相对路径。

2.9.2 GLOB/GLOB_RECURSE子命令的使用

使用GLOB/GLOB_RECURSE 来代替aux_source_directory 搜索目录下的文件。aux_source_directory只是搜索指定目录下的源文件;而FILE(GLOB)可以通过通配符搜索目录下的所有文件。
GLOB: 搜索当前目录符合模式的文件。
GLOB_RECURSE: 递归搜索子目录。
语法格式如下:

file(GLOB<variable>[LIST_DIRECTORIEStrue|false][RELATIVE<path>][CONFIGURE_DEPENDS]<globbing-expressions>...)
参数说明:

参数1:: 存储搜索结果的变量名。
参数2:[LIST_DIRECTORIES true|false]:是否在结果列表中包含目录。默认为 true。如果只想获取文件,可以设置为 false。
参数3:[RELATIVE]: 让返回的文件路径相对于指定的,而不是绝对路径。${CMAKE_CURRENT_SOURCE_DIR} 作为相对基准。
参数4:[CONFIGURE_DEPENDS] (重要:CMake 3.12+):解决 GLOB 不会自动更新的问题。
如果加上这个参数,CMake 会在构建时检查目录内容。如果增加了新文件,构建系统会自动重新运行 CMake 来更新文件列表。
示例:

file(GLOB SOURCES CONFIGURE_DEPENDS"*.cpp")

[FOLLOW_SYMLINKS] (仅限 GLOB_RECURSE):
是否递归进入符号链接指向的目录。
参数5::匹配模式,可以写多个。
.cpp:匹配所有 C++ 源文件。
src/
.h:匹配 src 目录下所有头文件。
test?.cpp:匹配 test1.cpp, test2.cpp 等(? 匹配单个字符)。
代码文件结构:

cmake_minimum_required(VERSION3.30)project(testfile VERSION1.0LANGUAGES CXX)# GLOBfile(GLOB SOURCES"*.cpp")message("SOURCES =${SOURCES}")# SOURCES = E:/cmakeLearning/chap2/5file/main.cpp;# E:/cmakeLearning/chap2/5file/mycul.cpp# 可以看出,搜索到了两个.cpp文件。# GLOB_RECURSE# file(GLOB_RECURSE ALL_SOURCES RELATIVE "./build" "*.cpp")file(GLOB_RECURSE ALL_SOURCES RELATIVE${CMAKE_CURRENT_SOURCE_DIR}CONFIGURE_DEPENDS"*.cpp")message("ALL_SOURCES =${ALL_SOURCES}")#[[ALL_SOURCES=a/a.cpp;build/CMakeFiles/4.2.1/CompilerIdCXX/CMakeCXXCompilerId.cpp;main.cpp;mycul.cpp]]# 可以发现,递归搜索出了目录下面的所有.cpp文件add_executable(testfile${SOURCES})

2.9.3 写文件 (WRITE / APPEND)

WRITE: 写入内容(覆盖原文件)。
APPEND: 在末尾追加内容。

message("###############################")file(WRITE"version.txt""hello cmake")#追加file(APPEND"version.txt""\nhello APPEND")

WRITE测试结果:会在当前目录下面生成一个version.txt文件,并在该文件中插入 hello cmake字符串。
APPEND测试结果:会在version.txt文件中,添加 hello APPEND字符串,结果如下:

2.9.4读文件 (READ / STRINGS)

READ: 读取整个文件内容。
STRINGS: 按行读取,适合处理配置文件。
下面分别测试

# 读文件file(READ"version.txt"CONTENTS)message("CONTENTS =${CONTENTS}")#[[CONTENTS=hello cmake hello APPEND]]# 按行读file(STRINGS"version.txt"lines)message("line =${lines}")# line = hello cmake;hello APPEND

2.9.5 复制/重命名/删除(COPY/RENAME/REMOVE)

拷贝测试:拷贝一份version.txt 到指定的目录下。

# 拷贝一份file(COPY"version.txt"DESTINATION"${CMAKE_CURRENT_SOURCE_DIR}/a/version.txt")

重命名测试:

# 重命名:将 a/version.txt 重命名为 a/version2.txtfile(RENAME"${CMAKE_CURRENT_SOURCE_DIR}/a/version.txt""${CMAKE_CURRENT_SOURCE_DIR}/a/version2.txt")

输出文件测试:删除指定的文件

# 删除文件或目录file(REMOVE"${CMAKE_CURRENT_SOURCE_DIR}/a/version2.txt")

2.9.6 file部分完整测试代码

cmake_minimum_required(VERSION3.30)project(testfile VERSION1.0LANGUAGES CXX)# GLOBfile(GLOB SOURCES"*.cpp")message("SOURCES =${SOURCES}")# SOURCES = E:/cmakeLearning/chap2/5file/main.cpp;# E:/cmakeLearning/chap2/5file/mycul.cpp# 可以看出,搜索到了两个.cpp文件。# GLOB_RECURSE# file(GLOB_RECURSE ALL_SOURCES RELATIVE "./build" "*.cpp")file(GLOB_RECURSE ALL_SOURCES RELATIVE${CMAKE_CURRENT_SOURCE_DIR}CONFIGURE_DEPENDS"*.cpp")message("ALL_SOURCES =${ALL_SOURCES}")#[[ALL_SOURCES=a/a.cpp;build/CMakeFiles/4.2.1/CompilerIdCXX/CMakeCXXCompilerId.cpp;main.cpp;mycul.cpp]]# 可以发现,递归搜索出了目录下面的所有.cpp文件message("###############################")file(WRITE"version.txt""hello cmake")#追加file(APPEND"version.txt""\nhello APPEND")# 读文件file(READ"version.txt"CONTENTS)message("CONTENTS =${CONTENTS}")#[[CONTENTS=hello cmake hello APPEND]]# 按行读file(STRINGS"version.txt"lines)message("line =${lines}")# line = hello cmake;hello APPEND# 拷贝一份#file(COPY "version.txt" DESTINATION "${CMAKE_CURRENT_SOURCE_DIR}/a/version.txt")# 重命名:将 a/version.txt 重命名为 a/version2.txt# file(RENAME "${CMAKE_CURRENT_SOURCE_DIR}/a/version.txt" "${CMAKE_CURRENT_SOURCE_DIR}/a/version2.txt")# 删除文件或目录file(REMOVE"${CMAKE_CURRENT_SOURCE_DIR}/a/version2.txt")add_executable(testfile${SOURCES})
http://www.cnnetsun.cn/news/164882.html

相关文章:

  • 5分钟搭建python八股文原型
  • DeskGo实战:打造个人效率工作台的5个案例
  • Java新手必看:5分钟学会File转MultipartFile
  • AI自动生成BAT清理脚本:告别手动写代码
  • 【稀缺技术曝光】:Open-AutoGLM内部协同算法首次公开,仅限本次解读
  • 数字人疲劳感规避:Linly-Talker表情多样性优化
  • CSS nth-child在电商网站商品列表中的实战应用
  • 数字人交互延迟优化:Linly-Talker实时性提升方案
  • 产品经理学AI-9:AI黑话秒懂指南,Embedding
  • 5分钟快速验证:免安装体验npm功能的创新方案
  • Linly-Talker能否实现双语交替讲解视频生成?
  • 上周AI要闻:美国机器人出租车竞赛与AI商业动态
  • 从部署到调优全流程拆解,掌握Open-AutoGLM高效适配的7个秘密步骤
  • 深入解析最长公共子序列(LCS):三种实现方法与性能对比
  • 比fastestmirror快30%!新一代AI镜像选择算法
  • Java开发者如何切入大模型时代?一文掌握LLM开发核心路径
  • Linly-Talker在机场航站楼引导服务中的试点成果
  • 远程办公新工具:Linly-Talker生成会议发言数字人
  • 1小时搭建自定义软件源测速工具
  • 黑客入门——最好用的渗透测试工具
  • Docusaurus vs 传统文档工具:效率对比实测
  • 渗透测试全流程实操!零基础入门到精通,收藏这一篇就够了_渗透测试实战
  • Open-AutoGLM如何重塑手机AI?:3年演进路线图首次曝光
  • 2025年安徽省职业院校技能大赛(高职组)信息安全管理与评估竞赛任务书
  • 超越基础:深入探索 pyttsx3 的架构、缺陷与高阶实践
  • 告别手动编号!Word公式自动化技巧大公开
  • Open-AutoGLM + IoT 联动架构设计精要,资深专家20年经验倾囊相授
  • 用NVIDIA Container Toolkit快速验证AI创意
  • 柯尼卡美能达 CS-1000 分光辐射辉度计
  • 从零开始:用Keil uVision5开发智能温控系统实战