CMakeDetermineSystem.cmake 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. #=============================================================================
  2. # Copyright 2002-2009 Kitware, Inc.
  3. #
  4. # Distributed under the OSI-approved BSD License (the "License");
  5. # see accompanying file Copyright.txt for details.
  6. #
  7. # This software is distributed WITHOUT ANY WARRANTY; without even the
  8. # implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  9. # See the License for more information.
  10. #=============================================================================
  11. # (To distributed this file outside of CMake, substitute the full
  12. # License text for the above reference.)
  13. # This module is used by the Makefile generator to determin the following variables:
  14. # CMAKE_SYSTEM_NAME - on unix this is uname -s, for windows it is Windows
  15. # CMAKE_SYSTEM_VERSION - on unix this is uname -r, for windows it is empty
  16. # CMAKE_SYSTEM - ${CMAKE_SYSTEM}-${CMAKE_SYSTEM_VERSION}, for windows: ${CMAKE_SYSTEM}
  17. #
  18. # Expected uname -s output:
  19. #
  20. # AIX AIX
  21. # BSD/OS BSD/OS
  22. # FreeBSD FreeBSD
  23. # HP-UX HP-UX
  24. # IRIX IRIX
  25. # Linux Linux
  26. # NetBSD NetBSD
  27. # OpenBSD OpenBSD
  28. # OFS/1 (Digital Unix) OSF1
  29. # SCO OpenServer 5 SCO_SV
  30. # SCO UnixWare 7 UnixWare
  31. # SCO UnixWare (pre release 7) UNIX_SV
  32. # SCO XENIX Xenix
  33. # Solaris SunOS
  34. # SunOS SunOS
  35. # Tru64 Tru64
  36. # Ultrix ULTRIX
  37. # cygwin CYGWIN_NT-5.1
  38. # MacOSX Darwin
  39. # find out on which system cmake runs
  40. IF(CMAKE_HOST_UNIX)
  41. FIND_PROGRAM(CMAKE_UNAME uname /bin /usr/bin /usr/local/bin )
  42. IF(CMAKE_UNAME)
  43. EXEC_PROGRAM(uname ARGS -s OUTPUT_VARIABLE CMAKE_HOST_SYSTEM_NAME)
  44. EXEC_PROGRAM(uname ARGS -r OUTPUT_VARIABLE CMAKE_HOST_SYSTEM_VERSION)
  45. IF(CMAKE_HOST_SYSTEM_NAME MATCHES "Linux")
  46. EXEC_PROGRAM(uname ARGS -m OUTPUT_VARIABLE CMAKE_HOST_SYSTEM_PROCESSOR
  47. RETURN_VALUE val)
  48. ELSE(CMAKE_HOST_SYSTEM_NAME MATCHES "Linux")
  49. EXEC_PROGRAM(uname ARGS -p OUTPUT_VARIABLE CMAKE_HOST_SYSTEM_PROCESSOR
  50. RETURN_VALUE val)
  51. IF("${val}" GREATER 0)
  52. EXEC_PROGRAM(uname ARGS -m OUTPUT_VARIABLE CMAKE_HOST_SYSTEM_PROCESSOR
  53. RETURN_VALUE val)
  54. ENDIF("${val}" GREATER 0)
  55. ENDIF(CMAKE_HOST_SYSTEM_NAME MATCHES "Linux")
  56. # check the return of the last uname -m or -p
  57. IF("${val}" GREATER 0)
  58. SET(CMAKE_HOST_SYSTEM_PROCESSOR "unknown")
  59. ENDIF("${val}" GREATER 0)
  60. SET(CMAKE_UNAME ${CMAKE_UNAME} CACHE INTERNAL "uname command")
  61. # processor may have double quote in the name, and that needs to be removed
  62. STRING(REGEX REPLACE "\"" "" CMAKE_HOST_SYSTEM_PROCESSOR "${CMAKE_HOST_SYSTEM_PROCESSOR}")
  63. STRING(REGEX REPLACE "/" "_" CMAKE_HOST_SYSTEM_PROCESSOR "${CMAKE_HOST_SYSTEM_PROCESSOR}")
  64. ENDIF(CMAKE_UNAME)
  65. ELSE(CMAKE_HOST_UNIX)
  66. IF(CMAKE_HOST_WIN32)
  67. SET (CMAKE_HOST_SYSTEM_NAME "Windows")
  68. SET (CMAKE_HOST_SYSTEM_PROCESSOR "$ENV{PROCESSOR_ARCHITECTURE}")
  69. ENDIF(CMAKE_HOST_WIN32)
  70. ENDIF(CMAKE_HOST_UNIX)
  71. # if a toolchain file is used, the user wants to cross compile.
  72. # in this case read the toolchain file and keep the CMAKE_HOST_SYSTEM_*
  73. # variables around so they can be used in CMakeLists.txt.
  74. # In all other cases, the host and target platform are the same.
  75. IF(CMAKE_TOOLCHAIN_FILE)
  76. # at first try to load it as path relative to the directory from which cmake has been run
  77. INCLUDE("${CMAKE_BINARY_DIR}/${CMAKE_TOOLCHAIN_FILE}" OPTIONAL RESULT_VARIABLE _INCLUDED_TOOLCHAIN_FILE)
  78. IF(NOT _INCLUDED_TOOLCHAIN_FILE)
  79. # if the file isn't found there, check the default locations
  80. INCLUDE("${CMAKE_TOOLCHAIN_FILE}" OPTIONAL RESULT_VARIABLE _INCLUDED_TOOLCHAIN_FILE)
  81. ENDIF(NOT _INCLUDED_TOOLCHAIN_FILE)
  82. IF(_INCLUDED_TOOLCHAIN_FILE)
  83. SET(CMAKE_TOOLCHAIN_FILE "${_INCLUDED_TOOLCHAIN_FILE}" CACHE FILEPATH "The CMake toolchain file" FORCE)
  84. ELSE(_INCLUDED_TOOLCHAIN_FILE)
  85. MESSAGE(FATAL_ERROR "Could not find toolchain file: ${CMAKE_TOOLCHAIN_FILE}")
  86. SET(CMAKE_TOOLCHAIN_FILE "NOTFOUND" CACHE FILEPATH "The CMake toolchain file" FORCE)
  87. ENDIF(_INCLUDED_TOOLCHAIN_FILE)
  88. ENDIF(CMAKE_TOOLCHAIN_FILE)
  89. # if CMAKE_SYSTEM_NAME is here already set, either it comes from a toolchain file
  90. # or it was set via -DCMAKE_SYSTEM_NAME=...
  91. # if that's the case, assume we are crosscompiling
  92. IF(CMAKE_SYSTEM_NAME)
  93. IF(NOT DEFINED CMAKE_CROSSCOMPILING)
  94. SET(CMAKE_CROSSCOMPILING TRUE)
  95. ENDIF(NOT DEFINED CMAKE_CROSSCOMPILING)
  96. SET(PRESET_CMAKE_SYSTEM_NAME TRUE)
  97. ELSE(CMAKE_SYSTEM_NAME)
  98. SET(CMAKE_SYSTEM_NAME "${CMAKE_HOST_SYSTEM_NAME}")
  99. SET(CMAKE_SYSTEM_VERSION "${CMAKE_HOST_SYSTEM_VERSION}")
  100. SET(CMAKE_SYSTEM_PROCESSOR "${CMAKE_HOST_SYSTEM_PROCESSOR}")
  101. SET(CMAKE_CROSSCOMPILING FALSE)
  102. SET(PRESET_CMAKE_SYSTEM_NAME FALSE)
  103. ENDIF(CMAKE_SYSTEM_NAME)
  104. MACRO(ADJUST_CMAKE_SYSTEM_VARIABLES _PREFIX)
  105. IF(NOT ${_PREFIX}_NAME)
  106. SET(${_PREFIX}_NAME "UnknownOS")
  107. ENDIF(NOT ${_PREFIX}_NAME)
  108. # fix for BSD/OS , remove the /
  109. IF(${_PREFIX}_NAME MATCHES BSD.OS)
  110. SET(${_PREFIX}_NAME BSDOS)
  111. ENDIF(${_PREFIX}_NAME MATCHES BSD.OS)
  112. # fix for CYGWIN which has windows version in it
  113. IF(${_PREFIX}_NAME MATCHES CYGWIN)
  114. SET(${_PREFIX}_NAME CYGWIN)
  115. ENDIF(${_PREFIX}_NAME MATCHES CYGWIN)
  116. # set CMAKE_SYSTEM to the CMAKE_SYSTEM_NAME
  117. SET(${_PREFIX} ${${_PREFIX}_NAME})
  118. # if there is a CMAKE_SYSTEM_VERSION then add a -${CMAKE_SYSTEM_VERSION}
  119. IF(${_PREFIX}_VERSION)
  120. SET(${_PREFIX} ${${_PREFIX}}-${${_PREFIX}_VERSION})
  121. ENDIF(${_PREFIX}_VERSION)
  122. ENDMACRO(ADJUST_CMAKE_SYSTEM_VARIABLES _PREFIX)
  123. ADJUST_CMAKE_SYSTEM_VARIABLES(CMAKE_SYSTEM)
  124. ADJUST_CMAKE_SYSTEM_VARIABLES(CMAKE_HOST_SYSTEM)
  125. # this file is also executed from cpack, then we don't need to generate these files
  126. # in this case there is no CMAKE_BINARY_DIR
  127. IF(CMAKE_BINARY_DIR)
  128. # write entry to the log file
  129. IF(PRESET_CMAKE_SYSTEM_NAME)
  130. FILE(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeOutput.log
  131. "The target system is: ${CMAKE_SYSTEM_NAME} - ${CMAKE_SYSTEM_VERSION} - ${CMAKE_SYSTEM_PROCESSOR}\n")
  132. FILE(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeOutput.log
  133. "The host system is: ${CMAKE_HOST_SYSTEM_NAME} - ${CMAKE_HOST_SYSTEM_VERSION} - ${CMAKE_HOST_SYSTEM_PROCESSOR}\n")
  134. ELSE(PRESET_CMAKE_SYSTEM_NAME)
  135. FILE(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeOutput.log
  136. "The system is: ${CMAKE_SYSTEM_NAME} - ${CMAKE_SYSTEM_VERSION} - ${CMAKE_SYSTEM_PROCESSOR}\n")
  137. ENDIF(PRESET_CMAKE_SYSTEM_NAME)
  138. # if a toolchain file is used, it needs to be included in the configured file,
  139. # so settings done there are also available if they don't go in the cache and in TRY_COMPILE()
  140. SET(INCLUDE_CMAKE_TOOLCHAIN_FILE_IF_REQUIRED)
  141. IF(DEFINED CMAKE_TOOLCHAIN_FILE)
  142. SET(INCLUDE_CMAKE_TOOLCHAIN_FILE_IF_REQUIRED "INCLUDE(\"${CMAKE_TOOLCHAIN_FILE}\")")
  143. ENDIF(DEFINED CMAKE_TOOLCHAIN_FILE)
  144. # configure variables set in this file for fast reload, the template file is defined at the top of this file
  145. CONFIGURE_FILE(${CMAKE_ROOT}/Modules/CMakeSystem.cmake.in
  146. ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeSystem.cmake
  147. IMMEDIATE @ONLY)
  148. ENDIF(CMAKE_BINARY_DIR)