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

C++ CMake FetchContent用法介绍

CMake 的 FetchContent 模块是一个非常方便的工具,用于在构建过程中从远程位置下载和管理外部依赖项。通过 FetchContent,您可以在项目的 CMake 配置过程中下载、提取和添加外部项目,而不需要手动管理这些依赖项。下面是 FetchContent 的基本用法介绍以及一个简单的代码示例,代码结构如下:
在这里插入图片描述

FetchContent 基本用法

  1. 引入 FetchContent 模块
    在 CMakeLists.txt 文件中,首先需要引入 FetchContent 模块:

    include(FetchContent)
    
  2. 声明并下载外部项目
    使用 FetchContent_Declare 函数声明外部项目,并使用 FetchContent_MakeAvailable 函数下载并解压该项目。例如,下载并构建一个外部项目 googletest

    FetchContent_Declare(
      googletest
      GIT_REPOSITORY https://github.com/google/googletest.git
      GIT_TAG release-1.11.0
    )
    
    FetchContent_MakeAvailable(googletest)
    
  3. 使用外部项目
    一旦外部项目被下载和解压,就可以像项目中的其他库一样使用它。例如,链接 googletest 库到你的项目中:

    target_link_libraries(my_project PRIVATE gtest_main)
    

完整示例

下面是一个完整的示例,演示如何使用 FetchContent 下载并构建 googletest 并将其链接到一个简单的 C++ 项目。

项目结构:

/my_project
|-- CMakeLists.txt
|-- src
|   |-- main.cpp
|-- tests
    |-- test_main.cpp

CMakeLists.txt:

cmake_minimum_required(VERSION 3.14)
project(MyProject)

# 设置C++标准
set(CMAKE_CXX_STANDARD 14)

# 引入FetchContent模块
include(FetchContent)

# 声明googletest
FetchContent_Declare(
  googletest
  GIT_REPOSITORY https://github.com/google/googletest.git
  GIT_TAG release-1.11.0
)

# 下载并解压googletest
FetchContent_MakeAvailable(googletest)

# 添加源文件
add_executable(my_project src/main.cpp)

# 链接googletest库到测试项目
enable_testing()
add_executable(test_main tests/test_main.cpp)
target_link_libraries(test_main PRIVATE gtest_main)

# 添加测试
add_test(NAME MyTest COMMAND test_main)

src/main.cpp:

#include <iostream>

int main() {
    std::cout << "Hello, World!" << std::endl;
    return 0;
}

tests/test_main.cpp:

#include <gtest/gtest.h>

TEST(SampleTest, AssertionTrue) {
    EXPECT_TRUE(true);
}

int main(int argc, char **argv) {
    ::testing::InitGoogleTest(&argc, argv);
    return RUN_ALL_TESTS();
}

解释

  1. CMakeLists.txt 中包含了项目配置、FetchContent 配置以及项目和测试可执行文件的构建和链接。
  2. FetchContent_DeclareFetchContent_MakeAvailable 用于声明和下载 googletest
  3. 使用 target_link_librariesgoogletest 链接到测试可执行文件 test_main
  4. tests/test_main.cpp 中编写了一个简单的测试案例,并使用 gtest_main 运行所有测试。

通过这种方式,您可以轻松地在项目中引入和管理外部依赖项,而无需手动下载和配置这些库。
注意由于需要从github下载库,得有合适的网络环境,不然会无法下载或编译失败,例如下图:
在这里插入图片描述
如果是正常编译下载库,在编译后的目录build/_deps是FetchContent下载的库

FetchContent如何添加多个库

使用 CMake 的 FetchContent_DeclareFetchContent_MakeAvailable 可以下载和管理多个库。您只需为每个库单独调用 FetchContent_DeclareFetchContent_MakeAvailable

示例代码

假设您想要下载并使用 googletestfmt 库,这里是如何编写 CMakeLists.txt 文件的示例。

项目结构:

/my_project
|-- CMakeLists.txt
|-- src
|   |-- main.cpp
|-- tests
    |-- test_main.cpp

CMakeLists.txt:

cmake_minimum_required(VERSION 3.14)
project(MyProject)

# 设置C++标准
set(CMAKE_CXX_STANDARD 14)

# 引入FetchContent模块
include(FetchContent)

# 声明googletest
FetchContent_Declare(
  googletest
  GIT_REPOSITORY https://github.com/google/googletest.git
  GIT_TAG release-1.11.0
)

# 声明fmt
FetchContent_Declare(
  fmt
  GIT_REPOSITORY https://github.com/fmtlib/fmt.git
  GIT_TAG 8.0.1
)

# 下载并解压所有声明的内容
FetchContent_MakeAvailable(googletest fmt)

# 添加源文件
add_executable(my_project src/main.cpp)

# 链接fmt库到主项目
target_link_libraries(my_project PRIVATE fmt::fmt)

# 链接googletest库到测试项目
enable_testing()
add_executable(test_main tests/test_main.cpp)
target_link_libraries(test_main PRIVATE gtest_main)

# 添加测试
add_test(NAME MyTest COMMAND test_main)

src/main.cpp:

#include <iostream>
#include <fmt/core.h>

int main() {
    fmt::print("Hello, World!\n");
    return 0;
}

tests/test_main.cpp:

#include <gtest/gtest.h>

TEST(SampleTest, AssertionTrue) {
    EXPECT_TRUE(true);
}

int main(int argc, char **argv) {
    ::testing::InitGoogleTest(&argc, argv);
    return RUN_ALL_TESTS();
}

解释

  1. 引入 FetchContent 模块

    include(FetchContent)
    
  2. 声明多个库
    使用 FetchContent_Declare 为每个库声明其存储库位置和版本。

    FetchContent_Declare(
      googletest
      GIT_REPOSITORY https://github.com/google/googletest.git
      GIT_TAG release-1.11.0
    )
    
    FetchContent_Declare(
      fmt
      GIT_REPOSITORY https://github.com/fmtlib/fmt.git
      GIT_TAG 8.0.1
    )
    
  3. 下载并解压所有声明的内容
    使用 FetchContent_MakeAvailable 下载并解压所有已声明的库。

    FetchContent_MakeAvailable(googletest fmt)
    
  4. 使用下载的库
    将下载的库链接到您的项目中。

    target_link_libraries(my_project PRIVATE fmt::fmt)
    target_link_libraries(test_main PRIVATE gtest_main)
    

通过这种方式,您可以轻松地管理和使用多个外部库。每个库的声明和下载是独立的,FetchContent 模块会自动处理依赖关系和构建顺序。

相关文章:

  • BGP基础实验
  • 三维可视化技术在厂区人员、车辆定位中的设计与应用效益
  • 正则表达式三
  • sqlilabs靶场安装
  • python + selenium 实现浏览器的基本操作
  • 上传图片并显示#Vue3#后端接口数据
  • Datetime,一个 Python 的时间掌控者
  • 乙二醇水溶液物性参数
  • 将SU模型导入ARCGIS,并获取高度信息,多面体转SHP文件(ARCMAP)
  • Spring boot 集成mybatis-plus
  • 【MMU】——MMU 相关的 CP15 寄存器
  • uniapp通过Canvas绘制网格(心电图,坐标纸等可用)
  • 联合(union)和枚举(enum)学习(c语言)
  • 常用STL标准模板库
  • 区间预测 | Matlab实现QRCNN-GRU-Attention分位数回归卷积门控循环单元注意力机制时序区间预测
  • for深入学习
  • MySQL报ERROR 2002 (HY000)解决
  • NocoDB开源的智能表格详解-腾讯文档本地替代品
  • zs6d配置-2
  • python基础——-多任务-正则-装饰器
  • “五一”假期预计全社会跨区域人员流动量累计14.67亿人次
  • 解放日报头版:上海张江模力社区托举“年轻的事业”
  • 马上评|提供情绪价值,也是文旅经济的软实力
  • 商务部新闻发言人就中美经贸对话磋商情况答记者问
  • 阿根廷发生5.6级地震,震源深度30公里
  • 来论|受美国“保护”,日本民众要付出什么代价?