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

CMake构建学习笔记21-通用的CMake构建脚本

在之前使用CMake构建程序的脚本(CMake构建学习笔记-目录)中,大部分内容都有比较强的相似性,那么是不是可以这些相似的内容提取出来作为一个单独的脚本,在构建具体的程序的时候再去调用这个脚本呢?这样做的好处是如果构建的配置有什么变动,就不用每个程序的构建脚本都修改了,只用修改这个通用的脚本就可以了。

具体的脚本cmake-build.ps1如下,适用于PowerShell终端:

param([string]$SourceLocalPath,[string]$BuildDir,[string]$Generator,[string]$InstallDir,[string]$SymbolDir,[string[]]$PdbFiles,[hashtable]$CMakeCacheVariables,[bool]$MultiConfig = $false  # 控制是否使用多配置类型
)# 清除旧的构建目录
if (Test-Path $BuildDir) {Remove-Item -Path $BuildDir -Recurse -Force
}
New-Item -ItemType Directory -Path $BuildDir# 构建CMake命令行参数
$CMakeArgs = @("-B", "`"$BuildDir`"","-G", "`"$Generator`"","-A", "x64"
)if ($MultiConfig) {$CMakeArgs += "-DCMAKE_CONFIGURATION_TYPES=RelWithDebInfo"
}
else {$CMakeArgs += "-DCMAKE_BUILD_TYPE=RelWithDebInfo"
}$CMakeArgs += ("-DCMAKE_PREFIX_PATH=`"$InstallDir`"","-DCMAKE_INSTALL_PREFIX=`"$InstallDir`""
)# 添加额外的CMake缓存变量
foreach ($key in $CMakeCacheVariables.Keys) {$CMakeArgs += "-D$key=$($CMakeCacheVariables[$key])"
}# 配置CMake
cmake $SourceLocalPath $CMakeArgs# 构建阶段,指定构建类型
cmake --build $BuildDir --config RelWithDebInfo --parallel# 安装阶段,指定构建类型和安装目标
cmake --build $BuildDir --config RelWithDebInfo --target install# 复制符号库
foreach ($file in $PdbFiles) {  Write-Output $fileif (Test-Path $file) {Copy-Item -Path $file -Destination $SymbolDir}else {Write-Output "Warning: PDB file not found: $file"}
}# 清理构建目录
#Remove-Item -Path $BuildDir -Recurse -Force

这段脚本的关键在于以下几点:

  1. CMake配置参数$CMakeArgs。首先是通用配置,-B表示生成的目录;-G表示生成器,比如"Ninja"或者"Visual Studio 17 2022";-A表示目标平台的架构。然后是构建目标的类型,有的库使用CMAKE_CONFIGURATION_TYPES,有的库使用CMAKE_BUILD_TYPE,值设置成RelWithDebInfo表示Release版本,但是带调试信息。接下来是设置依赖库查找路径CMAKE_PREFIX_PATH和安装路径CMAKE_INSTALL_PREFIX。最后是添加额外的CMake缓存变量,这些缓存变量通常与要构建的库有关。
  2. 使用生成的配置参数$CMakeArgs进行项目配置:cmake $SourceLocalPath $CMakeArgs。这一步会把设置的参数固定成具体的项目参数,如果使用Visual Studio进行构建,就是生成sln项目。
  3. 编译、链接,生成构建目标:cmake --build $BuildDir --config RelWithDebInfo --parallel。这里的--parallel的意思是并行构建,会采用多线程的方式构建项目,自动决定线程数。
  4. 安装构建目标cmake --build $BuildDir --config RelWithDebInfo --target install
  5. 最后一步复制符号库的作用是将生成的符号库文件复制到特定的目录中进行管理,这样在程序崩溃之后,可以通过符号库找到相应的代码,便于进行错误排查。

那么有没有具体使用这个cmake-build.ps1脚本的例子呢?后续文章中的程序构建会使用这个脚本,敬请期待。

http://www.dtcms.com/a/354109.html

相关文章:

  • Liunx内核驱动
  • Java中StringBuilder原理以及使用
  • D4145低功耗GFCI接地故障控制芯片介绍
  • 题目—移除元素
  • 作业帮,途虎养车,得物,途游游戏,三七互娱,汤臣倍健,游卡,快手26届秋招内推
  • JUC多线程个人笔记
  • 【DC工具GUI入门】
  • APP测试全流程以及测试点
  • 【开题答辩全过程】以 基于SpringBoot的流浪动物领养系统的设计与实现 为例,包含答辩的问题和答案
  • 从Java到Go:初遇Go语言的震撼体验
  • 力扣 30 天 JavaScript 挑战 第41天 (第十二题)对异步操作,promise,async/await有了更深理解
  • 【Linux实时内核机制】ww_rt_mutex 的contending_lock异常问题
  • android/java中主线程和子线程的详解
  • Nano Banana揭秘:Google Gemini 2.5 Flash Image正式发布 | AI图像编辑新时代
  • 内网应用如何实现外网访问?外地通过公网地址访问内网服务器的设置方法
  • 动态规划:青蛙跳台阶实践
  • H20 性能表现之 Kimi-K2
  • 【git】:gitee项目管理vs2019
  • 装饰器进阶与设计模式
  • Linux入门教程 第十五章 Linux 系统调优工具
  • 【工具篇】github/huggingface 镜像源总结
  • 嵌入式系统学习Day24(线程)
  • Custom SRP - Shadow Masks
  • Axure:如何将SVG转换为形状
  • leetcode 155 官方golang标准答案错误
  • Java Lambda 处理日期时间 根据区间找出区间内集合
  • Linux程序与进程:核心概念与管理全解析
  • Class45循环神经网络RNN
  • “互联网 +”时代下开源 AI 大模型 AI 智能名片 S2B2C 商城小程序:行业变革与未来展望
  • 基于 Ultralytics YOLO11与 TrackZone 的驱动的高效区域目标跟踪方案实践