supporting multiple directories

automatically excluding obvious things
cleanup and verification

Signed-off-by: Esteban Papp <81431996+amznestebanpapp@users.noreply.github.com>
monroegm-disable-blank-issue-2
Esteban Papp 4 years ago
parent a1b59e5e5e
commit b609d5e2cb

@ -6,4 +6,4 @@
# #
# #
ly_install_directory(DIRECTORY .) ly_install_directory(DIRECTORIES .)

@ -100,19 +100,17 @@ endif()
ly_install_files( ly_install_files(
FILES FILES
${LY_ROOT_FOLDER}/Code/LauncherUnified/launcher_generator.cmake launcher_generator.cmake
${LY_ROOT_FOLDER}/Code/LauncherUnified/launcher_project_files.cmake launcher_project_files.cmake
${LY_ROOT_FOLDER}/Code/LauncherUnified/LauncherProject.cpp LauncherProject.cpp
${LY_ROOT_FOLDER}/Code/LauncherUnified/StaticModules.in StaticModules.in
DESTINATION LauncherGenerator DESTINATION LauncherGenerator
) )
ly_install_directory( ly_install_directory(
DIRECTORY Platform/${PAL_PLATFORM_NAME} DIRECTORIES
DESTINATION LauncherGenerator Platform/${PAL_PLATFORM_NAME}
) Platform/Common
ly_install_directory( DESTINATION LauncherGenerator/Platform
DIRECTORY Platform/Common
DESTINATION LauncherGenerator
) )
ly_install_files( ly_install_files(
FILES FindLauncherGenerator.cmake FILES FindLauncherGenerator.cmake

@ -6,11 +6,10 @@
# #
# #
ly_install_directory(DIRECTORY .) ly_install_directory(DIRECTORIES .)
cmake_path(RELATIVE_PATH CMAKE_RUNTIME_OUTPUT_DIRECTORY BASE_DIRECTORY ${CMAKE_BINARY_DIR} OUTPUT_VARIABLE runtime_output_directory) cmake_path(RELATIVE_PATH CMAKE_RUNTIME_OUTPUT_DIRECTORY BASE_DIRECTORY ${CMAKE_BINARY_DIR} OUTPUT_VARIABLE runtime_output_directory)
ly_install_directory(DIRECTORY ly_install_directory(DIRECTORIES ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/$<CONFIG>/Registry
${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/$<CONFIG>/Registry
DESTINATION ${runtime_output_directory}/${PAL_PLATFORM_NAME}/$<CONFIG> DESTINATION ${runtime_output_directory}/${PAL_PLATFORM_NAME}/$<CONFIG>
) )

@ -6,4 +6,4 @@
# #
# #
ly_install_directory(DIRECTORY .) ly_install_directory(DIRECTORIES .)

@ -11,4 +11,4 @@ if(NOT PAL_PLATFORM_NAME STREQUAL "Mac")
add_subdirectory(tests) add_subdirectory(tests)
endif() endif()
ly_install_directory(DIRECTORY .) ly_install_directory(DIRECTORIES .)

@ -11,4 +11,6 @@ if(NOT PAL_PLATFORM_NAME STREQUAL "Mac")
add_subdirectory(ly_remote_console/tests) add_subdirectory(ly_remote_console/tests)
endif() endif()
ly_install_directory(DIRECTORY .) ly_install_directory(DIRECTORIES .
EXCLUDE_PATTERNS tests
)

@ -13,7 +13,7 @@ endif()
#! ly_install_directory: specifies a directory to be copied to the install layout at install time #! ly_install_directory: specifies a directory to be copied to the install layout at install time
# #
# \arg:DIRECTORY directory to install # \arg:DIRECTORIES directories to install
# \arg:DESTINATION (optional) destination to install the directory to (relative to CMAKE_PREFIX_PATH) # \arg:DESTINATION (optional) destination to install the directory to (relative to CMAKE_PREFIX_PATH)
# \arg:EXCLUDE_PATTERNS (optional) patterns to exclude # \arg:EXCLUDE_PATTERNS (optional) patterns to exclude
# #
@ -22,40 +22,53 @@ endif()
function(ly_install_directory) function(ly_install_directory)
set(options) set(options)
set(oneValueArgs DIRECTORY DESTINATION) set(oneValueArgs DESTINATION)
set(multiValueArgs EXCLUDE_PATTERNS) set(multiValueArgs DIRECTORIES EXCLUDE_PATTERNS)
cmake_parse_arguments(ly_install_directory "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN}) cmake_parse_arguments(ly_install_directory "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
if(NOT ly_install_directory_DIRECTORY) if(NOT ly_install_directory_DIRECTORIES)
message(FATAL_ERROR "You must provide a directory to install") message(FATAL_ERROR "You must provide at least a directory to install")
endif() endif()
if(NOT ly_install_directory_DESTINATION) foreach(directory ${ly_install_directory_DIRECTORIES})
# maintain the same structure relative to LY_ROOT_FOLDER
set(ly_install_directory_DESTINATION ${ly_install_directory_DIRECTORY}) cmake_path(ABSOLUTE_PATH directory)
if(${ly_install_directory_DESTINATION} STREQUAL ".")
set(ly_install_directory_DESTINATION ${CMAKE_CURRENT_LIST_DIR}) if(NOT ly_install_directory_DESTINATION)
else() # maintain the same structure relative to LY_ROOT_FOLDER
cmake_path(ABSOLUTE_PATH ly_install_directory_DESTINATION BASE_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}) set(ly_install_directory_DESTINATION ${directory})
if(${ly_install_directory_DESTINATION} STREQUAL ".")
set(ly_install_directory_DESTINATION ${CMAKE_CURRENT_LIST_DIR})
else()
cmake_path(ABSOLUTE_PATH ly_install_directory_DESTINATION BASE_DIRECTORY ${CMAKE_CURRENT_LIST_DIR})
endif()
# take out the last directory since install asks for the destination of the folder, without including the fodler itself
cmake_path(GET ly_install_directory_DESTINATION PARENT_PATH ly_install_directory_DESTINATION)
cmake_path(RELATIVE_PATH ly_install_directory_DESTINATION BASE_DIRECTORY ${LY_ROOT_FOLDER})
endif() endif()
# take out the last directory since install asks for the destination of the folder, without including the fodler itself
cmake_path(GET ly_install_directory_DESTINATION PARENT_PATH ly_install_directory_DESTINATION)
cmake_path(RELATIVE_PATH ly_install_directory_DESTINATION BASE_DIRECTORY ${LY_ROOT_FOLDER})
endif()
unset(exclude_patterns) unset(exclude_patterns)
if(ly_install_directory_EXCLUDE_PATTERNS) if(ly_install_directory_EXCLUDE_PATTERNS)
foreach(exclude_pattern ${ly_install_directory_EXCLUDE_PATTERNS}) foreach(exclude_pattern ${ly_install_directory_EXCLUDE_PATTERNS})
list(APPEND exclude_patterns PATTERN ${exclude_pattern} EXCLUDE) list(APPEND exclude_patterns PATTERN ${exclude_pattern} EXCLUDE)
endforeach() endforeach()
endif() endif()
install(DIRECTORY ${ly_install_directory_DIRECTORY} # Exclude cmake since that has to be generated
DESTINATION ${ly_install_directory_DESTINATION} list(APPEND exclude_patterns PATTERN CMakeLists.txt EXCLUDE)
COMPONENT ${CMAKE_INSTALL_DEFAULT_COMPONENT_NAME} # use the deafult for the time being list(APPEND exclude_patterns PATTERN *.cmake EXCLUDE)
${exclude_patterns}
) # Exclude python-related things that dont need to be installed
list(APPEND exclude_patterns PATTERN __pycache__ EXCLUDE)
list(APPEND exclude_patterns PATTERN *.egg-info EXCLUDE)
install(DIRECTORY ${directory}
DESTINATION ${ly_install_directory_DESTINATION}
COMPONENT ${CMAKE_INSTALL_DEFAULT_COMPONENT_NAME} # use the deafult for the time being
${exclude_patterns}
)
endforeach()
endfunction() endfunction()
@ -65,7 +78,7 @@ endfunction()
# \arg:DESTINATION (optional) destination to install the directory to (relative to CMAKE_PREFIX_PATH) # \arg:DESTINATION (optional) destination to install the directory to (relative to CMAKE_PREFIX_PATH)
# \arg:PROGRAMS (optional) indicates if the files are programs that should be installed with EXECUTE permissions # \arg:PROGRAMS (optional) indicates if the files are programs that should be installed with EXECUTE permissions
# #
# \notes: refer to cmake's install(DIRECTORY documentation for more information # \notes: refer to cmake's install(FILES/PROGRAMS documentation for more information
# #
function(ly_install_files) function(ly_install_files)
@ -82,13 +95,19 @@ function(ly_install_files)
message(FATAL_ERROR "You must provide a destination to install filest to") message(FATAL_ERROR "You must provide a destination to install filest to")
endif() endif()
unset(files)
foreach(file ${ly_install_files_FILES})
cmake_path(ABSOLUTE_PATH file)
list(APPEND files ${file})
endforeach()
if(ly_install_files_PROGRAMS) if(ly_install_files_PROGRAMS)
set(install_type PROGRAMS) set(install_type PROGRAMS)
else() else()
set(install_type FILES) set(install_type FILES)
endif() endif()
install(${install_type} ${ly_install_files_FILES} install(${install_type} ${files}
DESTINATION ${ly_install_files_DESTINATION} DESTINATION ${ly_install_files_DESTINATION}
COMPONENT ${CMAKE_INSTALL_DEFAULT_COMPONENT_NAME} # use the deafult for the time being COMPONENT ${CMAKE_INSTALL_DEFAULT_COMPONENT_NAME} # use the deafult for the time being
) )

@ -6,8 +6,10 @@
# #
# #
add_subdirectory(bundler) if(PAL_TRAIT_BUILD_HOST_TOOLS)
add_subdirectory(detect_file_changes) add_subdirectory(bundler)
add_subdirectory(commit_validation) add_subdirectory(detect_file_changes)
add_subdirectory(o3de) add_subdirectory(commit_validation)
add_subdirectory(ctest) add_subdirectory(o3de)
add_subdirectory(ctest)
endif()

@ -6,8 +6,6 @@
# #
# #
ly_install_directory(DIRECTORY . ly_install_directory(DIRECTORIES .
EXCLUDE_PATTERNS EXCLUDE_PATTERNS tests
__pycache__
CMakeLists.txt
) )

@ -8,15 +8,22 @@
add_subdirectory(tests) add_subdirectory(tests)
file(GLOB o3de_scripts "${LY_ROOT_FOLDER}/scripts/o3de.*") ly_get_list_relative_pal_filename(pal_dir ${CMAKE_CURRENT_LIST_DIR}/Platform/${PAL_PLATFORM_NAME})
ly_install_files(FILES ${o3de_scripts} include(${pal_dir}/o3de_install_${PAL_PLATFORM_NAME_LOWERCASE}.cmake)
PROGRAMS
DESTINATION ./scripts ly_install_files(FILES ../o3de.py
DESTINATION scripts
)
ly_install_files(FILES setup.py PROGRAMS
DESTINATION scripts/o3de
)
ly_install_files(FILES README.txt
DESTINATION scripts/o3de
) )
ly_install_directory(DIRECTORY . ly_install_directory(DIRECTORIES .
EXCLUDE_PATTERNS EXCLUDE_PATTERNS
__pycache__
CMakeLists.txt
tests tests
Platform
) )

@ -0,0 +1,12 @@
#
# 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
#
#
ly_install_files(FILES ../o3de.sh PROGRAMS
DESTINATION scripts
)

@ -0,0 +1,11 @@
#
# 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
#
#
ly_install_files(FILES ../o3de.sh PROGRAMS
DESTINATION scripts
)

@ -0,0 +1,11 @@
#
# 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
#
#
ly_install_files(FILES ../o3de.bat PROGRAMS
DESTINATION scripts
)
Loading…
Cancel
Save