From 41f444a23042b0cbbdd76f8accf8b8ae2c5996a9 Mon Sep 17 00:00:00 2001 From: Ilya Lavrenov Date: Fri, 7 Feb 2020 18:10:14 +0300 Subject: [PATCH] CMAKE: more robust custom IE libraries support backporting of commit 98d96f2cc84ea4192e278125b431eb2ced29b786 --- cmake/OpenCVDetectInferenceEngine.cmake | 24 +++++++++++------------- 1 file changed, 11 insertions(+), 13 deletions(-) diff --git a/cmake/OpenCVDetectInferenceEngine.cmake b/cmake/OpenCVDetectInferenceEngine.cmake index 328ac462d2..5326eb9795 100644 --- a/cmake/OpenCVDetectInferenceEngine.cmake +++ b/cmake/OpenCVDetectInferenceEngine.cmake @@ -36,13 +36,16 @@ function(add_custom_ie_build _inc _lib _lib_rel _lib_dbg _msg) INTERFACE_INCLUDE_DIRECTORIES "${_inc}" ) - find_library(ie_builder_custom_lib "inference_engine_nn_builder" PATHS "${INF_ENGINE_LIB_DIRS}" NO_DEFAULT_PATH) - if(EXISTS "${ie_builder_custom_lib}") - add_library(inference_engine_nn_builder UNKNOWN IMPORTED) - set_target_properties(inference_engine_nn_builder PROPERTIES - IMPORTED_LOCATION "${ie_builder_custom_lib}" - ) - endif() + set(custom_libraries "") + file(GLOB libraries "${INF_ENGINE_LIB_DIRS}/${CMAKE_SHARED_LIBRARY_PREFIX}inference_engine_*${CMAKE_SHARED_LIBRARY_SUFFIX}") + foreach(full_path IN LISTS libraries) + get_filename_component(library "${full_path}" NAME_WE) + string(REPLACE "${CMAKE_SHARED_LIBRARY_PREFIX}" "" library "${library}") + add_library(${library} UNKNOWN IMPORTED) + set_target_properties(${library} PROPERTIES + IMPORTED_LOCATION "${full_path}") + list(APPEND custom_libraries ${library}) + endforeach() if(NOT INF_ENGINE_RELEASE VERSION_GREATER "2018050000") find_library(INF_ENGINE_OMP_LIBRARY iomp5 PATHS "${INF_ENGINE_OMP_DIR}" NO_DEFAULT_PATH) @@ -53,12 +56,7 @@ function(add_custom_ie_build _inc _lib _lib_rel _lib_dbg _msg) endif() endif() set(INF_ENGINE_VERSION "Unknown" CACHE STRING "") - set(INF_ENGINE_TARGET inference_engine) - if(TARGET inference_engine_nn_builder) - list(APPEND INF_ENGINE_TARGET inference_engine_nn_builder) - set(_msg "${_msg}, with IE NN Builder API") - endif() - set(INF_ENGINE_TARGET "${INF_ENGINE_TARGET}" PARENT_SCOPE) + set(INF_ENGINE_TARGET "inference_engine;${custom_libraries}" PARENT_SCOPE) message(STATUS "Detected InferenceEngine: ${_msg}") endfunction()