12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- #
- # Copyright (c) Contributors to the Open 3D Engine Project.
- # For complete copyright and license terms please see the LICENSE at the root of this distribution.
- #
- # SPDX-License-Identifier: Apache-2.0 OR MIT
- #
- #
- # Query the gem name from the gem.json file if possible
- # otherwise fallback to using ${Name}
- o3de_find_ancestor_gem_root(gempath gem_name "${CMAKE_CURRENT_SOURCE_DIR}")
- if (NOT gem_name)
- set(gem_name "RobotVacuumSample")
- endif()
- # Fallback to using the current source CMakeLists.txt directory as the gem root path
- if (NOT gem_path)
- set(gem_path ${CMAKE_CURRENT_SOURCE_DIR})
- endif()
- set(gem_json ${gem_path}/gem.json)
- o3de_restricted_path(${gem_json} gem_restricted_path gem_parent_relative_path)
- # Currently we are in the RobotVacuumSample/Gem folder: ${CMAKE_CURRENT_LIST_DIR}
- # Get the platform specific folder ${pal_dir} for the current folder: ${CMAKE_CURRENT_LIST_DIR}/Platform/${PAL_PLATFORM_NAME}
- # Note: o3de_pal_dir will take care of the details for us, as this may be a restricted platform
- # in which case it will see if that platform is present here or in the restricted folder.
- # i.e. It could here : RobotVacuumSample/Gem/Platform/<platform_name> or
- # <restricted_folder>/<platform_name>/RobotVacuumSample/Gem
- o3de_pal_dir(pal_dir ${CMAKE_CURRENT_LIST_DIR}/Platform/${PAL_PLATFORM_NAME} "${gem_restricted_path}" "${gem_path}" "${gem_parent_relative_path}")
- # Now that we have the platform abstraction layer (PAL) folder for this folder, thats where we will find the
- # traits for this platform. Traits for a platform are defines for things like whether or not something in this project
- # is supported by this platform.
- include(${pal_dir}/PAL_${PAL_PLATFORM_NAME_LOWERCASE}.cmake)
- # Now that we have loaded our project traits for this platform, see if this project is even supported on this platform.
- # If its not supported we just return after including the unsupported.
- if(NOT PAL_TRAIT_ROBOT_VACUUM_SAMPLE_SUPPORTED)
- message(FATAL_ERROR "The Robot Vacuum Sample application is not supported on this platform")
- return()
- endif()
- # We are on a supported platform, so add the ${gem_name} target
- # Note: We include the common files and the platform specific files which are set in robot-vacuum-sample_files.cmake and
- # in ${pal_dir}/robot_vacuum_sample_${PAL_PLATFORM_NAME_LOWERCASE}_files.cmake
- ly_add_target(
- NAME ${gem_name}.Static STATIC
- NAMESPACE Gem
- FILES_CMAKE
- robot_vacuum_sample_files.cmake
- ${pal_dir}/robot_vacuum_sample_${PAL_PLATFORM_NAME_LOWERCASE}_files.cmake
- INCLUDE_DIRECTORIES
- PUBLIC
- Include
- BUILD_DEPENDENCIES
- PRIVATE
- AZ::AzGameFramework
- Gem::Atom_AtomBridge.Static
- )
- ly_add_target(
- NAME ${gem_name} ${PAL_TRAIT_MONOLITHIC_DRIVEN_MODULE_TYPE}
- NAMESPACE Gem
- FILES_CMAKE
- robot_vacuum_sample_shared_files.cmake
- ${pal_dir}/robot_vacuum_sample_shared_${PAL_PLATFORM_NAME_LOWERCASE}_files.cmake
- INCLUDE_DIRECTORIES
- PUBLIC
- Include
- BUILD_DEPENDENCIES
- PRIVATE
- Gem::${gem_name}.Static
- AZ::AzCore
- )
- # if enabled, RobotVacuumSample is used by all kinds of applications
- ly_create_alias(NAME ${gem_name}.Builders NAMESPACE Gem TARGETS Gem::${gem_name})
- ly_create_alias(NAME ${gem_name}.Tools NAMESPACE Gem TARGETS Gem::${gem_name})
- ly_create_alias(NAME ${gem_name}.Clients NAMESPACE Gem TARGETS Gem::${gem_name})
- ly_create_alias(NAME ${gem_name}.Servers NAMESPACE Gem TARGETS Gem::${gem_name})
- ################################################################################
- # Gem dependencies
- ################################################################################
- # Query the project name from the nearest project.json file in a directory at or above
- # the current one.
- # This gem is the project gem and therefore should be part of the project that is using it
- o3de_find_ancestor_project_root(project_path project_name "${CMAKE_CURRENT_SOURCE_DIR}")
- # If the project name could not be queried from a project.json file, then fallback
- # to using the name of the project provided when the project template was instantiated
- if (NOT project_name)
- set(project_name ${Name})
- endif()
|