xzyang / rpms / cmake

Forked from rpms/cmake 3 years ago
Clone
f9cb51
commit a22eeca3fd7fe022e06001428d5e903913467fa0
f9cb51
Author: Brad King <brad.king@kitware.com>
f9cb51
Date:   Fri Feb 7 16:45:10 2014 -0500
f9cb51
f9cb51
    FindBoost: Search next to MPI libraries for boost_mpi (#14739)
f9cb51
    
f9cb51
    Some distributions place boost_mpi next to the MPI libraries against
f9cb51
    which it was built instead of next to the other Boost libraries.  If
f9cb51
    find_package(MPI) has already been run prior to find_package(Boost) then
f9cb51
    MPI_CXX_LIBRARIES or MPI_C_LIBRARIES may be set to the location of the
f9cb51
    MPI libraries.  Teach FindBoost.cmake to look there for boost_mpi and
f9cb51
    boost_mpi_python after looking next to the other Boost libraries but
f9cb51
    not consider the location to be Boost_LIBRARY_DIR.
f9cb51
f9cb51
diff -Nrup a/Modules/FindBoost.cmake b/Modules/FindBoost.cmake
f9cb51
--- a/Modules/FindBoost.cmake	2014-01-16 12:15:08.000000000 -0500
f9cb51
+++ b/Modules/FindBoost.cmake	2016-03-02 16:10:18.252811225 -0500
f9cb51
@@ -279,10 +279,15 @@ endmacro()
f9cb51
 macro(_Boost_FIND_LIBRARY var)
f9cb51
   find_library(${var} ${ARGN})
f9cb51
 
f9cb51
-  # If we found the first library save Boost_LIBRARY_DIR.
f9cb51
-  if(${var} AND NOT Boost_LIBRARY_DIR)
f9cb51
-    get_filename_component(_dir "${${var}}" PATH)
f9cb51
-    set(Boost_LIBRARY_DIR "${_dir}" CACHE PATH "Boost library directory" FORCE)
f9cb51
+  if(${var})
f9cb51
+    # If this is the first library found then save Boost_LIBRARY_DIR.
f9cb51
+    if(NOT Boost_LIBRARY_DIR)
f9cb51
+      get_filename_component(_dir "${${var}}" PATH)
f9cb51
+      set(Boost_LIBRARY_DIR "${_dir}" CACHE PATH "Boost library directory" FORCE)
f9cb51
+    endif()
f9cb51
+  elseif(_Boost_FIND_LIBRARY_HINTS_FOR_COMPONENT)
f9cb51
+    # Try component-specific hints but do not save Boost_LIBRARY_DIR.
f9cb51
+    find_library(${var} HINTS ${_Boost_FIND_LIBRARY_HINTS_FOR_COMPONENT} ${ARGN})
f9cb51
   endif()
f9cb51
 
f9cb51
   # If Boost_LIBRARY_DIR is known then search only there.
f9cb51
@@ -906,6 +911,28 @@ foreach(COMPONENT ${Boost_FIND_COMPONENT
f9cb51
   set( _boost_docstring_release "Boost ${COMPONENT} library (release)")
f9cb51
   set( _boost_docstring_debug   "Boost ${COMPONENT} library (debug)")
f9cb51
 
f9cb51
+  # Compute component-specific hints.
f9cb51
+  set(_Boost_FIND_LIBRARY_HINTS_FOR_COMPONENT "")
f9cb51
+  if(${COMPONENT} STREQUAL "mpi" OR ${COMPONENT} STREQUAL "mpi_python")
f9cb51
+    foreach(lib ${MPI_CXX_LIBRARIES} ${MPI_C_LIBRARIES})
f9cb51
+      if(IS_ABSOLUTE "${lib}")
f9cb51
+        get_filename_component(libdir "${lib}" PATH)
f9cb51
+        string(REPLACE "\\" "/" libdir "${libdir}")
f9cb51
+        list(APPEND _Boost_FIND_LIBRARY_HINTS_FOR_COMPONENT ${libdir})
f9cb51
+      endif()
f9cb51
+    endforeach()
f9cb51
+  endif()
f9cb51
+
f9cb51
+  # Consolidate and report component-specific hints.
f9cb51
+  if(_Boost_FIND_LIBRARY_HINTS_FOR_COMPONENT)
f9cb51
+    list(REMOVE_DUPLICATES _Boost_FIND_LIBRARY_HINTS_FOR_COMPONENT)
f9cb51
+    if(Boost_DEBUG)
f9cb51
+      message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] "
f9cb51
+        "Component-specific library search paths for ${COMPONENT}: "
f9cb51
+        "${_Boost_FIND_LIBRARY_HINTS_FOR_COMPONENT}")
f9cb51
+    endif()
f9cb51
+  endif()
f9cb51
+
f9cb51
   #
f9cb51
   # Find RELEASE libraries
f9cb51
   #