CMakeLists.txt 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. # {BEGIN_LICENSE}
  2. # Copyright (c) Contributors to the Open 3D Engine Project.
  3. # For complete copyright and license terms please see the LICENSE at the root of this distribution.
  4. #
  5. # SPDX-License-Identifier: Apache-2.0 OR MIT
  6. #
  7. # {END_LICENSE}
  8. # Currently we are in the Code folder: ${CMAKE_CURRENT_LIST_DIR}
  9. # Get the platform specific folder ${pal_dir} for the current folder: ${CMAKE_CURRENT_LIST_DIR}/Platform/${PAL_PLATFORM_NAME}
  10. # Note: o3de_pal_dir will take care of the details for us, as this may be a restricted platform
  11. # in which case it will see if that platform is present here or in the restricted folder.
  12. # i.e. It could here in our gem : Gems/${Name}/Code/Platform/<platorm_name> or
  13. # <restricted_folder>/<platform_name>/Gems/${Name}/Code
  14. o3de_pal_dir(pal_dir ${CMAKE_CURRENT_LIST_DIR}/Platform/${PAL_PLATFORM_NAME} "${gem_restricted_path}" "${gem_path}" "${gem_parent_relative_path}")
  15. # Now that we have the platform abstraction layer (PAL) folder for this folder, thats where we will find the
  16. # traits for this platform. Traits for a platform are defines for things like whether or not something in this gem
  17. # is supported by this platform.
  18. include(${pal_dir}/PAL_${PAL_PLATFORM_NAME_LOWERCASE}.cmake)
  19. # Check to see if building the Gem Modules are supported for the current platform
  20. if(NOT PAL_TRAIT_${NameUpper}_SUPPORTED)
  21. return()
  22. endif()
  23. # The ${gem_name}.API target declares the common interface that users of this gem should depend on in their targets
  24. ly_add_target(
  25. NAME ${gem_name}.API INTERFACE
  26. NAMESPACE Gem
  27. FILES_CMAKE
  28. ${NameLower}_api_files.cmake
  29. ${pal_dir}/${NameLower}_api_files.cmake
  30. INCLUDE_DIRECTORIES
  31. INTERFACE
  32. Include
  33. BUILD_DEPENDENCIES
  34. INTERFACE
  35. AZ::AzCore
  36. )
  37. # The ${gem_name}.Private.Object target is an internal target
  38. # It should not be used outside of this Gems CMakeLists.txt
  39. ly_add_target(
  40. NAME ${gem_name}.Private.Object STATIC
  41. NAMESPACE Gem
  42. FILES_CMAKE
  43. ${NameLower}_private_files.cmake
  44. ${pal_dir}/${NameLower}_private_files.cmake
  45. TARGET_PROPERTIES
  46. O3DE_PRIVATE_TARGET TRUE
  47. INCLUDE_DIRECTORIES
  48. PRIVATE
  49. Include
  50. Source
  51. BUILD_DEPENDENCIES
  52. PUBLIC
  53. AZ::AzCore
  54. AZ::AzFramework
  55. )
  56. # Here add ${gem_name} target, it depends on the Private Object library and Public API interface
  57. ly_add_target(
  58. NAME ${gem_name} ${PAL_TRAIT_MONOLITHIC_DRIVEN_MODULE_TYPE}
  59. NAMESPACE Gem
  60. FILES_CMAKE
  61. ${NameLower}_shared_files.cmake
  62. ${pal_dir}/${NameLower}_shared_files.cmake
  63. INCLUDE_DIRECTORIES
  64. PUBLIC
  65. Include
  66. PRIVATE
  67. Source
  68. BUILD_DEPENDENCIES
  69. PUBLIC
  70. Gem::${gem_name}.API
  71. PRIVATE
  72. Gem::${gem_name}.Private.Object
  73. )
  74. # By default, we will specify that the above target ${gem_name} would be used by
  75. # Client and Server type targets when this gem is enabled. If you don't want it
  76. # active in Clients or Servers by default, delete one of both of the following lines:
  77. ly_create_alias(NAME ${gem_name}.Clients NAMESPACE Gem TARGETS Gem::${gem_name})
  78. ly_create_alias(NAME ${gem_name}.Servers NAMESPACE Gem TARGETS Gem::${gem_name})
  79. ly_create_alias(NAME ${gem_name}.Unified NAMESPACE Gem TARGETS Gem::${gem_name})
  80. # For the Client and Server variants of ${gem_name} Gem, an alias to the ${gem_name}.API target will be made
  81. ly_create_alias(NAME ${gem_name}.Clients.API NAMESPACE Gem TARGETS Gem::${gem_name}.API)
  82. ly_create_alias(NAME ${gem_name}.Servers.API NAMESPACE Gem TARGETS Gem::${gem_name}.API)
  83. ly_create_alias(NAME ${gem_name}.Unified.API NAMESPACE Gem TARGETS Gem::${gem_name}.API)
  84. # Add in CMake dependencies for each gem dependency listed in this gem's gem.json file
  85. # for the Clients, Servers, Unified gem variants
  86. o3de_add_variant_dependencies_for_gem_dependencies(GEM_NAME ${gem_name} VARIANTS Clients Servers Unified)
  87. # If we are on a host platform, we want to add the host tools targets like the ${gem_name}.Editor MODULE target
  88. if(PAL_TRAIT_BUILD_HOST_TOOLS)
  89. # The ${gem_name}.Editor.API target can be used by other gems that want to interact with the ${gem_name}.Editor module
  90. ly_add_target(
  91. NAME ${gem_name}.Editor.API INTERFACE
  92. NAMESPACE Gem
  93. FILES_CMAKE
  94. ${NameLower}_editor_api_files.cmake
  95. ${pal_dir}/${NameLower}_editor_api_files.cmake
  96. INCLUDE_DIRECTORIES
  97. INTERFACE
  98. Include
  99. BUILD_DEPENDENCIES
  100. INTERFACE
  101. AZ::AzToolsFramework
  102. )
  103. # The ${gem_name}.Editor.Private.Object target is an internal target
  104. # which is only to be used by this gems CMakeLists.txt and any subdirectories
  105. # Other gems should not use this target
  106. ly_add_target(
  107. NAME ${gem_name}.Editor.Private.Object STATIC
  108. NAMESPACE Gem
  109. FILES_CMAKE
  110. ${NameLower}_editor_private_files.cmake
  111. TARGET_PROPERTIES
  112. O3DE_PRIVATE_TARGET TRUE
  113. INCLUDE_DIRECTORIES
  114. PRIVATE
  115. Include
  116. Source
  117. BUILD_DEPENDENCIES
  118. PUBLIC
  119. AZ::AzToolsFramework
  120. $<TARGET_OBJECTS:Gem::${gem_name}.Private.Object>
  121. )
  122. ly_add_target(
  123. NAME ${gem_name}.Editor GEM_MODULE
  124. NAMESPACE Gem
  125. AUTOMOC
  126. FILES_CMAKE
  127. ${NameLower}_editor_shared_files.cmake
  128. INCLUDE_DIRECTORIES
  129. PRIVATE
  130. Source
  131. PUBLIC
  132. Include
  133. BUILD_DEPENDENCIES
  134. PUBLIC
  135. Gem::${gem_name}.Editor.API
  136. PRIVATE
  137. Gem::${gem_name}.Editor.Private.Object
  138. )
  139. # By default, we will specify that the above target ${gem_name} would be used by
  140. # Tool and Builder type targets when this gem is enabled. If you don't want it
  141. # active in Tools or Builders by default, delete one of both of the following lines:
  142. ly_create_alias(NAME ${gem_name}.Tools NAMESPACE Gem TARGETS Gem::${gem_name}.Editor)
  143. ly_create_alias(NAME ${gem_name}.Builders NAMESPACE Gem TARGETS Gem::${gem_name}.Editor)
  144. # For the Tools and Builders variants of ${gem_name} Gem, an alias to the ${gem_name}.Editor API target will be made
  145. ly_create_alias(NAME ${gem_name}.Tools.API NAMESPACE Gem TARGETS Gem::${gem_name}.Editor.API)
  146. ly_create_alias(NAME ${gem_name}.Builders.API NAMESPACE Gem TARGETS Gem::${gem_name}.Editor.API)
  147. # Add in CMake dependencies for each gem dependency listed in this gem's gem.json file
  148. # for the Tools and Builders gem variants
  149. o3de_add_variant_dependencies_for_gem_dependencies(GEM_NAME ${gem_name} VARIANTS Tools Builders)
  150. endif()
  151. ################################################################################
  152. # Tests
  153. ################################################################################
  154. # See if globally, tests are supported
  155. if(PAL_TRAIT_BUILD_TESTS_SUPPORTED)
  156. # We globally support tests, see if we support tests on this platform for ${gem_name}.Tests
  157. if(PAL_TRAIT_${NameUpper}_TEST_SUPPORTED)
  158. # We support ${gem_name}.Tests on this platform, add dependency on the Private Object target
  159. ly_add_target(
  160. NAME ${gem_name}.Tests ${PAL_TRAIT_TEST_TARGET_TYPE}
  161. NAMESPACE Gem
  162. FILES_CMAKE
  163. ${NameLower}_tests_files.cmake
  164. INCLUDE_DIRECTORIES
  165. PRIVATE
  166. Tests
  167. Source
  168. Include
  169. BUILD_DEPENDENCIES
  170. PRIVATE
  171. AZ::AzTest
  172. AZ::AzFramework
  173. Gem::${gem_name}.Private.Object
  174. )
  175. # Add ${gem_name}.Tests to googletest
  176. ly_add_googletest(
  177. NAME Gem::${gem_name}.Tests
  178. )
  179. endif()
  180. # If we are a host platform we want to add tools test like editor tests here
  181. if(PAL_TRAIT_BUILD_HOST_TOOLS)
  182. # We are a host platform, see if Editor tests are supported on this platform
  183. if(PAL_TRAIT_${NameUpper}_EDITOR_TEST_SUPPORTED)
  184. # We support ${gem_name}.Editor.Tests on this platform, add ${gem_name}.Editor.Tests target which depends on
  185. # private ${gem_name}.Editor.Private.Object target
  186. ly_add_target(
  187. NAME ${gem_name}.Editor.Tests ${PAL_TRAIT_TEST_TARGET_TYPE}
  188. NAMESPACE Gem
  189. FILES_CMAKE
  190. ${NameLower}_editor_tests_files.cmake
  191. INCLUDE_DIRECTORIES
  192. PRIVATE
  193. Tests
  194. Source
  195. Include
  196. BUILD_DEPENDENCIES
  197. PRIVATE
  198. AZ::AzTest
  199. Gem::${gem_name}.Editor.Private.Object
  200. )
  201. # Add ${gem_name}.Editor.Tests to googletest
  202. ly_add_googletest(
  203. NAME Gem::${gem_name}.Editor.Tests
  204. )
  205. endif()
  206. endif()
  207. endif()