| # - Try to find Boost include dirs and libraries |
| # Usage of this module as follows: |
| # |
| # NOTE: Take note of the Boost_ADDITIONAL_VERSIONS variable below. |
| # Due to Boost naming conventions and limitations in CMake this find |
| # module is NOT future safe with respect to Boost version numbers, |
| # and may break. |
| # |
| # == Using Header-Only libraries from within Boost: == |
| # |
| # find_package( Boost 1.36.0 ) |
| # if(Boost_FOUND) |
| # include_directories(${Boost_INCLUDE_DIRS}) |
| # add_executable(foo foo.cc) |
| # endif() |
| # |
| # |
| # == Using actual libraries from within Boost: == |
| # |
| # set(Boost_USE_STATIC_LIBS ON) |
| # set(Boost_USE_MULTITHREADED ON) |
| # set(Boost_USE_STATIC_RUNTIME OFF) |
| # find_package( Boost 1.36.0 COMPONENTS date_time filesystem system ... ) |
| # |
| # if(Boost_FOUND) |
| # include_directories(${Boost_INCLUDE_DIRS}) |
| # add_executable(foo foo.cc) |
| # target_link_libraries(foo ${Boost_LIBRARIES}) |
| # endif() |
| # |
| # |
| # The components list needs to contain actual names of boost libraries only, |
| # such as "date_time" for "libboost_date_time". If you're using parts of |
| # Boost that contain header files only (e.g. foreach) you do not need to |
| # specify COMPONENTS. |
| # |
| # You should provide a minimum version number that should be used. If you provide this |
| # version number and specify the REQUIRED attribute, this module will fail if it |
| # can't find the specified or a later version. If you specify a version number this is |
| # automatically put into the considered list of version numbers and thus doesn't need |
| # to be specified in the Boost_ADDITIONAL_VERSIONS variable (see below). |
| # |
| # NOTE for Visual Studio Users: |
| # Automatic linking is used on MSVC & Borland compilers by default when |
| # #including things in Boost. It's important to note that setting |
| # Boost_USE_STATIC_LIBS to OFF is NOT enough to get you dynamic linking, |
| # should you need this feature. Automatic linking typically uses static |
| # libraries with a few exceptions (Boost.Python is one). |
| # |
| # Please see the section below near Boost_LIB_DIAGNOSTIC_DEFINITIONS for |
| # more details. Adding a TARGET_LINK_LIBRARIES() as shown in the example |
| # above appears to cause VS to link dynamically if Boost_USE_STATIC_LIBS |
| # gets set to OFF. It is suggested you avoid automatic linking since it |
| # will make your application less portable. |
| # |
| # =========== The mess that is Boost_ADDITIONAL_VERSIONS (sorry?) ============ |
| # |
| # OK, so the Boost_ADDITIONAL_VERSIONS variable can be used to specify a list of |
| # boost version numbers that should be taken into account when searching |
| # for Boost. Unfortunately boost puts the version number into the |
| # actual filename for the libraries, so this variable will certainly be needed |
| # in the future when new Boost versions are released. |
| # |
| # Currently this module searches for the following version numbers: |
| # 1.33, 1.33.0, 1.33.1, 1.34, 1.34.0, 1.34.1, 1.35, 1.35.0, 1.35.1, |
| # 1.36, 1.36.0, 1.36.1, 1.37, 1.37.0, 1.38, 1.38.0, 1.39, 1.39.0, |
| # 1.40, 1.40.0, 1.41, 1.41.0, 1.42, 1.42.0, 1.43, 1.43.0, 1.44, 1.44.0, |
| # 1.45, 1.45.0, 1.46, 1.46.0, 1.46.1, 1.47, 1.47.0, 1.48, 1.48.0, |
| # 1.49, 1.49.0, 1.50, 1.50.0 |
| # |
| # NOTE: If you add a new major 1.x version in Boost_ADDITIONAL_VERSIONS you should |
| # add both 1.x and 1.x.0 as shown above. Official Boost include directories |
| # omit the 3rd version number from include paths if it is 0 although not all |
| # binary Boost releases do so. |
| # |
| # set(Boost_ADDITIONAL_VERSIONS "1.78" "1.78.0" "1.79" "1.79.0") |
| # |
| # ===================================== ============= ======================== |
| # |
| # Variables used by this module, they can change the default behaviour and |
| # need to be set before calling find_package: |
| # |
| # Boost_USE_MULTITHREADED Can be set to OFF to use the non-multithreaded |
| # boost libraries. If not specified, defaults |
| # to ON. |
| # |
| # Boost_USE_STATIC_LIBS Can be set to ON to force the use of the static |
| # boost libraries. Defaults to OFF. |
| # |
| # Boost_NO_SYSTEM_PATHS Set to TRUE to suppress searching in system |
| # paths (or other locations outside of BOOST_ROOT |
| # or BOOST_INCLUDEDIR). Useful when specifying |
| # BOOST_ROOT. Defaults to OFF. |
| # [Since CMake 2.8.3] |
| # |
| # Boost_NO_BOOST_CMAKE Do not do a find_package call in config mode |
| # before searching for a regular boost install. |
| # This will avoid finding boost-cmake installs. |
| # Defaults to OFF. |
| # [Since CMake 2.8.6] |
| # |
| # Boost_USE_STATIC_RUNTIME If enabled, searches for boost libraries |
| # linked against a static C++ standard library |
| # ('s' ABI tag). This option should be set to |
| # ON or OFF because the default behavior |
| # if not specified is platform dependent |
| # for backwards compatibility. |
| # [Since CMake 2.8.3] |
| # |
| # Boost_USE_DEBUG_PYTHON If enabled, searches for boost libraries |
| # compiled against a special debug build of |
| # Python ('y' ABI tag). Defaults to OFF. |
| # [Since CMake 2.8.3] |
| # |
| # Boost_USE_STLPORT If enabled, searches for boost libraries |
| # compiled against the STLPort standard |
| # library ('p' ABI tag). Defaults to OFF. |
| # [Since CMake 2.8.3] |
| # |
| # Boost_USE_STLPORT_DEPRECATED_NATIVE_IOSTREAMS |
| # If enabled, searches for boost libraries |
| # compiled against the deprecated STLPort |
| # "native iostreams" feature ('n' ABI tag). |
| # Defaults to OFF. |
| # [Since CMake 2.8.3] |
| # |
| # Other Variables used by this module which you may want to set. |
| # |
| # Boost_ADDITIONAL_VERSIONS A list of version numbers to use for searching |
| # the boost include directory. Please see |
| # the documentation above regarding this |
| # annoying, but necessary variable :( |
| # |
| # Boost_DEBUG Set this to TRUE to enable debugging output |
| # of FindBoost.cmake if you are having problems. |
| # Please enable this before filing any bug |
| # reports. |
| # |
| # Boost_DETAILED_FAILURE_MSG FindBoost doesn't output detailed information |
| # about why it failed or how to fix the problem |
| # unless this is set to TRUE or the REQUIRED |
| # keyword is specified in find_package(). |
| # [Since CMake 2.8.0] |
| # |
| # Boost_COMPILER Set this to the compiler suffix used by Boost |
| # (e.g. "-gcc43") if FindBoost has problems finding |
| # the proper Boost installation |
| # |
| # Boost_THREADAPI When building boost.thread, sometimes the name of the |
| # library contains an additional "pthread" or "win32" |
| # string known as the threadapi. This can happen when |
| # compiling against pthreads on Windows or win32 threads |
| # on Cygwin. You may specify this variable and if set |
| # when FindBoost searches for the Boost threading library |
| # it will first try to match the threadapi you specify. |
| # For Example: libboost_thread_win32-mgw45-mt-1_43.a |
| # might be found if you specified "win32" here before |
| # falling back on libboost_thread-mgw45-mt-1_43.a. |
| # [Since CMake 2.8.3] |
| # |
| # Boost_REALPATH Resolves symbolic links for discovered boost libraries |
| # to assist with packaging. For example, instead of |
| # Boost_SYSTEM_LIBRARY_RELEASE being resolved to |
| # "/usr/lib/libboost_system.so" it would be |
| # "/usr/lib/libboost_system.so.1.42.0" instead. |
| # This does not affect linking and should not be |
| # enabled unless the user needs this information. |
| # [Since CMake 2.8.3] |
| # |
| |
| |
| # |
| # These last three variables are available also as environment variables: |
| # Also, note they are completely UPPERCASE, except Boost_DIR. |
| # |
| # Boost_DIR or The preferred installation prefix for searching for |
| # BOOST_ROOT or BOOSTROOT Boost. Set this if the module has problems finding |
| # the proper Boost installation. |
| # |
| # Note that Boost_DIR behaves exactly as <package>_DIR |
| # variables are documented to behave in find_package's |
| # Config mode. That is, if it is set as a -D argument |
| # to CMake, it must point to the location of the |
| # BoostConfig.cmake or Boost-config.cmake file. If it |
| # is set as an environment variable, it must point to |
| # the root of the boost installation. BOOST_ROOT and |
| # BOOSTROOT, on the other hand, will point to the root |
| # in either case. |
| # |
| # To prevent falling back on the system paths, set |
| # Boost_NO_SYSTEM_PATHS to true. |
| # |
| # To avoid finding boost-cmake installations, set |
| # Boost_NO_BOOST_CMAKE to true. |
| # |
| # BOOST_INCLUDEDIR Set this to the include directory of Boost, if the |
| # module has problems finding the proper Boost installation |
| # |
| # BOOST_LIBRARYDIR Set this to the lib directory of Boost, if the |
| # module has problems finding the proper Boost installation |
| # |
| # Variables defined by this module: |
| # |
| # Boost_FOUND System has Boost, this means the include dir was |
| # found, as well as all the libraries specified in |
| # the COMPONENTS list. |
| # |
| # Boost_INCLUDE_DIRS Boost include directories: not cached |
| # |
| # Boost_INCLUDE_DIR This is almost the same as above, but this one is |
| # cached and may be modified by advanced users |
| # |
| # Boost_LIBRARIES Link to these to use the Boost libraries that you |
| # specified: not cached |
| # |
| # Boost_LIBRARY_DIRS The path to where the Boost library files are. |
| # |
| # Boost_VERSION The version number of the boost libraries that |
| # have been found, same as in version.hpp from Boost |
| # |
| # Boost_LIB_VERSION The version number in filename form as |
| # it's appended to the library filenames |
| # |
| # Boost_MAJOR_VERSION major version number of boost |
| # Boost_MINOR_VERSION minor version number of boost |
| # Boost_SUBMINOR_VERSION subminor version number of boost |
| # |
| # Boost_LIB_DIAGNOSTIC_DEFINITIONS [WIN32 Only] You can call |
| # add_definitions(${Boost_LIB_DIAGNOSTIC_DEFINITIONS}) |
| # to have diagnostic information about Boost's |
| # automatic linking outputted during compilation time. |
| # |
| # For each component you specify in find_package(), the following (UPPER-CASE) |
| # variables are set. You can use these variables if you would like to pick and |
| # choose components for your targets instead of just using Boost_LIBRARIES. |
| # |
| # Boost_${COMPONENT}_FOUND True IF the Boost library "component" was found. |
| # |
| # Boost_${COMPONENT}_LIBRARY Contains the libraries for the specified Boost |
| # "component" (includes debug and optimized keywords |
| # when needed). |
| |
| #============================================================================= |
| # Copyright 2006-2009 Kitware, Inc. |
| # Copyright 2006-2008 Andreas Schneider <mail@cynapses.org> |
| # Copyright 2007 Wengo |
| # Copyright 2007 Mike Jackson |
| # Copyright 2008 Andreas Pakulat <apaku@gmx.de> |
| # Copyright 2008-2010 Philip Lowman <philip@yhbt.com> |
| # |
| # 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.) |
| |
| |
| #------------------------------------------------------------------------------- |
| # Before we go searching, check whether boost-cmake is avaialble, unless the |
| # user specifically asked NOT to search for boost-cmake. |
| # |
| # If Boost_DIR is set, this behaves as any find_package call would. If not, |
| # it looks at BOOST_ROOT and BOOSTROOT to find Boost. |
| # |
| if (NOT Boost_NO_BOOST_CMAKE) |
| # If Boost_DIR is not set, look for BOOSTROOT and BOOST_ROOT as alternatives, |
| # since these are more conventional for Boost. |
| if ("$ENV{Boost_DIR}" STREQUAL "") |
| if (NOT "$ENV{BOOST_ROOT}" STREQUAL "") |
| set(ENV{Boost_DIR} $ENV{BOOST_ROOT}) |
| elseif (NOT "$ENV{BOOSTROOT}" STREQUAL "") |
| set(ENV{Boost_DIR} $ENV{BOOSTROOT}) |
| endif() |
| endif() |
| |
| # Do the same find_package call but look specifically for the CMake version. |
| # Note that args are passed in the Boost_FIND_xxxxx variables, so there is no |
| # need to delegate them to this find_package call. |
| find_package(Boost QUIET NO_MODULE) |
| |
| # If we found boost-cmake, then we're done. Print out what we found. |
| # Otherwise let the rest of the module try to find it. |
| if (Boost_FOUND) |
| message("Boost ${Boost_FIND_VERSION} found.") |
| if (Boost_FIND_COMPONENTS) |
| message("Found Boost components:") |
| message(" ${Boost_FIND_COMPONENTS}") |
| endif() |
| return() |
| endif() |
| endif() |
| |
| |
| #------------------------------------------------------------------------------- |
| # FindBoost functions & macros |
| # |
| ############################################ |
| # |
| # Check the existence of the libraries. |
| # |
| ############################################ |
| # This macro was taken directly from the FindQt4.cmake file that is included |
| # with the CMake distribution. This is NOT my work. All work was done by the |
| # original authors of the FindQt4.cmake file. Only minor modifications were |
| # made to remove references to Qt and make this file more generally applicable |
| # And ELSE/ENDIF pairs were removed for readability. |
| ######################################################################### |
| |
| macro(_Boost_ADJUST_LIB_VARS basename) |
| if(Boost_INCLUDE_DIR ) |
| if(Boost_${basename}_LIBRARY_DEBUG AND Boost_${basename}_LIBRARY_RELEASE) |
| # if the generator supports configuration types then set |
| # optimized and debug libraries, or if the CMAKE_BUILD_TYPE has a value |
| if(CMAKE_CONFIGURATION_TYPES OR CMAKE_BUILD_TYPE) |
| set(Boost_${basename}_LIBRARY optimized ${Boost_${basename}_LIBRARY_RELEASE} debug ${Boost_${basename}_LIBRARY_DEBUG}) |
| else() |
| # if there are no configuration types and CMAKE_BUILD_TYPE has no value |
| # then just use the release libraries |
| set(Boost_${basename}_LIBRARY ${Boost_${basename}_LIBRARY_RELEASE} ) |
| endif() |
| # FIXME: This probably should be set for both cases |
| set(Boost_${basename}_LIBRARIES optimized ${Boost_${basename}_LIBRARY_RELEASE} debug ${Boost_${basename}_LIBRARY_DEBUG}) |
| endif() |
| |
| # if only the release version was found, set the debug variable also to the release version |
| if(Boost_${basename}_LIBRARY_RELEASE AND NOT Boost_${basename}_LIBRARY_DEBUG) |
| set(Boost_${basename}_LIBRARY_DEBUG ${Boost_${basename}_LIBRARY_RELEASE}) |
| set(Boost_${basename}_LIBRARY ${Boost_${basename}_LIBRARY_RELEASE}) |
| set(Boost_${basename}_LIBRARIES ${Boost_${basename}_LIBRARY_RELEASE}) |
| endif() |
| |
| # if only the debug version was found, set the release variable also to the debug version |
| if(Boost_${basename}_LIBRARY_DEBUG AND NOT Boost_${basename}_LIBRARY_RELEASE) |
| set(Boost_${basename}_LIBRARY_RELEASE ${Boost_${basename}_LIBRARY_DEBUG}) |
| set(Boost_${basename}_LIBRARY ${Boost_${basename}_LIBRARY_DEBUG}) |
| set(Boost_${basename}_LIBRARIES ${Boost_${basename}_LIBRARY_DEBUG}) |
| endif() |
| |
| # If the debug & release library ends up being the same, omit the keywords |
| if(${Boost_${basename}_LIBRARY_RELEASE} STREQUAL ${Boost_${basename}_LIBRARY_DEBUG}) |
| set(Boost_${basename}_LIBRARY ${Boost_${basename}_LIBRARY_RELEASE} ) |
| set(Boost_${basename}_LIBRARIES ${Boost_${basename}_LIBRARY_RELEASE} ) |
| endif() |
| |
| if(Boost_${basename}_LIBRARY) |
| set(Boost_${basename}_LIBRARY ${Boost_${basename}_LIBRARY} CACHE FILEPATH "The Boost ${basename} library") |
| |
| # Remove superfluous "debug" / "optimized" keywords from |
| # Boost_LIBRARY_DIRS |
| foreach(_boost_my_lib ${Boost_${basename}_LIBRARY}) |
| get_filename_component(_boost_my_lib_path "${_boost_my_lib}" PATH) |
| list(APPEND Boost_LIBRARY_DIRS ${_boost_my_lib_path}) |
| endforeach() |
| list(REMOVE_DUPLICATES Boost_LIBRARY_DIRS) |
| |
| set(Boost_LIBRARY_DIRS ${Boost_LIBRARY_DIRS} CACHE FILEPATH "Boost library directory") |
| set(Boost_${basename}_FOUND ON CACHE INTERNAL "Whether the Boost ${basename} library found") |
| endif(Boost_${basename}_LIBRARY) |
| |
| endif(Boost_INCLUDE_DIR ) |
| # Make variables changeble to the advanced user |
| mark_as_advanced( |
| Boost_${basename}_LIBRARY |
| Boost_${basename}_LIBRARY_RELEASE |
| Boost_${basename}_LIBRARY_DEBUG |
| ) |
| endmacro(_Boost_ADJUST_LIB_VARS) |
| |
| #------------------------------------------------------------------------------- |
| |
| # |
| # Runs compiler with "-dumpversion" and parses major/minor |
| # version with a regex. |
| # |
| function(_Boost_COMPILER_DUMPVERSION _OUTPUT_VERSION) |
| |
| exec_program(${CMAKE_CXX_COMPILER} |
| ARGS ${CMAKE_CXX_COMPILER_ARG1} -dumpversion |
| OUTPUT_VARIABLE _boost_COMPILER_VERSION |
| ) |
| string(REGEX REPLACE "([0-9])\\.([0-9])(\\.[0-9])?" "\\1\\2" |
| _boost_COMPILER_VERSION ${_boost_COMPILER_VERSION}) |
| |
| set(${_OUTPUT_VERSION} ${_boost_COMPILER_VERSION} PARENT_SCOPE) |
| endfunction() |
| |
| # |
| # A convenience function for marking desired components |
| # as found or not |
| # |
| function(_Boost_MARK_COMPONENTS_FOUND _yes_or_no) |
| foreach(COMPONENT ${Boost_FIND_COMPONENTS}) |
| string(TOUPPER ${COMPONENT} UPPERCOMPONENT) |
| set(Boost_${UPPERCOMPONENT}_FOUND ${_yes_or_no} CACHE INTERNAL "Whether the Boost ${COMPONENT} library found" FORCE) |
| endforeach() |
| endfunction() |
| |
| # |
| # Take a list of libraries with "thread" in it |
| # and prepend duplicates with "thread_${Boost_THREADAPI}" |
| # at the front of the list |
| # |
| function(_Boost_PREPEND_LIST_WITH_THREADAPI _output) |
| set(_orig_libnames ${ARGN}) |
| string(REPLACE "thread" "thread_${Boost_THREADAPI}" _threadapi_libnames "${_orig_libnames}") |
| set(${_output} ${_threadapi_libnames} ${_orig_libnames} PARENT_SCOPE) |
| endfunction() |
| |
| # |
| # If a library is found, replace its cache entry with its REALPATH |
| # |
| function(_Boost_SWAP_WITH_REALPATH _library _docstring) |
| if(${_library}) |
| get_filename_component(_boost_filepathreal ${${_library}} REALPATH) |
| unset(${_library} CACHE) |
| set(${_library} ${_boost_filepathreal} CACHE FILEPATH "${_docstring}") |
| endif() |
| endfunction() |
| |
| function(_Boost_CHECK_SPELLING _var) |
| if(${_var}) |
| string(TOUPPER ${_var} _var_UC) |
| message(FATAL_ERROR "ERROR: ${_var} is not the correct spelling. The proper spelling is ${_var_UC}.") |
| endif() |
| endfunction() |
| |
| # |
| # End functions/macros |
| # |
| #------------------------------------------------------------------------------- |
| |
| |
| |
| |
| if(NOT DEFINED Boost_USE_MULTITHREADED) |
| set(Boost_USE_MULTITHREADED TRUE) |
| endif() |
| |
| if(Boost_FIND_VERSION_EXACT) |
| # The version may appear in a directory with or without the patch |
| # level, even when the patch level is non-zero. |
| set(_boost_TEST_VERSIONS |
| "${Boost_FIND_VERSION_MAJOR}.${Boost_FIND_VERSION_MINOR}.${Boost_FIND_VERSION_PATCH}" |
| "${Boost_FIND_VERSION_MAJOR}.${Boost_FIND_VERSION_MINOR}") |
| else(Boost_FIND_VERSION_EXACT) |
| # The user has not requested an exact version. Among known |
| # versions, find those that are acceptable to the user request. |
| set(_Boost_KNOWN_VERSIONS ${Boost_ADDITIONAL_VERSIONS} |
| "1.50.0" "1.50" "1.49.0" "1.49" "1.48.0" "1.48" "1.47.0" "1.47" "1.46.1" |
| "1.46.0" "1.46" "1.45.0" "1.45" "1.44.0" "1.44" "1.43.0" "1.43" "1.42.0" "1.42" |
| "1.41.0" "1.41" "1.40.0" "1.40" "1.39.0" "1.39" "1.38.0" "1.38" "1.37.0" "1.37" |
| "1.36.1" "1.36.0" "1.36" "1.35.1" "1.35.0" "1.35" "1.34.1" "1.34.0" |
| "1.34" "1.33.1" "1.33.0" "1.33") |
| set(_boost_TEST_VERSIONS) |
| if(Boost_FIND_VERSION) |
| set(_Boost_FIND_VERSION_SHORT "${Boost_FIND_VERSION_MAJOR}.${Boost_FIND_VERSION_MINOR}") |
| # Select acceptable versions. |
| foreach(version ${_Boost_KNOWN_VERSIONS}) |
| if(NOT "${version}" VERSION_LESS "${Boost_FIND_VERSION}") |
| # This version is high enough. |
| list(APPEND _boost_TEST_VERSIONS "${version}") |
| elseif("${version}.99" VERSION_EQUAL "${_Boost_FIND_VERSION_SHORT}.99") |
| # This version is a short-form for the requested version with |
| # the patch level dropped. |
| list(APPEND _boost_TEST_VERSIONS "${version}") |
| endif() |
| endforeach(version) |
| else(Boost_FIND_VERSION) |
| # Any version is acceptable. |
| set(_boost_TEST_VERSIONS "${_Boost_KNOWN_VERSIONS}") |
| endif(Boost_FIND_VERSION) |
| endif(Boost_FIND_VERSION_EXACT) |
| |
| # The reason that we failed to find Boost. This will be set to a |
| # user-friendly message when we fail to find some necessary piece of |
| # Boost. |
| set(Boost_ERROR_REASON) |
| |
| set( _boost_IN_CACHE TRUE) |
| if(Boost_INCLUDE_DIR) |
| |
| # On versions < 1.35, remove the System library from the considered list |
| # since it wasn't added until 1.35. |
| if(Boost_VERSION AND Boost_FIND_COMPONENTS) |
| if(Boost_VERSION LESS 103500) |
| list(REMOVE_ITEM Boost_FIND_COMPONENTS system) |
| endif() |
| endif() |
| |
| foreach(COMPONENT ${Boost_FIND_COMPONENTS}) |
| string(TOUPPER ${COMPONENT} COMPONENT) |
| if(NOT Boost_${COMPONENT}_FOUND) |
| set( _boost_IN_CACHE FALSE) |
| endif(NOT Boost_${COMPONENT}_FOUND) |
| endforeach(COMPONENT) |
| else(Boost_INCLUDE_DIR) |
| set( _boost_IN_CACHE FALSE) |
| endif(Boost_INCLUDE_DIR) |
| |
| if(_boost_IN_CACHE) |
| # in cache already |
| set(Boost_FOUND TRUE) |
| foreach(COMPONENT ${Boost_FIND_COMPONENTS}) |
| string(TOUPPER ${COMPONENT} COMPONENT) |
| _Boost_ADJUST_LIB_VARS( ${COMPONENT} ) |
| set(Boost_LIBRARIES ${Boost_LIBRARIES} ${Boost_${COMPONENT}_LIBRARY}) |
| endforeach(COMPONENT) |
| set(Boost_INCLUDE_DIRS ${Boost_INCLUDE_DIR}) |
| if(Boost_VERSION AND NOT "${Boost_VERSION}" STREQUAL "0") |
| math(EXPR Boost_MAJOR_VERSION "${Boost_VERSION} / 100000") |
| math(EXPR Boost_MINOR_VERSION "${Boost_VERSION} / 100 % 1000") |
| math(EXPR Boost_SUBMINOR_VERSION "${Boost_VERSION} % 100") |
| endif(Boost_VERSION AND NOT "${Boost_VERSION}" STREQUAL "0") |
| if(Boost_DEBUG) |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| "boost ${Boost_MAJOR_VERSION}.${Boost_MINOR_VERSION}.${Boost_SUBMINOR_VERSION} " |
| "is already in the cache. To view debugging messages, please clear the cache.") |
| endif() |
| else(_boost_IN_CACHE) |
| # Need to search for boost |
| if(Boost_DEBUG) |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| "Boost not in cache") |
| # Output some of their choices |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| "_boost_TEST_VERSIONS = ${_boost_TEST_VERSIONS}") |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| "Boost_USE_MULTITHREADED = ${Boost_USE_MULTITHREADED}") |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| "Boost_USE_STATIC_LIBS = ${Boost_USE_STATIC_LIBS}") |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| "Boost_USE_STATIC_RUNTIME = ${Boost_USE_STATIC_RUNTIME}") |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| "Boost_ADDITIONAL_VERSIONS = ${Boost_ADDITIONAL_VERSIONS}") |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| "Boost_NO_SYSTEM_PATHS = ${Boost_NO_SYSTEM_PATHS}") |
| endif() |
| |
| if(WIN32) |
| # In windows, automatic linking is performed, so you do not have |
| # to specify the libraries. If you are linking to a dynamic |
| # runtime, then you can choose to link to either a static or a |
| # dynamic Boost library, the default is to do a static link. You |
| # can alter this for a specific library "whatever" by defining |
| # BOOST_WHATEVER_DYN_LINK to force Boost library "whatever" to be |
| # linked dynamically. Alternatively you can force all Boost |
| # libraries to dynamic link by defining BOOST_ALL_DYN_LINK. |
| |
| # This feature can be disabled for Boost library "whatever" by |
| # defining BOOST_WHATEVER_NO_LIB, or for all of Boost by defining |
| # BOOST_ALL_NO_LIB. |
| |
| # If you want to observe which libraries are being linked against |
| # then defining BOOST_LIB_DIAGNOSTIC will cause the auto-linking |
| # code to emit a #pragma message each time a library is selected |
| # for linking. |
| set(Boost_LIB_DIAGNOSTIC_DEFINITIONS |
| "-DBOOST_LIB_DIAGNOSTIC" CACHE STRING "Boost diagnostic define") |
| endif(WIN32) |
| |
| set(_boost_INCLUDE_SEARCH_DIRS_SYSTEM |
| C:/boost/include |
| C:/boost |
| "$ENV{ProgramFiles}/boost/include" |
| "$ENV{ProgramFiles}/boost" |
| /sw/local/include |
| ) |
| |
| _Boost_CHECK_SPELLING(Boost_ROOT) |
| _Boost_CHECK_SPELLING(Boost_LIBRARYDIR) |
| _Boost_CHECK_SPELLING(Boost_INCLUDEDIR) |
| |
| # If BOOST_ROOT was defined in the environment, use it. |
| if (NOT BOOST_ROOT AND NOT $ENV{Boost_DIR} STREQUAL "") |
| set(BOOST_ROOT $ENV{Boost_DIR}) |
| endif() |
| |
| # If BOOST_ROOT was defined in the environment, use it. |
| if (NOT BOOST_ROOT AND NOT $ENV{BOOST_ROOT} STREQUAL "") |
| set(BOOST_ROOT $ENV{BOOST_ROOT}) |
| endif() |
| |
| # If BOOSTROOT was defined in the environment, use it. |
| if (NOT BOOST_ROOT AND NOT $ENV{BOOSTROOT} STREQUAL "") |
| set(BOOST_ROOT $ENV{BOOSTROOT}) |
| endif() |
| |
| # If BOOST_INCLUDEDIR was defined in the environment, use it. |
| if( NOT $ENV{BOOST_INCLUDEDIR} STREQUAL "" ) |
| set(BOOST_INCLUDEDIR $ENV{BOOST_INCLUDEDIR}) |
| endif() |
| |
| # If BOOST_LIBRARYDIR was defined in the environment, use it. |
| if( NOT $ENV{BOOST_LIBRARYDIR} STREQUAL "" ) |
| set(BOOST_LIBRARYDIR $ENV{BOOST_LIBRARYDIR}) |
| endif() |
| |
| if( BOOST_ROOT ) |
| file(TO_CMAKE_PATH ${BOOST_ROOT} BOOST_ROOT) |
| endif() |
| |
| if(Boost_DEBUG) |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| "Declared as CMake or Environmental Variables:") |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| " BOOST_ROOT = ${BOOST_ROOT}") |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| " BOOST_INCLUDEDIR = ${BOOST_INCLUDEDIR}") |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| " BOOST_LIBRARYDIR = ${BOOST_LIBRARYDIR}") |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| "_boost_TEST_VERSIONS = ${_boost_TEST_VERSIONS}") |
| endif() |
| |
| if( Boost_NO_SYSTEM_PATHS) |
| set(_boost_FIND_OPTIONS NO_CMAKE_SYSTEM_PATH) |
| else() |
| set(_boost_INCLUDE_SEARCH_DIRS ${_boost_INCLUDE_SEARCH_DIRS_SYSTEM}) |
| endif() |
| |
| if( BOOST_ROOT ) |
| set(_boost_INCLUDE_SEARCH_DIRS |
| ${BOOST_ROOT}/include |
| ${BOOST_ROOT} |
| ${_boost_INCLUDE_SEARCH_DIRS}) |
| endif() |
| |
| # prepend BOOST_INCLUDEDIR to search path if specified |
| if( BOOST_INCLUDEDIR ) |
| file(TO_CMAKE_PATH ${BOOST_INCLUDEDIR} BOOST_INCLUDEDIR) |
| set(_boost_INCLUDE_SEARCH_DIRS |
| ${BOOST_INCLUDEDIR} ${_boost_INCLUDE_SEARCH_DIRS}) |
| endif( BOOST_INCLUDEDIR ) |
| |
| # ------------------------------------------------------------------------ |
| # Search for Boost include DIR |
| # ------------------------------------------------------------------------ |
| # Try to find Boost by stepping backwards through the Boost versions |
| # we know about. |
| if( NOT Boost_INCLUDE_DIR ) |
| # Build a list of path suffixes for each version. |
| set(_boost_PATH_SUFFIXES) |
| foreach(_boost_VER ${_boost_TEST_VERSIONS}) |
| # Add in a path suffix, based on the required version, ideally |
| # we could read this from version.hpp, but for that to work we'd |
| # need to know the include dir already |
| set(_boost_BOOSTIFIED_VERSION) |
| |
| # Transform 1.35 => 1_35 and 1.36.0 => 1_36_0 |
| if(_boost_VER MATCHES "[0-9]+\\.[0-9]+\\.[0-9]+") |
| string(REGEX REPLACE "([0-9]+)\\.([0-9]+)\\.([0-9]+)" "\\1_\\2_\\3" |
| _boost_BOOSTIFIED_VERSION ${_boost_VER}) |
| elseif(_boost_VER MATCHES "[0-9]+\\.[0-9]+") |
| string(REGEX REPLACE "([0-9]+)\\.([0-9]+)" "\\1_\\2" |
| _boost_BOOSTIFIED_VERSION ${_boost_VER}) |
| endif() |
| |
| list(APPEND _boost_PATH_SUFFIXES "boost-${_boost_BOOSTIFIED_VERSION}") |
| list(APPEND _boost_PATH_SUFFIXES "boost_${_boost_BOOSTIFIED_VERSION}") |
| |
| endforeach(_boost_VER) |
| |
| if(Boost_DEBUG) |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| "Include debugging info:") |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| " _boost_INCLUDE_SEARCH_DIRS = ${_boost_INCLUDE_SEARCH_DIRS}") |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| " _boost_PATH_SUFFIXES = ${_boost_PATH_SUFFIXES}") |
| endif() |
| |
| # Look for a standard boost header file. |
| find_path(Boost_INCLUDE_DIR |
| NAMES boost/config.hpp |
| HINTS ${_boost_INCLUDE_SEARCH_DIRS} |
| PATH_SUFFIXES ${_boost_PATH_SUFFIXES} |
| ${_boost_FIND_OPTIONS} |
| ) |
| endif( NOT Boost_INCLUDE_DIR ) |
| |
| # ------------------------------------------------------------------------ |
| # Extract version information from version.hpp |
| # ------------------------------------------------------------------------ |
| |
| if(Boost_INCLUDE_DIR) |
| # Extract Boost_VERSION and Boost_LIB_VERSION from version.hpp |
| # Read the whole file: |
| # |
| set(BOOST_VERSION 0) |
| set(BOOST_LIB_VERSION "") |
| file(READ "${Boost_INCLUDE_DIR}/boost/version.hpp" _boost_VERSION_HPP_CONTENTS) |
| if(Boost_DEBUG) |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| "location of version.hpp: ${Boost_INCLUDE_DIR}/boost/version.hpp") |
| endif() |
| |
| string(REGEX REPLACE ".*#define BOOST_VERSION ([0-9]+).*" "\\1" Boost_VERSION "${_boost_VERSION_HPP_CONTENTS}") |
| string(REGEX REPLACE ".*#define BOOST_LIB_VERSION \"([0-9_]+)\".*" "\\1" Boost_LIB_VERSION "${_boost_VERSION_HPP_CONTENTS}") |
| |
| set(Boost_LIB_VERSION ${Boost_LIB_VERSION} CACHE INTERNAL "The library version string for boost libraries") |
| set(Boost_VERSION ${Boost_VERSION} CACHE INTERNAL "The version number for boost libraries") |
| |
| if(NOT "${Boost_VERSION}" STREQUAL "0") |
| math(EXPR Boost_MAJOR_VERSION "${Boost_VERSION} / 100000") |
| math(EXPR Boost_MINOR_VERSION "${Boost_VERSION} / 100 % 1000") |
| math(EXPR Boost_SUBMINOR_VERSION "${Boost_VERSION} % 100") |
| |
| set(Boost_ERROR_REASON |
| "${Boost_ERROR_REASON}Boost version: ${Boost_MAJOR_VERSION}.${Boost_MINOR_VERSION}.${Boost_SUBMINOR_VERSION}\nBoost include path: ${Boost_INCLUDE_DIR}") |
| endif(NOT "${Boost_VERSION}" STREQUAL "0") |
| if(Boost_DEBUG) |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| "version.hpp reveals boost " |
| "${Boost_MAJOR_VERSION}.${Boost_MINOR_VERSION}.${Boost_SUBMINOR_VERSION}") |
| endif() |
| else(Boost_INCLUDE_DIR) |
| set(Boost_ERROR_REASON |
| "${Boost_ERROR_REASON}Unable to find the Boost header files. Please set BOOST_ROOT to the root directory containing Boost or BOOST_INCLUDEDIR to the directory containing Boost's headers.") |
| endif(Boost_INCLUDE_DIR) |
| |
| # ------------------------------------------------------------------------ |
| # Suffix initialization and compiler suffix detection. |
| # ------------------------------------------------------------------------ |
| |
| # Setting some more suffixes for the library |
| set(Boost_LIB_PREFIX "") |
| if ( WIN32 AND Boost_USE_STATIC_LIBS AND NOT CYGWIN) |
| set(Boost_LIB_PREFIX "lib") |
| endif() |
| |
| if (Boost_COMPILER) |
| set(_boost_COMPILER ${Boost_COMPILER}) |
| if(Boost_DEBUG) |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| "using user-specified Boost_COMPILER = ${_boost_COMPILER}") |
| endif() |
| else(Boost_COMPILER) |
| # Attempt to guess the compiler suffix |
| # NOTE: this is not perfect yet, if you experience any issues |
| # please report them and use the Boost_COMPILER variable |
| # to work around the problems. |
| if("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Intel" |
| OR "${CMAKE_CXX_COMPILER}" MATCHES "icl" |
| OR "${CMAKE_CXX_COMPILER}" MATCHES "icpc") |
| if(WIN32) |
| set (_boost_COMPILER "-iw") |
| else() |
| set (_boost_COMPILER "-il") |
| endif() |
| elseif (MSVC11) |
| set(_boost_COMPILER "-vc110") |
| elseif (MSVC10) |
| set(_boost_COMPILER "-vc100") |
| elseif (MSVC90) |
| set(_boost_COMPILER "-vc90") |
| elseif (MSVC80) |
| set(_boost_COMPILER "-vc80") |
| elseif (MSVC71) |
| set(_boost_COMPILER "-vc71") |
| elseif (MSVC70) # Good luck! |
| set(_boost_COMPILER "-vc7") # yes, this is correct |
| elseif (MSVC60) # Good luck! |
| set(_boost_COMPILER "-vc6") # yes, this is correct |
| elseif (BORLAND) |
| set(_boost_COMPILER "-bcb") |
| elseif("${CMAKE_CXX_COMPILER_ID}" STREQUAL "SunPro") |
| set(_boost_COMPILER "-sw") |
| elseif (MINGW) |
| if(${Boost_MAJOR_VERSION}.${Boost_MINOR_VERSION} VERSION_LESS 1.34) |
| set(_boost_COMPILER "-mgw") # no GCC version encoding prior to 1.34 |
| else() |
| _Boost_COMPILER_DUMPVERSION(_boost_COMPILER_VERSION) |
| set(_boost_COMPILER "-mgw${_boost_COMPILER_VERSION}") |
| endif() |
| elseif (UNIX) |
| if (CMAKE_COMPILER_IS_GNUCXX) |
| if(${Boost_MAJOR_VERSION}.${Boost_MINOR_VERSION} VERSION_LESS 1.34) |
| set(_boost_COMPILER "-gcc") # no GCC version encoding prior to 1.34 |
| else() |
| _Boost_COMPILER_DUMPVERSION(_boost_COMPILER_VERSION) |
| # Determine which version of GCC we have. |
| if(APPLE) |
| if(Boost_MINOR_VERSION) |
| if(${Boost_MINOR_VERSION} GREATER 35) |
| # In Boost 1.36.0 and newer, the mangled compiler name used |
| # on Mac OS X/Darwin is "xgcc". |
| set(_boost_COMPILER "-xgcc${_boost_COMPILER_VERSION}") |
| else(${Boost_MINOR_VERSION} GREATER 35) |
| # In Boost <= 1.35.0, there is no mangled compiler name for |
| # the Mac OS X/Darwin version of GCC. |
| set(_boost_COMPILER "") |
| endif(${Boost_MINOR_VERSION} GREATER 35) |
| else(Boost_MINOR_VERSION) |
| # We don't know the Boost version, so assume it's |
| # pre-1.36.0. |
| set(_boost_COMPILER "") |
| endif(Boost_MINOR_VERSION) |
| else() |
| set(_boost_COMPILER "-gcc${_boost_COMPILER_VERSION}") |
| endif() |
| endif() |
| endif (CMAKE_COMPILER_IS_GNUCXX) |
| endif() |
| if(Boost_DEBUG) |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| "guessed _boost_COMPILER = ${_boost_COMPILER}") |
| endif() |
| endif(Boost_COMPILER) |
| |
| set (_boost_MULTITHREADED "-mt") |
| if( NOT Boost_USE_MULTITHREADED ) |
| set (_boost_MULTITHREADED "") |
| endif() |
| if(Boost_DEBUG) |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| "_boost_MULTITHREADED = ${_boost_MULTITHREADED}") |
| endif() |
| |
| #====================== |
| # Systematically build up the Boost ABI tag |
| # http://boost.org/doc/libs/1_41_0/more/getting_started/windows.html#library-naming |
| set( _boost_RELEASE_ABI_TAG "-") |
| set( _boost_DEBUG_ABI_TAG "-") |
| # Key Use this library when: |
| # s linking statically to the C++ standard library and |
| # compiler runtime support libraries. |
| if(Boost_USE_STATIC_RUNTIME) |
| set( _boost_RELEASE_ABI_TAG "${_boost_RELEASE_ABI_TAG}s") |
| set( _boost_DEBUG_ABI_TAG "${_boost_DEBUG_ABI_TAG}s") |
| endif() |
| # g using debug versions of the standard and runtime |
| # support libraries |
| if(WIN32) |
| if(MSVC OR "${CMAKE_CXX_COMPILER}" MATCHES "icl" |
| OR "${CMAKE_CXX_COMPILER}" MATCHES "icpc") |
| set(_boost_DEBUG_ABI_TAG "${_boost_DEBUG_ABI_TAG}g") |
| endif() |
| endif() |
| # y using special debug build of python |
| if(Boost_USE_DEBUG_PYTHON) |
| set(_boost_DEBUG_ABI_TAG "${_boost_DEBUG_ABI_TAG}y") |
| endif() |
| # d using a debug version of your code |
| set(_boost_DEBUG_ABI_TAG "${_boost_DEBUG_ABI_TAG}d") |
| # p using the STLport standard library rather than the |
| # default one supplied with your compiler |
| if(Boost_USE_STLPORT) |
| set( _boost_RELEASE_ABI_TAG "${_boost_RELEASE_ABI_TAG}p") |
| set( _boost_DEBUG_ABI_TAG "${_boost_DEBUG_ABI_TAG}p") |
| endif() |
| # n using the STLport deprecated "native iostreams" feature |
| if(Boost_USE_STLPORT_DEPRECATED_NATIVE_IOSTREAMS) |
| set( _boost_RELEASE_ABI_TAG "${_boost_RELEASE_ABI_TAG}n") |
| set( _boost_DEBUG_ABI_TAG "${_boost_DEBUG_ABI_TAG}n") |
| endif() |
| |
| if(Boost_DEBUG) |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| "_boost_RELEASE_ABI_TAG = ${_boost_RELEASE_ABI_TAG}") |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| "_boost_DEBUG_ABI_TAG = ${_boost_DEBUG_ABI_TAG}") |
| endif() |
| |
| # ------------------------------------------------------------------------ |
| # Begin finding boost libraries |
| # ------------------------------------------------------------------------ |
| |
| if(BOOST_ROOT) |
| set(_boost_LIBRARY_SEARCH_DIRS_ALWAYS |
| ${BOOST_ROOT}/lib |
| ${BOOST_ROOT}/stage/lib) |
| endif() |
| set(_boost_LIBRARY_SEARCH_DIRS_ALWAYS |
| ${_boost_LIBRARY_SEARCH_DIRS_ALWAYS} |
| ${Boost_INCLUDE_DIR}/lib |
| ${Boost_INCLUDE_DIR}/../lib |
| ${Boost_INCLUDE_DIR}/stage/lib |
| ) |
| set(_boost_LIBRARY_SEARCH_DIRS_SYSTEM |
| C:/boost/lib |
| C:/boost |
| "$ENV{ProgramFiles}/boost/boost_${Boost_MAJOR_VERSION}_${Boost_MINOR_VERSION}_${Boost_SUBMINOR_VERSION}/lib" |
| "$ENV{ProgramFiles}/boost/boost_${Boost_MAJOR_VERSION}_${Boost_MINOR_VERSION}/lib" |
| "$ENV{ProgramFiles}/boost/lib" |
| "$ENV{ProgramFiles}/boost" |
| /sw/local/lib |
| ) |
| set(_boost_LIBRARY_SEARCH_DIRS ${_boost_LIBRARY_SEARCH_DIRS_ALWAYS}) |
| if( Boost_NO_SYSTEM_PATHS ) |
| set(_boost_FIND_OPTIONS NO_CMAKE_SYSTEM_PATH) |
| else() |
| list(APPEND _boost_LIBRARY_SEARCH_DIRS ${_boost_LIBRARY_SEARCH_DIRS_SYSTEM}) |
| endif() |
| |
| # prepend BOOST_LIBRARYDIR to search path if specified |
| if( BOOST_LIBRARYDIR ) |
| file(TO_CMAKE_PATH ${BOOST_LIBRARYDIR} BOOST_LIBRARYDIR) |
| set(_boost_LIBRARY_SEARCH_DIRS |
| ${BOOST_LIBRARYDIR} ${_boost_LIBRARY_SEARCH_DIRS}) |
| endif() |
| |
| if(Boost_DEBUG) |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| "_boost_LIBRARY_SEARCH_DIRS = ${_boost_LIBRARY_SEARCH_DIRS}") |
| endif() |
| |
| # Support preference of static libs by adjusting CMAKE_FIND_LIBRARY_SUFFIXES |
| if( Boost_USE_STATIC_LIBS ) |
| set( _boost_ORIG_CMAKE_FIND_LIBRARY_SUFFIXES ${CMAKE_FIND_LIBRARY_SUFFIXES}) |
| if(WIN32) |
| set(CMAKE_FIND_LIBRARY_SUFFIXES .lib .a ${CMAKE_FIND_LIBRARY_SUFFIXES}) |
| else() |
| set(CMAKE_FIND_LIBRARY_SUFFIXES .a ) |
| endif() |
| endif() |
| |
| # We want to use the tag inline below without risking double dashes |
| if(_boost_RELEASE_ABI_TAG) |
| if(${_boost_RELEASE_ABI_TAG} STREQUAL "-") |
| set(_boost_RELEASE_ABI_TAG "") |
| endif() |
| endif() |
| if(_boost_DEBUG_ABI_TAG) |
| if(${_boost_DEBUG_ABI_TAG} STREQUAL "-") |
| set(_boost_DEBUG_ABI_TAG "") |
| endif() |
| endif() |
| |
| # The previous behavior of FindBoost when Boost_USE_STATIC_LIBS was enabled |
| # on WIN32 was to: |
| # 1. Search for static libs compiled against a SHARED C++ standard runtime library (use if found) |
| # 2. Search for static libs compiled against a STATIC C++ standard runtime library (use if found) |
| # We maintain this behavior since changing it could break people's builds. |
| # To disable the ambiguous behavior, the user need only |
| # set Boost_USE_STATIC_RUNTIME either ON or OFF. |
| set(_boost_STATIC_RUNTIME_WORKAROUND false) |
| if(WIN32 AND Boost_USE_STATIC_LIBS) |
| if(NOT DEFINED Boost_USE_STATIC_RUNTIME) |
| set(_boost_STATIC_RUNTIME_WORKAROUND true) |
| endif() |
| endif() |
| |
| |
| foreach(COMPONENT ${Boost_FIND_COMPONENTS}) |
| string(TOUPPER ${COMPONENT} UPPERCOMPONENT) |
| set( Boost_${UPPERCOMPONENT}_LIBRARY "Boost_${UPPERCOMPONENT}_LIBRARY-NOTFOUND" ) |
| set( Boost_${UPPERCOMPONENT}_LIBRARY_RELEASE "Boost_${UPPERCOMPONENT}_LIBRARY_RELEASE-NOTFOUND" ) |
| set( Boost_${UPPERCOMPONENT}_LIBRARY_DEBUG "Boost_${UPPERCOMPONENT}_LIBRARY_DEBUG-NOTFOUND") |
| |
| set( _boost_docstring_release "Boost ${COMPONENT} library (release)") |
| set( _boost_docstring_debug "Boost ${COMPONENT} library (debug)") |
| |
| # |
| # Find RELEASE libraries |
| # |
| set(_boost_RELEASE_NAMES |
| ${Boost_LIB_PREFIX}boost_${COMPONENT}${_boost_COMPILER}${_boost_MULTITHREADED}${_boost_RELEASE_ABI_TAG}-${Boost_LIB_VERSION} |
| ${Boost_LIB_PREFIX}boost_${COMPONENT}${_boost_COMPILER}${_boost_MULTITHREADED}${_boost_RELEASE_ABI_TAG} |
| ${Boost_LIB_PREFIX}boost_${COMPONENT}${_boost_MULTITHREADED}${_boost_RELEASE_ABI_TAG}-${Boost_LIB_VERSION} |
| ${Boost_LIB_PREFIX}boost_${COMPONENT}${_boost_MULTITHREADED}${_boost_RELEASE_ABI_TAG} |
| ${Boost_LIB_PREFIX}boost_${COMPONENT} ) |
| if(_boost_STATIC_RUNTIME_WORKAROUND) |
| set(_boost_RELEASE_STATIC_ABI_TAG "-s${_boost_RELEASE_ABI_TAG}") |
| list(APPEND _boost_RELEASE_NAMES |
| ${Boost_LIB_PREFIX}boost_${COMPONENT}${_boost_COMPILER}${_boost_MULTITHREADED}${_boost_RELEASE_STATIC_ABI_TAG}-${Boost_LIB_VERSION} |
| ${Boost_LIB_PREFIX}boost_${COMPONENT}${_boost_COMPILER}${_boost_MULTITHREADED}${_boost_RELEASE_STATIC_ABI_TAG} |
| ${Boost_LIB_PREFIX}boost_${COMPONENT}${_boost_MULTITHREADED}${_boost_RELEASE_STATIC_ABI_TAG}-${Boost_LIB_VERSION} |
| ${Boost_LIB_PREFIX}boost_${COMPONENT}${_boost_MULTITHREADED}${_boost_RELEASE_STATIC_ABI_TAG} ) |
| endif() |
| if(Boost_THREADAPI AND ${COMPONENT} STREQUAL "thread") |
| _Boost_PREPEND_LIST_WITH_THREADAPI(_boost_RELEASE_NAMES ${_boost_RELEASE_NAMES}) |
| endif() |
| if(Boost_DEBUG) |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| "Searching for ${UPPERCOMPONENT}_LIBRARY_RELEASE: ${_boost_RELEASE_NAMES}") |
| endif() |
| find_library(Boost_${UPPERCOMPONENT}_LIBRARY_RELEASE |
| NAMES ${_boost_RELEASE_NAMES} |
| HINTS ${_boost_LIBRARY_SEARCH_DIRS} |
| ${_boost_FIND_OPTIONS} |
| DOC "${_boost_docstring_release}" |
| ) |
| |
| # |
| # Find DEBUG libraries |
| # |
| set(_boost_DEBUG_NAMES |
| ${Boost_LIB_PREFIX}boost_${COMPONENT}${_boost_COMPILER}${_boost_MULTITHREADED}${_boost_DEBUG_ABI_TAG}-${Boost_LIB_VERSION} |
| ${Boost_LIB_PREFIX}boost_${COMPONENT}${_boost_COMPILER}${_boost_MULTITHREADED}${_boost_DEBUG_ABI_TAG} |
| ${Boost_LIB_PREFIX}boost_${COMPONENT}${_boost_MULTITHREADED}${_boost_DEBUG_ABI_TAG}-${Boost_LIB_VERSION} |
| ${Boost_LIB_PREFIX}boost_${COMPONENT}${_boost_MULTITHREADED}${_boost_DEBUG_ABI_TAG} |
| ${Boost_LIB_PREFIX}boost_${COMPONENT}${_boost_MULTITHREADED} |
| ${Boost_LIB_PREFIX}boost_${COMPONENT} ) |
| if(_boost_STATIC_RUNTIME_WORKAROUND) |
| set(_boost_DEBUG_STATIC_ABI_TAG "-s${_boost_DEBUG_ABI_TAG}") |
| list(APPEND _boost_DEBUG_NAMES |
| ${Boost_LIB_PREFIX}boost_${COMPONENT}${_boost_COMPILER}${_boost_MULTITHREADED}${_boost_DEBUG_STATIC_ABI_TAG}-${Boost_LIB_VERSION} |
| ${Boost_LIB_PREFIX}boost_${COMPONENT}${_boost_COMPILER}${_boost_MULTITHREADED}${_boost_DEBUG_STATIC_ABI_TAG} |
| ${Boost_LIB_PREFIX}boost_${COMPONENT}${_boost_MULTITHREADED}${_boost_DEBUG_STATIC_ABI_TAG}-${Boost_LIB_VERSION} |
| ${Boost_LIB_PREFIX}boost_${COMPONENT}${_boost_MULTITHREADED}${_boost_DEBUG_STATIC_ABI_TAG} ) |
| endif() |
| if(Boost_THREADAPI AND ${COMPONENT} STREQUAL "thread") |
| _Boost_PREPEND_LIST_WITH_THREADAPI(_boost_DEBUG_NAMES ${_boost_DEBUG_NAMES}) |
| endif() |
| if(Boost_DEBUG) |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] " |
| "Searching for ${UPPERCOMPONENT}_LIBRARY_DEBUG: ${_boost_DEBUG_NAMES}") |
| endif() |
| find_library(Boost_${UPPERCOMPONENT}_LIBRARY_DEBUG |
| NAMES ${_boost_DEBUG_NAMES} |
| HINTS ${_boost_LIBRARY_SEARCH_DIRS} |
| ${_boost_FIND_OPTIONS} |
| DOC "${_boost_docstring_debug}" |
| ) |
| |
| if(Boost_REALPATH) |
| _Boost_SWAP_WITH_REALPATH(Boost_${UPPERCOMPONENT}_LIBRARY_RELEASE "${_boost_docstring_release}") |
| _Boost_SWAP_WITH_REALPATH(Boost_${UPPERCOMPONENT}_LIBRARY_DEBUG "${_boost_docstring_debug}" ) |
| endif() |
| |
| _Boost_ADJUST_LIB_VARS(${UPPERCOMPONENT}) |
| |
| endforeach(COMPONENT) |
| |
| # Restore the original find library ordering |
| if( Boost_USE_STATIC_LIBS ) |
| set(CMAKE_FIND_LIBRARY_SUFFIXES ${_boost_ORIG_CMAKE_FIND_LIBRARY_SUFFIXES}) |
| endif() |
| # ------------------------------------------------------------------------ |
| # End finding boost libraries |
| # ------------------------------------------------------------------------ |
| |
| set(Boost_INCLUDE_DIRS |
| ${Boost_INCLUDE_DIR} |
| ) |
| |
| set(Boost_FOUND FALSE) |
| if(Boost_INCLUDE_DIR) |
| set( Boost_FOUND TRUE ) |
| |
| # Check the version of Boost against the requested version. |
| if (Boost_FIND_VERSION AND NOT Boost_FIND_VERSION_MINOR) |
| message(SEND_ERROR "When requesting a specific version of Boost, you must provide at least the major and minor version numbers, e.g., 1.34") |
| endif (Boost_FIND_VERSION AND NOT Boost_FIND_VERSION_MINOR) |
| if(Boost_MAJOR_VERSION LESS "${Boost_FIND_VERSION_MAJOR}" ) |
| set( Boost_FOUND FALSE ) |
| set(_Boost_VERSION_AGE "old") |
| elseif(Boost_MAJOR_VERSION EQUAL "${Boost_FIND_VERSION_MAJOR}" ) |
| if(Boost_MINOR_VERSION LESS "${Boost_FIND_VERSION_MINOR}" ) |
| set( Boost_FOUND FALSE ) |
| set(_Boost_VERSION_AGE "old") |
| elseif(Boost_MINOR_VERSION EQUAL "${Boost_FIND_VERSION_MINOR}" ) |
| if( Boost_FIND_VERSION_PATCH AND Boost_SUBMINOR_VERSION LESS "${Boost_FIND_VERSION_PATCH}" ) |
| set( Boost_FOUND FALSE ) |
| set(_Boost_VERSION_AGE "old") |
| endif( Boost_FIND_VERSION_PATCH AND Boost_SUBMINOR_VERSION LESS "${Boost_FIND_VERSION_PATCH}" ) |
| endif( Boost_MINOR_VERSION LESS "${Boost_FIND_VERSION_MINOR}" ) |
| endif( Boost_MAJOR_VERSION LESS "${Boost_FIND_VERSION_MAJOR}" ) |
| |
| if (NOT Boost_FOUND) |
| _Boost_MARK_COMPONENTS_FOUND(OFF) |
| endif() |
| |
| if (Boost_FOUND AND Boost_FIND_VERSION_EXACT) |
| # If the user requested an exact version of Boost, check |
| # that. We already know that the Boost version we have is >= the |
| # requested version. |
| set(_Boost_VERSION_AGE "new") |
| |
| # If the user didn't specify a patchlevel, it's 0. |
| if (NOT Boost_FIND_VERSION_PATCH) |
| set(Boost_FIND_VERSION_PATCH 0) |
| endif (NOT Boost_FIND_VERSION_PATCH) |
| |
| # We'll set Boost_FOUND true again if we have an exact version match. |
| set(Boost_FOUND FALSE) |
| _Boost_MARK_COMPONENTS_FOUND(OFF) |
| if(Boost_MAJOR_VERSION EQUAL "${Boost_FIND_VERSION_MAJOR}" ) |
| if(Boost_MINOR_VERSION EQUAL "${Boost_FIND_VERSION_MINOR}" ) |
| if(Boost_SUBMINOR_VERSION EQUAL "${Boost_FIND_VERSION_PATCH}" ) |
| set( Boost_FOUND TRUE ) |
| _Boost_MARK_COMPONENTS_FOUND(ON) |
| endif(Boost_SUBMINOR_VERSION EQUAL "${Boost_FIND_VERSION_PATCH}" ) |
| endif( Boost_MINOR_VERSION EQUAL "${Boost_FIND_VERSION_MINOR}" ) |
| endif( Boost_MAJOR_VERSION EQUAL "${Boost_FIND_VERSION_MAJOR}" ) |
| endif (Boost_FOUND AND Boost_FIND_VERSION_EXACT) |
| |
| if(NOT Boost_FOUND) |
| # State that we found a version of Boost that is too new or too old. |
| set(Boost_ERROR_REASON |
| "${Boost_ERROR_REASON}\nDetected version of Boost is too ${_Boost_VERSION_AGE}. Requested version was ${Boost_FIND_VERSION_MAJOR}.${Boost_FIND_VERSION_MINOR}") |
| if (Boost_FIND_VERSION_PATCH) |
| set(Boost_ERROR_REASON |
| "${Boost_ERROR_REASON}.${Boost_FIND_VERSION_PATCH}") |
| endif (Boost_FIND_VERSION_PATCH) |
| if (NOT Boost_FIND_VERSION_EXACT) |
| set(Boost_ERROR_REASON "${Boost_ERROR_REASON} (or newer)") |
| endif (NOT Boost_FIND_VERSION_EXACT) |
| set(Boost_ERROR_REASON "${Boost_ERROR_REASON}.") |
| endif (NOT Boost_FOUND) |
| |
| # Always check for missing components |
| set(_boost_CHECKED_COMPONENT FALSE) |
| set(_Boost_MISSING_COMPONENTS "") |
| foreach(COMPONENT ${Boost_FIND_COMPONENTS}) |
| string(TOUPPER ${COMPONENT} COMPONENT) |
| set(_boost_CHECKED_COMPONENT TRUE) |
| if(NOT Boost_${COMPONENT}_FOUND) |
| string(TOLOWER ${COMPONENT} COMPONENT) |
| list(APPEND _Boost_MISSING_COMPONENTS ${COMPONENT}) |
| set( Boost_FOUND FALSE) |
| endif() |
| endforeach(COMPONENT) |
| |
| if(Boost_DEBUG) |
| message(STATUS "[ ${CMAKE_CURRENT_LIST_FILE}:${CMAKE_CURRENT_LIST_LINE} ] Boost_FOUND = ${Boost_FOUND}") |
| endif() |
| |
| if (_Boost_MISSING_COMPONENTS) |
| # We were unable to find some libraries, so generate a sensible |
| # error message that lists the libraries we were unable to find. |
| set(Boost_ERROR_REASON |
| "${Boost_ERROR_REASON}\nThe following Boost libraries could not be found:\n") |
| foreach(COMPONENT ${_Boost_MISSING_COMPONENTS}) |
| set(Boost_ERROR_REASON |
| "${Boost_ERROR_REASON} boost_${COMPONENT}\n") |
| endforeach(COMPONENT) |
| |
| list(LENGTH Boost_FIND_COMPONENTS Boost_NUM_COMPONENTS_WANTED) |
| list(LENGTH _Boost_MISSING_COMPONENTS Boost_NUM_MISSING_COMPONENTS) |
| if (${Boost_NUM_COMPONENTS_WANTED} EQUAL ${Boost_NUM_MISSING_COMPONENTS}) |
| set(Boost_ERROR_REASON |
| "${Boost_ERROR_REASON}No Boost libraries were found. You may need to set BOOST_LIBRARYDIR to the directory containing Boost libraries or BOOST_ROOT to the location of Boost.") |
| else (${Boost_NUM_COMPONENTS_WANTED} EQUAL ${Boost_NUM_MISSING_COMPONENTS}) |
| set(Boost_ERROR_REASON |
| "${Boost_ERROR_REASON}Some (but not all) of the required Boost libraries were found. You may need to install these additional Boost libraries. Alternatively, set BOOST_LIBRARYDIR to the directory containing Boost libraries or BOOST_ROOT to the location of Boost.") |
| endif (${Boost_NUM_COMPONENTS_WANTED} EQUAL ${Boost_NUM_MISSING_COMPONENTS}) |
| endif (_Boost_MISSING_COMPONENTS) |
| |
| if( NOT Boost_LIBRARY_DIRS AND NOT _boost_CHECKED_COMPONENT ) |
| # Compatibility Code for backwards compatibility with CMake |
| # 2.4's FindBoost module. |
| |
| # Look for the boost library path. |
| # Note that the user may not have installed any libraries |
| # so it is quite possible the Boost_LIBRARY_PATH may not exist. |
| set(_boost_LIB_DIR ${Boost_INCLUDE_DIR}) |
| |
| if("${_boost_LIB_DIR}" MATCHES "boost-[0-9]+") |
| get_filename_component(_boost_LIB_DIR ${_boost_LIB_DIR} PATH) |
| endif() |
| |
| if("${_boost_LIB_DIR}" MATCHES "/include$") |
| # Strip off the trailing "/include" in the path. |
| get_filename_component(_boost_LIB_DIR ${_boost_LIB_DIR} PATH) |
| endif() |
| |
| if(EXISTS "${_boost_LIB_DIR}/lib") |
| set(_boost_LIB_DIR ${_boost_LIB_DIR}/lib) |
| else() |
| if(EXISTS "${_boost_LIB_DIR}/stage/lib") |
| set(_boost_LIB_DIR ${_boost_LIB_DIR}/stage/lib) |
| else() |
| set(_boost_LIB_DIR "") |
| endif() |
| endif() |
| |
| if(_boost_LIB_DIR AND EXISTS "${_boost_LIB_DIR}") |
| set(Boost_LIBRARY_DIRS ${_boost_LIB_DIR} CACHE FILEPATH "Boost library directory") |
| endif() |
| |
| endif( NOT Boost_LIBRARY_DIRS AND NOT _boost_CHECKED_COMPONENT ) |
| |
| else(Boost_INCLUDE_DIR) |
| set( Boost_FOUND FALSE) |
| endif(Boost_INCLUDE_DIR) |
| |
| if(Boost_FOUND) |
| if(NOT Boost_FIND_QUIETLY) |
| message(STATUS "Boost version: ${Boost_MAJOR_VERSION}.${Boost_MINOR_VERSION}.${Boost_SUBMINOR_VERSION}") |
| if(Boost_FIND_COMPONENTS) |
| message(STATUS "Found the following Boost libraries:") |
| endif() |
| endif(NOT Boost_FIND_QUIETLY) |
| foreach( COMPONENT ${Boost_FIND_COMPONENTS} ) |
| string( TOUPPER ${COMPONENT} UPPERCOMPONENT ) |
| if( Boost_${UPPERCOMPONENT}_FOUND ) |
| if(NOT Boost_FIND_QUIETLY) |
| message (STATUS " ${COMPONENT}") |
| endif(NOT Boost_FIND_QUIETLY) |
| set(Boost_LIBRARIES ${Boost_LIBRARIES} ${Boost_${UPPERCOMPONENT}_LIBRARY}) |
| endif( Boost_${UPPERCOMPONENT}_FOUND ) |
| endforeach(COMPONENT) |
| else() |
| if(Boost_FIND_REQUIRED) |
| message(SEND_ERROR "Unable to find the requested Boost libraries.\n${Boost_ERROR_REASON}") |
| else() |
| if(NOT Boost_FIND_QUIETLY) |
| # we opt not to automatically output Boost_ERROR_REASON here as |
| # it could be quite lengthy and somewhat imposing in it's requests |
| # Since Boost is not always a required dependency we'll leave this |
| # up to the end-user. |
| if(Boost_DEBUG OR Boost_DETAILED_FAILURE_MSG) |
| message(STATUS "Could NOT find Boost\n${Boost_ERROR_REASON}") |
| else() |
| message(STATUS "Could NOT find Boost") |
| endif() |
| endif() |
| endif(Boost_FIND_REQUIRED) |
| endif() |
| |
| # show the Boost_INCLUDE_DIRS AND Boost_LIBRARIES variables only in the advanced view |
| mark_as_advanced(Boost_INCLUDE_DIR |
| Boost_INCLUDE_DIRS |
| Boost_LIBRARY_DIRS |
| ) |
| endif(_boost_IN_CACHE) |