From f0f5a9c629616b2a5f47ab6b344912e856cdc0bb Mon Sep 17 00:00:00 2001 From: David Hirvonen Date: Wed, 23 May 2018 21:37:08 -0400 Subject: [PATCH] fix rpath format (#666) * set CMAKE_INSTALL_RPATH w/ list syntax of string syntax * add Context::updateGL() to allow use to call `glewInit()` from within windows DLL (requirement) for multi-context scenarios and bump minor sdk version * add `add_library(drishti::drishti ALIAS drishti)` in install section for `add_subdirectory()` compatibility * update driahti-face-test sample config file defaults ``` set(CMAKE_INSTALL_RPATH "${DRISHTI_ORIGIN}/../lib" "${DRISHTI_ORIGIN}") ``` --- CMakeLists.txt | 7 +++---- cmake/Modules/drishti_set_rpath.cmake | 5 +++-- src/app/CMakeLists.txt | 1 - src/app/sdk/CMakeLists.txt | 2 +- src/app/sdk/face/CMakeLists.txt | 1 + src/app/sdk/face/config/orbbec_astra_pro.json | 12 ++++++------ src/lib/drishti/CMakeLists.txt | 3 +++ src/lib/drishti/drishti/Context.cpp | 13 +++++++++---- src/lib/drishti/drishti/Context.hpp | 2 ++ 9 files changed, 28 insertions(+), 18 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index ab3a6c0b..e94237d5 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -60,9 +60,8 @@ if(DRISHTI_USE_DRISHTI_UPLOAD) ) endif() else() - set(DRISHTI_HUNTER_GATE_URL "https://github.com/ruslo/hunter/archive/v0.21.9.tar.gz") - set(DRISHTI_HUNTER_GATE_SHA1 "0056188988906abb63a06c6f1aaef01832c62b74") - + set(DRISHTI_HUNTER_GATE_URL "https://github.com/ruslo/hunter/archive/v0.21.15.tar.gz") + set(DRISHTI_HUNTER_GATE_SHA1 "f52db0eb7c1663d4cdedbda82b61b23d5d6a75d9") if(HUNTER_ENABLED AND NOT DRISHTI_IS_REPO_BUILD) # DEPENDENCY: if(HUNTER_ENABLE): we are being used as a dependency from # another project and we will use the config.cmake from the parent project. @@ -94,7 +93,7 @@ endif() ### Drishti project ### ####################### -project(drishtisdk VERSION 0.11.1) +project(drishtisdk VERSION 0.12.0) set(CMAKE_POLICY_DEFAULT_CMP0069 NEW) # for 3rd parties added by add_subdirectory diff --git a/cmake/Modules/drishti_set_rpath.cmake b/cmake/Modules/drishti_set_rpath.cmake index 6dc5de42..e9317fb5 100644 --- a/cmake/Modules/drishti_set_rpath.cmake +++ b/cmake/Modules/drishti_set_rpath.cmake @@ -1,9 +1,10 @@ #https://cmake.org/Wiki/CMake_RPATH_handling macro(drishti_set_rpath) - set(DRISHTI_ORIGIN "$ORIGIN") if (APPLE) set(DRISHTI_ORIGIN "@loader_path") + else() + set(DRISHTI_ORIGIN "$ORIGIN") endif() - set(CMAKE_INSTALL_RPATH "${DRISHTI_ORIGIN}/../lib:${DRISHTI_ORIGIN}/") + set(CMAKE_INSTALL_RPATH "${DRISHTI_ORIGIN}/../lib" "${DRISHTI_ORIGIN}") endmacro() diff --git a/src/app/CMakeLists.txt b/src/app/CMakeLists.txt index 3e7b1b82..82cf1019 100644 --- a/src/app/CMakeLists.txt +++ b/src/app/CMakeLists.txt @@ -54,5 +54,4 @@ endif() target_include_directories(drishti PUBLIC $) add_library(drishti::drishti ALIAS drishti) -set(DRISHTI_BUNDLE_SDK_SAMPLES ON) # indicate they will be bundled add_subdirectory(sdk) diff --git a/src/app/sdk/CMakeLists.txt b/src/app/sdk/CMakeLists.txt index 52ad85e7..137e5e7b 100644 --- a/src/app/sdk/CMakeLists.txt +++ b/src/app/sdk/CMakeLists.txt @@ -8,7 +8,7 @@ # etc). ################################################################################ -if(NOT DRISHTI_BUNDLE_SDK_SAMPLES) +if(NOT TARGET drishti::drishti) set(DRISHTI_ROOT_DIR "${CMAKE_CURRENT_LIST_DIR}/../../..") diff --git a/src/app/sdk/face/CMakeLists.txt b/src/app/sdk/face/CMakeLists.txt index 4cb9e177..e14fb8ff 100644 --- a/src/app/sdk/face/CMakeLists.txt +++ b/src/app/sdk/face/CMakeLists.txt @@ -57,4 +57,5 @@ endif() if(DRISHTI_HAVE_LOCALECONV) target_compile_definitions(drishti-face-test PUBLIC DRISHTI_HAVE_LOCALECONV=1) endif() + install(TARGETS drishti-face-test DESTINATION bin) diff --git a/src/app/sdk/face/config/orbbec_astra_pro.json b/src/app/sdk/face/config/orbbec_astra_pro.json index 24161e8e..98a2ac0a 100644 --- a/src/app/sdk/face/config/orbbec_astra_pro.json +++ b/src/app/sdk/face/config/orbbec_astra_pro.json @@ -1,17 +1,17 @@ { - "acfCalibration": 0.015, + "acfCalibration": 0.002, "doAnnotation": true, "doSimplePipeline": false, "faceFinderInterval": 0.0, - "videoWidth": 1920, - "videoHeight": 1080, + "videoWidth": 1280, + "videoHeight": 720, "focalLength": 1618.0, - "minDetectionDistance": 0.0, - "maxDetectionDistance": 3.0, + "minDetectionDistance": 0.1, + "maxDetectionDistance": 2.0, "maxTrackMisses": 2, "minFaceSeparation": 0.1, "minTrackHits": 3, - "multiFace": false, + "multiFace": true, "regressorCropScale": 1.1, "doCpuAcf": false } diff --git a/src/lib/drishti/CMakeLists.txt b/src/lib/drishti/CMakeLists.txt index 1cd15f62..9e2a942a 100644 --- a/src/lib/drishti/CMakeLists.txt +++ b/src/lib/drishti/CMakeLists.txt @@ -282,6 +282,9 @@ if((NOT DRISHTI_BUILD_SHARED_SDK) AND DRISHTI_BUILD_MERGED_SDK) list(APPEND drishti_interface_libs drishti) endif() +# ALIAS target allow us to have same interface while including project +add_library(drishti::drishti ALIAS drishti) + if(DRISHTI_BUILD_SHARED_SDK AND NOT (IOS AND DRISHTI_BUILD_MERGED_SDK)) # Error: ld: Assertion failed: (0 && "need to handle arm64 -r reloc") #drishti_strip(drishti) diff --git a/src/lib/drishti/drishti/Context.cpp b/src/lib/drishti/drishti/Context.cpp index 5307f721..295b01fb 100644 --- a/src/lib/drishti/drishti/Context.cpp +++ b/src/lib/drishti/drishti/Context.cpp @@ -21,19 +21,24 @@ Context::Impl::Impl(drishti::sdk::SensorModel& sensor) , logger(drishti::core::Logger::create(DRISHTI_LOGGER_NAME)) , threads(std::make_shared>()) // thread-pool { -#if defined(_WIN32) || defined(_WIN64) - // A windows DLL must call glewInit() from within the library (not the application layer) - CV_Assert(wglGetCurrentContext() != NULL && GLEW_OK == glewInit()); -#endif } Context::Context(drishti::sdk::SensorModel& sensor) { impl = drishti::core::make_unique(sensor); + updateGL(); } Context::~Context() = default; +void Context::updateGL() +{ +#if defined(_WIN32) || defined(_WIN64) + // A windows DLL must call glewInit() from within the library (not the application layer) + CV_Assert(wglGetCurrentContext() != NULL && GLEW_OK == glewInit()); +#endif +} + void Context::setDoSingleFace(bool flag) { impl->doSingleFace = flag; diff --git a/src/lib/drishti/drishti/Context.hpp b/src/lib/drishti/drishti/Context.hpp index 2c69bf7a..76d7ba8b 100644 --- a/src/lib/drishti/drishti/Context.hpp +++ b/src/lib/drishti/drishti/Context.hpp @@ -35,6 +35,8 @@ class DRISHTI_EXPORT Context Impl* get() { return impl.get(); } + void updateGL(); + void setDoSingleFace(bool flag); bool getDoSingleFace() const;