mirror of
https://github.com/libsdl-org/SDL.git
synced 2025-10-22 17:11:43 +00:00
cmake: copy sources to binary directory in separate target
Don't do it in POST_BUILD to avoid multiple parallel builds
stepping on each others toes.
Also don't use copy_if_different, but unconditionally copy it.
The build system should take care of dependencies.
SDL2 backport of fea6e7afb1
This commit is contained in:
@@ -7,7 +7,7 @@ include(CMakePushCheckState)
|
|||||||
|
|
||||||
set(SDL_TEST_EXECUTABLES)
|
set(SDL_TEST_EXECUTABLES)
|
||||||
set(SDL_TESTS_NONINTERACTIVE)
|
set(SDL_TESTS_NONINTERACTIVE)
|
||||||
set(SDL_TESTS_NEEDS_ESOURCES)
|
set(SDL_TESTS_NEEDS_RESOURCES)
|
||||||
|
|
||||||
macro(add_sdl_test_executable TARGET)
|
macro(add_sdl_test_executable TARGET)
|
||||||
cmake_parse_arguments(AST "NONINTERACTIVE;NEEDS_RESOURCES" "" "" ${ARGN})
|
cmake_parse_arguments(AST "NONINTERACTIVE;NEEDS_RESOURCES" "" "" ${ARGN})
|
||||||
@@ -22,7 +22,7 @@ macro(add_sdl_test_executable TARGET)
|
|||||||
list(APPEND SDL_TESTS_NONINTERACTIVE ${TARGET})
|
list(APPEND SDL_TESTS_NONINTERACTIVE ${TARGET})
|
||||||
endif()
|
endif()
|
||||||
if(AST_NEEDS_RESOURCES)
|
if(AST_NEEDS_RESOURCES)
|
||||||
list(APPEND SDL_TESTS_NEEDS_ESOURCES ${TARGET})
|
list(APPEND SDL_TESTS_NEEDS_RESOURCES ${TARGET})
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(HAVE_GCC_WDOCUMENTATION)
|
if(HAVE_GCC_WDOCUMENTATION)
|
||||||
@@ -90,7 +90,7 @@ if(PSP)
|
|||||||
psppower
|
psppower
|
||||||
)
|
)
|
||||||
elseif(PS2)
|
elseif(PS2)
|
||||||
link_libraries(
|
link_libraries(
|
||||||
SDL2main
|
SDL2main
|
||||||
SDL2_test
|
SDL2_test
|
||||||
SDL2-static
|
SDL2-static
|
||||||
@@ -98,7 +98,7 @@ link_libraries(
|
|||||||
gskit
|
gskit
|
||||||
dmakit
|
dmakit
|
||||||
ps2_drivers
|
ps2_drivers
|
||||||
)
|
)
|
||||||
else()
|
else()
|
||||||
link_libraries(SDL2::SDL2test SDL2::SDL2-static)
|
link_libraries(SDL2::SDL2test SDL2::SDL2-static)
|
||||||
endif()
|
endif()
|
||||||
@@ -128,7 +128,7 @@ if(NOT MSVC OR NOT CMAKE_GENERATOR_PLATFORM STREQUAL "ARM64")
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
if (OPENGL_FOUND)
|
if (OPENGL_FOUND)
|
||||||
add_definitions(-DHAVE_OPENGL)
|
add_definitions(-DHAVE_OPENGL)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
add_sdl_test_executable(checkkeys checkkeys.c)
|
add_sdl_test_executable(checkkeys checkkeys.c)
|
||||||
@@ -254,18 +254,18 @@ endif()
|
|||||||
cmake_pop_check_state()
|
cmake_pop_check_state()
|
||||||
|
|
||||||
if(SDL_DUMMYAUDIO)
|
if(SDL_DUMMYAUDIO)
|
||||||
list(APPEND SDL_TESTS_NONINTERACTIVE
|
list(APPEND SDL_TESTS_NONINTERACTIVE
|
||||||
testaudioinfo
|
testaudioinfo
|
||||||
testsurround
|
testsurround
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(SDL_DUMMYVIDEO)
|
if(SDL_DUMMYVIDEO)
|
||||||
list(APPEND SDL_TESTS_NONINTERACTIVE
|
list(APPEND SDL_TESTS_NONINTERACTIVE
|
||||||
testkeys
|
testkeys
|
||||||
testbounds
|
testbounds
|
||||||
testdisplayinfo
|
testdisplayinfo
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(OPENGL_FOUND)
|
if(OPENGL_FOUND)
|
||||||
@@ -291,7 +291,7 @@ file(COPY ${RESOURCE_FILES} DESTINATION ${CMAKE_CURRENT_BINARY_DIR})
|
|||||||
if(PSP)
|
if(PSP)
|
||||||
# Build EBOOT files if building for PSP
|
# Build EBOOT files if building for PSP
|
||||||
set(BUILD_EBOOT
|
set(BUILD_EBOOT
|
||||||
${SDL_TESTS_NEEDS_ESOURCES}
|
${SDL_TESTS_NEEDS_RESOURCES}
|
||||||
testatomic
|
testatomic
|
||||||
testaudiocapture
|
testaudiocapture
|
||||||
testaudioinfo
|
testaudioinfo
|
||||||
@@ -400,14 +400,41 @@ if(RISCOS)
|
|||||||
endforeach()
|
endforeach()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if(CMAKE_RUNTIME_OUTPUT_DIRECTORY)
|
||||||
|
set(test_bin_dir "${CMAKE_RUNTIME_OUTPUT_DIRECTORY}")
|
||||||
|
if(NOT IS_ABSOLUTE "${CMAKE_RUNTIME_OUTPUT_DIRECTORY}")
|
||||||
|
set(test_bin_dir "${CMAKE_CURRENT_BINARY_DIR}/${CMAKE_RUNTIME_OUTPUT_DIRECTORY}")
|
||||||
|
endif()
|
||||||
|
else()
|
||||||
|
set(test_bin_dir "${CMAKE_CURRENT_BINARY_DIR}")
|
||||||
|
endif()
|
||||||
|
if(NOT CMAKE_VERSION VERSION_LESS 3.20)
|
||||||
|
get_property(is_multi_config GLOBAL PROPERTY GENERATOR_IS_MULTI_CONFIG)
|
||||||
|
set(test_bin_dir "${test_bin_dir}$<$<BOOL:${is_multi_config}>:/$<CONFIG>>")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set(RESOURCE_FILES_BINDIR)
|
||||||
|
foreach(resource_file IN LISTS RESOURCE_FILES)
|
||||||
|
get_filename_component(res_file_name ${resource_file} NAME)
|
||||||
|
set(resource_file_bindir "${test_bin_dir}/${res_file_name}")
|
||||||
|
add_custom_command(OUTPUT "${resource_file_bindir}"
|
||||||
|
COMMAND "${CMAKE_COMMAND}" -E copy "${resource_file}" "${resource_file_bindir}"
|
||||||
|
DEPENDS "${resource_file}"
|
||||||
|
)
|
||||||
|
list(APPEND RESOURCE_FILES_BINDIR "${resource_file_bindir}")
|
||||||
|
endforeach()
|
||||||
|
add_custom_target(copy-sdl-test-resources
|
||||||
|
DEPENDS "${RESOURCE_FILES_BINDIR}"
|
||||||
|
)
|
||||||
|
|
||||||
foreach(APP IN LISTS SDL_TESTS_NEEDS_RESOURCES)
|
foreach(APP IN LISTS SDL_TESTS_NEEDS_RESOURCES)
|
||||||
foreach(RESOURCE_FILE ${RESOURCE_FILES})
|
if(PSP OR PS2)
|
||||||
if(PSP OR PS2)
|
foreach(RESOURCE_FILE ${RESOURCE_FILES})
|
||||||
add_custom_command(TARGET ${APP} POST_BUILD COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${RESOURCE_FILE} $<TARGET_FILE_DIR:${APP}>/sdl-${APP})
|
add_custom_command(TARGET ${APP} POST_BUILD COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${RESOURCE_FILE} $<TARGET_FILE_DIR:${APP}>/sdl-${APP})
|
||||||
else()
|
endforeach()
|
||||||
add_custom_command(TARGET ${APP} POST_BUILD COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${RESOURCE_FILE} $<TARGET_FILE_DIR:${APP}>)
|
else()
|
||||||
endif()
|
add_dependencies(${APP} copy-sdl-test-resources)
|
||||||
endforeach(RESOURCE_FILE)
|
endif()
|
||||||
if(APPLE)
|
if(APPLE)
|
||||||
# Make sure resource files get installed into macOS/iOS .app bundles.
|
# Make sure resource files get installed into macOS/iOS .app bundles.
|
||||||
target_sources(${APP} PRIVATE "${RESOURCE_FILES}")
|
target_sources(${APP} PRIVATE "${RESOURCE_FILES}")
|
||||||
|
Reference in New Issue
Block a user