From 8fe0b39f18a5d5865d231bc342504d213a1f5625 Mon Sep 17 00:00:00 2001
From: Raphael Boucherie <raphael.boucherie@inria.fr>
Date: Mon, 12 Jun 2017 11:32:02 +0200
Subject: [PATCH] Rename FindHQR and update to match GTG

---
 modules/find/FindHQR.cmake    | 316 ++++++++++++++++++++++++++++++----
 modules/find/FindLIBHQR.cmake |  67 -------
 2 files changed, 278 insertions(+), 105 deletions(-)
 delete mode 100644 modules/find/FindLIBHQR.cmake

diff --git a/modules/find/FindHQR.cmake b/modules/find/FindHQR.cmake
index fff8fba..14863c2 100644
--- a/modules/find/FindHQR.cmake
+++ b/modules/find/FindHQR.cmake
@@ -3,65 +3,305 @@
 # @copyright (c) 2009-2014 The University of Tennessee and The University
 #                          of Tennessee Research Foundation.
 #                          All rights reserved.
-# @copyright (c) 2012-2016 Inria. All rights reserved.
+# @copyright (c) 2012-2017 Inria. All rights reserved.
 # @copyright (c) 2012-2014 Bordeaux INP, CNRS (LaBRI UMR 5800), Inria, Univ. Bordeaux. All rights reserved.
 #
 ###
 #
-# - Try to find LibHQR
-# Once done this will define
-#  LIBHQR_FOUND - System has LibHQR
-#  LIBHQR_INCLUDE_DIRS - The LibHQR include directories
-#  LIBHQR_LIBRARIES - The libraries needed to use LibHQR
-#  LIBHQR_DEFINITIONS - Compiler switches required for using LIBHQR
+# - Find HQR include dirs and libraries
+# Use this module by invoking find_package with the form:
+#  find_package(HQR
+#               [REQUIRED]) # Fail with error if hqr is not found
+#
+# This module finds headers and hqr library.
+# Results are reported in variables:
+#  HQR_FOUND           - True if headers and requested libraries were found
+#  HQR_INCLUDE_DIRS    - hqr include directories
+#  HQR_LIBRARY_DIRS    - Link directories for hqr libraries
+#  HQR_LIBRARIES       - hqr component libraries to be linked
+#
+# The user can give specific paths where to find the libraries adding cmake
+# options at configure (ex: cmake path/to/project -DHQR_DIR=path/to/hqr):
+#  HQR_DIR             - Where to find the base directory of hqr
+#  HQR_INCDIR          - Where to find the header files
+#  HQR_LIBDIR          - Where to find the library files
+# The module can also look for the following environment variables if paths
+# are not given as cmake variable: HQR_DIR, HQR_INCDIR, HQR_LIBDIR
 
 #=============================================================================
-# Copyright 2012-2017 Inria.
-# Copyright 2017      Raphael Boucherie.
-# Copyright 2012-2017 Mathieu Faverge.
+# Copyright 2012-2017 Inria
+# Copyright 2012-2013 Emmanuel Agullo
+# Copyright 2012-2013 Mathieu Faverge
+# Copyright 2012      Cedric Castagnede
+# Copyright 2013-2017 Florent Pruvost
 #
 # Distributed under the OSI-approved BSD License (the "License");
-# see accompanying file Copyright.txt for details.
+# see accompanying file MORSE-Copyright.txt for details.
 #
 # This software is distributed WITHOUT ANY WARRANTY; without even the
 # implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 # See the License for more information.
 #=============================================================================
-# (To distribute this file outside of CMake, substitute the full
+# (To distribute this file outside of Morse, substitute the full
 #  License text for the above reference.)
 
-find_package(PkgConfig)
-if(PKG_CONFIG_FOUND)
-  pkg_check_modules(PC_LIBHQR QUIET libhqr)
+if (NOT HQR_FOUND)
+  set(HQR_DIR "" CACHE PATH "Installation directory of HQR library")
+  if (NOT HQR_FIND_QUIETLY)
+    message(STATUS "A cache variable, namely HQR_DIR, has been set to specify the install directory of HQR")
+  endif()
 endif()
 
-set(LIBHQR_LIBRARIES ${LIBHQR_LIBRARY} )
-set(LIBHQR_INCLUDE_DIRS ${LIBHQR_INCLUDE_DIR} )
-set(LIBHQR_DEFINITIONS ${PC_LIBHQR_CFLAGS_OTHER} )
+set(ENV_HQR_DIR "$ENV{HQR_DIR}")
+set(ENV_HQR_INCDIR "$ENV{HQR_INCDIR}")
+set(ENV_HQR_LIBDIR "$ENV{HQR_LIBDIR}")
+set(HQR_GIVEN_BY_USER "FALSE")
+if ( HQR_DIR OR ( HQR_INCDIR AND HQR_LIBDIR) OR ENV_HQR_DIR OR (ENV_HQR_INCDIR AND ENV_HQR_LIBDIR) )
+  set(HQR_GIVEN_BY_USER "TRUE")
+endif()
 
-find_path(
-  LIBHQR_INCLUDE_DIR
-  libhqr.h
-  HINTS  ${LIBHQR_DIR} ${PC_LIBHQR_INCLUDEDIR} ${PC_LIBHQR_INCLUDE_DIRS}
-  PATH_SUFFIXES include include/libhqr
-  )
+# Optionally use pkg-config to detect include/library dirs (if pkg-config is available)
+# -------------------------------------------------------------------------------------
+include(FindPkgConfig)
+find_package(PkgConfig QUIET)
+if(PKG_CONFIG_EXECUTABLE AND NOT HQR_GIVEN_BY_USER)
 
-find_library(
-  LIBHQR_LIBRARY
-  NAMES hqr
-  HINTS ${LIBHQR_DIR} ${PC_LIBHQR_LIBDIR} ${PC_LIBHQR_LIBRARY_DIRS}
-  PATH_SUFFIXES lib lib32 lib64 lib/libhqr lib32/libhqr lib64/libhqr
-  )
+  pkg_search_module(HQR hqr)
+  if (NOT HQR_FIND_QUIETLY)
+    if (HQR_FOUND AND HQR_LIBRARIES)
+      message(STATUS "Looking for HQR - found using PkgConfig")
+      #if(NOT HQR_INCLUDE_DIRS)
+      #    message("${Magenta}HQR_INCLUDE_DIRS is empty using PkgConfig."
+      #        "Perhaps the path to hqr headers is already present in your"
+      #        "C(PLUS)_INCLUDE_PATH environment variable.${ColourReset}")
+      #endif()
+    else()
+      message(STATUS "${Magenta}Looking for HQR - not found using PkgConfig."
+	"\n   Perhaps you should add the directory containing hqr.pc to the"
+	"\n   PKG_CONFIG_PATH environment variable.${ColourReset}")
+    endif()
+  endif()
 
-set(LIBHQR_DIR "" CACHE PATH "Path where LIBHQR was installed")
+endif(PKG_CONFIG_EXECUTABLE AND NOT HQR_GIVEN_BY_USER)
 
+if( (NOT PKG_CONFIG_EXECUTABLE) OR (PKG_CONFIG_EXECUTABLE AND NOT HQR_FOUND) OR (HQR_GIVEN_BY_USER) )
 
-include(FindPackageHandleStandardArgs)
-# handle the QUIETLY and REQUIRED arguments
-# and set LIBHQR_FOUND to TRUE
-# if all listed variables are TRUE
-find_package_handle_standard_args(
-  LIBHQR DEFAULT_MSG LIBHQR_LIBRARY LIBHQR_INCLUDE_DIR)
+  if (NOT HQR_FIND_QUIETLY)
+    message(STATUS "Looking for HQR - PkgConfig not used")
+  endif()
+
+  # Looking for include
+  # -------------------
+
+  # Add system include paths to search include
+  # ------------------------------------------
+  unset(_inc_env)
+  set(ENV_HQR_DIR "$ENV{HQR_DIR}")
+  set(ENV_HQR_INCDIR "$ENV{HQR_INCDIR}")
+  if(ENV_HQR_INCDIR)
+    list(APPEND _inc_env "${ENV_HQR_INCDIR}")
+  elseif(ENV_HQR_DIR)
+    list(APPEND _inc_env "${ENV_HQR_DIR}")
+    list(APPEND _inc_env "${ENV_HQR_DIR}/include")
+  else()
+    if(WIN32)
+      string(REPLACE ":" ";" _inc_env "$ENV{INCLUDE}")
+    else()
+      string(REPLACE ":" ";" _path_env "$ENV{INCLUDE}")
+      list(APPEND _inc_env "${_path_env}")
+      string(REPLACE ":" ";" _path_env "$ENV{C_INCLUDE_PATH}")
+      list(APPEND _inc_env "${_path_env}")
+      string(REPLACE ":" ";" _path_env "$ENV{CPATH}")
+      list(APPEND _inc_env "${_path_env}")
+      string(REPLACE ":" ";" _path_env "$ENV{INCLUDE_PATH}")
+      list(APPEND _inc_env "${_path_env}")
+    endif()
+  endif()
+  list(APPEND _inc_env "${CMAKE_PLATFORM_IMPLICIT_INCLUDE_DIRECTORIES}")
+  list(APPEND _inc_env "${CMAKE_C_IMPLICIT_INCLUDE_DIRECTORIES}")
+  list(REMOVE_DUPLICATES _inc_env)
+
+  # Try to find the hqr header in the given paths
+  # -------------------------------------------------
+  # call cmake macro to find the header path
+  if(HQR_INCDIR)
+    set(HQR_HQR.h_DIRS "HQR_libhqr.h_DIRS-NOTFOUND")
+    find_path(HQR_libhqr.h_DIRS
+      NAMES libhqr.h
+      HINTS ${HQR_INCDIR})
+  else()
+    if(HQR_DIR)
+      set(HQR_libhqr.h_DIRS "HQR_libhqr.h_DIRS-NOTFOUND")
+      find_path(HQR_libhqr.h_DIRS
+	NAMES libhqr.h
+	HINTS ${HQR_DIR}
+    else()
+      set(HQR_libhqr.h_DIRS "HQR_libhqr.h_DIRS-NOTFOUND")
+      find_path(HQR_libhqr.h_DIRS
+	NAMES libhqr.h
+	HINTS ${_inc_env}
+	PATH_SUFFIXES "hqr")
+    endif()
+  endif()
+  mark_as_advanced(HQR_libhqr.h_DIRS)
+
+  # Add path to cmake variable
+  # ------------------------------------
+  if (HQR_libhqr.h_DIRS)
+    set(HQR_INCLUDE_DIRS "${HQR_libhqr.h_DIRS}")
+  else ()
+    set(HQR_INCLUDE_DIRS "HQR_INCLUDE_DIRS-NOTFOUND")
+    if(NOT HQR_FIND_QUIETLY)
+      message(STATUS "Looking for hqr -- libhqr.h not found")
+    endif()
+  endif ()
+
+  if (HQR_INCLUDE_DIRS)
+    list(REMOVE_DUPLICATES HQR_INCLUDE_DIRS)
+  endif ()
+
+  # Looking for lib
+  # ---------------
+
+  # Add system library paths to search lib
+  # --------------------------------------
+  unset(_lib_env)
+  set(ENV_HQR_LIBDIR "$ENV{HQR_LIBDIR}")
+  if(ENV_HQR_LIBDIR)
+    list(APPEND _lib_env "${ENV_HQR_LIBDIR}")
+  elseif(ENV_HQR_DIR)
+    list(APPEND _lib_env "${ENV_HQR_DIR}")
+    list(APPEND _lib_env "${ENV_HQR_DIR}/lib")
+  else()
+    if(WIN32)
+      string(REPLACE ":" ";" _lib_env "$ENV{LIB}")
+    else()
+      if(APPLE)
+	string(REPLACE ":" ";" _lib_env "$ENV{DYLD_LIBRARY_PATH}")
+      else()
+	string(REPLACE ":" ";" _lib_env "$ENV{LD_LIBRARY_PATH}")
+      endif()
+      list(APPEND _lib_env "${CMAKE_PLATFORM_IMPLICIT_LINK_DIRECTORIES}")
+      list(APPEND _lib_env "${CMAKE_C_IMPLICIT_LINK_DIRECTORIES}")
+    endif()
+  endif()
+  list(REMOVE_DUPLICATES _lib_env)
+
+  # Try to find the hqr lib in the given paths
+  # ----------------------------------------------
+
+  # call cmake macro to find the lib path
+  if(HQR_LIBDIR)
+    set(HQR_hqr_LIBRARY "HQR_hqr_LIBRARY-NOTFOUND")
+    find_library(HQR_hqr_LIBRARY
+      NAMES hqr
+      HINTS ${HQR_LIBDIR})
+  else()
+    if(HQR_DIR)
+      set(HQR_hqr_LIBRARY "HQR_hqr_LIBRARY-NOTFOUND")
+      find_library(HQR_hqr_LIBRARY
+	NAMES hqr
+	HINTS ${HQR_DIR}
+	PATH_SUFFIXES lib lib32 lib64)
+    else()
+      set(HQR_hqr_LIBRARY "HQR_hqr_LIBRARY-NOTFOUND")
+      find_library(HQR_hqr_LIBRARY
+	NAMES hqr
+	HINTS ${_lib_env})
+    endif()
+  endif()
+  mark_as_advanced(HQR_hqr_LIBRARY)
 
-mark_as_advanced(LIBHQR_INCLUDE_DIR LIBHQR_LIBRARY )
+  # If found, add path to cmake variable
+  # ------------------------------------
+  if (HQR_hqr_LIBRARY)
+    get_filename_component(hqr_lib_path ${HQR_hqr_LIBRARY} PATH)
+    # set cmake variables (respects naming convention)
+    set(HQR_LIBRARIES    "${HQR_hqr_LIBRARY}")
+    set(HQR_LIBRARY_DIRS "${hqr_lib_path}")
+  else ()
+    set(HQR_LIBRARIES    "HQR_LIBRARIES-NOTFOUND")
+    set(HQR_LIBRARY_DIRS "HQR_LIBRARY_DIRS-NOTFOUND")
+    if(NOT HQR_FIND_QUIETLY)
+      message(STATUS "Looking for hqr -- lib hqr not found")
+    endif()
+  endif ()
 
+  if (HQR_LIBRARY_DIRS)
+    list(REMOVE_DUPLICATES HQR_LIBRARY_DIRS)
+  endif ()
+
+  # check a function to validate the find
+  if(HQR_LIBRARIES)
+
+    set(REQUIRED_INCDIRS)
+    set(REQUIRED_LIBDIRS)
+    set(REQUIRED_LIBS)
+
+    # HQR
+    if (HQR_INCLUDE_DIRS)
+      set(REQUIRED_INCDIRS "${HQR_INCLUDE_DIRS}")
+    endif()
+    if (HQR_LIBRARY_DIRS)
+      set(REQUIRED_LIBDIRS "${HQR_LIBRARY_DIRS}")
+    endif()
+    set(REQUIRED_LIBS "${HQR_LIBRARIES}")
+
+    # set required libraries for link
+    set(CMAKE_REQUIRED_INCLUDES "${REQUIRED_INCDIRS}")
+    set(CMAKE_REQUIRED_LIBRARIES)
+    foreach(lib_dir ${REQUIRED_LIBDIRS})
+      list(APPEND CMAKE_REQUIRED_LIBRARIES "-L${lib_dir}")
+    endforeach()
+    list(APPEND CMAKE_REQUIRED_LIBRARIES "${REQUIRED_LIBS}")
+    string(REGEX REPLACE "^ -" "-" CMAKE_REQUIRED_LIBRARIES "${CMAKE_REQUIRED_LIBRARIES}")
+
+    # test link
+    unset(HQR_WORKS CACHE)
+    include(CheckFunctionExists)
+    check_function_exists(libhqr_hqr_init HQR_WORKS)
+    mark_as_advanced(HQR_WORKS)
+
+    if(NOT HQR_WORKS)
+      if(NOT HQR_FIND_QUIETLY)
+	message(STATUS "Looking for hqr : test of libhqr_hqr_init with hqr library fails")
+	message(STATUS "CMAKE_REQUIRED_LIBRARIES: ${CMAKE_REQUIRED_LIBRARIES}")
+	message(STATUS "CMAKE_REQUIRED_INCLUDES: ${CMAKE_REQUIRED_INCLUDES}")
+	message(STATUS "Check in CMakeFiles/CMakeError.log to figure out why it fails")
+      endif()
+    endif()
+    set(CMAKE_REQUIRED_INCLUDES)
+    set(CMAKE_REQUIRED_FLAGS)
+    set(CMAKE_REQUIRED_LIBRARIES)
+  endif(HQR_LIBRARIES)
+
+endif( (NOT PKG_CONFIG_EXECUTABLE) OR (PKG_CONFIG_EXECUTABLE AND NOT HQR_FOUND) OR (HQR_GIVEN_BY_USER) )
+
+if (HQR_LIBRARIES)
+  if (HQR_LIBRARY_DIRS)
+    list(GET HQR_LIBRARY_DIRS 0 first_lib_path)
+  else()
+    list(GET HQR_LIBRARIES 0 first_lib)
+    get_filename_component(first_lib_path "${first_lib}" PATH)
+  endif()
+  if (${first_lib_path} MATCHES "/lib(32|64)?$")
+    string(REGEX REPLACE "/lib(32|64)?$" "" not_cached_dir "${first_lib_path}")
+    set(HQR_DIR_FOUND "${not_cached_dir}" CACHE PATH "Installation directory of HQR library" FORCE)
+  else()
+    set(HQR_DIR_FOUND "${first_lib_path}" CACHE PATH "Installation directory of HQR library" FORCE)
+  endif()
+endif()
+mark_as_advanced(HQR_DIR)
+mark_as_advanced(HQR_DIR_FOUND)
+
+# check that HQR has been found
+# -------------------------------
+include(FindPackageHandleStandardArgs)
+if (PKG_CONFIG_EXECUTABLE AND HQR_FOUND)
+  find_package_handle_standard_args(HQR DEFAULT_MSG
+    HQR_LIBRARIES)
+else()
+  find_package_handle_standard_args(HQR DEFAULT_MSG
+    HQR_LIBRARIES
+    HQR_WORKS)
+endif()
diff --git a/modules/find/FindLIBHQR.cmake b/modules/find/FindLIBHQR.cmake
deleted file mode 100644
index fff8fba..0000000
--- a/modules/find/FindLIBHQR.cmake
+++ /dev/null
@@ -1,67 +0,0 @@
-###
-#
-# @copyright (c) 2009-2014 The University of Tennessee and The University
-#                          of Tennessee Research Foundation.
-#                          All rights reserved.
-# @copyright (c) 2012-2016 Inria. All rights reserved.
-# @copyright (c) 2012-2014 Bordeaux INP, CNRS (LaBRI UMR 5800), Inria, Univ. Bordeaux. All rights reserved.
-#
-###
-#
-# - Try to find LibHQR
-# Once done this will define
-#  LIBHQR_FOUND - System has LibHQR
-#  LIBHQR_INCLUDE_DIRS - The LibHQR include directories
-#  LIBHQR_LIBRARIES - The libraries needed to use LibHQR
-#  LIBHQR_DEFINITIONS - Compiler switches required for using LIBHQR
-
-#=============================================================================
-# Copyright 2012-2017 Inria.
-# Copyright 2017      Raphael Boucherie.
-# Copyright 2012-2017 Mathieu Faverge.
-#
-# Distributed under the OSI-approved BSD License (the "License");
-# see accompanying file Copyright.txt for details.
-#
-# This software is distributed WITHOUT ANY WARRANTY; without even the
-# implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
-# See the License for more information.
-#=============================================================================
-# (To distribute this file outside of CMake, substitute the full
-#  License text for the above reference.)
-
-find_package(PkgConfig)
-if(PKG_CONFIG_FOUND)
-  pkg_check_modules(PC_LIBHQR QUIET libhqr)
-endif()
-
-set(LIBHQR_LIBRARIES ${LIBHQR_LIBRARY} )
-set(LIBHQR_INCLUDE_DIRS ${LIBHQR_INCLUDE_DIR} )
-set(LIBHQR_DEFINITIONS ${PC_LIBHQR_CFLAGS_OTHER} )
-
-find_path(
-  LIBHQR_INCLUDE_DIR
-  libhqr.h
-  HINTS  ${LIBHQR_DIR} ${PC_LIBHQR_INCLUDEDIR} ${PC_LIBHQR_INCLUDE_DIRS}
-  PATH_SUFFIXES include include/libhqr
-  )
-
-find_library(
-  LIBHQR_LIBRARY
-  NAMES hqr
-  HINTS ${LIBHQR_DIR} ${PC_LIBHQR_LIBDIR} ${PC_LIBHQR_LIBRARY_DIRS}
-  PATH_SUFFIXES lib lib32 lib64 lib/libhqr lib32/libhqr lib64/libhqr
-  )
-
-set(LIBHQR_DIR "" CACHE PATH "Path where LIBHQR was installed")
-
-
-include(FindPackageHandleStandardArgs)
-# handle the QUIETLY and REQUIRED arguments
-# and set LIBHQR_FOUND to TRUE
-# if all listed variables are TRUE
-find_package_handle_standard_args(
-  LIBHQR DEFAULT_MSG LIBHQR_LIBRARY LIBHQR_INCLUDE_DIR)
-
-mark_as_advanced(LIBHQR_INCLUDE_DIR LIBHQR_LIBRARY )
-
-- 
GitLab