ceph/cmake/modules/BuildJaeger.cmake
Deepika Upadhyay fcb1eb91c4 cmake: remove buildthrift methods
we use Findthrift.cmake method for adding thrift dependencies, the
cleanup 80e82686eb missed removing these
methods intended to buildthrift from source.

this address the missing failure due to ,
```
CMake Error at cmake/modules/BuildJaeger.cmake:61 (include):
  include could not find load file:

    Buildthrift
```
this fixes regression introduced by: 80e82686eb

Signed-off-by: Deepika Upadhyay <dupadhya@redhat.com>
2021-07-22 21:25:56 +05:30

89 lines
3.5 KiB
CMake

# This module builds Jaeger after it's dependencies are installed and discovered
# opentracing: is built using cmake/modules/Buildopentracing.cmake
# Thrift: found using cmake/modules/Findthrift.cmake (not by default)
# yaml-cpp, nlhomann-json: are installed locally and then discovered using
# Find<package>.cmake
# Boost Libraries: uses ceph build boost cmake/modules/BuildBoost.cmake
include(BuildOpenTracing)
# will do all linking and path setting
function(set_library_properties_for_external_project _target _lib)
# Manually create the directory, it will be created as part of the build,
# but this runs in the configuration phase, and CMake generates an error if
# we add an include directory that does not exist yet.
set(_libfullname "${CMAKE_SHARED_LIBRARY_PREFIX}${_lib}${CMAKE_SHARED_LIBRARY_SUFFIX}")
set(_libpath "${CMAKE_BINARY_DIR}/external/lib/${_libfullname}")
set(_includepath "${CMAKE_BINARY_DIR}/external/include")
message(STATUS "Configuring ${_target} with ${_libpath}")
add_library(${_target} SHARED IMPORTED)
add_dependencies(${_target} ${_lib})
file(MAKE_DIRECTORY "${_includepath}")
set_target_properties(${_target} PROPERTIES
INTERFACE_LINK_LIBRARIES "${_libpath}"
IMPORTED_LINK_INTERFACE_LANGUAGES "CXX"
IMPORTED_LOCATION "${_libpath}"
INTERFACE_INCLUDE_DIRECTORIES "${_includepath}")
endfunction()
function(build_jaeger)
set(Jaeger_SOURCE_DIR "${CMAKE_SOURCE_DIR}/src/jaegertracing/jaeger-client-cpp")
set(Jaeger_INSTALL_DIR "${CMAKE_BINARY_DIR}/external")
set(Jaeger_BINARY_DIR "${CMAKE_BINARY_DIR}/external/jaegertracing")
file(MAKE_DIRECTORY "${Jaeger_INSTALL_DIR}")
set(Jaeger_CMAKE_ARGS -DCMAKE_POSITION_INDEPENDENT_CODE=ON
-DBUILD_SHARED_LIBS=ON
-DHUNTER_ENABLED=OFF
-DBUILD_TESTING=OFF
-DJAEGERTRACING_BUILD_EXAMPLES=OFF
-DCMAKE_PREFIX_PATH="${CMAKE_BINARY_DIR}/external;${CMAKE_BINARY_DIR}/boost"
-DCMAKE_INSTALL_RPATH=${CMAKE_BINARY_DIR}/external
-DCMAKE_INSTALL_RPATH_USE_LINK_PATH=TRUE
-DOpenTracing_DIR=${CMAKE_SOURCE_DIR}/src/jaegertracing/opentracing-cpp
-Dnlohmann_json_DIR=/usr/lib
-DCMAKE_FIND_ROOT_PATH=${CMAKE_BINARY_DIR}/external
-DCMAKE_INSTALL_PREFIX=${CMAKE_BINARY_DIR}/external
-DCMAKE_INSTALL_LIBDIR=${CMAKE_BINARY_DIR}/external/lib
-DBoost_INCLUDE_DIRS=${CMAKE_BINARY_DIR}/boost/include
-DBOOST_ROOT=${CMAKE_BINARY_DIR}/boost
-Dthrift_HOME=${CMAKE_BINARY_DIR}/external
-DOpenTracing_HOME=${CMAKE_BINARY_DIR}/external)
# build these libraries along with jaeger
set(dependencies opentracing)
if(NOT WITH_SYSTEM_BOOST)
list(APPEND dependencies Boost)
endif()
include(BuildOpenTracing)
build_opentracing()
if(CMAKE_MAKE_PROGRAM MATCHES "make")
# try to inherit command line arguments passed by parent "make" job
set(make_cmd $(MAKE) jaegertracing)
else()
set(make_cmd ${CMAKE_COMMAND} --build <BINARY_DIR> --target jaegertracing)
endif()
set(install_cmd DESTDIR= ${CMAKE_MAKE_PROGRAM} install)
include(ExternalProject)
ExternalProject_Add(jaegertracing
SOURCE_DIR ${Jaeger_SOURCE_DIR}
UPDATE_COMMAND ""
INSTALL_DIR "external"
PREFIX ${Jaeger_INSTALL_DIR}
CMAKE_ARGS ${Jaeger_CMAKE_ARGS}
BINARY_DIR ${Jaeger_BINARY_DIR}
BUILD_COMMAND ${make_cmd}
INSTALL_COMMAND ${install_cmd}
DEPENDS ${dependencies}
BUILD_BYPRODUCTS ${CMAKE_BINARY_DIR}/external/lib/libjaegertracing.so
)
set_library_properties_for_external_project(opentracing::libopentracing
opentracing)
set_library_properties_for_external_project(jaegertracing::libjaegertracing
jaegertracing)
endfunction()