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

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

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

cmake 复制代码
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 $file
    if (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脚本的例子呢?后续文章中的程序构建会使用这个脚本,敬请期待。

相关推荐
小雪_Snow1 小时前
PowerShell 版本升级教程
powershell
Whoami!2 天前
⓫⁄₅ ⟦ OSCP ⬖ 研记 ⟧ Windows权限提升 ➱ 利用PowerShell获取敏感信息
网络安全·信息安全·powershell·windows日志
小雪_Snow5 天前
PowerShell 修改编码为 UTF-8 教程
powershell
十五年专注C++开发7 天前
CMake基础: 在release模式下生成调试信息的方法
linux·c++·windows·cmake·跨平台构建
kimicsdn8 天前
opentelemetry-demo currency cpp 项目编译流程分享
c++·cmake·libprotobuf-dev
番茄灭世神9 天前
常见终端工具输出中文乱码的解决方案
bash·编码格式·powershell·终端工具
十五年专注C++开发10 天前
CMake进阶:模块模式示例FindOpenCL.cmake详解
开发语言·c++·cmake·跨平台编译
番茄灭世神11 天前
基于VScode搭建GD32开发环境
arm开发·vscode·单片机·cmake·gd32
l1t13 天前
在arm64 Linux系统上编译tdoku-lib的问题和解决
linux·运维·服务器·c语言·cmake
番茄灭世神13 天前
基于VScode的C/C++环境搭建
vscode·cmake·gcc·c\c++·llvm·工具链搭建