首页
/ CPM.cmake 使用教程

CPM.cmake 使用教程

2026-01-20 01:26:32作者:何举烈Damon

1. 项目介绍

CPM.cmake 是一个跨平台的 CMake 脚本,为 CMake 添加了依赖管理功能。它构建在 CMake 的 FetchContent 模块之上,提供了版本控制、缓存、简单的 API 等功能。CPM.cmake 的目标是简化 C++ 项目中第三方依赖的引入和管理,使开发者能够轻松地将所需的第三方库集成到项目中,而无需手动下载、配置和管理这些库。

2. 项目快速启动

2.1 安装 CPM.cmake

首先,将 CPM.cmake 添加到你的项目中。你可以通过以下命令自动完成这一步骤:

mkdir -p cmake
wget -O cmake/CPM.cmake https://github.com/cpm-cmake/CPM.cmake/releases/latest/download/get_cpm.cmake

2.2 在项目中使用 CPM.cmake

在你的 CMakeLists.txt 文件中,添加以下内容以使用 CPM.cmake:

cmake_minimum_required(VERSION 3.14 FATAL_ERROR)

# 创建项目
project(MyProject)

# 添加可执行文件
add_executable(main main.cpp)

# 添加依赖
include(cmake/CPM.cmake)

# 使用 CPMAddPackage 添加依赖库
CPMAddPackage("gh:fmtlib/fmt#7.1.3")
CPMAddPackage("gh:nlohmann/json@3.10.5")
CPMAddPackage("gh:catchorg/Catch2@3.4.0")

# 链接依赖库
target_link_libraries(main fmt::fmt nlohmann_json::nlohmann_json Catch2::Catch2WithMain)

2.3 构建项目

使用以下命令构建你的项目:

mkdir build
cd build
cmake ..
make

3. 应用案例和最佳实践

3.1 使用 CPM.cmake 管理复杂依赖

在大型项目中,依赖管理可能会变得非常复杂。CPM.cmake 通过版本控制和缓存功能,确保项目的依赖始终是最新的,并且可以在离线状态下进行构建。

CPMAddPackage(
    NAME Boost
    VERSION 1.84.0
    URL https://github.com/boostorg/boost/releases/download/boost-1.84.0/boost-1.84.0.tar.xz
    URL_HASH SHA256=2e64e5d79a738d0fa6fb546c6e5c2bd28f88d268a2a080546f74e5ff98f29d0e
    OPTIONS "BOOST_ENABLE_CMAKE ON"
)

3.2 使用 CPM.cmake 进行跨平台开发

CPM.cmake 支持跨平台开发,确保在不同操作系统上都能一致地管理依赖。

CPMAddPackage("gh:catchorg/Catch2@2.5.0")

4. 典型生态项目

以下是一些使用 CPM.cmake 的典型项目:

  • OTTO - 开源的 GrooveBox 项目。
  • Maphi - 数学应用程序。
  • ModernCppStarter - 现代 C++ 项目启动器。
  • liblava - 现代 Vulkan 图形库。
  • klogg - 快速的高级日志浏览器。

这些项目展示了 CPM.cmake 在实际应用中的强大功能和灵活性。

登录后查看全文
热门项目推荐
相关项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
27
11
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
514
3.69 K
ops-mathops-math
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
873
538
pytorchpytorch
Ascend Extension for PyTorch
Python
317
360
kernelkernel
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
334
153
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.31 K
732
flutter_flutterflutter_flutter
暂无简介
Dart
757
182
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
67
20
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.05 K
519