CMake configure_file拷贝文件

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

posted @ 2022-05-21 22:50  明明1109  阅读(934)  评论(0编辑  收藏  举报