diff options
Diffstat (limited to 'Modules')
-rw-r--r-- | Modules/FindBoost.cmake | 96 |
1 files changed, 53 insertions, 43 deletions
diff --git a/Modules/FindBoost.cmake b/Modules/FindBoost.cmake index 8ea67e5..3dc6739 100644 --- a/Modules/FindBoost.cmake +++ b/Modules/FindBoost.cmake @@ -3,25 +3,30 @@ # # == Using Header-Only libraries from within Boost: == # -# FIND_PACKAGE( Boost 1.36.0 ) -# INCLUDE_DIRECTORIES(${Boost_INCLUDE_DIRS}) -# ADD_EXECUTABLE(foo foo.cc) +# 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) -# FIND_PACKAGE( Boost 1.36.0 COMPONENTS date_time filesystem system ... ) -# INCLUDE_DIRECTORIES(${Boost_INCLUDE_DIRS}) +# set(Boost_USE_STATIC_LIBS ON) +# set(Boost_USE_MULTITHREADED ON) +# 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() # -# ADD_EXECUTABLE(foo foo.cc) -# TARGET_LINK_LIBRARIES(foo ${Boost_LIBRARIES}) # -# The components list needs to be the actual names of boost libraries, that is -# the part of the actual library files that differ on different libraries. So -# its "date_time" for "libboost_date_time...". Anything else will result in -# errors. If you're using parts of Boost that contains header files only (e.g. -# foreach) you do not need to specify COMPONENTS. +# 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 @@ -33,12 +38,14 @@ # 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, -# autolinking typically uses static libraries by default. +# 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. +# 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?) ============ # @@ -53,9 +60,9 @@ # 1.36, 1.36.0, 1.36.1, 1.37, 1.37.0, 1.38, 1.38.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 +# 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. +# binary Boost releases do so. # # SET(Boost_ADDITIONAL_VERSIONS "0.99" "0.99.0" "1.78" "1.78.0") # @@ -83,11 +90,15 @@ # Please enable this before filing any bug # reports. # -# Boost_COMPILER Set this to the compiler suffix used by boost (e.g. -gcc43) if the -# module has problems finding the proper Boost installation +# Boost_COMPILER Set this to the compiler suffix used by Boost +# (e.g. "-gcc43") if FindBoods has problems finding +# the proper Boost installation # -# BOOST_ROOT or BOOSTROOT Preferred installation prefix for searching for Boost, -# set this if the module has problems finding the proper Boost installation +# These last three variables are available also as environment variables: +# +# BOOST_ROOT or BOOSTROOT The preferred installation prefix for searching for +# Boost. Set this if the module has problems finding +# the proper Boost installation. # # BOOST_INCLUDEDIR Set this to the include directory of Boost, if the # module has problems finding the proper Boost installation @@ -95,27 +106,27 @@ # BOOST_LIBRARYDIR Set this to the lib directory of Boost, if the # module has problems finding the proper Boost installation # -# The last three variables are available also as environment variables -# -# # 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_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_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_INCLUDE_DIR This is almost the same as above, but this one is +# cached and may be modified by advanced users # -# Boost_LIBRARIES Link these to use the Boost libraries that you specified, not cached +# Boost_LIBRARIES Link 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_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 its appended to the library filenames +# 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 @@ -123,13 +134,12 @@ # # Boost_LIB_DIAGNOSTIC_DEFINITIONS [WIN32 Only] You can call # add_definitions(${Boost_LIB_DIAGNOSTIC_DEFINTIIONS}) -# to have diagnostic information about -# Boost's automatic linking outputted -# during compilation time. +# to have diagnostic information about Boost's +# automatic linking outputted during compilation time. # # For each component you list the following variables are set. # ATTENTION: The component names need to be in lower case, just as the boost -# library names however the cmake variables use upper case for the component +# library names however the CMake variables use upper case for the component # part. So you'd get Boost_SERIALIZATION_FOUND for example. # # Boost_${COMPONENT}_FOUND True IF the Boost library "component" was found. @@ -432,11 +442,11 @@ ELSE (_boost_IN_CACHE) _boost_BOOSTIFIED_VERSION ${_boost_VER}) ENDIF() - LIST(APPEND _boost_PATH_SUFFIXES "boost-${_boost_BOOSTIFIED_VERSION}") - IF(WIN32) - # Yay Boost Pro! We dig your underscores. - LIST(APPEND _boost_PATH_SUFFIXES "boost_${_boost_BOOSTIFIED_VERSION}") - ENDIF() + list(APPEND _boost_PATH_SUFFIXES "boost-${_boost_BOOSTIFIED_VERSION}") + if(WIN32) + # For BoostPro's underscores (and others?) + list(APPEND _boost_PATH_SUFFIXES "boost_${_boost_BOOSTIFIED_VERSION}") + endif() ENDFOREACH(_boost_VER) |