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

CMake 教程跟做与翻译 2

目录

STEP 1(Extra A):指定C++的版本

STEP1(Extra B): 为我们的项目添加版本信息与配置的头文件

Reference


STEP 1(Extra A):指定C++的版本

有的时候,我们会是对一个比较年老的项目进行构建。这个时候,我们可能就需要限制一下使用的C/C++的版本(比如说使用的是C++98)来进行编译;或者,我们的项目很潮,使用的是C++17以上的版本,这个时候限制就显得更为必要了(一些新的特性需要新版本支持)。我们就需要作出限制。

在这里,我们需要使用到的就是:

CMAKE_CXX_STANDARD              # CMake里的C++标准变量
CMAKE_CXX_STANDARD_REQUIRED     # CMake里的一个BOOL变量,用于指示是否强迫版本
set()                           # 设置这些变量使用到的CMake函数

当然,我们只需要在CMakeLists.txt中,在project的下方和add_executable函数的上方加入

set(CMAKE_CXX_STANDARD 11)
set(CMAKE_CXX_STANDARD_REQUIRED True)

这就表达了我们需要强制使用C++11编译本项目的意思!

STEP1(Extra B): 为我们的项目添加版本信息与配置的头文件

有时,让 CMakelists.txt 文件中定义的变量在源代码中可用可能会很有用。在这种情况下,我们想打印项目版本。实现此目的的一种方法是使用已配置的头文件。我们创建一个包含一个或多个要替换的变量的输入文件。这些变量具有特殊的语法,看起来像 @VAR@。然后,我们使用 configure_file() 命令将输入文件复制到给定的输出文件,并用 CMakelists.txt 文件中 VAR 的当前值替换这些变量。

虽然我们可以直接在源代码中编辑版本,但最好使用此功能,因为它可以创建单一事实来源并避免重复。

项目的版本信息很容易添加,我在上一篇就说到了:

project(CharliesDemo VERSION 1.0)

下面,我们可以在源代码文件中使用了。使用的bridge在哪里呢?那就是使用CMake里的configure_file指令。

他的作用很简单:将input文件复制到output文件,并在输入文件内容中的变量,替换引用为@VAR@或${VAR}的变量值。每个变量引用将替换为该变量的当前值,如果未定义该变量,则为空字符串

实际上就是做拷贝替换的工作

  • COPYONLY:只拷贝文件,不进行任何的变量替换。这个选项在指定了NEWLINE_STYLE选项时不能使用(无效)。

  • ESCAPE_QUOTES:躲过任何的反斜杠(C风格)转义。

  • @ONLY:限制变量替换,让其只替换被@VAR@引用的变量(那么${VAR}格式的变量将不会被替换)。这在配置${VAR}语法的脚本时是非常有用的。

  • NEWLINE_STYLE style:指定输出文件中的新行格式。UNIX和LF的新行是\n,DOS和WIN32和CRLF的新行格式是\r\n。这个选项在指定了COPYONLY选项时不能使用(无效)。

通常情况下,输入文件以.h.in为后缀,输出文件以.h为后缀。

我们下面来试试看:

#define VERSION_MAJOR @CharliesDemo_VERSION_MAJOR@
#define VERSION_MINOR @CharliesDemo_VERSION_MINOR@

引用工程的属性名称正式:工程名称+工程属性。我们的CMake在构建的时候就会替换我们的@VAR@为我们CMake的值。下面在CMake中配置:

configure_file(Config.h.in Config.h)

我们可以看看生成的Config.h文件

#define VERSION_MAJOR 1
#define VERSION_MINOR 0

使用一下,你会发现一个问题:

#include <stdio.h>
#include "Config.h"
#include "lib.h"
​
int main()
{printf("VERISON_MAJOR: %d", VERSION_MAJOR);printf("%d + %d = %d", 1, 2, my_add(1, 2));
}

gcc找不到我们的Config.h。这里需要超前的提供一个这样的命令:

target_include_directories(CharliesDemo PUBLIC "${PROJECT_BINARY_DIR}")

这句话的含义是:对于目标CharliesDemo提供要索引的目录为我们的build路径。这里正有Config.h!

下面我们来看看我们的CMakeLists.txt脚本:

cmake_minimum_required(VERSION 3.30)
​
project(CharliesDemoVERSION 1.0)
​
configure_file(Config.h.in Config.h)
​
add_executable(CharliesDemo lib.c main.c)
target_include_directories(CharliesDemo PUBLIC "${PROJECT_BINARY_DIR}")

看官自行回忆每一句话的含义。

Reference

_VERSION_MAJOR

_VERSION_MINOR

configure_file()

target_include_directories()

CMAKE_CXX_STANDARD

CMAKE_CXX_STANDARD_REQUIRED

set()

http://www.lryc.cn/news/456517.html

相关文章:

  • Linux 之 安装软件、GCC编译器、Linux 操作系统基础
  • [CTF夺旗赛] CTFshow Web13-14 详细过程保姆级教程~
  • 【Matlab】Matlab 导入数据.csv或者.xlsx文件,然后使用这些数据来绘制图表
  • Awaken Likho恶意组织利用高级网络工具对俄罗斯政府发起“猛攻”
  • 【洛谷】P10938 Vani和Cl2捉迷藏 的题解
  • 三角形面积 python
  • 【C++第十七章】二叉搜索树
  • Springboot 文件上传
  • 简单认识redis-5 jdbc 与 jedis 使用的区别
  • Unity3d动画插件DoTween使用指南
  • 学习函数知识
  • 案例-表白墙简单实现
  • 和鲸科技创始人范向伟:拐点即将来临,AI产业当前的三个瓶颈
  • 基于函数计算FC 部署 ComfyUI实现AI生图 的优势
  • 瑞萨IDE:CS+ for CC编译过程中执行脚本文件
  • 在 CentOS 上安装 Docker 的步骤
  • 【C#生态园】探索地理信息系统软件套件与库:功能、API和应用
  • Jupyter的使用分享
  • 24龙信比赛复现
  • PHP反射机制
  • 使用阿里云试用资源快速部署web应用-dofaker为例
  • 需求11——解决字段无法清空的两个小bug
  • mysql学习教程,从入门到精通,SQL 创建索引(CREATE INDEX 语句)(35)
  • Pikachu-Cross-Site Scripting-DOM型xss_x
  • Pikachu-Cross-Site Scripting-xss之htmlspecialchars
  • CSS基础中padding详解
  • OpenGL笔记十九之相机系统
  • P-Tuning v2:一种普遍有效的提示调整方法
  • 微信小程序启动不起来,报错凡是以~/包名/*.js路径的文件,都找不到,试过网上一切方法,最终居然这么解决的,【避坑】命运的齿轮开始转动
  • C#串口温度读取