<<Modern CMake>> 翻译 1. CMake 介绍

人们喜欢讨厌构建系统。 仅仅观看 CppCon17 上的演讲,就可以看到开发人员因为构建系统而闹笑话的例子。 这让我们思考一个问题:为什么会这样? 构建系统时当然不可能完美无缺。 但我认为,在 2018 年,我们可以很好地解决其中的一些问题。 这就是 CMake。不过 CMake 2.8 可能不行; 它在 C++11 发布之前就 release 了! 对于 CMake 来说也没有可怕的例子(甚至那些发布在 KitWare 自己的教程列表中的例子)。 我们来谈论现代 CMake。CMake 3.1+,甚至可能是 CMake 3.15+! 它整洁,强大,优雅,因此你可以将大部分时间花在编码上,而不是编写不可读,不可维护的 Make(或CMake 2)文件。 当然,CMake 3.11+ 运行起来也应该明显更快!

 

这本书作为在线文档发布。你可以在 GitLab 上提出问题或提交合并请求。 你也可以 从这里下载 PDF.

简而言之,如果你在考虑使用现代 CMake,这些可能是你最关心的问题:

为什么我需要一个好的构建系统?

下面哪几点适合你?

  • 你希望避免硬编码路径
  • 你需要在多台计算机上构建软件
  • 你想使用CI(持续集成)
  • 你需要支持不同的操作系统(虽然可能只是 Unix 的风格)
  • 你想支持多个编译器
  • 你想使用 IDE,但有时也不用
  • 你想要描述程序的逻辑结构,而不是标志和命令
  • 你想使用第三方软件包
  • 你想使用像 Clang-Tidy 这样的工具来帮助你编写代码
  • 你想使用调试器 (debugger)

如果是这样,你将受益于类似 CMake 的构建系统。

为什么我们选择 CMake?

构建系统是一个热门话题。 当然大家有很多选择。但即使是非常好的,或者重用一个熟悉的语法,也无法和 CMake 相提并论。 为什么?生态支持。 每个 IDE 都支持 CMake(或 CMake 支持这些 IDE)。 有更多的软件包在使用 CMake 而不是其他构建系统。 因此,如果你在使用一个软件包,它被设计为包含在你的代码中,你可以选择:创建自己的构建系统,或使用一个它支持的构建系统:这些软件包几乎总是支持 CMake。 如果你要使用多个软件包,CMake 将很快成为共同点。 而且,如果你需要一个预安装软件包,那么它有 CMake 查找或配置脚本的可能性非常高。

为什么要用现代 CMake?

大约 CMake 2.6-2.8 的时候,CMake 开始流行起来。出现在了大多数 Linux 操作系统的软件包管理器列表中,并且被用于许多软件包使用。 然后 Python 3 问世了。 我知道,这与 CMake 没有任何关系。 但它是第三版。 它前面有一个第二版: 这是一个艰难,丑陋的过渡,即使在今天,一些软件仍然还在使用第二版。

我相信 CMake 3 运气不会比 Python 3 好到哪儿去。1 尽管每个版本的 CMake 都是努力向后兼容,但 CMake 3 系列任然被视为新东西。 因此,你会发现操作系统,像 CentOS 7,已经拥有 GCC 4.8,几乎完全支持 C++ 14,还在使用在 C++ 11 之前就推出的 CMake 2.8。

你真的至少应该使用编译器发布之后出现的 CMake 版本,因为构建系统需要知道新版本编译器的编译标志等信息。 而且,由于 CMake 会将自己退化为 CMake 文件中指示的所需的最低版本,因此,即使你在系统范围内安装一个新的 CMake,也是非常安全的。 或者你至少应该在本地安装它。 这很容易 (大多数情况下也就一两行代码的事儿), 你会发现 5 分钟的工作将为你节省数百行和几小时的 CMakeLists.txt 编写时间,并且从长远来看将更容易维护。 本书试图解决那些网络上随处可见的糟糕问题和例子,以及提出最佳实践的方法。

其他资源

在网上还有一些其他地方可以找到有用的信息。下面是其中的一些:

  • The official help: 真的很棒的文档。组织精良,搜索便捷,还可以在顶部切换版本。它只是没有一本伟大的“最佳实践教程”,这本书就在试图填补这个空白
  • Effective Modern CMake: 一个非常好的使用指导原则清单
  • Embracing Modern CMake: 一个对该术语有很好描述的帖子
  • It's time to do CMake Right: 现代 CMake 项目的一个很好的最佳实践
  • The Ultimate Guide to Modern CMake: 具有类似意图的略微过时的帖子
  • More Modern CMake: 来自 Meeting C++ 2018 推荐的 CMake 3.12+ 精彩演示。这个讲话使得 CMake 3.0+ 现代化的 CMake 和 CMake 3.12+ 更现代化的 CMake 成为了一种话题
  • toeb/moderncmake: 关于 CMake 3.5+ 的一个很好的演示和示例,通过项目组织介绍语法

鸣谢

现代 CMake 最初由 Henry Schreiner 编写。其他贡献者信息可以 GitLab 项目贡献者列表 中找到。

本书中文版由 南大通用 工程师 何江 在业余时间翻译。

1. CMake 3.0 还从非常旧版本的 CMake 中删除了几个长期弃用的功能,并对与方括号相关的语法做了一个非常微小的向后不兼容的更改,所以这不完全公平; 可能会有一些非常非常古老的 CMake 文件在 CMake 3+ 中不能运行;虽然我从来没有见过。

<<Modern CMake>> 翻译 1. CMake 介绍的更多相关文章

  1. <<Modern CMake>> 翻译 2. CMake 基础

    <<Modern CMake>> 翻译 2. CMake 基础 最低版本 这是每个 CMakeLists.txt 文件的第一行.CMakeLists.txt 是 CMake 所 ...

  2. <<Modern CMake>> 翻译 2.4 项目目录结构

    <<Modern CMake>> 翻译 2.4 项目目录结构 本节内容有点跑题.但我认为这是一个很好的方法. 我将告诉你如何规划项目的目录. 这是基于惯例,但将帮助您: 轻松阅 ...

  3. <<Modern CMake>> 翻译 2.2 CMake 编程

    <<Modern CMake>> 翻译 2.2 CMake 编程 流程控制 CMake有一个 if 语句, 经年累月之后,现在它已经相当复杂. 您可以在 if 语句中使用全大写 ...

  4. <<Modern CMake>> 翻译 2.3 与代码通信

    <<Modern CMake>> 翻译 2.3 与代码通信 配置文件 CMake 允许您使用代码通过 configure_file 存取 CMake 变量. 此命令复制一个文件 ...

  5. 【转载】CMake 简介和 CMake 模板

    转载自我的博客: CMake 简介和 CMake 模板 . 如果你用 Linux 操作系统,使用 cmake 会简单很多,可以参考一个很好的教程: CMake 入门实战 | HaHack .如果你用 ...

  6. Effective Modern C++翻译(1):序言

    /*********************************************************** 关于书: 书是我从网上找到的effective Modern C++的样章,内 ...

  7. CMake安装或CMake Error at CMakeLists

    CMake安装或CMake Error at CMakeLists 发生情景: 使用cmake命令安装软件时,报如下错误: CMake Error at CMakeLists.txt:4 (CMAKE ...

  8. mysqlQL 5.7 安装报错CMake Error at cmake/boost.cmake:81 (MESSAGE)

    CMake Error at cmake/boost.cmake:81 (MESSAGE): You can download it with -DDOWNLOAD_BOOST=1 -DWITH_BO ...

  9. Cmake实践(Cmake Practice)第一部分

    参考资料地址:https://github.com/Akagi201/learning-cmake/blob/master/docs/cmake-practice.pdf 一.初识cmake 1. C ...

随机推荐

  1. New,Getmem,ReallocMem联系与区别(转)

    procedure New(var P: Pointer);  {为一个指针变量分配内存,会自动计算指针所指数据结构需要空的空间大小} procedure GetMem(var P: Pointer; ...

  2. No.595-Big Countries-(LeetCode之Database篇)

    数据库表 给出的数据库表如下,表名为World. +-----–+----+----+----–+-----+ |   name         | continent |    area    | ...

  3. 【Idea】JUnit单元测试%MODULE_WORKING_DIR%' does not exist

    Idea执行单元测试时报错:上午9:35 Error running 'MobileMessageImplTest.java': Cannot start process, the working d ...

  4. jQuery-ajax-.get,.post方法

    在上一篇中详细介绍了jQuery中ajax局部方法$.load()的使用.下面来介绍两个全局方法$.get(),$.post()的使用. 1.这两个全局方法其实和上一篇中的$.load()方法使用是差 ...

  5. bitmap-如何判断某个整数是否存在40亿个整数中?

    有这样一道面试题:现有40亿个整数,如果再给定一个新的整数,怎么判断这个整数是否在这40亿个整数中? 你可能首先会想到用一个set存储,那个新数只需判断是否在set中.但是如果用set存储的话,如果一 ...

  6. 前端js倒计时(精确到毫秒)

    话不多说,直接上代码: 有需要直接拿走, <html> <head> <style> div{ width:100%; text-align:center; fon ...

  7. jquery.cookie.js 获取不到cookie的值

    最近使用$.cookie获取cookie 的值.发现完全取不到.看了浏览器里也存了对应的值.可以添加,但是就是取不到., 折腾了半天,后来突然想起来加了个有可能带汉字的cookie键值.删掉就可以取出 ...

  8. 第一个SpringBoot

    Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置.用我 ...

  9. CDH 5.15.2 离线安装

    一.前置准备 1. 基础信息 1.1 机器 机器名 服务 hadoop1 主节点 hadoop2 data.task hadoop3 data.task 1.2 服务版本 服务 版本 cdh 5.15 ...

  10. 仿照Spring自己实现有各种通知的AOP,AOP实现的步骤分解

    一.需求: 仿照Spring的AOP写的 MyAOP 2.0,有环绕通知.前置通知.后置通知.返回通知.异常通知等. 已实现:①通过动态代理+通知的注解类,实现了前置通知.后置通知等各种通知:②切点( ...