好吧,这让我发疯了,所以我会请你们帮忙。 我正在尝试建立一个目前相当小的新项目。
为了简单起见,我的项目结构如下:
RootProject
- module1(仅限标题库)
- 包括
---模块1
----头文件(包含模板,我想测试)
--test
--- testmain.cpp(使用gmock和boost单元测试框架)
-CMakeLists.txt(1)
-module2(另一个lib,使用module1)
- 作为模块1的相同结构
CMakeLists.txt(2)
所以,我有一个根CMakeLists.txt和每个模块的几个CMakeLists.txt。
Root CMakeLists.txt:
`
cmake_minimum_required(VERSION 2.8)
project(root)
# compiler
set(CMAKE_CXX_COMPILER "g++")
# cpp flags
set(CMAKE_CXX_FLAGS "-g -Wall")
add_definitions(-std=gnu++0x)
find_package(Boost COMPONENTS system filesystem unit_test_framework REQUIRED)
set(BOOST_INCLUDES
${Boost_FILESYSTEM_INCLUDE_DIR}
${Boost_SYSTEM_INCLUDE_DIR}
${Boost_UNIT_TEST_FRAMEWORK_INCLUDE_DIR}
)
set(BOOST_LIBRARIES
${Boost_FILESYSTEM_LIBRARY}
${Boost_SYSTEM_LIBRARY}
${Boost_UNIT_TEST_FRAMEWORK_LIBRARY}
)
# Build with system gmock and embedded gtest
set (GMOCK_INCLUDE_DIR "C:/GMock/gmock-1.6.0/include")
set(GMOCK_LIBRARIES gmock gmock_main)
enable_testing()
# Add sub-directories
add_subdirectory (module1)
add_subdirectory (module2)
add_subdirectory (module3)
add_executable(root main.cxx)
但是对于module1有一个工作的CMakeLists.txt让我头疼。 哪个是测试仅标题模块的最简单的解决方案?我真的很感谢你的帮助!
答案 0 :(得分:1)
最简单的解决方案是只需引入module1的include目录,不做任何其他事情。特别是,您不需要为仅标头模块创建目标:
# Add sub-directories
# add_subdirectory (module1) this we don't need
set(MODULE1_INCLUDE_DIRS "${PROJECT_SOURCE_DIR}/module1/include")
add_subdirectory (module2)
add_subdirectory (module3)
add_executable(root main.cxx)
set_property(TARGET root APPEND PROPERTY INCLUDE_DIRECTORIES ${MODULE1_INCLUDE_DIRS})
另一种方法是为module1定义一个便利目标。不幸的是,自定义目标在过去给我带来了麻烦,所以我现在所做的是在每个只有头的库中放置一个空dummy.cpp
并从中创建一个静态库。这只是为了让CMake高兴。这允许您执行以下操作:
Module1 CMakeLists
cmake_minimum_required(VERSION 2.8.11) # 2.8.11 needed for target_include_directories
project("module1")
add_library(module1 STATIC dummy.cpp)
target_include_directories(module1 PUBLIC "${PROJECT_SOURCE_DIR}/include")
主要CMakeLists
[...]
# Add sub-directories
add_subdirectory (module1)
add_subdirectory (module2)
add_subdirectory (module3)
add_executable(root main.cxx)
target_link_libraries(root module1)
# thanks to target_include_directories, this will line
# pull in the correct include paths from module1 for you
这具有以下优点:用户不必担心任何模块的包含或库是什么。您只需将它们全部传递给target_link_libraries
,它就会自动处理所有事情。