iOS.cmake 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. # This file is based off of the Platform/Darwin.cmake and Platform/UnixPaths.cmake
  2. # files which are included with CMake 2.8.4
  3. # It has been altered for iOS development
  4. # Options:
  5. #
  6. # IOS_PLATFORM = OS (default) or SIMULATOR
  7. # This decides if SDKS will be selected from the iPhoneOS.platform or iPhoneSimulator.platform folders
  8. # OS - the default, used to build for iPhone and iPad physical devices, which have an arm arch.
  9. # SIMULATOR - used to build for the Simulator platforms, which have an x86 arch.
  10. #
  11. # CMAKE_IOS_DEVELOPER_ROOT = automatic(default) or /path/to/platform/Developer folder
  12. # By default this location is automatically chosen based on the IOS_PLATFORM value above.
  13. # If set manually, it will override the default location and force the user of a particular Developer Platform
  14. #
  15. # CMAKE_IOS_SDK_ROOT = automatic(default) or /path/to/platform/Developer/SDKs/SDK folder
  16. # By default this location is automatically chosen based on the CMAKE_IOS_DEVELOPER_ROOT value.
  17. # In this case it will always be the most up-to-date SDK found in the CMAKE_IOS_DEVELOPER_ROOT path.
  18. # If set manually, this will force the use of a specific SDK version
  19. # Macros:
  20. #
  21. # set_xcode_property (TARGET XCODE_PROPERTY XCODE_VALUE)
  22. # A convenience macro for setting xcode specific properties on targets
  23. # example: set_xcode_property (myioslib IPHONEOS_DEPLOYMENT_TARGET "3.1")
  24. #
  25. # find_host_package (PROGRAM ARGS)
  26. # A macro used to find executable programs on the host system, not within the iOS environment.
  27. # Thanks to the android-cmake project for providing the command
  28. # Standard settings
  29. set(CMAKE_SYSTEM_NAME Darwin)
  30. set(CMAKE_SYSTEM_VERSION 1)
  31. set(UNIX True)
  32. set(APPLE True)
  33. set(IOS True)
  34. # Required as of cmake 2.8.10
  35. set(CMAKE_OSX_DEPLOYMENT_TARGET "" CACHE STRING "Force unset of the deployment target for iOS" FORCE)
  36. # Determine the cmake host system version so we know where to find the iOS SDKs
  37. find_program(CMAKE_UNAME uname /bin /usr/bin /usr/local/bin)
  38. if(CMAKE_UNAME)
  39. exec_program(uname ARGS -r OUTPUT_VARIABLE CMAKE_HOST_SYSTEM_VERSION)
  40. string(REGEX REPLACE "^([0-9]+)\\.([0-9]+).*$" "\\1" DARWIN_MAJOR_VERSION "${CMAKE_HOST_SYSTEM_VERSION}")
  41. endif(CMAKE_UNAME)
  42. # Force the compilers to gcc for iOS
  43. set(CMAKE_C_COMPILER /usr/bin/gcc CACHE STRING "")
  44. set(CMAKE_CXX_COMPILER /usr/bin/g++ CACHE STRING "")
  45. set(CMAKE_AR ar CACHE FILEPATH "" FORCE)
  46. set(CMAKE_RANLIB ranlib CACHE FILEPATH "" FORCE)
  47. set(PKG_CONFIG_EXECUTABLE pkg-config CACHE FILEPATH "" FORCE)
  48. # Setup iOS platform unless specified manually with IOS_PLATFORM
  49. if(NOT DEFINED IOS_PLATFORM)
  50. set(IOS_PLATFORM "OS")
  51. endif(NOT DEFINED IOS_PLATFORM)
  52. set(IOS_PLATFORM ${IOS_PLATFORM} CACHE STRING "Type of iOS Platform")
  53. # Check the platform selection and setup for developer root
  54. if(${IOS_PLATFORM} STREQUAL "OS")
  55. set(IOS_PLATFORM_LOCATION "iPhoneOS.platform")
  56. set(XCODE_IOS_PLATFORM iphoneos)
  57. # This causes the installers to properly locate the output libraries
  58. set(CMAKE_XCODE_EFFECTIVE_PLATFORMS "-iphoneos")
  59. elseif(${IOS_PLATFORM} STREQUAL "SIMULATOR")
  60. set(IOS_PLATFORM_LOCATION "iPhoneSimulator.platform")
  61. set(XCODE_IOS_PLATFORM iphonesimulator)
  62. # This causes the installers to properly locate the output libraries
  63. set(CMAKE_XCODE_EFFECTIVE_PLATFORMS "-iphonesimulator")
  64. elseif(${IOS_PLATFORM} STREQUAL "WATCHOS")
  65. set(IOS_PLATFORM_LOCATION "WatchOS.platform")
  66. set(XCODE_IOS_PLATFORM watchos)
  67. # This causes the installers to properly locate the output libraries
  68. set(CMAKE_XCODE_EFFECTIVE_PLATFORMS "-watchos")
  69. else(${IOS_PLATFORM} STREQUAL "OS")
  70. message(FATAL_ERROR
  71. "Unsupported IOS_PLATFORM value selected. "
  72. "Please choose OS, SIMULATOR, or WATCHOS.")
  73. endif()
  74. # All iOS/Darwin specific settings - some may be redundant
  75. set(CMAKE_SHARED_LIBRARY_PREFIX "lib")
  76. set(CMAKE_SHARED_LIBRARY_SUFFIX ".dylib")
  77. set(CMAKE_SHARED_MODULE_PREFIX "lib")
  78. set(CMAKE_SHARED_MODULE_SUFFIX ".so")
  79. set(CMAKE_MODULE_EXISTS 1)
  80. set(CMAKE_DL_LIBS "")
  81. set(CMAKE_C_OSX_COMPATIBILITY_VERSION_FLAG "-compatibility_version ")
  82. set(CMAKE_C_OSX_CURRENT_VERSION_FLAG "-current_version ")
  83. set(CMAKE_CXX_OSX_COMPATIBILITY_VERSION_FLAG "${CMAKE_C_OSX_COMPATIBILITY_VERSION_FLAG}")
  84. set(CMAKE_CXX_OSX_CURRENT_VERSION_FLAG "${CMAKE_C_OSX_CURRENT_VERSION_FLAG}")
  85. if(IOS_DEPLOYMENT_TARGET)
  86. set(XCODE_IOS_PLATFORM_VERSION_FLAGS "-m${XCODE_IOS_PLATFORM}-version-min=${IOS_DEPLOYMENT_TARGET}")
  87. endif()
  88. # Hidden visibility is required for cxx on iOS
  89. set(CMAKE_C_FLAGS_INIT "${XCODE_IOS_PLATFORM_VERSION_FLAGS}")
  90. set(CMAKE_CXX_FLAGS_INIT "${XCODE_IOS_PLATFORM_VERSION_FLAGS} -fvisibility-inlines-hidden")
  91. set(CMAKE_C_LINK_FLAGS "${XCODE_IOS_PLATFORM_VERSION_FLAGS} -Wl,-search_paths_first ${CMAKE_C_LINK_FLAGS}")
  92. set(CMAKE_CXX_LINK_FLAGS "${XCODE_IOS_PLATFORM_VERSION_FLAGS} -Wl,-search_paths_first ${CMAKE_CXX_LINK_FLAGS}")
  93. set(CMAKE_PLATFORM_HAS_INSTALLNAME 1)
  94. set(CMAKE_SHARED_LIBRARY_CREATE_C_FLAGS "-dynamiclib -headerpad_max_install_names")
  95. set(CMAKE_SHARED_MODULE_CREATE_C_FLAGS "-bundle -headerpad_max_install_names")
  96. set(CMAKE_SHARED_MODULE_LOADER_C_FLAG "-Wl,-bundle_loader,")
  97. set(CMAKE_SHARED_MODULE_LOADER_CXX_FLAG "-Wl,-bundle_loader,")
  98. set(CMAKE_FIND_LIBRARY_SUFFIXES ".dylib" ".so" ".a")
  99. # hack: if a new cmake (which uses CMAKE_INSTALL_NAME_TOOL) runs on an old build tree
  100. # (where install_name_tool was hardcoded) and where CMAKE_INSTALL_NAME_TOOL isn't in the cache
  101. # and still cmake didn't fail in CMakeFindBinUtils.cmake (because it isn't rerun)
  102. # hardcode CMAKE_INSTALL_NAME_TOOL here to install_name_tool, so it behaves as it did before, Alex
  103. if(NOT DEFINED CMAKE_INSTALL_NAME_TOOL)
  104. find_program(CMAKE_INSTALL_NAME_TOOL install_name_tool)
  105. endif(NOT DEFINED CMAKE_INSTALL_NAME_TOOL)
  106. # Setup iOS deployment target
  107. set(IOS_DEPLOYMENT_TARGET ${IOS_DEPLOYMENT_TARGET} CACHE STRING "Minimum iOS version")
  108. # Setup iOS developer location unless specified manually with CMAKE_IOS_DEVELOPER_ROOT
  109. # Note Xcode 4.3 changed the installation location, choose the most recent one available
  110. exec_program(/usr/bin/xcode-select ARGS -print-path OUTPUT_VARIABLE CMAKE_XCODE_DEVELOPER_DIR)
  111. set(XCODE_POST_43_ROOT "${CMAKE_XCODE_DEVELOPER_DIR}/Platforms/${IOS_PLATFORM_LOCATION}/Developer")
  112. set(XCODE_PRE_43_ROOT "/Developer/Platforms/${IOS_PLATFORM_LOCATION}/Developer")
  113. if(NOT DEFINED CMAKE_IOS_DEVELOPER_ROOT)
  114. if(EXISTS ${XCODE_POST_43_ROOT})
  115. set(CMAKE_IOS_DEVELOPER_ROOT ${XCODE_POST_43_ROOT})
  116. elseif(EXISTS ${XCODE_PRE_43_ROOT})
  117. set(CMAKE_IOS_DEVELOPER_ROOT ${XCODE_PRE_43_ROOT})
  118. endif(EXISTS ${XCODE_POST_43_ROOT})
  119. endif(NOT DEFINED CMAKE_IOS_DEVELOPER_ROOT)
  120. set(CMAKE_IOS_DEVELOPER_ROOT ${CMAKE_IOS_DEVELOPER_ROOT} CACHE PATH "Location of iOS Platform")
  121. # Find and use the most recent iOS sdk unless specified manually with CMAKE_IOS_SDK_ROOT
  122. if(NOT DEFINED CMAKE_IOS_SDK_ROOT)
  123. file(GLOB _CMAKE_IOS_SDKS "${CMAKE_IOS_DEVELOPER_ROOT}/SDKs/*")
  124. if(_CMAKE_IOS_SDKS)
  125. list(SORT _CMAKE_IOS_SDKS)
  126. list(REVERSE _CMAKE_IOS_SDKS)
  127. list(GET _CMAKE_IOS_SDKS 0 CMAKE_IOS_SDK_ROOT)
  128. else(_CMAKE_IOS_SDKS)
  129. message(FATAL_ERROR "No iOS SDK's found in default search path ${CMAKE_IOS_DEVELOPER_ROOT}. Manually set CMAKE_IOS_SDK_ROOT or install the iOS SDK.")
  130. endif(_CMAKE_IOS_SDKS)
  131. message(STATUS "Toolchain using default iOS SDK: ${CMAKE_IOS_SDK_ROOT}")
  132. endif(NOT DEFINED CMAKE_IOS_SDK_ROOT)
  133. set(CMAKE_IOS_SDK_ROOT ${CMAKE_IOS_SDK_ROOT} CACHE PATH "Location of the selected iOS SDK")
  134. # Set the sysroot default to the most recent SDK
  135. set(CMAKE_OSX_SYSROOT ${CMAKE_IOS_SDK_ROOT} CACHE PATH "Sysroot used for iOS support")
  136. # set the architecture for iOS
  137. if(IOS_PLATFORM STREQUAL "OS")
  138. set(DEFAULT_IOS_ARCH "arm64")
  139. elseif(IOS_PLATFORM STREQUAL "SIMULATOR")
  140. set(DEFAULT_IOS_ARCH "x86_64")
  141. elseif(IOS_PLATFORM STREQUAL "WATCHOS")
  142. set(DEFAULT_IOS_ARCH "armv7k;arm64_32")
  143. endif()
  144. set(IOS_ARCH ${DEFAULT_IOS_ARCH} CACHE STRING "Build architecture for iOS")
  145. set(CMAKE_OSX_ARCHITECTURES ${IOS_ARCH} CACHE STRING "Build architecture for iOS")
  146. # Set the find root to the iOS developer roots and to user defined paths
  147. set(CMAKE_FIND_ROOT_PATH ${CMAKE_IOS_DEVELOPER_ROOT} ${CMAKE_IOS_SDK_ROOT} ${CMAKE_PREFIX_PATH} CACHE STRING "iOS find search path root")
  148. # default to searching for frameworks first
  149. set(CMAKE_FIND_FRAMEWORK FIRST)
  150. # set up the default search directories for frameworks
  151. set(CMAKE_SYSTEM_FRAMEWORK_PATH
  152. ${CMAKE_IOS_SDK_ROOT}/System/Library/Frameworks
  153. ${CMAKE_IOS_SDK_ROOT}/System/Library/PrivateFrameworks
  154. ${CMAKE_IOS_SDK_ROOT}/Developer/Library/Frameworks
  155. )
  156. # only search the iOS sdks, not the remainder of the host filesystem
  157. set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM ONLY)
  158. set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY)
  159. set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY)
  160. # This little macro lets you set any XCode specific property
  161. macro(set_xcode_property TARGET XCODE_PROPERTY XCODE_VALUE)
  162. set_property(TARGET ${TARGET} PROPERTY XCODE_ATTRIBUTE_${XCODE_PROPERTY} ${XCODE_VALUE})
  163. endmacro(set_xcode_property)
  164. # This macro lets you find executable programs on the host system
  165. macro(find_host_package)
  166. set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER)
  167. set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY NEVER)
  168. set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE NEVER)
  169. set(IOS FALSE)
  170. find_package(${ARGN})
  171. set(IOS TRUE)
  172. set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM ONLY)
  173. set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY)
  174. set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY)
  175. endmacro(find_host_package)