From f76392f4762e51c0506c1fd1fd18c978f491debf Mon Sep 17 00:00:00 2001
From: open-license-manager <rillf@maildrop.cc>
Date: 周五, 12 9月 2014 03:06:54 +0800
Subject: [PATCH] windows compile

---
 build/modules/add_boost.cmake |  615 ++++++++++++++++++++++++++-----------------------------
 1 files changed, 288 insertions(+), 327 deletions(-)

diff --git a/build/modules/add_boost.cmake b/build/modules/add_boost.cmake
index c3aa699..d8dbd8e 100644
--- a/build/modules/add_boost.cmake
+++ b/build/modules/add_boost.cmake
@@ -1,334 +1,295 @@
 
-#   Boost_INCLUDE_DIRS     - Boost include directories
-#   Boost_LIBRARY_DIRS     - Link directories for Boost libraries
+
+#usage add_boost(	[STATIC] , 
+#					[STATIC_RUNTIME], 
+#					[USE_BOOST_CACHE], #If user wants to use a cache copy of Boost, get the path to this location.
+#					[BOOST_CACHE_DIR path],
+#					[TARGET_ARCHITECHTURE_32],
+#					[MODULES module1, module2] )
+
+#This module will set the following variables
+#   Boost_INCLUDE_DIR      - Boost include directories
+#   Boost_LIBRARY_DIR      - Link directories for Boost libraries
 #   Boost_LIBRARIES        - Boost component libraries to be linked
-#FIXME: for boost find compatibility C must be upper case
 #   Boost_<C>_LIBRARY      - Libraries to link for component <C> (c is lower-case,may include
 #                            target_link_libraries debug/optimized keywords)
 
-function(ms_underscores_to_camel_case VarIn VarOut)
-  string(REPLACE "_" ";" Pieces ${VarIn})
-  foreach(Part ${Pieces})
-    string(SUBSTRING ${Part} 0 1 Initial)
-    string(SUBSTRING ${Part} 1 -1 Part)
-    string(TOUPPER ${Initial} Initial)
-    set(CamelCase ${CamelCase}${Initial}${Part})
-  endforeach()
-  set(${VarOut} ${CamelCase} PARENT_SCOPE)
+include (CMakeParseArguments)
+	
+function(add_boost)
+	set(BoostVersion 1.55.0)
+	set(BoostSHA1 cef9a0cc7084b1d639e06cd3bc34e4251524c840)
+
+	set(options STATIC STATIC_RUNTIME USE_BOOST_CACHE TARGET_ARCHITECHTURE_32)
+    set(oneValueArgs BOOST_CACHE_DIR)
+    set(multiValueArgs MODULES)
+    cmake_parse_arguments(ADD_BOOST "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN} )
+	
+	# Create build folder name derived from version
+	string(REGEX REPLACE "beta\\.([0-9])$" "beta\\1" BoostFolderName ${BoostVersion})
+	string(REPLACE "." "_" BoostFolderName ${BoostFolderName})
+	set(BoostFolderName boost_${BoostFolderName})
+
+	# If user wants to use a cache copy of Boost, get the path to this location.
+	#ADD_BOOST_USE_BOOST_CACHE is a parsed command line parameter
+	if(ADD_BOOST_USE_BOOST_CACHE)
+	  if(ADD_BOOST_BOOST_CACHE_DIR)
+		file(TO_CMAKE_PATH "${BOOST_CACHE_DIR}" BoostCacheDir)
+	  elseif(WIN32)
+		ms_get_temp_dir()
+		set(BoostCacheDir "${TempDir}")
+	  elseif(APPLE)
+		set(BoostCacheDir "$ENV{HOME}/Library/Caches")
+	  else()
+		set(BoostCacheDir "$ENV{HOME}/.cache")
+	  endif()
+	endif()
+
+	# If the cache directory doesn't exist, fall back to use the build root.
+	if(NOT IS_DIRECTORY "${BoostCacheDir}")
+	  if(ADD_BOOST_BOOST_CACHE_DIR)
+		set(Message "\nThe directory \"${ADD_BOOST_BOOST_CACHE_DIR}\" provided in BOOST_CACHE_DIR doesn't exist.")
+		set(Message "${Message}  Falling back to default path at \"${CMAKE_BINARY_DIR}/license++\"\n")
+		message(WARNING "${Message}")
+	  endif()
+	  set(BoostCacheDir ${CMAKE_BINARY_DIR})
+	else()
+	  if(NOT ADD_BOOST_USE_BOOST_CACHE AND NOT ADD_BOOST_BOOST_CACHE_DIR)
+		set(BoostCacheDir "${BoostCacheDir}/license++")
+	  endif()
+	  file(MAKE_DIRECTORY "${BoostCacheDir}")
+	endif()
+
+	# Set up the full path to the source directory
+	set(BoostSourceDir "${BoostFolderName}_${CMAKE_CXX_COMPILER_ID}_${CMAKE_CXX_COMPILER_VERSION}")
+	if(HAVE_LIBC++)
+	  set(BoostSourceDir "${BoostSourceDir}_LibCXX")
+	endif()
+	if(HAVE_LIBC++ABI)
+	  set(BoostSourceDir "${BoostSourceDir}_LibCXXABI")
+	endif()
+	if(CMAKE_CL_64)
+	  set(BoostSourceDir "${BoostSourceDir}_Win64")
+	endif()
+	string(REPLACE "." "_" BoostSourceDir ${BoostSourceDir})
+	set(BOOST_ROOT "${BoostCacheDir}/${BoostSourceDir}" CACHE PATH "BOOST base dir")
+
+	# Check the full path to the source directory is not too long for Windows.  File paths must be less
+	# than MAX_PATH which is 260.  The current longest relative path Boost tries to create is:
+	# Build\boost\bin.v2\libs\program_options\build\fd41f4c7d882e24faa6837508d6e5384\libboost_program_options-vc120-mt-gd-1_55.lib.rsp
+	# which along with a leading separator is 129 chars in length.  This gives a maximum path available
+	# for 'BOOST_ROOT' as 130 chars.
+	if(WIN32)
+	  get_filename_component(BoostSourceDirName "${BOOST_ROOT}" NAME)
+	  string(LENGTH "/${BoostSourceDirName}" BoostSourceDirNameLengthWithSeparator)
+	  math(EXPR AvailableLength 130-${BoostSourceDirNameLengthWithSeparator})
+	  string(LENGTH "${BOOST_ROOT}" BoostSourceDirLength)
+	  if(${BoostSourceDirLength} GREATER 130)
+		set(Msg "\n\nThe path to boost's source is too long to handle all the files which will ")
+		set(Msg "${Msg}be created when boost is built.  To avoid this, set the CMake variable ")
+		set(Msg "${Msg}USE_BOOST_CACHE to ON and set the variable BOOST_CACHE_DIR to a path ")
+		set(Msg "${Msg}which is at most ${AvailableLength} characters long.  For example:\n")
+		set(Msg "${Msg}  mkdir C:\\license_boost\n")
+		set(Msg "${Msg}  cmake . -DUSE_BOOST_CACHE=ON -DBOOST_CACHE_DIR=C:\\license_boost\n\n")
+		message(FATAL_ERROR "${Msg}")
+	  endif()
+	endif()
+
+	# Download boost if required
+	set(ZipFilePath "${BoostCacheDir}/${BoostFolderName}.tar.bz2")
+	if(NOT EXISTS ${ZipFilePath})
+	  message(STATUS "Downloading boost ${BoostVersion} to ${BoostCacheDir}")
+	endif()
+	file(DOWNLOAD http://sourceforge.net/projects/boost/files/boost/${BoostVersion}/${BoostFolderName}.tar.bz2/download
+		 ${ZipFilePath}
+		 STATUS Status
+		 SHOW_PROGRESS
+		 EXPECTED_HASH SHA1=${BoostSHA1}
+		 )
+
+	# Extract boost if required
+	string(FIND "${Status}" "returning early" Found)
+	if(Found LESS 0 OR NOT IS_DIRECTORY "${BOOST_ROOT}")
+	  set(BoostExtractFolder "${BoostCacheDir}/boost_unzip")
+	  file(REMOVE_RECURSE ${BoostExtractFolder})
+	  file(MAKE_DIRECTORY ${BoostExtractFolder})
+	  file(COPY ${ZipFilePath} DESTINATION ${BoostExtractFolder})
+	  message(STATUS "Extracting boost ${BoostVersion} to ${BoostExtractFolder}")
+	  execute_process(COMMAND ${CMAKE_COMMAND} -E tar xfz ${BoostFolderName}.tar.bz2
+					  WORKING_DIRECTORY ${BoostExtractFolder}
+					  RESULT_VARIABLE Result
+					  )
+	  if(NOT Result EQUAL 0)
+		message(FATAL_ERROR "Failed extracting boost ${BoostVersion} to ${BoostExtractFolder}")
+	  endif()
+	  file(REMOVE ${BoostExtractFolder}/${BoostFolderName}.tar.bz2)
+
+	  # Get the path to the extracted folder
+	  file(GLOB ExtractedDir "${BoostExtractFolder}/*")
+	  list(LENGTH ExtractedDir n)
+	  if(NOT n EQUAL 1 OR NOT IS_DIRECTORY ${ExtractedDir})
+		message(FATAL_ERROR "Failed extracting boost ${BoostVersion} to ${BoostExtractFolder}")
+	  endif()
+	  file(RENAME ${ExtractedDir} ${BOOST_ROOT})
+	  file(REMOVE_RECURSE ${BoostExtractFolder})
+	endif()
+
+
+	# Build b2 (bjam) if required
+	find_program(b2Path NAMES b2 PATHS ${BOOST_ROOT} NO_DEFAULT_PATH)
+	if(NOT b2Path)
+	  message(STATUS "Building b2 (bjam)")
+	  if(MSVC)
+		set(b2Bootstrap "bootstrap.bat")
+	  else()
+		set(b2Bootstrap "./bootstrap.sh")
+		if(${CMAKE_CXX_COMPILER_ID} STREQUAL "Clang")
+		  list(APPEND b2Bootstrap --with-toolset=clang)
+		elseif(${CMAKE_CXX_COMPILER_ID} STREQUAL "GNU")
+		  list(APPEND b2Bootstrap --with-toolset=gcc)
+		endif()
+	  endif()
+	  execute_process(COMMAND ${b2Bootstrap} WORKING_DIRECTORY ${BOOST_ROOT}
+					  RESULT_VARIABLE Result OUTPUT_VARIABLE Output ERROR_VARIABLE Error)
+	  find_program(b2Path NAMES b2 PATHS ${BOOST_ROOT} NO_DEFAULT_PATH)
+	  if(NOT Result EQUAL 0 OR NOT b2Path)
+		message(FATAL_ERROR "Failed running ${b2Bootstrap}:\n${Output}\n${Error}\n")
+	  endif()
+	endif()
+	execute_process(COMMAND ${CMAKE_COMMAND} -E make_directory ${BOOST_ROOT}/Build)
+
+	#ADD_BOOST_STATIC_RUNTIME is a parsed function parameter
+	if(ADD_BOOST_STATIC_RUNTIME)
+		set(RUNTIME_LINK "static")
+		set(BOOST_LIB_SUFFIX "-s")
+		set(Boost_USE_STATIC_RUNTIME ON)
+	else()
+		set(RUNTIME_LINK "shared")
+		set(BOOST_LIB_SUFFIX "")
+		set(Boost_USE_STATIC_RUNTIME OFF)
+	endif()
+	#ADD_BOOST_STATIC is a parsed function parameter
+	if(ADD_BOOST_STATIC)
+		set(BOOST_LINK "static")
+		set(LINUX_LIB_EXTENSION "a")
+		set(WINDOWS_LIB_PREFIX "lib")
+		set(Boost_USE_STATIC_LIBS ON)
+	else(ADD_BOOST_STATIC)
+		set(BOOST_LINK "shared")
+		set(LINUX_LIB_EXTENSION "so")
+		set(WINDOWS_LIB_PREFIX "")
+		set(Boost_USE_STATIC_LIBS OFF)
+	endif(ADD_BOOST_STATIC)
+	message(STATUS "Boost linking: libs ${BOOST_LINK} , C++ runtime ${RUNTIME_LINK}")
+	# Set up general b2 (bjam) command line arguments
+	set(b2Args ./b2
+			   link=${BOOST_LINK}
+			   threading=multi
+			   runtime-link=${RUNTIME_LINK}
+			   --build-dir=Build
+			   stage
+			   -d+2
+			   --hash
+			   )
+	if("${CMAKE_BUILD_TYPE}" STREQUAL "ReleaseNoInline")
+	  list(APPEND b2Args cxxflags="${RELEASENOINLINE_FLAGS}")
+	endif()
+	if("${CMAKE_BUILD_TYPE}" STREQUAL "DebugLibStdcxx")
+	  list(APPEND b2Args define=_GLIBCXX_DEBUG)
+	endif()
+
+	# Set up platform-specific b2 (bjam) command line arguments
+	if(MSVC)
+	  if(MSVC11)
+		list(APPEND b2Args toolset=msvc-11.0)
+	  elseif(MSVC12)
+		list(APPEND b2Args toolset=msvc-12.0)
+	  endif()
+	  list(APPEND b2Args
+				  define=_BIND_TO_CURRENT_MFC_VERSION=1
+				  define=_BIND_TO_CURRENT_CRT_VERSION=1
+				  --layout=versioned
+				  )
+		#command line parameter
+		if(NOT ADD_BOOST_TARGET_ARCHITECHTURE_32)
+			list(APPEND b2Args address-model=64)
+		endif()
+	elseif(APPLE)
+		list(APPEND b2Args variant=release toolset=clang cxxflags=-fPIC cxxflags=-std=c++11 cxxflags=-stdlib=libc++
+						 linkflags=-stdlib=libc++ architecture=combined address-model=32_64 --layout=tagged)
+	elseif(UNIX)
+	  list(APPEND b2Args variant=release cxxflags=-fPIC cxxflags=-std=c++11 -sNO_BZIP2=1 --layout=tagged)
+	  # Need to configure the toolset based on whatever version CMAKE_CXX_COMPILER is
+	  string(REGEX MATCH "[0-9]+\\.[0-9]+" ToolsetVer "${CMAKE_CXX_COMPILER_VERSION}")
+	  if(${CMAKE_CXX_COMPILER_ID} STREQUAL "Clang")
+		list(APPEND b2Args toolset=clang-${ToolsetVer})
+		if(HAVE_LIBC++)
+		  list(APPEND b2Args cxxflags=-stdlib=libc++ linkflags=-stdlib=libc++)
+		endif()
+	  elseif(${CMAKE_CXX_COMPILER_ID} STREQUAL "GNU")
+		list(APPEND b2Args toolset=gcc-${ToolsetVer})
+	  endif()
+	endif()
+
+	if(NOT ADD_BOOST_MODULES)
+		set (ADD_BOOST_MODULES atomic chrono context coroutine date_time exception filesystem
+				graph iostreams log math program_options python random regex signals system 
+				test thread timer wave)
+	endif()
+	
+	foreach(Component ${ADD_BOOST_MODULES})
+	  if(${Component} STREQUAL "test")
+		set(libName "unit_test_framework")
+	  elseif(${Component} STREQUAL "math")
+		set(libName "math_c99l")
+	  else()	
+		set(libName ${Component})
+	  endif()
+	  if(MSVC)
+		if(MSVC11)
+		  set(CompilerName vc110)
+		elseif(MSVC12)
+		  set(CompilerName vc120)
+		endif()
+		string(REGEX MATCH "[0-9]_[0-9][0-9]" Version "${BoostFolderName}")	
+		#http://www.boost.org/doc/libs/1_42_0/more/getting_started/windows.html#library-naming
+		set(OUTPUT_FILE ${BOOST_ROOT}/stage/lib/${WINDOWS_LIB_PREFIX}boost_${libName}-${CompilerName}-mt-${Version}.lib)
+		set(OUTPUT_FILE_DEBUG ${BOOST_ROOT}/stage/lib/${WINDOWS_LIB_PREFIX}boost_${libName}-${CompilerName}-mt-gd-${Version}.lib)
+	  else(MSVC)
+			set(OUTPUT_FILE ${BOOST_ROOT}/stage/lib/libboost_${libName}-mt${BOOST_LIB_SUFFIX}.${LINUX_LIB_EXTENSION})
+	  endif(MSVC)
+	  #if(NOT EXISTS "${OUTPUT_FILE}")
+		  message(STATUS "Building ${Component}: ${b2Args}")
+		  execute_process(COMMAND ${b2Args} --with-${Component} WORKING_DIRECTORY ${BOOST_ROOT} RESULT_VARIABLE Result OUTPUT_VARIABLE Output ERROR_VARIABLE Error)
+		  if(NOT Result EQUAL 0)
+			message(ERROR "Failed running ${b2Args} --with-${Component}:\n${Output}\n${Error}\n")
+		  endif()
+	  #endif()
+	endforeach()
+	
+	
+	LIST_REPLACE(ADD_BOOST_MODULES "test" "unit_test_framework")   
+	#   BOOST_ROOT             - Preferred installation prefix
+	#    (or BOOSTROOT)
+	#   BOOST_INCLUDEDIR       - Preferred include directory e.g. <prefix>/include
+	#   BOOST_LIBRARYDIR       - Preferred library directory e.g. <prefix>/lib
+	#   Boost_NO_SYSTEM_PATHS  - Set to ON to disable searching in locations not
+	#                            specified by these hint variables. Default is OFF.
+	set (BOOST_LIBRARYDIR ${BOOST_ROOT}/stage/lib CACHE PATH "BOOST library dir")
+	#set (Boost_NO_SYSTEM_PATHS ON)
+	find_package(Boost 1.55 REQUIRED COMPONENTS ${ADD_BOOST_MODULES})
+	#clean up variables
+	mark_as_advanced (BOOST_ROOT BOOST_LIBRARYDIR)
+	unset(b2Path CACHE)
+	
+	set(Boost_LIBRARIES ${Boost_LIBRARIES} PARENT_SCOPE)
 endfunction()
 
-set(BoostVersion 1.55.0)
-set(BoostSHA1 cef9a0cc7084b1d639e06cd3bc34e4251524c840)
-
-# Create build folder name derived from version
-string(REGEX REPLACE "beta\\.([0-9])$" "beta\\1" BoostFolderName ${BoostVersion})
-string(REPLACE "." "_" BoostFolderName ${BoostFolderName})
-set(BoostFolderName boost_${BoostFolderName})
-
-# If user wants to use a cache copy of Boost, get the path to this location.
-if(USE_BOOST_CACHE)
-  if(BOOST_CACHE_DIR)
-    file(TO_CMAKE_PATH "${BOOST_CACHE_DIR}" BoostCacheDir)
-  elseif(WIN32)
-    ms_get_temp_dir()
-    set(BoostCacheDir "${TempDir}")
-  elseif(APPLE)
-    set(BoostCacheDir "$ENV{HOME}/Library/Caches")
-  else()
-    set(BoostCacheDir "$ENV{HOME}/.cache")
-  endif()
-endif()
-
-# If the cache directory doesn't exist, fall back to use the build root.
-if(NOT IS_DIRECTORY "${BoostCacheDir}")
-  if(BOOST_CACHE_DIR)
-    set(Message "\nThe directory \"${BOOST_CACHE_DIR}\" provided in BOOST_CACHE_DIR doesn't exist.")
-    set(Message "${Message}  Falling back to default path at \"${CMAKE_BINARY_DIR}/license++\"\n")
-    message(WARNING "${Message}")
-  endif()
-  set(BoostCacheDir ${CMAKE_BINARY_DIR})
-else()
-  if(NOT USE_BOOST_CACHE AND NOT BOOST_CACHE_DIR)
-    set(BoostCacheDir "${BoostCacheDir}/license++")
-  endif()
-  file(MAKE_DIRECTORY "${BoostCacheDir}")
-endif()
-
-# Set up the full path to the source directory
-set(BoostSourceDir "${BoostFolderName}_${CMAKE_CXX_COMPILER_ID}_${CMAKE_CXX_COMPILER_VERSION}")
-if(HAVE_LIBC++)
-  set(BoostSourceDir "${BoostSourceDir}_LibCXX")
-endif()
-if(HAVE_LIBC++ABI)
-  set(BoostSourceDir "${BoostSourceDir}_LibCXXABI")
-endif()
-if(CMAKE_CL_64)
-  set(BoostSourceDir "${BoostSourceDir}_Win64")
-endif()
-string(REPLACE "." "_" BoostSourceDir ${BoostSourceDir})
-set(BoostSourceDir "${BoostCacheDir}/${BoostSourceDir}")
-
-# Check the full path to the source directory is not too long for Windows.  File paths must be less
-# than MAX_PATH which is 260.  The current longest relative path Boost tries to create is:
-# Build\boost\bin.v2\libs\program_options\build\fd41f4c7d882e24faa6837508d6e5384\libboost_program_options-vc120-mt-gd-1_55.lib.rsp
-# which along with a leading separator is 129 chars in length.  This gives a maximum path available
-# for 'BoostSourceDir' as 130 chars.
-if(WIN32)
-  get_filename_component(BoostSourceDirName "${BoostSourceDir}" NAME)
-  string(LENGTH "/${BoostSourceDirName}" BoostSourceDirNameLengthWithSeparator)
-  math(EXPR AvailableLength 130-${BoostSourceDirNameLengthWithSeparator})
-  string(LENGTH "${BoostSourceDir}" BoostSourceDirLength)
-  if(${BoostSourceDirLength} GREATER 130)
-    set(Msg "\n\nThe path to boost's source is too long to handle all the files which will ")
-    set(Msg "${Msg}be created when boost is built.  To avoid this, set the CMake variable ")
-    set(Msg "${Msg}USE_BOOST_CACHE to ON and set the variable BOOST_CACHE_DIR to a path ")
-    set(Msg "${Msg}which is at most ${AvailableLength} characters long.  For example:\n")
-    set(Msg "${Msg}  mkdir C:\\license_boost\n")
-    set(Msg "${Msg}  cmake . -DUSE_BOOST_CACHE=ON -DBOOST_CACHE_DIR=C:\\license_boost\n\n")
-    message(FATAL_ERROR "${Msg}")
-  endif()
-endif()
-
-# Download boost if required
-set(ZipFilePath "${BoostCacheDir}/${BoostFolderName}.tar.bz2")
-if(NOT EXISTS ${ZipFilePath})
-  message(STATUS "Downloading boost ${BoostVersion} to ${BoostCacheDir}")
-endif()
-file(DOWNLOAD http://sourceforge.net/projects/boost/files/boost/${BoostVersion}/${BoostFolderName}.tar.bz2/download
-     ${ZipFilePath}
-     STATUS Status
-     SHOW_PROGRESS
-     EXPECTED_HASH SHA1=${BoostSHA1}
-     )
-
-# Extract boost if required
-string(FIND "${Status}" "returning early" Found)
-if(Found LESS 0 OR NOT IS_DIRECTORY "${BoostSourceDir}")
-  set(BoostExtractFolder "${BoostCacheDir}/boost_unzip")
-  file(REMOVE_RECURSE ${BoostExtractFolder})
-  file(MAKE_DIRECTORY ${BoostExtractFolder})
-  file(COPY ${ZipFilePath} DESTINATION ${BoostExtractFolder})
-  message(STATUS "Extracting boost ${BoostVersion} to ${BoostExtractFolder}")
-  execute_process(COMMAND ${CMAKE_COMMAND} -E tar xfz ${BoostFolderName}.tar.bz2
-                  WORKING_DIRECTORY ${BoostExtractFolder}
-                  RESULT_VARIABLE Result
-                  )
-  if(NOT Result EQUAL 0)
-    message(FATAL_ERROR "Failed extracting boost ${BoostVersion} to ${BoostExtractFolder}")
-  endif()
-  file(REMOVE ${BoostExtractFolder}/${BoostFolderName}.tar.bz2)
-
-  # Get the path to the extracted folder
-  file(GLOB ExtractedDir "${BoostExtractFolder}/*")
-  list(LENGTH ExtractedDir n)
-  if(NOT n EQUAL 1 OR NOT IS_DIRECTORY ${ExtractedDir})
-    message(FATAL_ERROR "Failed extracting boost ${BoostVersion} to ${BoostExtractFolder}")
-  endif()
-  file(RENAME ${ExtractedDir} ${BoostSourceDir})
-  file(REMOVE_RECURSE ${BoostExtractFolder})
-endif()
-
-
-# Build b2 (bjam) if required
-unset(b2Path CACHE)
-find_program(b2Path NAMES b2 PATHS ${BoostSourceDir} NO_DEFAULT_PATH)
-if(NOT b2Path)
-  message(STATUS "Building b2 (bjam)")
-  if(MSVC)
-    set(b2Bootstrap "bootstrap.bat")
-  else()
-    set(b2Bootstrap "./bootstrap.sh")
-    if(${CMAKE_CXX_COMPILER_ID} STREQUAL "Clang")
-      list(APPEND b2Bootstrap --with-toolset=clang)
-    elseif(${CMAKE_CXX_COMPILER_ID} STREQUAL "GNU")
-      list(APPEND b2Bootstrap --with-toolset=gcc)
-    endif()
-  endif()
-  execute_process(COMMAND ${b2Bootstrap} WORKING_DIRECTORY ${BoostSourceDir}
-                  RESULT_VARIABLE Result OUTPUT_VARIABLE Output ERROR_VARIABLE Error)
-  if(NOT Result EQUAL 0)
-    message(FATAL_ERROR "Failed running ${b2Bootstrap}:\n${Output}\n${Error}\n")
-  endif()
-endif()
-execute_process(COMMAND ${CMAKE_COMMAND} -E make_directory ${BoostSourceDir}/Build)
-
-
-# Expose BoostSourceDir to parent scope
-#set(BoostSourceDir ${BoostSourceDir} ) #PARENT_SCOPE
-if(Boost_USE_STATIC_RUNTIME)
-    set(RUNTIME_LINK "static")
-    set(BOOST_LIB_SUFFIX "-s")
-else()
-    set(RUNTIME_LINK "shared")
-    set(BOOST_LIB_SUFFIX "")
-endif()
-if(Boost_USE_STATIC_LIBS)
-    set(BOOST_LINK "static")
-    set(BOOST_LIB_EXTENSION "a")
-else()
-    set(BOOST_LINK "shared")
-    set(BOOST_LIB_EXTENSION "so")
-endif()
-
-# Set up general b2 (bjam) command line arguments
-set(b2Args ./b2
-           link=${BOOST_LINK}
-           threading=multi
-           runtime-link=${RUNTIME_LINK}
-           --build-dir=Build
-           stage
-           -d+2
-           --hash
-           )
-if("${CMAKE_BUILD_TYPE}" STREQUAL "ReleaseNoInline")
-  list(APPEND b2Args cxxflags="${RELEASENOINLINE_FLAGS}")
-endif()
-if("${CMAKE_BUILD_TYPE}" STREQUAL "DebugLibStdcxx")
-  list(APPEND b2Args define=_GLIBCXX_DEBUG)
-endif()
-
-# Set up platform-specific b2 (bjam) command line arguments
-if(MSVC)
-  if(MSVC11)
-    list(APPEND b2Args toolset=msvc-11.0)
-  elseif(MSVC12)
-    list(APPEND b2Args toolset=msvc-12.0)
-  endif()
-  list(APPEND b2Args
-              define=_BIND_TO_CURRENT_MFC_VERSION=1
-              define=_BIND_TO_CURRENT_CRT_VERSION=1
-              --layout=versioned
-              )
-  if("${TargetArchitecture}" STREQUAL "x86_64")
-    list(APPEND b2Args address-model=64)
-  endif()
-elseif(APPLE)
-  list(APPEND b2Args variant=release toolset=clang cxxflags=-fPIC cxxflags=-std=c++11 cxxflags=-stdlib=libc++
-                     linkflags=-stdlib=libc++ architecture=combined address-model=32_64 --layout=tagged)
-elseif(UNIX)
-  list(APPEND b2Args variant=release cxxflags=-fPIC cxxflags=-std=c++11 -sNO_BZIP2=1 --layout=tagged)
-  # Need to configure the toolset based on whatever version CMAKE_CXX_COMPILER is
-  string(REGEX MATCH "[0-9]+\\.[0-9]+" ToolsetVer "${CMAKE_CXX_COMPILER_VERSION}")
-  if(${CMAKE_CXX_COMPILER_ID} STREQUAL "Clang")
-    list(APPEND b2Args toolset=clang-${ToolsetVer})
-    if(HAVE_LIBC++)
-      list(APPEND b2Args cxxflags=-stdlib=libc++ linkflags=-stdlib=libc++)
-    endif()
-  elseif(${CMAKE_CXX_COMPILER_ID} STREQUAL "GNU")
-    list(APPEND b2Args toolset=gcc-${ToolsetVer})
-  endif()
-endif()
-
-# Get list of components
-execute_process(COMMAND ./b2 --show-libraries WORKING_DIRECTORY ${BoostSourceDir}
-                ERROR_QUIET OUTPUT_VARIABLE Output)
-string(REGEX REPLACE "(^[^:]+:|[- ])" "" BoostComponents "${Output}")
-string(REGEX REPLACE "\n" ";" BoostComponents "${BoostComponents}")
-
-# Build each required component
-include(ExternalProject)
-foreach(Component ${BoostComponents})
-  ms_underscores_to_camel_case(${Component} CamelCaseComponent)
-  if(${Boost_USE_STATIC_LIBS})
-      add_library(boost_${Component} STATIC IMPORTED GLOBAL)
-  else(${Boost_USE_STATIC_LIBS})
-      add_library(boost_${Component} SHARED IMPORTED GLOBAL)
-  endif(${Boost_USE_STATIC_LIBS})
-  if(${Component} STREQUAL "test")
-      set(LibName "unit_test_framework")
-  else()
-      set(LibName ${Component})  
-  endif()
-  if(MSVC)
-    if(MSVC11)
-      set(CompilerName vc110)
-    elseif(MSVC12)
-      set(CompilerName vc120)
-    endif()
-    ExternalProject_Add(
-          Boost${CamelCaseComponent}
-          PREFIX ${CMAKE_BINARY_DIR}/${BoostFolderName}
-          SOURCE_DIR ${BoostSourceDir}
-          BINARY_DIR ${BoostSourceDir}
-          CONFIGURE_COMMAND ""
-          BUILD_COMMAND "${b2Args}" --with-${Component}
-          INSTALL_COMMAND ""
-          LOG_BUILD ON )
-    
-    string(REGEX MATCH "[0-9]_[0-9][0-9]" Version "${BoostFolderName}")
-    set_target_properties(boost_${Component} PROPERTIES
-                          IMPORTED_LOCATION_DEBUG ${BoostSourceDir}/stage/lib/libboost_${Component}-${CompilerName}-mt-gd-${Version}.lib
-                          IMPORTED_LOCATION_MINSIZEREL ${BoostSourceDir}/stage/lib/libboost_${Component}-${CompilerName}-mt-${Version}.lib
-                          IMPORTED_LOCATION_RELEASE ${BoostSourceDir}/stage/lib/libboost_${Component}-${CompilerName}-mt-${Version}.lib
-                          IMPORTED_LOCATION_RELWITHDEBINFO ${BoostSourceDir}/stage/lib/libboost_${Component}-${CompilerName}-mt-${Version}.lib
-                          IMPORTED_LOCATION_RELEASENOINLINE ${BoostSourceDir}/stage/lib/libboost_${Component}-${CompilerName}-mt-${Version}.lib
-                          LINKER_LANGUAGE CXX)
-  else(MSVC)
-        set(OUTPUT_FILE ${BoostSourceDir}/stage/lib/libboost_${LibName}-mt${BOOST_LIB_SUFFIX}.${BOOST_LIB_EXTENSION})
-        add_custom_command(OUTPUT ${OUTPUT_FILE}
-                   COMMAND ${b2Args} --with-${Component}
-                   WORKING_DIRECTORY ${BoostSourceDir}
-                   )
-        add_custom_target(Boost${CamelCaseComponent} 
-            DEPENDS ${OUTPUT_FILE} 
-            WORKING_DIRECTORY ${BoostSourceDir})      
-        set_target_properties(boost_${Component} PROPERTIES
-                          IMPORTED_LOCATION ${OUTPUT_FILE}
-                          #LINK_SEARCH_START_STATIC OFF
-                          LINKER_LANGUAGE CXX
-                          )
-  endif(MSVC)
-  set_target_properties(boost_${Component} Boost${CamelCaseComponent} PROPERTIES
-                        LABELS Boost FOLDER "Boost" EXCLUDE_FROM_ALL TRUE)
-  add_dependencies(boost_${Component} Boost${CamelCaseComponent})
-  set(Boost_${Component}_LIBRARY boost_${Component})
-  if("${Component}" STREQUAL "locale")
-    if(APPLE)
-      find_library(IconvLib iconv)
-      if(NOT IconvLib)
-        message(FATAL_ERROR "libiconv.dylib must be installed to a standard location.")
-      endif()
-      set(Boost_${Component}_LIBRARY boost_${Component} ${IconvLib})
-    elseif(UNIX)
-      if(BSD)
-        find_library(IconvLib libiconv.a)
-        if(NOT IconvLib)
-          set(Msg "libiconv.a must be installed to a standard location.")
-          set(Msg "  For ${Msg} on FreeBSD 10 or later, run\n  pkg install libiconv")
-          message(FATAL_ERROR "${Msg}")
-        endif()
-        set(Boost_${Component}_LIBRARY boost_${Component} ${IconvLib})
-      else()
-        find_library(Icui18nLib libicui18n.a)
-        find_library(IcuucLib libicuuc.a)
-        find_library(IcudataLib libicudata.a)
-        if(NOT Icui18nLib OR NOT IcuucLib OR NOT IcudataLib)
-          set(Msg "libicui18n.a, libicuuc.a & licudata.a must be installed to a standard location.")
-          set(Msg "  For ${Msg} on Ubuntu/Debian, run\n  sudo apt-get install libicu-dev")
-          message(FATAL_ERROR "${Msg}")
-        endif()
-        set(Boost_${Component}_LIBRARY boost_${Component} ${Icui18nLib} ${IcuucLib} ${IcudataLib})
-      endif()
-    else()
-      set(Boost_${Component}_LIBRARY boost_${Component})
-    endif()
-  endif()
-  #set(Boost${CamelCaseComponent}Libs ${Boost${CamelCaseComponent}Libs}) # PARENT_SCOPE
-  list(APPEND Boost_LIBRARIES Boost_${Component}_LIBRARY)
-endforeach()
-#set(AllBoostLibs ${AllBoostLibs}) # PARENT_SCOPE
-add_dependencies(BoostChrono BoostSystem)
-add_dependencies(BoostCoroutine BoostContext BoostSystem)
-add_dependencies(BoostFilesystem BoostSystem)
-add_dependencies(BoostGraph BoostRegex)
-add_dependencies(BoostLocale BoostSystem)
-add_dependencies(BoostLog BoostChrono BoostDateTime BoostFilesystem BoostThread)
-add_dependencies(BoostThread BoostChrono)
-add_dependencies(BoostTimer BoostChrono)
-add_dependencies(BoostWave BoostChrono BoostDateTime BoostFilesystem BoostThread)
-
-set(Boost_INCLUDE_DIRS ${BoostSourceDir})
-set(Boost_LIBRARY_DIRS ${BoostSourceDir}/stage/lib)
-
-
-
+macro(LIST_REPLACE LIST OLDVALUE NEWVALUE)
+    list(FIND ADD_BOOST_MODULES ${OLDVALUE} find_idx)                                    
+    if(find_idx GREATER -1)                                                    
+		list(INSERT ${LIST} ${find_idx} ${NEWVALUE})
+		MATH(EXPR __INDEX "${find_idx} + 1")
+		list (REMOVE_AT ${LIST} ${__INDEX})
+	endif()       
+endmacro(LIST_REPLACE)                          

--
Gitblit v1.9.1