-# Copyright (C) 2007-2008 CEA/DEN, EDF R&D, OPEN CASCADE
+# Copyright (C) 2007-2010 CEA/DEN, EDF R&D, OPEN CASCADE
#
# Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
# CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
#
# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
#
-SET(BOOST_ROOT $ENV{BOOST_ROOT})
-IF(BOOST_ROOT)
- FIND_PATH(BOOST_INCLUDES boost/shared_ptr.hpp ${BOOST_ROOT})
- FIND_LIBRARY(BOOST_LIB_THREAD libboost_thread-vc90-mt-gd-1_35 ${BOOST_ROOT}/lib)
- FIND_LIBRARY(BOOST_LIB_DATE_TIME libboost_date_time-vc90-mt-gd-1_35 ${BOOST_ROOT}/lib)
- SET(BOOST_LIBS ${BOOST_LIB_THREAD} ${BOOST_LIB_DATE_TIME})
- SET(BOOST_CPPFLAGS -I${BOOST_INCLUDES} -DBOOST_DISABLE_ASSERTS)
-ELSE(BOOST_ROOT)
- SET(boost_thread -lboost_thread)
-ENDIF(BOOST_ROOT)
+
+# ------
+
+MESSAGE(STATUS "Check for boost ...")
+
+# ------
+
+IF(BOOST_IS_MANDATORY STREQUAL 0)
+ SET(BOOST_IS_MANDATORY 0)
+ SET(BOOST_IS_OPTIONAL 1)
+ENDIF(BOOST_IS_MANDATORY STREQUAL 0)
+IF(BOOST_IS_OPTIONAL STREQUAL 0)
+ SET(BOOST_IS_MANDATORY 1)
+ SET(BOOST_IS_OPTIONAL 0)
+ENDIF(BOOST_IS_OPTIONAL STREQUAL 0)
+IF(NOT BOOST_IS_MANDATORY AND NOT BOOST_IS_OPTIONAL)
+ SET(BOOST_IS_MANDATORY 1)
+ SET(BOOST_IS_OPTIONAL 0)
+ENDIF(NOT BOOST_IS_MANDATORY AND NOT BOOST_IS_OPTIONAL)
+
+# ------
+
+SET(BOOST_STATUS 1)
+IF(WITHOUT_BOOST OR WITH_BOOST STREQUAL 0)
+ SET(BOOST_STATUS 0)
+ MESSAGE(STATUS "boost disabled from command line.")
+ENDIF(WITHOUT_BOOST OR WITH_BOOST STREQUAL 0)
+
+# ------
+
+IF(BOOST_STATUS)
+ IF(WITH_BOOST)
+ SET(BOOST_ROOT_USER ${WITH_BOOST})
+ ELSE(WITH_BOOST)
+ SET(BOOST_ROOT_USER $ENV{BOOST_ROOT})
+ IF(NOT BOOST_ROOT_USER)
+ SET(BOOST_ROOT_USER $ENV{BOOSTDIR})
+ ENDIF(NOT BOOST_ROOT_USER)
+ ENDIF(WITH_BOOST)
+ENDIF(BOOST_STATUS)
+
+# -----
+
+IF(BOOST_STATUS)
+ IF(BOOST_ROOT_USER)
+ SET(BOOST_FIND_PATHS_OPTION NO_DEFAULT_PATH)
+ ELSE(BOOST_ROOT_USER)
+ SET(BOOST_FIND_PATHS_OPTION)
+ ENDIF(BOOST_ROOT_USER)
+ENDIF(BOOST_STATUS)
+
+# -----
+
+IF(BOOST_STATUS)
+ IF(BOOST_ROOT_USER)
+ SET(BOOST_INCLUDE_PATHS ${BOOST_ROOT_USER} ${BOOST_ROOT_USER}/include)
+ ELSE(BOOST_ROOT_USER)
+ SET(BOOST_INCLUDE_PATHS)
+ ENDIF(BOOST_ROOT_USER)
+ SET(BOOST_INCLUDE_TO_FIND boost/shared_ptr.hpp)
+ FIND_PATH(BOOST_INCLUDE_DIR ${BOOST_INCLUDE_TO_FIND} PATHS ${BOOST_INCLUDE_PATHS} ${BOOST_FIND_PATHS_OPTION})
+ IF(BOOST_INCLUDE_DIR)
+ IF(BOOST_ROOT_USER)
+ SET(BOOST_CPPFLAGS -I${BOOST_INCLUDE_DIR})
+ ENDIF(BOOST_ROOT_USER)
+ MESSAGE(STATUS "${BOOST_INCLUDE_TO_FIND} found in ${BOOST_INCLUDE_DIR}")
+ ELSE(BOOST_INCLUDE_DIR)
+ SET(BOOST_STATUS 0)
+ IF(BOOST_ROOT_USER)
+ MESSAGE(STATUS "${BOOST_INCLUDE_TO_FIND} not found in ${BOOST_INCLUDE_PATHS}, check your BOOST installation.")
+ ELSE(BOOST_ROOT_USER)
+ MESSAGE(STATUS "${BOOST_INCLUDE_TO_FIND} not found on system, try to use WITH_BOOST option or BOOST_ROOT environment variable.")
+ ENDIF(BOOST_ROOT_USER)
+ ENDIF(BOOST_INCLUDE_DIR)
+ENDIF(BOOST_STATUS)
+
+# ----
+
+IF(BOOST_STATUS)
+ IF(BOOST_ROOT_USER)
+ SET(BOOST_LIB_PATHS ${BOOST_ROOT_USER}/lib)
+ ELSE(BOOST_ROOT_USER)
+ SET(BOOST_LIB_PATHS)
+ ENDIF(BOOST_ROOT_USER)
+ENDIF(BOOST_STATUS)
+
+IF(BOOST_STATUS)
+ SET(BOOST_LIBS)
+ FOREACH(name thread date_time signals filesystem system regex)
+ IF(WINDOWS)
+ IF(CMAKE_BUILD_TYPE STREQUAL Debug)
+ SET(EXTENSION -gd)
+ ELSE(CMAKE_BUILD_TYPE STREQUAL Debug)
+ SET(EXTENSION)
+ ENDIF(CMAKE_BUILD_TYPE STREQUAL Debug)
+ SET(LIB_NAMES)
+ FOREACH(version 1_35 1_38 1_42)
+ SET(LIB_NAMES ${LIB_NAMES} libboost_${name}-vc90-mt${EXTENSION}-${version})
+ ENDFOREACH(version 1_35 1_38 1_42)
+ FIND_LIBRARY(BOOST_LIB_${name} NAMES ${LIB_NAMES} PATHS ${BOOST_LIB_PATHS} ${BOOST_FIND_PATHS_OPTION})
+ ELSE(WINDOWS)
+ FIND_LIBRARY(BOOST_LIB_${name} boost_${name} PATHS ${BOOST_LIB_PATHS} ${BOOST_FIND_PATHS_OPTION})
+ ENDIF(WINDOWS)
+ IF(NOT BOOST_LIB_${name})
+ SET(BOOST_STATUS 0)
+ ENDIF(NOT BOOST_LIB_${name})
+ STRING(TOUPPER ${name} upname)
+ SET(BOOST_LIB_${upname} ${BOOST_LIB_${name}})
+ SET(BOOST_LIBS ${BOOST_LIBS} ${BOOST_LIB_${name}})
+ ENDFOREACH(name thread date_time signals filesystem system)
+ENDIF(BOOST_STATUS)
+
+# ------
+
+IF(BOOST_STATUS)
+ IF(WINDOWS)
+ SET(BOOST_CPPFLAGS ${BOOST_CPPFLAGS} -DBOOST_DISABLE_ASSERTS)
+ ENDIF(WINDOWS)
+ELSE(BOOST_STATUS)
+ IF(BOOST_IS_MANDATORY)
+ MESSAGE(FATAL_ERROR "boost not found ... mandatory ... abort")
+ ELSE(BOOST_IS_MANDATORY)
+ MESSAGE(STATUS "boost not found ... optional ... disabled")
+ ENDIF(BOOST_IS_MANDATORY)
+ENDIF(BOOST_STATUS)
+
+# ------