CMakeLists.txt 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. ##########################################################################
  2. # CMake Build Rules for Boost #
  3. ##########################################################################
  4. # Copyright (C) 2007, 2008 Douglas Gregor <doug.gregor@gmail.com> #
  5. # Copyright (C) 2007 Troy Straszheim #
  6. # #
  7. # Distributed under the Boost Software License, Version 1.0. #
  8. # See accompanying file LICENSE_1_0.txt or copy at #
  9. # http://www.boost.org/LICENSE_1_0.txt #
  10. ##########################################################################
  11. # Basic Usage: #
  12. # #
  13. # On Unix variants: #
  14. # ccmake BOOST_DIRECTORY #
  15. # #
  16. # (c)onfigure options to your liking, then (g)enerate #
  17. # makefiles. Use "make" to build, "make test" to test, "make #
  18. # install" to install, and "make package" to build binary #
  19. # packages. #
  20. # #
  21. # On Windows: #
  22. # run the CMake GNU, load the Boost directory, and generate #
  23. # project files or makefiles for your environment. #
  24. # #
  25. # For more information about CMake, see http://www.cmake.org #
  26. ##########################################################################
  27. cmake_minimum_required(VERSION 2.6.0 FATAL_ERROR)
  28. project(Boost)
  29. ##########################################################################
  30. # Post a warning to those attempting to use the CMake Build system. When #
  31. # the build system stabilizes this can be removed. #
  32. ##########################################################################
  33. if (NOT CMAKE_IS_EXPERIMENTAL)
  34. message(STATUS "##########################################################################")
  35. message(STATUS " THE CMAKE BUILD SYSTEM IS CURRENTLY UNDER DEVELOPMENT. PLEASE USE THE ")
  36. message(STATUS " BJAM BASED SYSTEM INSTEAD TO BUILD A PRODUCTION VERSION OF BOOST. IF YOU ")
  37. message(STATUS " STILL WANT TO TRY IT OUT INVOKE CMake WITH '-DCMAKE_IS_EXPERIMENTAL:boolean=TRUE'")
  38. message(STATUS " ARGUMENT. After this first run of cmake you will no longer have to supply")
  39. message(STATUS " the argument unless you need to run a cmake on a clean build directory.")
  40. message(STATUS "##########################################################################")
  41. message(FATAL_ERROR "")
  42. endif (NOT CMAKE_IS_EXPERIMENTAL)
  43. ##########################################################################
  44. # Version information #
  45. ##########################################################################
  46. set(BOOST_VERSION_MAJOR 1)
  47. set(BOOST_VERSION_MINOR 37)
  48. set(BOOST_VERSION_SUBMINOR 0)
  49. set(BOOST_VERSION "${BOOST_VERSION_MAJOR}.${BOOST_VERSION_MINOR}.${BOOST_VERSION_SUBMINOR}")
  50. ##########################################################################
  51. # Put the libaries and binaries that get built into directories at the
  52. # top of the build tree rather than in hard-to-find leaf
  53. # directories. This simplifies manual testing and the use of the build
  54. # tree rather than installed Boost libraries.
  55. SET(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib)
  56. SET(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin)
  57. SET(CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib)
  58. ##########################################################################
  59. # Boost CMake modules #
  60. ##########################################################################
  61. list(APPEND CMAKE_MODULE_PATH ${Boost_SOURCE_DIR}/tools/build/CMake)
  62. include(BoostUtils)
  63. include(BoostConfig)
  64. include(BoostBuildSlave)
  65. include(BoostCore)
  66. include(BoostDocs)
  67. include(BoostTesting)
  68. ##########################################################################
  69. ##########################################################################
  70. # Build Features and Variants #
  71. ##########################################################################
  72. # Determine default settings for the variable BUILD_feature options
  73. if (MSVC)
  74. set(BUILD_SINGLE_THREADED_DEFAULT OFF)
  75. else ()
  76. set(BUILD_SINGLE_THREADED_DEFAULT OFF)
  77. endif ()
  78. # User-level options deciding which variants we will build.
  79. option(BUILD_STATIC "Whether to build static libraries" ON)
  80. option(BUILD_SHARED "Whether to build shared libraries" ON)
  81. option(BUILD_DEBUG "Whether to build debugging libraries" ON)
  82. option(BUILD_RELEASE "Whether to build release libraries" ON)
  83. option(BUILD_SINGLE_THREADED "Whether to build single-threaded libraries"
  84. ${BUILD_SINGLE_THREADED_DEFAULT})
  85. option(BUILD_MULTI_THREADED "Whether to build multi-threaded libraries" ON)
  86. # For now, we only actually support static/dynamic run-time variants for
  87. # Visual C++. Provide both options for Visual C++ users, but just fix
  88. # the values of the variables for all other platforms.
  89. if(MSVC)
  90. option(BUILD_STATIC_RUNTIME "Whether to build libraries linking against the static runtime" ON)
  91. option(BUILD_DYNAMIC_RUNTIME "Whether to build libraries linking against the dynamic runtime" ON)
  92. else(MSVC)
  93. set(BUILD_STATIC_RUNTIME OFF)
  94. set(BUILD_DYNAMIC_RUNTIME ON)
  95. endif(MSVC)
  96. # The default set of library variants that we will be building
  97. boost_add_default_variant(RELEASE DEBUG)
  98. boost_add_default_variant(STATIC SHARED)
  99. boost_add_default_variant(SINGLE_THREADED MULTI_THREADED)
  100. boost_add_default_variant(DYNAMIC_RUNTIME STATIC_RUNTIME)
  101. # Extra features used by some libraries
  102. set(BUILD_PYTHON_NODEBUG ON)
  103. boost_add_extra_variant(PYTHON_NODEBUG PYTHON_DEBUG)
  104. ##########################################################################
  105. ##########################################################################
  106. # Installation #
  107. ##########################################################################
  108. if(BOOST_VERSION_SUBMINOR GREATER 0)
  109. set(BOOST_HEADER_DIR
  110. "include/boost-${BOOST_VERSION_MAJOR}_${BOOST_VERSION_MINOR}_${BOOST_VERSION_SUBMINOR}")
  111. else(BOOST_VERSION_SUBMINOR GREATER 0)
  112. set(BOOST_HEADER_DIR
  113. "include/boost-${BOOST_VERSION_MAJOR}_${BOOST_VERSION_MINOR}")
  114. endif(BOOST_VERSION_SUBMINOR GREATER 0)
  115. install(DIRECTORY boost
  116. DESTINATION ${BOOST_HEADER_DIR}
  117. PATTERN "CVS" EXCLUDE
  118. PATTERN ".svn" EXCLUDE)
  119. #
  120. # TDS 20080526: Getting a segfault here even with the ifs. At r45780, with these lines
  121. # uncommented:
  122. # 1. cmake the workspace
  123. # 2. run ccmake and turn OFF BUILD_MULTI_THREADED and BUILD_SHARED
  124. # 3. 'c' to configure
  125. # 4. 'g' to generate.... segfault.
  126. # 5. run rebuild_cache at the command line: no segfault this time.
  127. #
  128. # With these lines commented out, step 4 above does not segfault.
  129. #
  130. #if (NOT TEST_INSTALLED_TREE)
  131. # If I don't have if around this, I get a seg fault
  132. # install(EXPORT boost-targets DESTINATION "lib/Boost${BOOST_VERSION}")
  133. #endif (NOT TEST_INSTALLED_TREE)
  134. ##########################################################################
  135. ##########################################################################
  136. # Binary packages #
  137. ##########################################################################
  138. set(CPACK_PACKAGE_NAME "Boost")
  139. set(CPACK_PACKAGE_VENDOR "Boost.org")
  140. set(CPACK_PACKAGE_DESCRIPTION_SUMMARY "Boost ${BOOST_VERSION}")
  141. set(CPACK_PACKAGE_DESCRIPTION_FILE "${Boost_SOURCE_DIR}/README.txt")
  142. set(CPACK_RESOURCE_FILE_README "${Boost_SOURCE_DIR}/README.txt")
  143. set(CPACK_RESOURCE_FILE_LICENSE "${Boost_SOURCE_DIR}/LICENSE_1_0.txt")
  144. set(CPACK_RESOURCE_FILE_WELCOME "${Boost_SOURCE_DIR}/Welcome.txt")
  145. set(CPACK_PACKAGE_VERSION "${BOOST_VERSION}")
  146. set(CPACK_PACKAGE_VERSION_MAJOR "${BOOST_VERSION_MAJOR}")
  147. set(CPACK_PACKAGE_VERSION_MINOR "${BOOST_VERSION_MINOR}")
  148. set(CPACK_PACKAGE_VERSION_PATCH "${BOOST_VERSION_SUBMINOR}")
  149. set(CPACK_PACKAGE_INSTALL_DIRECTORY "Boost")
  150. if(WIN32 AND NOT UNIX)
  151. # There is a bug in NSI that does not handle full unix paths properly. Make
  152. # sure there is at least one set of four (4) backlasshes.
  153. # NOTE: No Boost icon yet
  154. # set(CPACK_PACKAGE_ICON "${Boost_SOURCE_DIR}/tools/build/CMake\\\\InstallIcon.bmp")
  155. # set(CPACK_NSIS_INSTALLED_ICON_NAME "bin\\\\MyExecutable.exe")
  156. set(CPACK_NSIS_DISPLAY_NAME "Boost ${BOOST_VERSION_MAJOR}.${BOOST_VERSION_MINOR}.${BOOST_VERSION_SUBMINOR}")
  157. set(CPACK_NSIS_HELP_LINK "http:\\\\\\\\www.boost.org")
  158. set(CPACK_NSIS_URL_INFO_ABOUT "http:\\\\\\\\www.boost.org")
  159. set(CPACK_NSIS_CONTACT "boost-users@lists.boost.org")
  160. set(CPACK_NSIS_MODIFY_PATH ON)
  161. # Encode the compiler name in the package
  162. if (MSVC60)
  163. set(CPACK_PACKAGE_FILE_NAME "Boost-${BOOST_VERSION}-vc6")
  164. set(CPACK_NSIS_DISPLAY_NAME "${CPACK_NSIS_DISPLAY_NAME} for Microsoft Visual C++ 6")
  165. elseif (MSVC70)
  166. set(CPACK_PACKAGE_FILE_NAME "Boost-${BOOST_VERSION}-vc7")
  167. set(CPACK_NSIS_DISPLAY_NAME "${CPACK_NSIS_DISPLAY_NAME} for Microsoft Visual Studio 2002")
  168. elseif (MSVC71)
  169. set(CPACK_PACKAGE_FILE_NAME "Boost-${BOOST_VERSION}-vc71")
  170. set(CPACK_NSIS_DISPLAY_NAME "${CPACK_NSIS_DISPLAY_NAME} for Microsoft Visual Studio 2003")
  171. elseif (MSVC80)
  172. set(CPACK_PACKAGE_FILE_NAME "Boost-${BOOST_VERSION}-vc8")
  173. set(CPACK_NSIS_DISPLAY_NAME "${CPACK_NSIS_DISPLAY_NAME} for Microsoft Visual Studio 2005")
  174. elseif (MSVC90)
  175. set(CPACK_PACKAGE_FILE_NAME "Boost-${BOOST_VERSION}-vc9")
  176. set(CPACK_NSIS_DISPLAY_NAME "${CPACK_NSIS_DISPLAY_NAME} for Microsoft Visual Studio 2008")
  177. elseif (BORLAND)
  178. set(CPACK_PACKAGE_FILE_NAME "Boost-${BOOST_VERSION}-borland")
  179. set(CPACK_NSIS_DISPLAY_NAME "${CPACK_NSIS_DISPLAY_NAME} for Borland C++ Builder")
  180. endif (MSVC60)
  181. set(CPACK_PACKAGE_DESCRIPTION_SUMMARY "${CPACK_NSIS_DISPLAY_NAME}")
  182. endif(WIN32 AND NOT UNIX)
  183. include(CPack)
  184. if(COMMAND cpack_configure_downloads)
  185. cpack_configure_downloads(
  186. "http://www.osl.iu.edu/~dgregor/Boost-CMake/${BOOST_VERSION}/"
  187. ALL ADD_REMOVE)
  188. endif()
  189. ##########################################################################
  190. ##########################################################################
  191. # Building Boost libraries #
  192. ##########################################################################
  193. # Always include the directory where Boost's include files will be.
  194. if (TEST_INSTALLED_TREE)
  195. # Use the headers from the installation directory
  196. include_directories("${CMAKE_INSTALL_PREFIX}/${BOOST_HEADER_DIR}")
  197. else (TEST_INSTALLED_TREE)
  198. # Use the headers directly from the Boost source tree (in boost/)
  199. include_directories(${Boost_SOURCE_DIR})
  200. endif (TEST_INSTALLED_TREE)
  201. # Boost.Build version 2 does this due to trouble with autolinking
  202. # during building and testing.
  203. # TODO: See if we can actually use auto-linking in our regression tests.
  204. add_definitions(-DBOOST_ALL_NO_LIB=1)
  205. # Add build rules for documentation
  206. add_subdirectory(doc)
  207. # Add build rules for all of the Boost libraries
  208. add_subdirectory(${BOOST_LIBS_DIR})
  209. # Add build rules for all of the Boost tools
  210. # TODO: On hold while I work on the modularity code
  211. add_subdirectory(tools)
  212. ##########################################################################
粤ICP备19079148号