From d0a24d43e90f099aca7347199c6354d13b1a069c Mon Sep 17 00:00:00 2001 From: Vlad Lazar Date: Mon, 15 Jan 2024 10:15:10 -0500 Subject: [PATCH] Build Blosc as a part of the regular build (#4) Signed-off-by: Vlad-Andrei Lazar --- cmake/LibraryDefine.cmake | 11 +++++ cmake/OpenEXRSetup.cmake | 88 ++++++++++++++++++++++++++++++++++ src/lib/OpenEXR/CMakeLists.txt | 5 +- 3 files changed, 100 insertions(+), 4 deletions(-) diff --git a/cmake/LibraryDefine.cmake b/cmake/LibraryDefine.cmake index a242ec8519..8df620ca30 100644 --- a/cmake/LibraryDefine.cmake +++ b/cmake/LibraryDefine.cmake @@ -30,6 +30,17 @@ function(OPENEXR_DEFINE_LIBRARY libname) # we are embedding libdeflate target_include_directories(${objlib} PRIVATE ${EXR_DEFLATE_INCLUDE_DIR}) + # we are statically linking blosc2 + if(${objlib} STREQUAL "OpenEXR") # OR ${objlib} STREQUAL "OpenEXRCore" + target_include_directories(${objlib} PRIVATE ${BLOSC2_INCLUDE_DIRS}) + target_link_directories(${objlib} PRIVATE ${BLOSC2_LIB_DIR}) + target_link_libraries(${objlib} PRIVATE "dl" ${BLOSC2_LIB_NAME}) + if(TARGET blosc2_static) + install(TARGETS blosc2_static EXPORT ${objlib}) + endif() + endif() + + if(OPENEXR_CURLIB_PRIV_EXPORT AND BUILD_SHARED_LIBS) target_compile_definitions(${objlib} PRIVATE ${OPENEXR_CURLIB_PRIV_EXPORT}) if(WIN32) diff --git a/cmake/OpenEXRSetup.cmake b/cmake/OpenEXRSetup.cmake index 7d01362c84..c0c15174b0 100644 --- a/cmake/OpenEXRSetup.cmake +++ b/cmake/OpenEXRSetup.cmake @@ -290,6 +290,94 @@ else() endif() endif() +####################################### +# Find or install Blosc2 +####################################### + +set(MINIMUM_BLOSC2_VERSION 2.11.0) +option(OPENEXR_FORCE_INTERNAL_BLOSC2 [=[Force using installed Blosc2.]=] OFF) + +set(BLOSC2_REPO "https://github.com/Blosc/c-blosc2.git" CACHE STRING "Repo path for blosc2 source") +set(BLOSC2_TAG "v${MINIMUM_BLOSC2_VERSION}" CACHE STRING "Tag to use for blosc2 source repo") + +if(NOT OPENEXR_FORCE_INTERNAL_BLOSC2) + #TODO: ^^ Release should not clone from main, this is a place holder + set(CMAKE_IGNORE_PATH "${CMAKE_CURRENT_BINARY_DIR}/_deps/blosc2-src/config;${CMAKE_CURRENT_BINARY_DIR}/_deps/blosc2-build/config") + find_package(Blosc2 ${MINIMUM_BLOSC2_VERSION}) + set(CMAKE_IGNORE_PATH) +endif() + +if(NOT TARGET Blosc2::blosc2_static AND NOT Blosc2_FOUND) + if(OPENEXR_FORCE_INTERNAL_BLOSC2) + message(STATUS "Blosc2 forced internal, installing from ${BLOSC2_REPO} (${BLOSC2_TAG})") + else() + message(STATUS "Blosc2 was not found, installing from ${BLOSC2_REPO} (${BLOSC2_TAG})") + endif() + + # configure the blosc2 build + set(BUILD_BENCHMARKS OFF CACHE INTERNAL "no benchmarks") + set(BUILD_EXAMPLES OFF CACHE INTERNAL "no examples") + set(BUILD_FUZZERS OFF CACHE INTERNAL "no fuzzer") + set(BUILD_SHARED OFF CACHE INTERNAL "no shared library") + set(BUILD_TESTS OFF CACHE INTERNAL "no tests") + + include(FetchContent) + FetchContent_Declare(Blosc2 + GIT_REPOSITORY "${BLOSC2_REPO}" + GIT_TAG "${BLOSC2_TAG}" + GIT_SHALLOW ON + GIT_PROGRESS ON) + + FetchContent_GetProperties(Blosc2) + if(NOT Blosc2_POPULATED) + FetchContent_Populate(Blosc2) + # Propagate OpenEXR's setting for pkg-config generation to Blosc2: + # If OpenEXR is generating it, the internal Blosc2 should, too. + # TODO: Do we really need that here ? + # set(BLOSC2_INSTALL_PKG_CONFIG ${OPENEXR_INSTALL_PKG_CONFIG}) + add_subdirectory(${blosc2_SOURCE_DIR} ${blosc2_BINARY_DIR}) + endif() + # the install creates this but if we're using the library locally we + # haven't installed the header files yet, so need to extract those + # and make a variable for header only usage + if(NOT TARGET Blosc2::Blosc2Config) + # TODO: Do we really need that here ? + # get_target_property(blosc2inc blosc2_static INTERFACE_INCLUDE_DIRECTORIES) + # get_target_property(blosc2confinc blosc2_shared INTERFACE_INCLUDE_DIRECTORIES) + # list(APPEND blosc2inc ${blosc2confinc}) + # set(BLOSC2_HEADER_ONLY_INCLUDE_DIRS ${blosc2inc}) + # message(STATUS "Blosc2 interface dirs ${BLOSC2_HEADER_ONLY_INCLUDE_DIRS}") + + get_target_property(blosc2inc Blosc2::blosc2_static INCLUDE_DIRECTORIES) + set(BLOSC2_INCLUDE_DIRS ${blosc2inc}) + + get_target_property(blosc2libdir Blosc2::blosc2_static BINARY_DIR) + set(BLOSC2_LIB_DIR ${blosc2libdir}) + + get_target_property(blosc2libname Blosc2::blosc2_static OUTPUT_NAME) + set(BLOSC2_LIB_NAME ${blosc2libname}) + endif() +else() + message(STATUS "Using Blosc2 ${Blosc2_VERSION} from ${Blosc2_DIR}") + # local build + if(NOT TARGET Blosc2::Blosc2Config AND TARGET Blosc2 AND TARGET Blosc2Config) + get_target_property(blosc2inc blosc2_static INTERFACE_INCLUDE_DIRECTORIES) + get_target_property(blosc2confinc blosc2_shared INTERFACE_INCLUDE_DIRECTORIES) + list(APPEND blosc2inc ${blosc2confinc}) + set(BLOSC2_HEADER_ONLY_INCLUDE_DIRS ${blosc2inc}) + message(STATUS "Blosc2 internal interface dirs: ${BLOSC2_HEADER_ONLY_INCLUDE_DIRS}") + + get_target_property(blosc2inc Blosc2::blosc2_static INCLUDE_DIRECTORIES) + set(BLOSC2_INCLUDE_DIRS ${blosc2inc}) + + get_target_property(blosc2libdir Blosc2::blosc2_static BINARY_DIR) + set(BLOSC2_LIB_DIR ${blosc2libdir}) + + get_target_property(blosc2libname Blosc2::blosc2_static OUTPUT_NAME) + set(BLOSC2_LIB_NAME ${blosc2libname}) + endif() +endif() + ########################################### # Check if we need to emulate vld1q_f32_x2 ########################################### diff --git a/src/lib/OpenEXR/CMakeLists.txt b/src/lib/OpenEXR/CMakeLists.txt index 45a809f386..1cccbdd8be 100644 --- a/src/lib/OpenEXR/CMakeLists.txt +++ b/src/lib/OpenEXR/CMakeLists.txt @@ -217,12 +217,9 @@ openexr_define_library(OpenEXR ImfXdr.h DEPENDENCIES Imath::Imath + Blosc2::blosc2_static OpenEXR::Config OpenEXR::Iex OpenEXR::IlmThread OpenEXR::OpenEXRCore ) - -target_include_directories(OpenEXR PUBLIC "/home/vladal/bin/include/") -target_link_directories(OpenEXR PUBLIC "/home/vladal/bin/lib") -target_link_libraries(OpenEXR PUBLIC "dl" "blosc2") \ No newline at end of file