1 # Copyright (C) 2018-2019 Intel Corporation
2 # SPDX-License-Identifier: Apache-2.0
5 function (debug_message)
11 function(clean_message type)
12 string (REPLACE ";" "" output_string "${ARGN}")
13 execute_process(COMMAND ${CMAKE_COMMAND} -E echo "${output_string}")
14 if(${ARGV0} STREQUAL "FATAL_ERROR")
19 file(REMOVE ${CMAKE_BINARY_DIR}/ld_library_rpath_64.txt)
21 # log relative path to shared library that has to be used in LD_LIBRARY_PATH
22 function (log_rpath_remove_top component component_remove_top lib lib_remove_top)
24 set(top_lib_dir ${${component}})
27 # debug_message(STATUS "LIB-IN=${lib} ")
28 # debug_message(STATUS "TOPLIB-IN=${top_lib_dir} ")
29 get_filename_component(top_lib_dir ${${component}} DIRECTORY)
31 if (${component_remove_top} AND ${component})
33 get_filename_component(add_name ${${component}} NAME)
34 set(top_lib_dir "${top_lib_dir}/${add_name}")
36 if (${lib_remove_top} AND lib)
37 get_filename_component(lib_dir ${lib} DIRECTORY)
40 string (REPLACE "//" "/" top_lib_dir "${top_lib_dir}")
41 string (REPLACE "//" "/" lib_dir "${lib_dir}")
43 string (REPLACE "\\\\" "/" top_lib_dir "${top_lib_dir}")
44 string (REPLACE "\\\\" "/" lib_dir "${lib_dir}")
46 # debug_message(STATUS "LIB-OUT=${lib_dir}")
47 # debug_message(STATUS "TOPLIB-OUT=${top_lib_dir}")
50 string (TOLOWER "${top_lib_dir}" top_lib_dir)
51 string (TOLOWER "${lib_dir}" lib_dir)
54 string (REPLACE "${top_lib_dir}" "" component_dir "${lib_dir}")
56 set(RPATH_INFO "${component}=${component_dir}")
57 debug_message(STATUS "LD_LIBRARY_RPATH: ${RPATH_INFO}")
58 file(APPEND ${CMAKE_BINARY_DIR}/ld_library_rpath_64.txt "${RPATH_INFO}\n")
61 function (log_rpath_from_dir component lib_dir)
62 log_rpath_remove_top("${component}" TRUE "${lib_dir}" FALSE)
65 function (log_rpath component lib_path)
66 log_rpath_remove_top(${component} TRUE ${lib_path} TRUE)
69 # Just wrapping of the original message() function to make this macro known during IE build.
70 # This macro is redefined (with additional checks) within the InferenceEngineConfig.cmake file.
71 macro(ext_message TRACE_LEVEL)
72 message(${TRACE_LEVEL} "${ARGN}")