一、命令格式
configure_file(input output options)
将一个文件(由
input
参数指定)拷贝到指定位置(由output
参数指定),并根据options
修改其内容。
二、命令解析
configure_file命令一般用于自定义编译选项或者自定义宏的场景。configure_file命令会根据options
指定的规则,自动对input
文件中cmakedefine
关键字及其内容进行转换。
具体来说,会做如下几个替换:
1. 将input文件中的@var@
或者${var}
替换成cmake中指定的值。
2. 将input文件中的#cmakedefine var
关键字替换成#define var
或者#undef var
,取决于cmake是否定义了var。
三、举例说明
需要准备2个文件,config.h.in(input)、CMakeLists.txt,(output是自动生成的)内容如下:
config.h.in
#cmakedefine var1
#cmakedefine var2 "@var2@" #注意:@@之间的名称要与cmakedefine后的变量名一样
#cmakedefine var3 "${var3}" #注意:${}之间的名称要与cmakedefine后的变量名一样
#ifdef _@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"
#ifdef _VARTEST4_VARTEST5_
#endif
四、更多细节
-
参数详解
input
- 输入文件的路径,它是一个相对路径,以CMAKE_CURRENT_SOURCE_DIR
为路径前缀。此外,。
output
- 输出文件或目录,它也是一个相对路径,以CMAKE_CURRENT_BINARY_DIR
为前缀。如果output的名称与已存在的目录名称相同,则会在该目录下生成一个与input文件名相同的文件。举个例子:如果input的文件名是inputfile,output是一个目录currentdir,那么生成的文件为currentdir/inputfile。
options
- 参数选项
COPYONLY
:简单的把input
文件拷贝到output
,不做任何替换。注意,NEWLINE_STYLE
。ESCAPE_QUOTES
:忽略反斜杠(C语言风格)的转义。
举个例子,不加ESCAPE_QUOTES
的情况,也就是默认会对反斜杠进行转义:config.h.in文件: #define @var@ CMakeLists.txt文件: set (var "\"VAR\"") configure_file (config.h.in config.h) 生成的config.h文件: #define "VAR"
加
ESCAPE_QUOTES
的情况,不对反斜杠进行转义:config.h.in文件: #define @var@ CMakeLists.txt文件: set (var "\"VAR\"") configure_file (config.h.in config.h ESCAPE_QUOTES) 生成的config.h文件: #define \"VAR\"
@ONLY
:只替换@var@
,不替换${var}
。${var}
在脚本语言中有语义含义(替换会导致含义发生变化),因此在处理这类文件的时候,该选项很有用。NEWLINE_STYLE
:指定output
文件的换行风格,例如linux以\n作为换行,windows以\r\n作为换行。该参数后面要指明换行的规则,如UNIX|DOS|WIN32|LF|CRLF
。
-
cmakedefine01命令
#cmakedefine01 var
如果var有定义,则实际生成的效果为:#define var 1
;如果var未定义,生成的效果为:#define var 0
。
config.h.in文件:
#cmakedefine01 var
CMakeLists.txt文件:
option(var "use var..." ON) # 实际也可以用cmake -Dvar=ON或者cmake -Dvar=OFF来定义或者不定义
#set (var XXX) # 用set来定义var也可以,验证发现XXX为0的时候相当于var未定义,XXX为非0的时候效果相当于var有定义
生成的config.h文件:
#define var 1 # 当var有定义
#define var 0 # 当var未定义
-
其他注意事项
- 对于
#cmakedefine var @var@
或#cmakedefine var ${var}
,@@之间或${}内的变量名称要与cmakedefine后的变量名称一样,否则替换不成功。configure_file
要放在变量定义之后(验证发现OPTION
定义的变量可以在configure_file之后)。