CMakePresets.json与cmake区别

CMakePresets.json 是干什么的?

一句话CMakePresets.json 是用来预先定义一组"配置/编译方案"的标准配置文件 ,方便你在命令行或 IDE 里一键选择,而不用每次自己拼 -G -DCMAKE_TOOLCHAIN_FILE=... -DCMAKE_BUILD_TYPE=... 这些参数。

  • 典型功能
    • 统一定义多个构建配置(如 Debug / Release / arm-gcc-debug 等)。
    • 指定构建目录(build/Debugbuild/Release 等)。
    • 指定工具链文件(比如你项目里的 tools/cmake_toolchain_files/armgcc.cmake)。
    • 传各种 -DXXX=ON/OFF 选项。

它和 .cmake 文件的本质区别

  • CMakePresets.json

    • 是一个 "如何调用 cmake 的配置清单"
    • 作用范围:外部(调用 cmake 时,决定用什么生成器、什么工具链、放到哪个 build 目录、开哪些选项)。
    • 用法:cmake --preset <名字>、IDE 里的 "Configure Preset / Build Preset" 下拉菜单。
  • xxx.cmake(模块/工具链等)

    • cmake 语言写的脚本 ,在 CMake 运行过程中被 include() / toolchain 使用
    • 比如:
      • tools/cmake_toolchain_files/armgcc.cmake:定义交叉编译器路径、cpu 选项等 → 典型 工具链文件
      • flags.cmake、某些 SDK/.../*.cmake:设置编译选项、添加库、宏等 → 典型 模块/配置脚本
    • 用法:
      • 在命令行:-DCMAKE_TOOLCHAIN_FILE=tools/cmake_toolchain_files/armgcc.cmake
      • 或在 CMakeLists.txt 里:include(flags.cmake) 等。

对比总结

  • Presets(json) :告诉 cmake "怎么启动、用哪个工具链、放哪编"
  • .cmake 脚本 :在 cmake 运行时,告诉 cmake "怎么配置项目自身:用哪些编译选项、哪些库、交叉编译器在哪"

在你的工程里,大概怎么用 Presets

结合你的项目结构(已存在 CMakePresets.jsontools/cmake_toolchain_files/armgcc.cmake):

  • 在命令行构建:
bash 复制代码
# 查看有哪些 preset
cmake --list-presets

# 用某个配置 preset(例如叫 "armgcc-debug")生成 build 目录
cmake --preset armgcc-debug

# 用某个 build preset 编译
cmake --build --preset armgcc-debug
  • 在 VS Code / CLion / VS:
    • 打开工程根目录(有 CMakePresets.json 那层)。
    • IDE 会自动识别 presets,弹出 配置选项 ,你直接选 Debug / Release / armgcc-debug
    • 之后直接点 Configure / Build 就会按 preset 里定义的参数运行。

什么时候改 Presets?什么时候改 .cmake?

  • CMakePresets.json

    • 想新增一种编译方案:比如同一个源码,既要为 Windows x64 编,又要为 i.MX8 ARM 编。
    • 想换构建目录命名、默认构建类型、默认工具链等。
  • .cmake(如 armgcc.cmakeflags.cmake

    • 想改交叉编译器路径、CPU 选项、FPU 选项。
    • 想统一调整 -O2/-O0/-g、警告等级、宏定义、链接脚本等。

如果你愿意,可以把当前的 CMakePresets.json 内容贴出来,我可以逐项解释每个字段具体对你这个 i.MX8 + AD7606 工程的含义。

相关推荐
CSCN新手听安14 小时前
【linux】网络基础(三)TCP服务端网络版本计算器的优化,Json的使用,服务器守护进程化daemon,重谈OSI七层模型
linux·服务器·网络·c++·tcp/ip·json
bloglin9999915 小时前
Qwen3-32B报错Invalid json output:{“type“: “1“}For troubleshooting, visit
llm·json
Trouvaille ~16 小时前
【Linux】应用层协议设计实战(二):Jsoncpp序列化与完整实现
linux·运维·服务器·网络·c++·json·应用层
剩下了什么1 天前
MySQL JSON_SET() 函数
数据库·mysql·json
梦帮科技1 天前
Node.js配置生成器CLI工具开发实战
前端·人工智能·windows·前端框架·node.js·json
数据知道2 天前
PostgreSQL实战:详解如何用Python优雅地从PG中存取处理JSON
python·postgresql·json
缘空如是2 天前
基础工具包之JSON 工厂类
java·json·json切换
墨痕诉清风2 天前
CVS文件转Json格式
json·python3·cvs
数研小生3 天前
1688商品列表API:高效触达批发电商海量商品数据的技术方案
大数据·python·算法·信息可视化·json
devmoon3 天前
快速了解兼容 Ethereum 的 JSON-RPC 接口
开发语言·网络·rpc·json·区块链·智能合约·polkadot