Fix link dependencies. ()

Add dependencies via target_link_libraries as PUBLIC.
It seems the new behavior which defaults to PRIVATE was
used implicitly causing transitive dependencies to be
omitted.
master
Wolfgang Hess 2016-12-12 14:56:54 +01:00 committed by GitHub
parent 78f5e2f088
commit efe700a9f3
2 changed files with 20 additions and 20 deletions

View File

@ -15,9 +15,9 @@
# Usage from an external project: # Usage from an external project:
# In your CMakeLists.txt, add these lines: # In your CMakeLists.txt, add these lines:
# #
# find_package(cartographer REQUIRED ) # find_package(cartographer REQUIRED)
# include_directories(${CARTOGRAPHER_INCLUDE_DIRS}) # include_directories(${CARTOGRAPHER_INCLUDE_DIRS})
# target_link_libraries(MY_TARGET_NAME ${CARTOGRAPHER_LIBRARIES}) # target_link_libraries(MY_TARGET_NAME PUBLIC ${CARTOGRAPHER_LIBRARIES})
# #
# #
# This file will define the following variables: # This file will define the following variables:

View File

@ -41,14 +41,10 @@ endmacro(_parse_arguments)
macro(_common_compile_stuff VISIBILITY) macro(_common_compile_stuff VISIBILITY)
set(TARGET_COMPILE_FLAGS "${TARGET_COMPILE_FLAGS} ${GOOG_CXX_FLAGS}") set(TARGET_COMPILE_FLAGS "${TARGET_COMPILE_FLAGS} ${GOOG_CXX_FLAGS}")
foreach(DEPENDENCY ${ARG_DEPENDS})
target_link_libraries(${NAME} ${DEPENDENCY})
endforeach()
if(catkin_INCLUDE_DIRS) if(catkin_INCLUDE_DIRS)
target_include_directories("${NAME}" SYSTEM ${VISIBILITY} target_include_directories("${NAME}" SYSTEM ${VISIBILITY}
"${catkin_INCLUDE_DIRS}") "${catkin_INCLUDE_DIRS}")
target_link_libraries("${NAME}" ${catkin_LIBRARIES}) target_link_libraries("${NAME}" PUBLIC ${catkin_LIBRARIES})
add_dependencies("${NAME}" ${catkin_EXPORTED_TARGETS} add_dependencies("${NAME}" ${catkin_EXPORTED_TARGETS}
) )
endif() endif()
@ -56,50 +52,50 @@ macro(_common_compile_stuff VISIBILITY)
if(ARG_USES_EIGEN) if(ARG_USES_EIGEN)
target_include_directories("${NAME}" SYSTEM ${VISIBILITY} target_include_directories("${NAME}" SYSTEM ${VISIBILITY}
"${EIGEN3_INCLUDE_DIR}") "${EIGEN3_INCLUDE_DIR}")
target_link_libraries("${NAME}" ${EIGEN3_LIBRARIES}) target_link_libraries("${NAME}" PUBLIC ${EIGEN3_LIBRARIES})
endif() endif()
if(ARG_USES_CERES) if(ARG_USES_CERES)
target_include_directories("${NAME}" SYSTEM ${VISIBILITY} target_include_directories("${NAME}" SYSTEM ${VISIBILITY}
"${CERES_INCLUDE_DIRS}") "${CERES_INCLUDE_DIRS}")
target_link_libraries("${NAME}" ${CERES_LIBRARIES}) target_link_libraries("${NAME}" PUBLIC ${CERES_LIBRARIES})
endif() endif()
if(ARG_USES_LUA) if(ARG_USES_LUA)
target_include_directories("${NAME}" SYSTEM ${VISIBILITY} target_include_directories("${NAME}" SYSTEM ${VISIBILITY}
"${LUA_INCLUDE_DIR}") "${LUA_INCLUDE_DIR}")
target_link_libraries("${NAME}" ${LUA_LIBRARIES}) target_link_libraries("${NAME}" PUBLIC ${LUA_LIBRARIES})
endif() endif()
if(ARG_USES_BOOST) if(ARG_USES_BOOST)
target_include_directories("${NAME}" SYSTEM ${VISIBILITY} target_include_directories("${NAME}" SYSTEM ${VISIBILITY}
"{Boost_INCLUDE_DIRS}") "{Boost_INCLUDE_DIRS}")
target_link_libraries("${NAME}" ${Boost_LIBRARIES}) target_link_libraries("${NAME}" PUBLIC ${Boost_LIBRARIES})
endif() endif()
if(ARG_USES_WEBP) if(ARG_USES_WEBP)
target_link_libraries("${NAME}" webp) target_link_libraries("${NAME}" PUBLIC webp)
endif() endif()
# We rely on Ceres to find glog and gflags for us. # We rely on Ceres to find glog and gflags for us.
if(ARG_USES_GLOG) if(ARG_USES_GLOG)
target_link_libraries("${NAME}" glog) target_link_libraries("${NAME}" PUBLIC glog)
endif() endif()
if(ARG_USES_GFLAGS) if(ARG_USES_GFLAGS)
target_link_libraries("${NAME}" gflags) target_link_libraries("${NAME}" PUBLIC gflags)
endif() endif()
if(ARG_USES_CARTOGRAPHER) if(ARG_USES_CARTOGRAPHER)
target_include_directories("${NAME}" SYSTEM ${VISIBILITY} target_include_directories("${NAME}" SYSTEM ${VISIBILITY}
"${CARTOGRAPHER_INCLUDE_DIRS}") "${CARTOGRAPHER_INCLUDE_DIRS}")
target_link_libraries("${NAME}" ${CARTOGRAPHER_LIBRARIES}) target_link_libraries("${NAME}" PUBLIC ${CARTOGRAPHER_LIBRARIES})
endif() endif()
if(ARG_USES_PCL) if(ARG_USES_PCL)
target_include_directories("${NAME}" SYSTEM ${VISIBILITY} target_include_directories("${NAME}" SYSTEM ${VISIBILITY}
"${PCL_INCLUDE_DIRS}") "${PCL_INCLUDE_DIRS}")
target_link_libraries("${NAME}" ${PCL_LIBRARIES}) target_link_libraries("${NAME}" PUBLIC ${PCL_LIBRARIES})
foreach(DEFINITION ${PCL_DEFINITIONS}) foreach(DEFINITION ${PCL_DEFINITIONS})
set(TARGET_COMPILE_FLAGS "${TARGET_COMPILE_FLAGS} ${DEFINITION}") set(TARGET_COMPILE_FLAGS "${TARGET_COMPILE_FLAGS} ${DEFINITION}")
endforeach() endforeach()
@ -108,13 +104,13 @@ macro(_common_compile_stuff VISIBILITY)
if(ARG_USES_YAMLCPP) if(ARG_USES_YAMLCPP)
target_include_directories("${NAME}" SYSTEM ${VISIBILITY} target_include_directories("${NAME}" SYSTEM ${VISIBILITY}
"${YAMLCPP_INCLUDE_DIRS}") "${YAMLCPP_INCLUDE_DIRS}")
target_link_libraries("${NAME}" ${YAMLCPP_LIBRARIES}) target_link_libraries("${NAME}" PUBLIC ${YAMLCPP_LIBRARIES})
endif() endif()
if(ARG_USES_CAIRO) if(ARG_USES_CAIRO)
target_include_directories("${NAME}" SYSTEM ${VISIBILITY} target_include_directories("${NAME}" SYSTEM ${VISIBILITY}
"${CAIRO_INCLUDE_DIRS}") "${CAIRO_INCLUDE_DIRS}")
target_link_libraries("${NAME}" ${CAIRO_LIBRARIES}) target_link_libraries("${NAME}" PUBLIC ${CAIRO_LIBRARIES})
endif() endif()
set_target_properties(${NAME} PROPERTIES set_target_properties(${NAME} PROPERTIES
@ -125,6 +121,10 @@ macro(_common_compile_stuff VISIBILITY)
target_include_directories("${NAME}" ${VISIBILITY} "${CMAKE_BINARY_DIR}") target_include_directories("${NAME}" ${VISIBILITY} "${CMAKE_BINARY_DIR}")
target_include_directories("${NAME}" ${VISIBILITY} "${CMAKE_SOURCE_DIR}") target_include_directories("${NAME}" ${VISIBILITY} "${CMAKE_SOURCE_DIR}")
foreach(DEPENDENCY ${ARG_DEPENDS})
target_link_libraries("${NAME}" PUBLIC ${DEPENDENCY})
endforeach()
# Figure out where to install the header. The logic goes like this: either # Figure out where to install the header. The logic goes like this: either
# the header is in the current binary directory (i.e. generated, like port.h) # the header is in the current binary directory (i.e. generated, like port.h)
# or in the current source directory - a regular header. It could also # or in the current source directory - a regular header. It could also
@ -218,7 +218,7 @@ macro(_common_test_stuff)
# Make sure that gmock always includes the correct gtest/gtest.h. # Make sure that gmock always includes the correct gtest/gtest.h.
target_include_directories("${NAME}" SYSTEM PRIVATE target_include_directories("${NAME}" SYSTEM PRIVATE
"${GMOCK_INCLUDE_DIRS}") "${GMOCK_INCLUDE_DIRS}")
target_link_libraries("${NAME}" ${GMOCK_LIBRARIES}) target_link_libraries("${NAME}" PUBLIC ${GMOCK_LIBRARIES})
endmacro() endmacro()
function(_google_catkin_test NAME) function(_google_catkin_test NAME)
@ -318,7 +318,7 @@ function(google_proto_library NAME)
"${PROTOBUF_INCLUDE_DIR}") "${PROTOBUF_INCLUDE_DIR}")
# TODO(hrapp): This should not explicityly list pthread and use # TODO(hrapp): This should not explicityly list pthread and use
# PROTOBUF_LIBRARIES, but that failed on first try. # PROTOBUF_LIBRARIES, but that failed on first try.
target_link_libraries("${NAME}" ${PROTOBUF_LIBRARY} pthread) target_link_libraries("${NAME}" PUBLIC ${PROTOBUF_LIBRARY} pthread)
endfunction() endfunction()
macro(google_initialize_cartographer_project) macro(google_initialize_cartographer_project)