CMake的INSTALL FILES和INSTALL DIRECTORY有什么区别

news/2024/12/23 18:23:14 标签: cmake

在 CMake 中,install() 命令用于安装构建的目标文件、头文件、库等到指定的目标路径。install(FILES ...)install(DIRECTORY ...) 都是 install() 命令的具体用法,它们的功能和适用场景不同。

以下是两者的详细区别和用法说明:


1. install(FILES ...)

功能

  • 直接安装指定的文件到目标路径。
  • 适用于安装单个文件(如头文件、配置文件等)。

语法

install(FILES file1 file2 ... DESTINATION target_directory [OPTIONAL_ARGUMENTS])

参数说明

  • FILES: 需要安装的文件列表。
  • DESTINATION: 安装的目标路径,相对于 CMAKE_INSTALL_PREFIX
  • 可选参数:
    • PERMISSIONS: 指定文件权限(如 OWNER_READ, OWNER_WRITE 等)。
    • RENAME: 重命名文件时使用。

示例

# 将头文件安装到目标 include 目录
install(FILES header1.h header2.h DESTINATION include)

# 将文件安装到目标路径并设置权限
install(FILES config.json DESTINATION etc
    PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ
)

2. install(DIRECTORY ...)

功能

  • 递归安装整个目录的内容到目标路径。
  • 适用于安装文件夹及其子文件夹中的所有内容。

语法

install(DIRECTORY dir1 dir2 ... DESTINATION target_directory [OPTIONAL_ARGUMENTS])

参数说明

  • DIRECTORY: 需要安装的目录列表。
  • DESTINATION: 安装的目标路径,相对于 CMAKE_INSTALL_PREFIX
  • 可选参数:
    • FILES_MATCHING: 只安装符合指定模式的文件。
    • PATTERNREGEX: 用于过滤文件或目录的匹配模式。
    • EXCLUDE: 排除匹配的文件或目录。

示例

# 将目录的内容递归安装到目标路径
install(DIRECTORY my_include/ DESTINATION include)

# 只安装特定扩展名的文件(如 .h 文件)
install(DIRECTORY my_include/ DESTINATION include
    FILES_MATCHING PATTERN "*.h"
)

# 排除特定目录
install(DIRECTORY my_project/ DESTINATION project
    PATTERN "build" EXCLUDE
)

主要区别

特性install(FILES)install(DIRECTORY)
用途安装指定的单个或多个文件安装整个目录及其内容
递归处理子目录不支持支持递归安装目录及其子目录
支持过滤和模式匹配不支持支持通过 PATTERNREGEX 进行过滤
适用场景安装头文件、配置文件、库文件等安装包含多个文件或目录的资源(如源码、数据、文档等)
排除内容不支持支持使用 EXCLUDE 排除匹配的文件或目录

使用建议

  • install(FILES): 当需要安装少量的特定文件时使用。
  • install(DIRECTORY): 当需要递归安装整个目录(如头文件目录、资源目录)时使用,尤其是需要过滤或排除特定文件时。

示例:结合使用 FILESDIRECTORY

# 将单个文件安装到配置目录
install(FILES config.json DESTINATION etc)

# 将整个头文件目录安装到目标 include 目录
install(DIRECTORY my_include/ DESTINATION include)

# 仅安装特定文件类型(如 .h 和 .cpp 文件),排除子目录中的文件
install(DIRECTORY my_src/ DESTINATION src
    FILES_MATCHING PATTERN "*.h" PATTERN "*.cpp"
    PATTERN "tests" EXCLUDE
)

总结

  • 使用 install(FILES) 直接安装单个或多个文件,适合静态文件或非递归安装场景。
  • 使用 install(DIRECTORY) 递归安装整个目录,适合安装复杂的目录结构或需要文件过滤的场景。

http://www.niftyadmin.cn/n/5796802.html

相关文章

力扣150题

88. 合并两个有序数组 给你两个按 非递减顺序 排列的整数数组 nums1 和 nums2,另有两个整数 m 和 n ,分别表示 nums1 和 nums2 中的元素数目。 请你 合并 nums2 到 nums1 中,使合并后的数组同样按 非递减顺序 排列。 **注意:**…

深度学习卷积神经网络CNN之MobileNet模型网络模型详解说明(超详细理论篇)

1.MobileNet背景 2.MobileNet V1论文 3. MobileNett改进史 4. MobileNet模型结构 5. 特点(超详细创新、优缺点及新知识点) 一、MobileNet背景 随着移动设备的普及,深度学习模型的应用场景逐渐扩展至移动端和嵌入式设备。然而,传统…

AI多模态技术介绍:理解多模态大语言模型的原理

本文目标是解释多模态LLMs的工作原理,虽然多模态的输入可以有音频,文本,图像和视频,但这里主要讨论的还是以图文为主的多模态大语言模型。 参考文章:https://magazine.sebastianraschka.com/p/understanding-multimoda…

详解redis哨兵(高可用)

华子目录 为什么会出现redis的哨兵?redis哨兵哨兵机制能做什么?什么是主观下线和客观下线?主观下线客观下线 哨兵的三个定时监控master主节点下线后,怎么进行故障转移?leader哨兵的选举故障转移,选举新的master执行故…

实验6-2 基于二叉链表存储结构实现二叉树的基本操作

题目:计算二叉树中的叶子结点个数 (1)如果二叉树为空,则叶子结点个数为0。 (2)如果二叉树只有根节点,则叶子结点个数为1 (3)左子树叶子结点数+右子树叶子结点数 一、原代码 #include <stdio.h> #include <stdlib.h> #define TRUE 1 #define FALSE 0 #define …

数据可视化echarts学习笔记

目录&#xff0c;介绍 知识储备 一端操作&#xff0c;多端联动的效果&#xff08;开启了多个网页&#xff0c;操作一端&#xff0c;多个网页的效果会跟着改变&#xff09; cmd命令控制面板返回上一级或上上级 在当前目录打开文件&#xff1a; cd 文件名 在Windows命令提示符&am…

[文献阅读] Unsupervised Deep Embedding for Clustering Analysis (无监督的深度嵌入式聚类)

文章目录 Abstract:摘要聚类深度聚类 KL散度深度嵌入式聚类(DEC)KL散度聚类软分配&#xff08;soft assignment&#xff09;KL散度损失训练编码器的初始化聚类中心的初始化 实验评估总结 Abstract: This week I read Unsupervised Deep Embedding for Clustering Analysis .It…

HTTP协议及安全防范

由于图片解析问题&#xff0c;可以点击查看 &#x1f449;&#x1f3fb; 博客原文 HTTP&#xff08;Hypertext Transfer Protocol&#xff09;超文本传输协议是一个用于 Web 应用程序通信的应用层协议。它是一种客户端-服务器协议&#xff0c;客户端通过发送请求到服务器来获取…