我已经搜索了这个,但也许我使用了错误的措辞;我希望在安装另一个目标后构建一个CMake目标。
通过一个具体的例子,我希望我的测试包含和链接库的一个版本,其目录结构类似于实际安装。 目录结构:
project
lib
first_library
header1.hpp
source1.cpp # this includes "first_library/header1.hpp"
second_library
header2.hpp
source2.cpp # likewise, #include "second_library/header2.hpp"
tests
lib1_tests
test1.cpp # this must include "first_library/header1.hpp"
lib2_tests
test2.cpp # likewise, #include "second_library/header2.hpp"
这些都不适合我。在lib目录的CMakeLists.txt中,我有:
add_library(lib1 STATIC ${lib1_SOURCES} ${lib1_HEADERS})
set_property(TARGET lib1 APPEND
PROPERTY INCLUDE_DIRECTORIES "${CMAKE_CURRENT_LIST_DIR}/../")
install(TARGETS lib1 EXPORT lib1
ARCHIVE DESTINATION lib
INCLUDES DESTINATION include)
install(FILES ${lib1_HEADERS}
DESTINATION include/my_lib_collection/first_library)
并且测试有
add_executable(tests "${TEST_SOURCES}")
add_dependencies(tests lib1)
add_dependencies(tests lib2)
target_link_libraries(tests ${GTEST_BOTH_LIBRARIES}
lib1 lib2)
target_include_directories(tests
INTERFACE $<INSTALL_INTERFACE:INTERFACE_INCLUDE_DIRECTORIES:include/my_lib_collection>)
set_property(TARGET tests APPEND
PROPERTY INCLUDE_DIRECTORIES ${GTEST_INCLUDE_DIRS})
最终,我想要的是一个与已安装状态兼容的目录结构,并且能够在构建测试时使用这些目录结构。
谢谢!
答案 0 :(得分:1)
我面临着你现在面临的同样问题。 不能说我找到了一本教科书解决方案,但我确实设法解决了这个问题
我有多个子目录,每个目录都有一个CmakeList.txt文件。
有一个分支,分支的其余部分都依赖于它的安装
我所做的是使用add_custom_target
(而不是add_subdirectory
)以及该自定义目标中用于构建子目录的命令行的命令