有时,我们希望include包含程序输出目录,则${CMAKE_OUTPUT_DIRECTORIES}只能获取输出路径,无法获取当前的Config,经过查找,发现CMAKE_CFG_INTDIR 变量正好可以做此时。
CMAKE_CFG_INTDIR
对每个配置输出子目录的构建时引用。
对于支持构建树中的多个配置的本机构建系统(例如Visual Studio和Xcode),该值是对构建时变量的引用,该变量指定每个配置输出子目录的名称。在Makefile生成器上,它的计算结果为“。”,因为构建树中只有一个配置。示例值:
$(IntDir) = Visual Studio 6
$(OutDir) = Visual Studio 7, 8, 9
$(Configuration) = Visual Studio 10
$(CONFIGURATION) = Xcode
. = Make-based tools
由于这些值是由本机构建系统评估的,因此该变量仅适用于将在构建时评估的命令行。预期用途示例:
add_executable(mytool mytool.c)
add_custom_command(
OUTPUT out.txt
COMMAND ${CMAKE_CURRENT_BINARY_DIR}/${CMAKE_CFG_INTDIR}/mytool
${CMAKE_CURRENT_SOURCE_DIR}/in.txt out.txt
DEPENDS mytool in.txt
)
add_custom_target(drive ALL DEPENDS out.txt)
请注意,为此目的不再需要CMAKE_CFG_INTDIR,而是为了与现有项目兼容。相反,add_custom_command()在其COMMAND选项中识别可执行目标名称,因此“$ {CMAKE_CURRENT_BINARY_DIR} / $ {CMAKE_CFG_INTDIR} / mytool”可以仅由“mytool”替换。
此变量是只读的。设置它是未定义的行为。在多配置构建系统中,此变量的值作为预处理程序符号“CMAKE_INTDIR”的值传递给所有源文件的编译。
包含程序输出目录
# include tlb directory CMAKE_CFG_INTDIR 可以在VS中生成$(Configuration) 宏
INCLUDE_DIRECTORIES(${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/${CMAKE_CFG_INTDIR})
MESSAGE(${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/${CMAKE_CFG_INTDIR})