首页
/ Conan 2.16.0 发布:构建工具链增强与安全检查升级

Conan 2.16.0 发布:构建工具链增强与安全检查升级

2025-06-07 17:55:06作者:庞眉杨Will

Conan 是一款功能强大的 C/C++ 包管理器,专为管理软件依赖关系和构建过程而设计。它通过简化依赖管理、跨平台构建和包分发,极大地提升了 C/C++ 项目的开发效率。最新发布的 Conan 2.16.0 版本带来了一系列重要更新,主要集中在工具链支持、安全检查和构建系统集成等方面。

编译器与工具链增强

本次更新显著扩展了对现代编译器和工具链的支持。新增了对 GCC 15.1 的完整支持,确保开发者可以使用最新的 GCC 编译器特性。同时,针对 Intel 编译器系列,补充了多个缺失的版本支持,为使用 Intel 编译工具链的项目提供了更好的兼容性。

在工具链方面,GnuToolchain 现在包含了 AutotoolsToolchain 的最新改进,提供了更完善的 GNU 工具链支持。对于 Apple 平台开发者,修复了 MesonToolchain 在 visionOS 上的使用问题,并移除了某些 Apple OS 上不存在的 SDK 版本,避免了潜在的配置错误。

构建系统集成改进

CMake 构建系统的支持得到了多项增强。CMakeConfigDeps 现在可以正确处理包含多库(multilibs)的组件,虽然目前会显示弃用警告,但为过渡期提供了更好的兼容性。此外,新增了 CMAKE_MODULE_PATH 支持,使得 include(module) 指令能够正常工作,进一步提升了 CMake 集成的灵活性。

对于 MSBuild 用户,新增了对 ARM64EC 平台的支持,填补了之前缺失的平台类型。同时公开了 MSBuildDeps.platform 属性的文档,特别是为需要设置 x86 值的 WiX 项目提供了明确的配置指导。

安全检查功能升级

安全检查功能在本版本中获得了显著提升。新增了严重级别阈值设置,允许用户根据需求过滤检查结果。检查结果的 HTML 输出也进行了多项改进,包括修复了严重级别排序问题、解决了列溢出问题,并优化了整体显示效果。

在安全机制方面,check_providers.json 文件现在被设置为仅允许所有者读写,增强了安全性。同时改进了当私有检查提供者缺少策展数据时的错误信息,帮助开发者更快定位问题。

依赖管理与构建流程优化

依赖管理方面引入了新的 no_skip=True 需求特性,解决了某些特殊情况下的依赖跳过问题,比如当一个应用程序需要私有依赖另一个应用程序时。构建流程中,现在可以输出每个包的构建配置信息,并通过 -vv 详细模式显示图中每个依赖项的配置详情,大大提升了构建过程的透明度。

对于使用 Git 作为源码管理的项目,修复了 Azure DevOps 等环境下特定提交无法被检出问题,通过显式执行 git fetch commit 确保了可靠性。同时,当本地配方索引中的 user/channel 不匹配请求时,现在会正确抛出未找到错误,避免了潜在的混淆。

配置系统与错误处理

配置系统进行了多项改进,包括早期检测并阻止在 conf_info 中直接赋值原始设置/选项的错误用法。Apple 平台相关的 bitcode、visibility 和 arc 配置现在会正确应用到 Autotools、Gnu 和 Meson 工具链中,确保了跨工具链的一致性。

错误处理方面,当 conan graph build-order 处理"可编辑"包时,现在能够正确输出 build_args,解决了之前的功能缺失问题。同时,继续推进内部代码清理工作,将更多功能从 Command 层迁移到 ConanAPI,并标记了一些内部实现为私有,为未来的架构演进做准备。

Conan 2.16.0 的这些改进进一步巩固了其作为现代 C/C++ 项目依赖管理解决方案的地位,特别是在跨平台构建、安全检查和工具链支持方面提供了更强大、更可靠的功能。无论是个人开发者还是企业团队,都能从这些增强功能中受益,构建更安全、更高效的 C/C++ 项目。

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

热门内容推荐

最新内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
178
262
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
867
513
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
183
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
265
305
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
371
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
598
57
GitNextGitNext
基于可以运行在OpenHarmony的git,提供git客户端操作能力
ArkTS
10
3