target_include_directories 是 CMake 中用于指定目标(target)的头文件搜索路径的命令。 它的语法如下: 1 2 3 4 target_include_directories(target [SYSTEM] [BEFORE] <INTERFACE|PUBLIC|PRIVATE> [items1...] [<INTERFACE|PUBLIC|PRIVATE> [items2...] ...]) 其中,`target` 是目标名称,可以是库或可执行...
为指定目标(target)添加搜索路径,指定目标是指通过如add_executable(),add_library()这样的命令生成的,并且决不能是alias target(引用目标,别名目标)。 语法格式: target_include_directories(<target> [SYSTEM] [AFTER|BEFORE] <INTERFACE|PUBLIC|PRIVATE> [items1...] [<INTERFACE|PUBLIC|PRIVATE> [items2...]...
$ cmake.……# In parent scope, target main: interface[], normal[/XXX/target_include_directories]$ make VERBOSE=1……/usr/bin/c++-MD-MT CMakeFiles/main.dir/main.cpp.o-MF CMakeFiles/main.dir/main.cpp.o.d-o CMakeFiles/main.dir/main.cpp.o-c/XXX/target_include_directories/main.cpp ...
target_include_directories(mylib PUBLIC $<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include/mylib> $<INSTALL_INTERFACE:include/mylib> # <prefix>/include/mylib ) 创建可重定位包 请注意,不建议使用依赖项包含目录的绝对路径填充目标的INSTALL_INTERFACE或INTERFACE_INCLUDE_DIRECTORIES。这会将依赖项的包含...
当然了,在最终子目录的 CMakeLists.txt 文件中,使用include_directories()和target_include_directories()的效果是相同的。 4. 目录划分 每一个目录都是一个模块,目录内部应将对外和对内的头文件进行区分,由模块的调用者决定模块是否被传递(PRIVATE,INTERFACE,PUBLIC)。
PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}/include/public INTERFACE ${CMAKE_CURRENT_SOURCE_DIR}/include/interface ) # 链接另一个库,并使用其头文件 target_link_libraries(my_lib PUBLIC other_lib) # 另一个库也可以使用当前库的头文件 add_library(other_lib STATIC other_source.cpp) ...
则需要后一个。后一个是因为target_include_directories()支持PRIVATE,PUBLIC和INTERFACE限定符。
target_include_directories(<target> [SYSTEM] [AFTER|BEFORE] <INTERFACE|PUBLIC|PRIVATE> [items1...] [<INTERFACE|PUBLIC|PRIVATE> [items2...] ...]) 1. 2. 3. 指定编译给定目标时要使用的include目录。名为< target >的必须由add_executable()或add_library()等命令创建的,并且不能是ALIAS目标。
这些关键字用于告诉何时需要传递给目标的包含目录列表。when表示是否需要这些包含目录:
[<INTERFACE|PUBLIC|PRIVATE> [items2...] ...]) <target>必须是已经通过add_executable()或add_library()等命令创建出来的目标,对于每一个添加的目录,也有可选的范围参数PUBLIC、PRIVATE和INTERFACE,区别是:指定PUBLIC或PRIVATE时,目录会添加到目标的LINK_DIRECTORIES属性中;指定PUBLIC或INTERFACE时,目录会添加到目标...