1
0
Fork 0
mirror of https://gitlab.alpinelinux.org/alpine/aports.git synced 2025-07-16 20:55:20 +03:00
aports/testing/tiledb/50-magic.patch
Holger Jaekel e7539b4287 testing/tiledb: new aport
https://tiledb.com/
Engine for storing and accessing dense and sparse multi-dimensional arrays
2023-03-03 23:13:11 +01:00

180 lines
5.8 KiB
Diff

From bc235a65a25757f93fc4da7fd0d82c70e47bff70 Mon Sep 17 00:00:00 2001
From: Seth Shelnutt <Shelnutt2@gmail.com>
Date: Sun, 12 Jun 2022 12:00:28 -0400
Subject: [PATCH] Improve FindMagic_EP to support system installs
This improves the support for detection of system installations with
libmagic. We remove checking for the find_package and default to always
looking for the library and header files for simplicity.
URL: https://github.com/TileDB-Inc/TileDB/pull/3270
---
--- a/cmake/Modules/FindMagic_EP.cmake
+++ b/cmake/Modules/FindMagic_EP.cmake
@@ -3,7 +3,7 @@
#
# The MIT License
#
-# Copyright (c) 2018-2021 TileDB, Inc.
+# Copyright (c) 2022 TileDB, Inc.
#
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal
@@ -34,47 +34,47 @@
# Include some common helper functions.
include(TileDBCommon)
-# Search the path set during the superbuild for the EP.
-set(LIBMAGIC_PATHS ${TILEDB_EP_INSTALL_PREFIX})
-
-if(TILEDB_LIBMAGIC_EP_BUILT)
- find_package(libmagic PATHS ${TILEDB_EP_INSTALL_PREFIX} ${TILEDB_DEPS_NO_DEFAULT_PATH})
-endif()
+# First check for a static version in the EP prefix.
+find_library(libmagic_LIBRARIES
+ NAMES
+ magic${CMAKE_STATIC_LIBRARY_SUFFIX}
+ libmagic${CMAKE_STATIC_LIBRARY_SUFFIX}
+ PATHS ${TILEDB_EP_INSTALL_PREFIX}
+ PATH_SUFFIXES lib
+ NO_DEFAULT_PATH
+)
-if (TILEDB_LIBMAGIC_EP_BUILT)
+if (libmagic_LIBRARIES)
+ set(libmagic_STATIC_EP_FOUND TRUE)
find_path(libmagic_INCLUDE_DIR
- NAMES magic.h
- PATHS ${LIBMAGIC_PATHS}
- PATH_SUFFIXES include
- ${NO_DEFAULT_PATH}
- )
-
- if (NOT libmagic_INCLUDE_DIR)
- find_path(libmagic_INCLUDE_DIR
- NAMES file/file.h
- PATHS ${LIBMAGIC_PATHS}
- PATH_SUFFIXES include
- ${NO_DEFAULT_PATH}
- )
- endif()
-
- # Link statically if installed with the EP.
+ NAMES magic.h
+ PATHS ${TILEDB_EP_INSTALL_PREFIX}
+ PATH_SUFFIXES include
+ NO_DEFAULT_PATH
+ )
+elseif(NOT TILEDB_FORCE_ALL_DEPS)
+ set(libmagic_STATIC_EP_FOUND FALSE)
+ # Static EP not found, search in system paths.
find_library(libmagic_LIBRARIES
- libmagic
- PATHS ${LIBMAGIC_PATHS}
- PATH_SUFFIXES lib a
- #${TILEDB_DEPS_NO_DEFAULT_PATH}
- ${NO_DEFAULT_PATH}
- )
-
- include(FindPackageHandleStandardArgs)
- FIND_PACKAGE_HANDLE_STANDARD_ARGS(libmagic
- REQUIRED_VARS libmagic_LIBRARIES libmagic_INCLUDE_DIR
- )
+ NAMES
+ magic libmagic
+ PATH_SUFFIXES lib bin
+ ${TILEDB_DEPS_NO_DEFAULT_PATH}
+ )
+ find_path(libmagic_INCLUDE_DIR
+ NAMES magic.h
+ PATH_SUFFIXES include
+ ${TILEDB_DEPS_NO_DEFAULT_PATH}
+ )
endif()
+include(FindPackageHandleStandardArgs)
+FIND_PACKAGE_HANDLE_STANDARD_ARGS(libmagic
+ REQUIRED_VARS libmagic_LIBRARIES libmagic_INCLUDE_DIR
+)
+
# if not yet built add it as an external project
-if(NOT TILEDB_LIBMAGIC_EP_BUILT)
+if(NOT libmagic_FOUND)
if (TILEDB_SUPERBUILD)
message(STATUS "Adding Magic as an external project")
@@ -115,11 +115,22 @@ if(NOT TILEDB_LIBMAGIC_EP_BUILT)
endif()
endif()
-find_file(libmagic_DICTIONARY magic.mgc
- PATHS ${LIBMAGIC_PATHS}
- PATH_SUFFIXES bin share
- ${NO_DEFAULT_PATH}
-)
+if(TILEDB_LIBMAGIC_EP_BUILT)
+ find_file(libmagic_DICTIONARY magic.mgc
+ PATHS ${LIBMAGIC_PATHS}
+ PATH_SUFFIXES bin share misc
+ ${TILEDB_DEPS_NO_DEFAULT_PATH}
+ )
+else()
+ find_file(libmagic_DICTIONARY magic.mgc
+ PATH_SUFFIXES bin share misc share/misc
+ ${TILEDB_DEPS_NO_DEFAULT_PATH}
+ )
+endif()
+
+if(NOT TILEDB_SUPERBUILD AND NOT libmagic_DICTIONARY)
+ message(FATAL_ERROR "Unable to find libmagic dictionary")
+endif()
if (libmagic_FOUND AND NOT TARGET libmagic)
message(STATUS "Found Magic, adding imported target: ${libmagic_LIBRARIES}")
--- a/tiledb/CMakeLists.txt
+++ b/tiledb/CMakeLists.txt
@@ -384,17 +384,22 @@
############################################################
# provide actions/target for preparation of magic.mgc data for embedding/build
-set(MGC_GZIPPED_BIN_OUTPUT_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/..")
+set(MGC_GZIPPED_BIN_OUTPUT_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/sm/misc")
set(MGC_GZIPPED_BIN_OUTPUT_FILE "${MGC_GZIPPED_BIN_OUTPUT_DIRECTORY}/magic_mgc_gzipped.bin")
set(MGC_GZIPPED_BIN_INPUT_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/sm/misc")
set(MGC_GZIPPED_BIN_INPUT_FILE "${MGC_GZIPPED_BIN_INPUT_DIRECTORY}/magic_mgc_gzipped.bin.tar.bz2")
+# Create the output directory if it does not exist
+add_custom_target(create_magic_bin_output_directory ALL
+ COMMAND ${CMAKE_COMMAND} -E make_directory ${MGC_GZIPPED_BIN_OUTPUT_DIRECTORY})
+
add_custom_command(
OUTPUT "${MGC_GZIPPED_BIN_OUTPUT_FILE}"
- DEPENDS "${MGC_GZIPPED_BIN_INPUT_FILE}"
+ DEPENDS "${MGC_GZIPPED_BIN_INPUT_FILE}" create_magic_bin_output_directory
COMMAND ${CMAKE_COMMAND} -E tar x "${MGC_GZIPPED_BIN_INPUT_FILE}"
WORKING_DIRECTORY "${MGC_GZIPPED_BIN_OUTPUT_DIRECTORY}"
)
+
add_custom_target(gen_mgc_unarch ALL
DEPENDS ${MGC_GZIPPED_BIN_OUTPUT_FILE}
)
@@ -407,7 +412,7 @@
WORKING_DIRECTORY "${MGC_GZIPPED_BIN_OUTPUT_DIRECTORY}"
COMMAND ${CMAKE_COMMAND} -E tar cvj "magic_mgc_gzipped.bin.tar.bz2" "magic_mgc_gzipped.bin"
COMMAND ${CMAKE_COMMAND} -E copy "magic_mgc_gzipped.bin.tar.bz2" "${MGC_GZIPPED_BIN_INPUT_FILE}"
- DEPENDS "${libmagic_DICTIONARY}"
+ DEPENDS "${libmagic_DICTIONARY}" create_magic_bin_output_directory
COMMENT "Re-generate ${MGC_GZIPPED_BIN_INPUT_FILE} for embedded magic.mgc support"
)
@@ -421,6 +426,8 @@
"${TILEDB_EXTERNALS_INCLUDE_DIRS}"
# to pickup <build_dir>/tiledb for capnp gen'd files
"${CMAKE_CURRENT_BINARY_DIR}/.."
+ # For libmagic binary data include
+ "${CMAKE_CURRENT_BINARY_DIR}/sm/misc"
)
# Build a separate copy of the object library for use with static TileDB