我想在每次构建之前运行的二进制文件的示例源,每个add_executable:
#include <stdio.h>
int main(int argc, char *argv[]) {
for(int i=0; i<argc; ++i)
printf("argv[%d] = %s\n", i, argv[i]);
fclose(fopen("foo.hh", "a"));
}
Run Code Online (Sandbox Code Playgroud)
CMakeLists.txt
cmake_minimum_required(VERSION 3.5)
project(foo_proj)
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++14")
set(SOURCE_FILES main.cpp)
# ---- this line changes ----
add_executable(foo_proj ${SOURCE_FILES})
Run Code Online (Sandbox Code Playgroud)
尝试:
add_custom_target(create_foo_hh COMMAND /tmp/bin/create_foo_hh)
add_dependencies(${SOURCE_FILES} create_foo_hh)
Run Code Online (Sandbox Code Playgroud)
错误:无法将目标级依赖项添加到不存在的目标“main.cpp”。add_dependencies 适用于由 add_executable、add_library 或 add_custom_target 命令创建的顶级逻辑目标。如果要添加文件级依赖项,请参阅 add_custom_target 和 add_custom_command 命令的 DEPENDS 选项。
execute_process(COMMAND /tmp/bin/create_foo_hh main.cpp)
Run Code Online (Sandbox Code Playgroud)
没有错误,但没有创建 foo.hh。
如何自动运行此命令?
execute_process() 在配置时调用。
您可以使用add_custom_command():
add_custom_command(
OUTPUT foo.hh
COMMAND /tmp/bin/create_foo_h main.cpp
DEPENDS ${SOURCE_FILES} /tmp/bin/create_foo_hh main.cpp
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
)
include_directories(${CMAKE_CURRENT_BINARY_DIR})
add_executable(foo_proj ${SOURCE_FILES} foo.hh)
Run Code Online (Sandbox Code Playgroud)
这样,foo.hh是 : 的依赖项,foo_proj并且您的命令将在构建foo_proj. 它取决于${SOURCE_FILES}并且/tmp/bin/create_foo_hh main.cpp如果这些文件之一发生更改,它会再次生成。
关于路径,add_custom_command()配置为在当前构建目录中运行以在那里生成文件,并include_directories()用于将构建目录添加到包含目录中。
您可能不希望自定义目标依赖于您的源文件(因为它们本身不是目标,因此永远不会“运行”),而是依赖于您使用它们创建的目标:
target_add_dependencies(foo_proj create_foo_hh)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
11931 次 |
| 最近记录: |