当前位置: 首页 > 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.rkmt.cn/news/125919.html

相关文章:

  • 2025年断桥铝门窗厂家权威推荐榜单:系统门窗品牌/品牌系统门窗/系统门窗型材源头厂家精选 - 品牌推荐官
  • Open-AutoGLM奖励机制揭秘:为什么顶尖开发者都在抢名额?
  • Linly-Talker在消防演练教学中的沉浸式应用
  • 【独家分析】Open-AutoGLM商业化布局:2024年最值得关注的开源AI赛道突围案例
  • python八股文零基础入门指南
  • 联邦学习+同态加密+差分隐私,Open-AutoGLM的三大护城河,你了解吗?
  • 2025年靠谱UPS系统服务排名,UPS系统调试服务哪家好? - mypinpai
  • 【Open-AutoGLM安全防线构建指南】:5步实现模型推理中的数据零泄露
  • 零基础玩转Docusaurus:小白也能建专业文档站
  • 2025年西北旅游极力推荐的冷门景点年度排名:西北旅游景点游玩路线分享 - myqiye
  • 3分钟解决cryptography库版本问题:新旧版本对比
  • CSS nth-child在电商网站商品列表中的实战应用
  • 2025年靠谱封包机生产厂排名,封包机哪个牌子更可靠、质量好测评推荐 - 工业推荐榜
  • Open-AutoGLM硬件适配进展通报:90%主流GPU明年Q1完成驱动支持
  • 一文讲透普通人的AI学习路径,从0到100的通关指南
  • Git小白也能懂的提交修正指南
  • Linly-Talker能否支持4K高清输出?画质升级方案
  • 传统VS AI:DeskGo开发效率提升300%的秘密
  • AI助力Java文件转换:File转MultipartFile全自动方案
  • Open-AutoGLM合规之路(监管风暴下的AI模型生存指南)
  • Linly-Talker在医疗器械操作培训中的标准化应用
  • 【好写作AI】文献焦虑终结者:如何用AI 3分钟精准梳理文献核心与争议
  • Linly-Talker用户反馈汇总:最受欢迎的三大功能
  • 为什么90%的AI项目 failed?Open-AutoGLM多智能体协作给出答案(稀缺架构曝光)
  • AI帮你自动优化Windows系统:快马一键生成实用设置工具
  • 如何通过提示词工程优化Linly-Talker对话质量?
  • 2025年本地采购指南:恒温恒湿箱优质厂商TOP10,恒温恒湿房/高温老化试验箱/盐水喷雾试验箱及各种老化房恒温恒湿箱供应商推荐排行 - 品牌推荐师
  • 如何利用容器化部署提升Linly-Talker可维护性?
  • 靠谱的轮胎品牌哪家好:官方精选可靠品牌指南 - 品牌测评家
  • 基于springboot + vue物业管理系统