ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

CMake configure_file拷贝文件

2022-05-21 23:01:04  阅读:197  来源: 互联网

标签:文件 CMake configure file var config define


目录

configure_file简介

configure_file 将文件复制到另一个位置并修改其内容。该命令将<input>文件复制到<output>文件,并根据指定规则对其内容进行转换。

configure_file(<input> <output>
               [NO_SOURCE_PERMISSIONS | USE_SOURCE_PERMISSIONS |
                FILE_PERMISSIONS <permissions>...]
               [COPYONLY] [ESCAPE_QUOTES] [@ONLY]
               [NEWLINE_STYLE [UNIX|DOS|WIN32|LF|CRLF] ])

主要参数说明:
input为输入文件,output为输出文件。通常,输入文件为 xxx-config.h.in,输出文件为xxx-config.h。
@ONLY 指定在<input>文件中只使用@VAR@的方式获取变量值,而不用${VAR}。如果CMake没用定义该遍历,则替换为空字符串。

示例

需要准备2个文件:config.h.in(input),CMakeLists.txt(与input在同一目录)。output是自动生成的。

config.h.in

#cmakedefine var1
#cmakedefine var2 "@var2" #注意:@@之间的名称要与cmakedefine后变量名一样
#cmakedefine var3 "${var3}"  # 注意:${}之间的名称要与cmakedefine后的变量名一样
#ifndef _@var4@_${var5}_
#define _@var4@_${var5}_
#endif

CMakeLists.txt

cmake_mininum_required(VERSION 2.8)
project (configure_file_test)
option (var1 "use var1..." ON)  #定义var1,也可以使用cmake -Dvar1=ON替代
set (var2 13) #指定var2的值
set (var3 "var3string") #指定var3的值
set (var4 "VARTEST4")
set (var5 "VARTEST5")

configure_file (config.h.in config.h)

执行cmake命令“cmake .”后,自动生成config.h文件

#define var1
#define var2 "13"
#define var3 "var3string"
#ifndef _VARTEST4_VARTEST5_
#define _VARTEST4_VARTEST5_
#endif

其他细节

参数详解

input 输入文件的路径,是一个相对路径,以CMAKE_CURRENT_SOURCE_DIR为路径前缀。而且,它必须是一个文件,不能是目录。

output 输出文件或目录,也是一个相对路径,以 CMAKE_CURRENT_SOURCE_DIR为前缀。如果output的名称与已经存在的目录名相同,就会在该目录下生成一个与input文件名相同的文件。e.g. 如果input文件名“inputfile”,output是一个目录“currentdir”(已经存在),那么生成的文件路径为“currentdir/inputfile”。

options 参数选项

1)COPYONLY 简单把input文件拷贝到output,不做任何替换。该选项与NEWLINE_STYLE冲突,不能同时使用。

2)ESCAPE_QUATES 忽略反斜杠(C语言风格)的转义。
e.g. 不加ESCAPE_QUATES,默认会对反斜杠进行转义:

config.h.in文件:
#define @var@

CMakeLists.txt文件:
set (var "\"VAR\"")
configure_file(config.h.in config.h)

生成的config.h文件:
#define "VAR"

加ESCAPE_QUATES,不对反斜杠进行转义:

config.h.in文件:
#define @var@

CMakeLists.txt文件:
set(var "\"VAR\"")
configure_file(config.h.in config.h ESCAPE_QUATES)

生成的config.h文件:
#define \"VAR\"

3)@ONLY
只替换input文件中的@var,不替换\({var}。\){var}在脚本语言中有语义含义(替换会导致含义变化),因此在处理这类文件时很有用。

4)NEWLINE_STYLE
指定output文件的换行风格,如linux以\n(LF)作为换行,windows以\r\n(CRLF)作为换行。该参数后腰指明换行的规则,如UNIX|DOS|WIN32|LF|CRLF。

cmakedefine命令

#cmakedefine var
#cmakedefine var1 10

如果var后面没用跟着值,生成效果为“#define var”;如果跟着值,生成效果为“#define var1 10”

cmakedefine01命令

#cmakedefine01 var

如果var有定义,生成效果为“#define var 1”;如果未定义,生成效果为“#define var 0”。

其他注意事项

1)对于input中的“#cmakedefine var @var@”或“#cmakedefine var \({var}”,@@之间或\){}内变量名要与cmakedefine命令后变量名一样,否则替换不成功。

2)configure_file 要放在变量定义后(OPTION定义的变量可以在configure_file之后)。

参考

https://www.jianshu.com/p/2946eeec2489
https://cmake.org/cmake/help/latest/command/configure_file.html

标签:文件,CMake,configure,file,var,config,define
来源: https://www.cnblogs.com/fortunely/p/16296318.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有