diff options
author | Stanislaw Halik <sthalik@misaki.pl> | 2018-07-10 06:42:15 +0200 |
---|---|---|
committer | Stanislaw Halik <sthalik@misaki.pl> | 2018-07-10 06:42:15 +0200 |
commit | e85d85265adb9f3d1eba93811440a83b6b74500d (patch) | |
tree | 651fa9c984d644ed168761fcbb980a4fac9d9bc9 /tracker-aruco | |
parent | 8c1dec7a5f16bd1eed656810a7009f4ce87adc80 (diff) |
tracker/aruco: simplify abi test
The issue was that with LTO enabled, the `try_compile'
call took way too long for a simple compile test.
Rather, add a #define to Aruco to avoid the slow link.
Bump aruco ABI version.
Please update your opentrack/aruco and/or
opentrack/opentrack-depends repos.
Diffstat (limited to 'tracker-aruco')
-rw-r--r-- | tracker-aruco/CMakeLists.txt | 18 | ||||
-rw-r--r-- | tracker-aruco/compile-test/abi.cpp | 14 |
2 files changed, 14 insertions, 18 deletions
diff --git a/tracker-aruco/CMakeLists.txt b/tracker-aruco/CMakeLists.txt index 9c228831..253cdd5f 100644 --- a/tracker-aruco/CMakeLists.txt +++ b/tracker-aruco/CMakeLists.txt @@ -17,14 +17,18 @@ if(OpenCV_FOUND) set(modules "${SDK_ARUCO_LIBPATH}" opencv_core opencv_calib3d opencv_imgproc opencv_videoio) + get_filename_component(dir "${SDK_ARUCO_LIBPATH}" DIRECTORY) + get_filename_component(dir "${dir}" ABSOLUTE) + set(dir "${dir}/include") + file(TIMESTAMP "${SDK_ARUCO_LIBPATH}" tm "%s" UTC) - set(cache-str "${tm}|${SDK_ARUCO_LIBPATH}") + set(cache-str "${tm}^|^${SDK_ARUCO_LIBPATH}") if(NOT aruco_has-working-abi STREQUAL "${cache-str}") try_compile(result "${CMAKE_CURRENT_BINARY_DIR}" SOURCES "${CMAKE_CURRENT_SOURCE_DIR}/compile-test/abi.cpp" - OUTPUT_VARIABLE krap - LINK_LIBRARIES ${modules}) + CMAKE_FLAGS "-DINCLUDE_DIRECTORIES=${dir}" + OUTPUT_VARIABLE krap) if(NOT result) message(FATAL_ERROR "${krap}\n" "Must use Aruco fork from <https://github.com/opentrack/aruco>") endif() @@ -34,11 +38,7 @@ if(OpenCV_FOUND) otr_module(tracker-aruco) - target_include_directories(opentrack-tracker-aruco SYSTEM PUBLIC ${OpenCV_INCLUDE_DIRS}) - target_link_libraries(opentrack-tracker-aruco opentrack-cv ${modules}) - - get_filename_component(dir "${SDK_ARUCO_LIBPATH}" DIRECTORY) - get_filename_component(dir "${dir}" ABSOLUTE) - include_directories(opentrack-tracker-aruco SYSTEM PUBLIC "${dir}/include") + target_include_directories(${self} SYSTEM PUBLIC ${OpenCV_INCLUDE_DIRS} "${dir}") + target_link_libraries(${self} opentrack-cv ${modules}) endif() endif() diff --git a/tracker-aruco/compile-test/abi.cpp b/tracker-aruco/compile-test/abi.cpp index 633188de..9c72fe2a 100644 --- a/tracker-aruco/compile-test/abi.cpp +++ b/tracker-aruco/compile-test/abi.cpp @@ -1,11 +1,7 @@ -#include "../../compat/linkage-macros.hpp" +#include <aruco/abi.h> -#define ARUCO_ABI aruco_opentrack_fork_abi_1 +#if ARUCO_OPENTRACK_FORK_ABI != 2 +# error "wrong ABI" +#endif -extern "C" void ARUCO_ABI(void); - -int main(void) -{ - ARUCO_ABI(); - return 0; -} +int main(void) { return 0; } |