blob: da65912a38d91a5593b2618a1fc1de1096e5f3eb [file] [log] [blame]
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
# - Find GANDIVA (gandiva/client.h, libgandiva.a, libgandiva.so)
# This module defines
# GANDIVA_INCLUDE_DIR, directory containing headers
# GANDIVA_LIBS, directory containing gandiva libraries
# GANDIVA_STATIC_LIB, path to libgandiva.a
# GANDIVA_SHARED_LIB, path to libgandiva's shared library
# GANDIVA_SHARED_IMP_LIB, path to libgandiva's import library (MSVC only)
# GANDIVA_FOUND, whether gandiva has been found
include(FindPkgConfig)
if("$ENV{ARROW_HOME}" STREQUAL "")
pkg_check_modules(GANDIVA gandiva)
if(GANDIVA_FOUND)
pkg_get_variable(GANDIVA_SO_VERSION gandiva so_version)
set(GANDIVA_ABI_VERSION ${GANDIVA_SO_VERSION})
message(STATUS "Gandiva SO and ABI version: ${GANDIVA_SO_VERSION}")
pkg_get_variable(GANDIVA_FULL_SO_VERSION gandiva full_so_version)
message(STATUS "Gandiva full SO version: ${GANDIVA_FULL_SO_VERSION}")
set(GANDIVA_INCLUDE_DIR ${GANDIVA_INCLUDE_DIRS})
set(GANDIVA_LIBS ${GANDIVA_LIBRARY_DIRS})
# TODO: ARROW-5021
set(GANDIVA_SEARCH_LIB_PATH ${GANDIVA_LIBRARY_DIRS})
# TODO: ARROW-5025
set(GANDIVA_SEARCH_SHARED_LIB_PATH ${GANDIVA_LIBRARY_DIRS})
endif()
else()
set(GANDIVA_HOME "$ENV{ARROW_HOME}")
set(GANDIVA_SEARCH_HEADER_PATHS ${GANDIVA_HOME}/include)
# TODO: ARROW-5021
set(GANDIVA_SEARCH_LIB_PATH "${GANDIVA_HOME}/lib")
if(WIN32)
# TODO: ARROW-5025
set(GANDIVA_SEARCH_SHARED_LIB_PATH "${GANDIVA_HOME}/bin")
else()
# TODO: ARROW-5026
set(GANDIVA_SEARCH_SHARED_LIB_PATH "${GANDIVA_HOME}/lib")
endif()
find_path(GANDIVA_INCLUDE_DIR gandiva/expression_registry.h
PATHS ${GANDIVA_SEARCH_HEADER_PATHS}
# make sure we don't accidentally pick up a different version
NO_DEFAULT_PATH)
endif()
find_library(GANDIVA_LIB_PATH
NAMES gandiva
PATHS ${GANDIVA_SEARCH_LIB_PATH}
NO_DEFAULT_PATH)
get_filename_component(GANDIVA_LIBS ${GANDIVA_LIB_PATH} DIRECTORY)
find_library(GANDIVA_SHARED_LIB_PATH
NAMES gandiva
PATHS ${GANDIVA_SEARCH_SHARED_LIB_PATH}
NO_DEFAULT_PATH)
get_filename_component(GANDIVA_SHARED_LIBS ${GANDIVA_SHARED_LIB_PATH} PATH)
if(GANDIVA_INCLUDE_DIR AND GANDIVA_LIBS AND GANDIVA_SHARED_LIBS)
set(GANDIVA_FOUND TRUE)
set(GANDIVA_LIB_NAME gandiva)
if(MSVC)
set(
GANDIVA_STATIC_LIB
"${GANDIVA_LIBS}/${GANDIVA_LIB_NAME}${GANDIVA_MSVC_STATIC_LIB_SUFFIX}${CMAKE_STATIC_LIBRARY_SUFFIX}"
)
set(GANDIVA_SHARED_LIB
"${GANDIVA_SHARED_LIBS}/${GANDIVA_LIB_NAME}${CMAKE_SHARED_LIBRARY_SUFFIX}")
set(GANDIVA_SHARED_IMP_LIB "${GANDIVA_LIBS}/${GANDIVA_LIB_NAME}.lib")
else()
set(
GANDIVA_STATIC_LIB
${GANDIVA_LIBS}/${CMAKE_STATIC_LIBRARY_PREFIX}${GANDIVA_LIB_NAME}${CMAKE_STATIC_LIBRARY_SUFFIX}
)
set(
GANDIVA_SHARED_LIB
${GANDIVA_SHARED_LIBS}/${CMAKE_SHARED_LIBRARY_PREFIX}${GANDIVA_LIB_NAME}${CMAKE_SHARED_LIBRARY_SUFFIX}
)
endif()
endif()
if(GANDIVA_FOUND)
if(NOT Gandiva_FIND_QUIETLY)
message(STATUS "Found the Gandiva core library: ${GANDIVA_LIB_PATH}")
endif()
else()
if(NOT Gandiva_FIND_QUIETLY)
set(GANDIVA_ERR_MSG "Could not find the Gandiva library. Looked for headers")
set(GANDIVA_ERR_MSG
"${GANDIVA_ERR_MSG} in ${GANDIVA_SEARCH_HEADER_PATHS}, and for libs")
set(GANDIVA_ERR_MSG "${GANDIVA_ERR_MSG} in ${GANDIVA_SEARCH_LIB_PATH}")
if(Gandiva_FIND_REQUIRED)
message(FATAL_ERROR "${GANDIVA_ERR_MSG}")
else(Gandiva_FIND_REQUIRED)
message(STATUS "${GANDIVA_ERR_MSG}")
endif(Gandiva_FIND_REQUIRED)
endif()
set(GANDIVA_FOUND FALSE)
endif()
mark_as_advanced(GANDIVA_INCLUDE_DIR GANDIVA_STATIC_LIB GANDIVA_SHARED_LIB)