|
@@ -3,12 +3,12 @@ if(${CMAKE_CURRENT_SOURCE_DIR} STREQUAL ${CMAKE_CURRENT_BINARY_DIR})
|
|
|
endif()
|
|
|
|
|
|
cmake_minimum_required(VERSION 3.0.0)
|
|
|
-project(SDL2 C CXX)
|
|
|
+project(SDL3 C CXX)
|
|
|
|
|
|
if(CMAKE_SOURCE_DIR STREQUAL PROJECT_SOURCE_DIR)
|
|
|
- set(SDL2_SUBPROJECT OFF)
|
|
|
+ set(SDL3_SUBPROJECT OFF)
|
|
|
else()
|
|
|
- set(SDL2_SUBPROJECT ON)
|
|
|
+ set(SDL3_SUBPROJECT ON)
|
|
|
endif()
|
|
|
|
|
|
if (HAIKU)
|
|
@@ -35,7 +35,7 @@ endif()
|
|
|
# Build in parallel under Visual Studio. Not enabled by default.
|
|
|
if(MSVC)
|
|
|
target_compile_options(sdl-build-options INTERFACE "/MP")
|
|
|
-endif(MSVC)
|
|
|
+endif()
|
|
|
|
|
|
# CMake 3.0 expands the "if(${A})" in "set(OFF 1);set(A OFF);if(${A})" to "if(1)"
|
|
|
# CMake 3.24+ emits a warning when not set.
|
|
@@ -46,7 +46,7 @@ if(POLICY CMP0054)
|
|
|
endif()
|
|
|
|
|
|
# !!! FIXME: this should probably do "MACOSX_RPATH ON" as a target property
|
|
|
-# !!! FIXME: for the SDL2 shared library (so you get an
|
|
|
+# !!! FIXME: for the SDL shared library (so you get an
|
|
|
# !!! FIXME: install_name ("soname") of "@rpath/libSDL-whatever.dylib"
|
|
|
# !!! FIXME: instead of "/usr/local/lib/libSDL-whatever.dylib"), but I'm
|
|
|
# !!! FIXME: punting for now and leaving the existing behavior. Until this
|
|
@@ -58,6 +58,7 @@ endif()
|
|
|
include(CheckLibraryExists)
|
|
|
include(CheckIncludeFiles)
|
|
|
include(CheckIncludeFile)
|
|
|
+include(CheckLanguage)
|
|
|
include(CheckSymbolExists)
|
|
|
include(CheckCSourceCompiles)
|
|
|
include(CheckCSourceRuns)
|
|
@@ -66,12 +67,14 @@ include(CheckCXXCompilerFlag)
|
|
|
include(CheckStructHasMember)
|
|
|
include(CMakeDependentOption)
|
|
|
include(CMakePushCheckState)
|
|
|
-include(FindPkgConfig)
|
|
|
include(GNUInstallDirs)
|
|
|
|
|
|
-list(APPEND CMAKE_MODULE_PATH "${SDL2_SOURCE_DIR}/cmake")
|
|
|
-include(${SDL2_SOURCE_DIR}/cmake/macros.cmake)
|
|
|
-include(${SDL2_SOURCE_DIR}/cmake/sdlchecks.cmake)
|
|
|
+find_package(PkgConfig)
|
|
|
+
|
|
|
+list(APPEND CMAKE_MODULE_PATH "${SDL3_SOURCE_DIR}/cmake")
|
|
|
+include(${SDL3_SOURCE_DIR}/cmake/macros.cmake)
|
|
|
+include(${SDL3_SOURCE_DIR}/cmake/sdlchecks.cmake)
|
|
|
+include(${SDL3_SOURCE_DIR}/cmake/CheckCPUArchitecture.cmake)
|
|
|
|
|
|
# Enable large file support on 32-bit glibc, so that we can access files
|
|
|
# with large inode numbers
|
|
@@ -81,8 +84,8 @@ if (LIBC_IS_GLIBC AND CMAKE_SIZEOF_VOID_P EQUAL 4)
|
|
|
endif()
|
|
|
|
|
|
# See docs/release_checklist.md
|
|
|
-set(SDL_MAJOR_VERSION 2)
|
|
|
-set(SDL_MINOR_VERSION 25)
|
|
|
+set(SDL_MAJOR_VERSION 3)
|
|
|
+set(SDL_MINOR_VERSION 0)
|
|
|
set(SDL_MICRO_VERSION 0)
|
|
|
set(SDL_VERSION "${SDL_MAJOR_VERSION}.${SDL_MINOR_VERSION}.${SDL_MICRO_VERSION}")
|
|
|
|
|
@@ -95,15 +98,15 @@ mark_as_advanced(CMAKE_IMPORT_LIBRARY_SUFFIX SDL_CMAKE_DEBUG_POSTFIX)
|
|
|
# Calculate a libtool-like version number
|
|
|
math(EXPR SDL_BINARY_AGE "${SDL_MINOR_VERSION} * 100 + ${SDL_MICRO_VERSION}")
|
|
|
if(SDL_MINOR_VERSION MATCHES "[02468]$")
|
|
|
- # Stable branch, 2.24.1 -> libSDL2-2.0.so.0.2400.1
|
|
|
+ # Stable branch, 3.24.1 -> libSDL3-3.0.so.0.2400.1
|
|
|
set(SDL_INTERFACE_AGE ${SDL_MICRO_VERSION})
|
|
|
else()
|
|
|
- # Development branch, 2.23.1 -> libSDL2-2.0.so.0.2301.0
|
|
|
+ # Development branch, 3.23.1 -> libSDL3-3.0.so.0.2301.0
|
|
|
set(SDL_INTERFACE_AGE 0)
|
|
|
endif()
|
|
|
|
|
|
# Increment this if there is an incompatible change - but if that happens,
|
|
|
-# we should rename the library from SDL2 to SDL3, at which point this would
|
|
|
+# we should rename the library from SDL3 to SDL4, at which point this would
|
|
|
# reset to 0 anyway.
|
|
|
set(LT_MAJOR "0")
|
|
|
|
|
@@ -111,10 +114,10 @@ math(EXPR LT_AGE "${SDL_BINARY_AGE} - ${SDL_INTERFACE_AGE}")
|
|
|
math(EXPR LT_CURRENT "${LT_MAJOR} + ${LT_AGE}")
|
|
|
set(LT_REVISION "${SDL_INTERFACE_AGE}")
|
|
|
# For historical reasons, the library name redundantly includes the major
|
|
|
-# version twice: libSDL2-2.0.so.0.
|
|
|
+# version twice: libSDL3-3.0.so.0.
|
|
|
# TODO: in SDL 3, set the OUTPUT_NAME to plain SDL3, which will simplify
|
|
|
# it to libSDL3.so.0
|
|
|
-set(LT_RELEASE "2.0")
|
|
|
+set(LT_RELEASE "3.0")
|
|
|
set(LT_VERSION "${LT_MAJOR}.${LT_AGE}.${LT_REVISION}")
|
|
|
|
|
|
# The following should match the versions in the Xcode project file.
|
|
@@ -143,7 +146,7 @@ else()
|
|
|
set(ARCH_64 FALSE)
|
|
|
set(PROCESSOR_ARCH "x86")
|
|
|
endif()
|
|
|
-set(LIBNAME SDL2)
|
|
|
+set(LIBNAME SDL3)
|
|
|
if(NOT LIBTYPE)
|
|
|
set(LIBTYPE SHARED)
|
|
|
endif()
|
|
@@ -196,6 +199,8 @@ elseif(CMAKE_SYSTEM_NAME MATCHES "BeOS.*")
|
|
|
message_error("BeOS support has been removed as of SDL 2.0.2.")
|
|
|
elseif(CMAKE_SYSTEM_NAME MATCHES "Haiku.*")
|
|
|
set(HAIKU TRUE)
|
|
|
+elseif(NINTENDO_3DS)
|
|
|
+ set(N3DS TRUE)
|
|
|
endif()
|
|
|
|
|
|
# Don't mistake osx for unix
|
|
@@ -277,7 +282,7 @@ if(APPLE OR ARCH_64 OR MSVC_CLANG)
|
|
|
set(OPT_DEF_SSEMATH ON)
|
|
|
endif()
|
|
|
endif()
|
|
|
-if(UNIX OR MINGW OR MSYS OR (USE_CLANG AND NOT WINDOWS) OR VITA OR PSP OR PS2)
|
|
|
+if(UNIX OR MINGW OR MSYS OR (USE_CLANG AND NOT WINDOWS) OR VITA OR PSP OR PS2 OR N3DS)
|
|
|
set(OPT_DEF_LIBC ON)
|
|
|
endif()
|
|
|
|
|
@@ -320,9 +325,9 @@ if(MSVC)
|
|
|
endif()
|
|
|
endif()
|
|
|
|
|
|
-# Those are used for pkg-config and friends, so that the sdl2.pc, sdl2-config,
|
|
|
+# Those are used for pkg-config and friends, so that the sdl3.pc, sdl3-config,
|
|
|
# etc. are created correctly.
|
|
|
-set(SDL_LIBS "-lSDL2")
|
|
|
+set(SDL_LIBS "-lSDL3")
|
|
|
set(SDL_CFLAGS )
|
|
|
|
|
|
# When building shared lib for Windows with MinGW,
|
|
@@ -353,13 +358,13 @@ endif()
|
|
|
|
|
|
# General includes
|
|
|
target_compile_definitions(sdl-build-options INTERFACE "-DUSING_GENERATED_CONFIG_H")
|
|
|
-target_include_directories(sdl-build-options BEFORE INTERFACE "${SDL2_BINARY_DIR}/include" "${SDL2_BINARY_DIR}/include-config-$<LOWER_CASE:$<CONFIG>>")
|
|
|
+target_include_directories(sdl-build-options BEFORE INTERFACE "${SDL3_BINARY_DIR}/include" "${SDL3_BINARY_DIR}/include-config-$<LOWER_CASE:$<CONFIG>>")
|
|
|
# Note: The clang toolset for Visual Studio does not support the '-idirafter' option.
|
|
|
if(USE_GCC OR (USE_CLANG AND NOT MSVC_CLANG))
|
|
|
# !!! FIXME: do we _need_ to mess with CMAKE_C_FLAGS here?
|
|
|
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -idirafter \"${SDL2_SOURCE_DIR}/src/video/khronos\"")
|
|
|
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -idirafter \"${SDL3_SOURCE_DIR}/src/video/khronos\"")
|
|
|
else()
|
|
|
- target_include_directories(sdl-build-options INTERFACE "${SDL2_SOURCE_DIR}/src/video/khronos")
|
|
|
+ target_include_directories(sdl-build-options INTERFACE "${SDL3_SOURCE_DIR}/src/video/khronos")
|
|
|
endif()
|
|
|
|
|
|
# All these ENABLED_BY_DEFAULT vars will default to ON if not specified, so
|
|
@@ -378,10 +383,9 @@ if(EMSCRIPTEN)
|
|
|
set(SDL_ATOMIC_ENABLED_BY_DEFAULT OFF)
|
|
|
set(SDL_LOADSO_ENABLED_BY_DEFAULT OFF)
|
|
|
set(SDL_CPUINFO_ENABLED_BY_DEFAULT OFF)
|
|
|
- set(SDL_TEST_ENABLED_BY_DEFAULT OFF)
|
|
|
endif()
|
|
|
|
|
|
-if(VITA OR PSP OR PS2)
|
|
|
+if(VITA OR PSP OR PS2 OR N3DS)
|
|
|
set(SDL_SHARED_ENABLED_BY_DEFAULT OFF)
|
|
|
set(SDL_LOADSO_ENABLED_BY_DEFAULT OFF)
|
|
|
endif()
|
|
@@ -423,9 +427,9 @@ foreach(_SUB ${SDL_SUBSYSTEMS})
|
|
|
endforeach()
|
|
|
|
|
|
# Allow some projects to be built conditionally.
|
|
|
-set_option(SDL2_DISABLE_SDL2MAIN "Disable building/installation of SDL2main" OFF)
|
|
|
-set_option(SDL2_DISABLE_INSTALL "Disable installation of SDL2" ${SDL2_SUBPROJECT})
|
|
|
-set_option(SDL2_DISABLE_UNINSTALL "Disable uninstallation of SDL2" OFF)
|
|
|
+set_option(SDL3_DISABLE_SDL3MAIN "Disable building/installation of SDL3main" OFF)
|
|
|
+set_option(SDL3_DISABLE_INSTALL "Disable installation of SDL3" ${SDL3_SUBPROJECT})
|
|
|
+set_option(SDL3_DISABLE_UNINSTALL "Disable uninstallation of SDL3" OFF)
|
|
|
|
|
|
option_string(SDL_ASSERTIONS "Enable internal sanity checks (auto/disabled/release/enabled/paranoid)" "auto")
|
|
|
#set_option(SDL_DEPENDENCY_TRACKING "Use gcc -MMD -MT dependency tracking" ON)
|
|
@@ -444,10 +448,9 @@ set_option(SDL_ARMNEON "use NEON assembly blitters on ARM" OFF)
|
|
|
dep_option(SDL_DBUS "Enable D-Bus support" ON ${UNIX_SYS} OFF)
|
|
|
set_option(SDL_DISKAUDIO "Support the disk writer audio driver" ON)
|
|
|
set_option(SDL_DUMMYAUDIO "Support the dummy audio driver" ON)
|
|
|
-set_option(SDL_DIRECTFB "Use DirectFB video driver" OFF)
|
|
|
-dep_option(SDL_DIRECTFB_SHARED "Dynamically load directfb support" ON "SDL_DIRECTFB" OFF)
|
|
|
set_option(SDL_DUMMYVIDEO "Use dummy video driver" ON)
|
|
|
dep_option(SDL_IBUS "Enable IBus support" ON ${UNIX_SYS} OFF)
|
|
|
+set_option(SDL_SYSTEM_ICONV "Use iconv() from system-installed libraries" ON)
|
|
|
set_option(SDL_OPENGL "Include OpenGL support" ON)
|
|
|
set_option(SDL_OPENGLES "Include OpenGL ES support" ON)
|
|
|
set_option(SDL_PTHREADS "Use POSIX threads for multi-threading" ${SDL_PTHREADS_ENABLED_BY_DEFAULT})
|
|
@@ -457,20 +460,12 @@ set_option(SDL_ALSA "Support the ALSA audio API" ${UNIX_SYS})
|
|
|
dep_option(SDL_ALSA_SHARED "Dynamically load ALSA audio support" ON "SDL_ALSA" OFF)
|
|
|
set_option(SDL_JACK "Support the JACK audio API" ${UNIX_SYS})
|
|
|
dep_option(SDL_JACK_SHARED "Dynamically load JACK audio support" ON "SDL_JACK" OFF)
|
|
|
-set_option(SDL_ESD "Support the Enlightened Sound Daemon" ${UNIX_SYS})
|
|
|
-dep_option(SDL_ESD_SHARED "Dynamically load ESD audio support" ON "SDL_ESD" OFF)
|
|
|
set_option(SDL_PIPEWIRE "Use Pipewire audio" ${UNIX_SYS})
|
|
|
dep_option(SDL_PIPEWIRE_SHARED "Dynamically load Pipewire support" ON "SDL_PIPEWIRE" OFF)
|
|
|
set_option(SDL_PULSEAUDIO "Use PulseAudio" ${UNIX_SYS})
|
|
|
dep_option(SDL_PULSEAUDIO_SHARED "Dynamically load PulseAudio support" ON "SDL_PULSEAUDIO" OFF)
|
|
|
-set_option(SDL_ARTS "Support the Analog Real Time Synthesizer" ${UNIX_SYS})
|
|
|
-dep_option(SDL_ARTS_SHARED "Dynamically load aRts audio support" ON "SDL_ARTS" OFF)
|
|
|
-set_option(SDL_NAS "Support the NAS audio API" ${UNIX_SYS})
|
|
|
-dep_option(SDL_NAS_SHARED "Dynamically load NAS audio support" ON "SDL_NAS" OFF)
|
|
|
set_option(SDL_SNDIO "Support the sndio audio API" ${UNIX_SYS})
|
|
|
dep_option(SDL_SNDIO_SHARED "Dynamically load the sndio audio API" ON "SDL_SNDIO" OFF)
|
|
|
-set_option(SDL_FUSIONSOUND "Use FusionSound audio driver" OFF)
|
|
|
-dep_option(SDL_FUSIONSOUND_SHARED "Dynamically load fusionsound audio support" ON "SDL_FUSIONSOUND" OFF)
|
|
|
set_option(SDL_LIBSAMPLERATE "Use libsamplerate for audio rate conversion" ${UNIX_SYS})
|
|
|
dep_option(SDL_LIBSAMPLERATE_SHARED "Dynamically load libsamplerate" ON "SDL_LIBSAMPLERATE" OFF)
|
|
|
set_option(SDL_RPATH "Use an rpath when linking SDL" ${UNIX_SYS})
|
|
@@ -507,10 +502,14 @@ dep_option(SDL_HIDAPI_LIBUSB "Use libusb for low level joystick drivers" O
|
|
|
dep_option(SDL_HIDAPI_JOYSTICK "Use HIDAPI for low level joystick drivers" ON SDL_HIDAPI OFF)
|
|
|
dep_option(SDL_VIRTUAL_JOYSTICK "Enable the virtual-joystick driver" ON SDL_HIDAPI OFF)
|
|
|
set_option(SDL_ASAN "Use AddressSanitizer to detect memory errors" OFF)
|
|
|
+option_string(SDL_VENDOR_INFO "Vendor name and/or version to add to SDL_REVISION" "")
|
|
|
+set_option(SDL_CCACHE "Use Ccache to speed up build" ON)
|
|
|
+
|
|
|
+option(SDL_WERROR "Enable -Werror" OFF)
|
|
|
|
|
|
option(SDL_SHARED "Build a shared version of the library" ${SDL_SHARED_ENABLED_BY_DEFAULT})
|
|
|
option(SDL_STATIC "Build a static version of the library" ${SDL_STATIC_ENABLED_BY_DEFAULT})
|
|
|
-option(SDL_TEST "Build the SDL2_test library" ${SDL_TEST_ENABLED_BY_DEFAULT})
|
|
|
+option(SDL_TEST "Build the SDL3_test library" ${SDL_TEST_ENABLED_BY_DEFAULT})
|
|
|
|
|
|
dep_option(SDL_STATIC_PIC "Static version of the library should be built with Position Independent Code" "${CMAKE_POSITION_INDEPENDENT_CODE}" "SDL_STATIC" OFF)
|
|
|
dep_option(SDL_TESTS "Build the test directory" OFF SDL_TEST OFF)
|
|
@@ -518,6 +517,26 @@ set_option(SDL_INSTALL_TESTS "Install test-cases" OFF)
|
|
|
|
|
|
set(HAVE_STATIC_PIC "${SDL_STATIC_PIC}")
|
|
|
|
|
|
+if(SDL_WERROR)
|
|
|
+ if(MSVC)
|
|
|
+ cmake_push_check_state(RESET)
|
|
|
+ check_c_compiler_flag(/WX HAVE_WX)
|
|
|
+ if(HAVE_WX)
|
|
|
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /WX")
|
|
|
+ set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /WX")
|
|
|
+ endif()
|
|
|
+ elseif(USE_GCC OR USE_CLANG)
|
|
|
+ cmake_push_check_state(RESET)
|
|
|
+ check_c_compiler_flag(-Werror HAVE_WERROR)
|
|
|
+ if(HAVE_WERROR)
|
|
|
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Werror")
|
|
|
+ set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Werror")
|
|
|
+ set(CMAKE_OBJC_FLAGS "${CMAKE_OBJC_FLAGS} -Werror")
|
|
|
+ endif()
|
|
|
+ cmake_pop_check_state()
|
|
|
+ endif()
|
|
|
+endif()
|
|
|
+
|
|
|
if(SDL_HIDAPI)
|
|
|
if(HIDAPI_ONLY_LIBUSB)
|
|
|
set(SDL_HIDAPI_LIBUSB ON CACHE BOOL "" FORCE)
|
|
@@ -533,28 +552,28 @@ endif()
|
|
|
|
|
|
# General source files
|
|
|
file(GLOB SOURCE_FILES
|
|
|
- ${SDL2_SOURCE_DIR}/src/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/atomic/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/audio/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/cpuinfo/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/dynapi/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/events/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/file/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/joystick/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/haptic/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/hidapi/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/libm/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/locale/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/misc/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/power/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/render/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/render/*/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/sensor/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/stdlib/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/thread/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/timer/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/video/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/video/yuv2rgb/*.c)
|
|
|
+ ${SDL3_SOURCE_DIR}/src/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/atomic/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/audio/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/cpuinfo/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/dynapi/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/events/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/file/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/joystick/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/haptic/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/hidapi/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/libm/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/locale/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/misc/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/power/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/render/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/render/*/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/sensor/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/stdlib/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/thread/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/timer/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/video/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/video/yuv2rgb/*.c)
|
|
|
|
|
|
|
|
|
set(SDL_DEFAULT_ASSERT_LEVEL_CONFIGURED 1)
|
|
@@ -605,9 +624,11 @@ if(USE_GCC OR USE_CLANG)
|
|
|
|
|
|
check_c_compiler_flag(-Wdeclaration-after-statement HAVE_GCC_WDECLARATION_AFTER_STATEMENT)
|
|
|
if(HAVE_GCC_WDECLARATION_AFTER_STATEMENT)
|
|
|
- check_c_compiler_flag(-Werror=declaration-after-statement HAVE_GCC_WERROR_DECLARATION_AFTER_STATEMENT)
|
|
|
- if(HAVE_GCC_WERROR_DECLARATION_AFTER_STATEMENT)
|
|
|
- list(APPEND EXTRA_CFLAGS "-Werror=declaration-after-statement")
|
|
|
+ if(SDL_WERROR)
|
|
|
+ check_c_compiler_flag(-Werror=declaration-after-statement HAVE_GCC_WERROR_DECLARATION_AFTER_STATEMENT)
|
|
|
+ if(HAVE_GCC_WERROR_DECLARATION_AFTER_STATEMENT)
|
|
|
+ list(APPEND EXTRA_CFLAGS "-Werror=declaration-after-statement")
|
|
|
+ endif()
|
|
|
endif()
|
|
|
list(APPEND EXTRA_CFLAGS "-Wdeclaration-after-statement")
|
|
|
endif()
|
|
@@ -661,8 +682,15 @@ if(USE_GCC OR USE_CLANG)
|
|
|
endif()
|
|
|
|
|
|
if(APPLE)
|
|
|
+ cmake_push_check_state(RESET)
|
|
|
+ # FIXME: don't use deprecated declarations
|
|
|
+ check_c_compiler_flag(-Wno-error=deprecated-declarations HAVE_WNO_ERROR_DEPRECATED_DECLARATIONS)
|
|
|
+ if(HAVE_WNO_ERROR_DEPRECATED_DECLARATIONS)
|
|
|
+ target_compile_options(sdl-build-options INTERFACE "-Wno-error=deprecated-declarations")
|
|
|
+ endif()
|
|
|
+ cmake_pop_check_state()
|
|
|
+
|
|
|
# FIXME: use generator expression instead of appending to EXTRA_LDFLAGS_BUILD
|
|
|
- list(APPEND EXTRA_LDFLAGS_BUILD "-Wl,-undefined,error")
|
|
|
list(APPEND EXTRA_LDFLAGS_BUILD "-Wl,-compatibility_version,${DYLIB_COMPATIBILITY_VERSION}")
|
|
|
list(APPEND EXTRA_LDFLAGS_BUILD "-Wl,-current_version,${DYLIB_CURRENT_VERSION}")
|
|
|
elseif(NOT OPENBSD)
|
|
@@ -674,6 +702,18 @@ if(USE_GCC OR USE_CLANG)
|
|
|
endif()
|
|
|
endif()
|
|
|
|
|
|
+ if(MINGW)
|
|
|
+ # See if GCC's -gdwarf-4 is supported
|
|
|
+ # See https://gcc.gnu.org/bugzilla/show_bug.cgi?id=101377 for why this is needed on Windows
|
|
|
+ cmake_push_check_state(RESET)
|
|
|
+ check_c_compiler_flag("-gdwarf-4" HAVE_GDWARF_4)
|
|
|
+ if(HAVE_GDWARF_4)
|
|
|
+ set(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} -gdwarf-4")
|
|
|
+ set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} -gdwarf-4")
|
|
|
+ endif()
|
|
|
+ cmake_pop_check_state()
|
|
|
+ endif()
|
|
|
+
|
|
|
# Force color diagnostics when one of these conditions are met
|
|
|
if(DEFINED ENV{CI} OR DEFINED ENV{USE_CCACHE} OR CMAKE_GENERATOR MATCHES Ninja)
|
|
|
if(EMSCRIPTEN OR (USE_GCC AND NOT CMAKE_C_COMPILER_VERSION VERSION_LESS 4.9))
|
|
@@ -694,10 +734,10 @@ if(MSVC)
|
|
|
endif()
|
|
|
endif()
|
|
|
|
|
|
-if(MSVC)
|
|
|
+if(CMAKE_C_COMPILER_ID STREQUAL "MSVC")
|
|
|
# Due to a limitation of Microsoft's LTO implementation, LTO must be disabled for memcpy and memset.
|
|
|
# The same applies to various functions normally belonging in the C library (for x86 architecture).
|
|
|
- set_property(SOURCE src/stdlib/SDL_mslibc.c APPEND PROPERTY COMPILE_FLAGS /GL-)
|
|
|
+ set_property(SOURCE src/stdlib/SDL_mslibc.c APPEND_STRING PROPERTY COMPILE_FLAGS " /GL-")
|
|
|
endif()
|
|
|
|
|
|
if(SDL_ASSEMBLY)
|
|
@@ -874,7 +914,7 @@ if(SDL_ASSEMBLY)
|
|
|
if(ARMSIMD_FOUND)
|
|
|
set(HAVE_ARMSIMD TRUE)
|
|
|
set(SDL_ARM_SIMD_BLITTERS 1)
|
|
|
- file(GLOB ARMSIMD_SOURCES ${SDL2_SOURCE_DIR}/src/video/arm/pixman-arm-simd*.S)
|
|
|
+ file(GLOB ARMSIMD_SOURCES ${SDL3_SOURCE_DIR}/src/video/arm/pixman-arm-simd*.S)
|
|
|
list(APPEND SOURCE_FILES ${ARMSIMD_SOURCES})
|
|
|
set(WARN_ABOUT_ARM_SIMD_ASM_MIT TRUE)
|
|
|
endif()
|
|
@@ -902,7 +942,7 @@ if(SDL_ASSEMBLY)
|
|
|
if(ARMNEON_FOUND)
|
|
|
set(HAVE_ARMNEON TRUE)
|
|
|
set(SDL_ARM_NEON_BLITTERS 1)
|
|
|
- file(GLOB ARMNEON_SOURCES ${SDL2_SOURCE_DIR}/src/video/arm/pixman-arm-neon*.S)
|
|
|
+ file(GLOB ARMNEON_SOURCES ${SDL3_SOURCE_DIR}/src/video/arm/pixman-arm-neon*.S)
|
|
|
list(APPEND SOURCE_FILES ${ARMNEON_SOURCES})
|
|
|
set(WARN_ABOUT_ARM_NEON_ASM_MIT TRUE)
|
|
|
endif()
|
|
@@ -949,18 +989,38 @@ if(SDL_LIBC)
|
|
|
endforeach()
|
|
|
set(HAVE_ALLOCA 1)
|
|
|
check_symbol_exists(M_PI math.h HAVE_M_PI)
|
|
|
- target_compile_definitions(sdl-build-options INTERFACE "-D_USE_MATH_DEFINES") # needed for M_PI
|
|
|
set(STDC_HEADERS 1)
|
|
|
else()
|
|
|
set(HAVE_LIBC TRUE)
|
|
|
- check_include_file(sys/types.h HAVE_SYS_TYPES_H)
|
|
|
- foreach(_HEADER
|
|
|
- stdio.h stdlib.h stddef.h stdarg.h malloc.h memory.h string.h limits.h float.h
|
|
|
- strings.h wchar.h inttypes.h stdint.h ctype.h math.h iconv.h signal.h libunwind.h)
|
|
|
+ set(headers_to_check
|
|
|
+ ctype.h
|
|
|
+ float.h
|
|
|
+ iconv.h
|
|
|
+ inttypes.h
|
|
|
+ limits.h
|
|
|
+ malloc.h
|
|
|
+ math.h
|
|
|
+ memory.h
|
|
|
+ signal.h
|
|
|
+ stdarg.h
|
|
|
+ stddef.h
|
|
|
+ stdint.h
|
|
|
+ stdio.h
|
|
|
+ stdlib.h
|
|
|
+ string.h
|
|
|
+ strings.h
|
|
|
+ sys/types.h
|
|
|
+ wchar.h
|
|
|
+ )
|
|
|
+ if(NOT EMSCRIPTEN)
|
|
|
+ list(APPEND headers_to_check libunwind.h)
|
|
|
+ endif()
|
|
|
+ foreach(_HEADER ${headers_to_check})
|
|
|
string(TOUPPER "HAVE_${_HEADER}" _UPPER)
|
|
|
- string(REPLACE "." "_" _HAVE_H ${_UPPER})
|
|
|
+ string(REGEX REPLACE "[./]" "_" _HAVE_H ${_UPPER})
|
|
|
check_include_file("${_HEADER}" ${_HAVE_H})
|
|
|
endforeach()
|
|
|
+ check_include_file(linux/input.h HAVE_LINUX_INPUT_H)
|
|
|
|
|
|
set(STDC_HEADER_NAMES "stddef.h;stdarg.h;stdlib.h;string.h;stdio.h;wchar.h;float.h")
|
|
|
check_include_files("${STDC_HEADER_NAMES}" STDC_HEADERS)
|
|
@@ -974,7 +1034,7 @@ if(SDL_LIBC)
|
|
|
bsearch qsort abs bcopy memset memcpy memmove memcmp strlen strlcpy strlcat
|
|
|
_strrev _strupr _strlwr index rindex strchr strrchr strstr strtok_r
|
|
|
itoa _ltoa _uitoa _ultoa strtol strtoul _i64toa _ui64toa strtoll strtoull
|
|
|
- atoi atof strcmp strncmp _stricmp strcasecmp _strnicmp strncasecmp
|
|
|
+ atoi atof strcmp strncmp _stricmp strcasecmp _strnicmp strncasecmp strcasestr
|
|
|
wcscmp _wcsdup wcsdup wcslcat wcslcpy wcslen wcsncmp wcsstr
|
|
|
wcscasecmp _wcsicmp wcsncasecmp _wcsnicmp
|
|
|
sscanf vsscanf vsnprintf fopen64 fseeko fseeko64 _Exit
|
|
@@ -1011,14 +1071,18 @@ if(SDL_LIBC)
|
|
|
endif()
|
|
|
endif()
|
|
|
|
|
|
- check_library_exists(iconv iconv_open "" HAVE_LIBICONV)
|
|
|
- if(HAVE_LIBICONV)
|
|
|
- list(APPEND EXTRA_LIBS iconv)
|
|
|
- set(HAVE_ICONV 1)
|
|
|
- else()
|
|
|
- check_library_exists(c iconv_open "" HAVE_BUILTIN_ICONV)
|
|
|
- if(HAVE_BUILTIN_ICONV)
|
|
|
+ if(SDL_SYSTEM_ICONV)
|
|
|
+ check_library_exists(iconv iconv_open "" HAVE_LIBICONV)
|
|
|
+ if(HAVE_LIBICONV)
|
|
|
+ list(APPEND EXTRA_LIBS iconv)
|
|
|
set(HAVE_ICONV 1)
|
|
|
+ set(HAVE_SYSTEM_ICONV TRUE)
|
|
|
+ else()
|
|
|
+ check_library_exists(c iconv_open "" HAVE_BUILTIN_ICONV)
|
|
|
+ if(HAVE_BUILTIN_ICONV)
|
|
|
+ set(HAVE_ICONV 1)
|
|
|
+ set(HAVE_SYSTEM_ICONV TRUE)
|
|
|
+ endif()
|
|
|
endif()
|
|
|
endif()
|
|
|
|
|
@@ -1066,14 +1130,14 @@ if(SDL_AUDIO)
|
|
|
# CheckDummyAudio/CheckDiskAudio - valid for all platforms
|
|
|
if(SDL_DUMMYAUDIO)
|
|
|
set(SDL_AUDIO_DRIVER_DUMMY 1)
|
|
|
- file(GLOB DUMMYAUDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/dummy/*.c)
|
|
|
+ file(GLOB DUMMYAUDIO_SOURCES ${SDL3_SOURCE_DIR}/src/audio/dummy/*.c)
|
|
|
list(APPEND SOURCE_FILES ${DUMMYAUDIO_SOURCES})
|
|
|
set(HAVE_DUMMYAUDIO TRUE)
|
|
|
set(HAVE_SDL_AUDIO TRUE)
|
|
|
endif()
|
|
|
if(SDL_DISKAUDIO)
|
|
|
set(SDL_AUDIO_DRIVER_DISK 1)
|
|
|
- file(GLOB DISKAUDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/disk/*.c)
|
|
|
+ file(GLOB DISKAUDIO_SOURCES ${SDL3_SOURCE_DIR}/src/audio/disk/*.c)
|
|
|
list(APPEND SOURCE_FILES ${DISKAUDIO_SOURCES})
|
|
|
set(HAVE_DISKAUDIO TRUE)
|
|
|
set(HAVE_SDL_AUDIO TRUE)
|
|
@@ -1086,7 +1150,7 @@ if(UNIX OR APPLE)
|
|
|
CheckDLOPEN()
|
|
|
if(SDL_LOADSO AND HAVE_DLOPEN)
|
|
|
set(SDL_LOADSO_DLOPEN 1)
|
|
|
- file(GLOB DLOPEN_SOURCES ${SDL2_SOURCE_DIR}/src/loadso/dlopen/*.c)
|
|
|
+ file(GLOB DLOPEN_SOURCES ${SDL3_SOURCE_DIR}/src/loadso/dlopen/*.c)
|
|
|
list(APPEND SOURCE_FILES ${DLOPEN_SOURCES})
|
|
|
set(HAVE_SDL_LOADSO TRUE)
|
|
|
endif()
|
|
@@ -1100,7 +1164,7 @@ if(SDL_JOYSTICK)
|
|
|
if(SDL_VIRTUAL_JOYSTICK)
|
|
|
set(HAVE_VIRTUAL_JOYSTICK TRUE)
|
|
|
set(SDL_JOYSTICK_VIRTUAL 1)
|
|
|
- file(GLOB JOYSTICK_VIRTUAL_SOURCES ${SDL2_SOURCE_DIR}/src/joystick/virtual/*.c)
|
|
|
+ file(GLOB JOYSTICK_VIRTUAL_SOURCES ${SDL3_SOURCE_DIR}/src/joystick/virtual/*.c)
|
|
|
list(APPEND SOURCE_FILES ${JOYSTICK_VIRTUAL_SOURCES})
|
|
|
endif()
|
|
|
endif()
|
|
@@ -1108,14 +1172,14 @@ endif()
|
|
|
if(SDL_VIDEO)
|
|
|
if(SDL_DUMMYVIDEO)
|
|
|
set(SDL_VIDEO_DRIVER_DUMMY 1)
|
|
|
- file(GLOB VIDEO_DUMMY_SOURCES ${SDL2_SOURCE_DIR}/src/video/dummy/*.c)
|
|
|
+ file(GLOB VIDEO_DUMMY_SOURCES ${SDL3_SOURCE_DIR}/src/video/dummy/*.c)
|
|
|
list(APPEND SOURCE_FILES ${VIDEO_DUMMY_SOURCES})
|
|
|
set(HAVE_DUMMYVIDEO TRUE)
|
|
|
set(HAVE_SDL_VIDEO TRUE)
|
|
|
endif()
|
|
|
if(SDL_OFFSCREEN)
|
|
|
set(SDL_VIDEO_DRIVER_OFFSCREEN 1)
|
|
|
- file(GLOB VIDEO_OFFSCREEN_SOURCES ${SDL2_SOURCE_DIR}/src/video/offscreen/*.c)
|
|
|
+ file(GLOB VIDEO_OFFSCREEN_SOURCES ${SDL3_SOURCE_DIR}/src/video/offscreen/*.c)
|
|
|
list(APPEND SOURCE_FILES ${VIDEO_OFFSCREEN_SOURCES})
|
|
|
set(HAVE_OFFSCREEN TRUE)
|
|
|
set(HAVE_SDL_VIDEO TRUE)
|
|
@@ -1124,12 +1188,12 @@ endif()
|
|
|
|
|
|
# Platform-specific options and settings
|
|
|
if(ANDROID)
|
|
|
- file(GLOB ANDROID_CORE_SOURCES ${SDL2_SOURCE_DIR}/src/core/android/*.c)
|
|
|
+ file(GLOB ANDROID_CORE_SOURCES ${SDL3_SOURCE_DIR}/src/core/android/*.c)
|
|
|
list(APPEND SOURCE_FILES ${ANDROID_CORE_SOURCES} ${ANDROID_NDK}/sources/android/cpufeatures/cpu-features.c)
|
|
|
set_property(SOURCE "${ANDROID_NDK}/sources/android/cpufeatures/cpu-features.c" APPEND_STRING PROPERTY COMPILE_FLAGS " -Wno-declaration-after-statement")
|
|
|
|
|
|
if(SDL_MISC)
|
|
|
- file(GLOB ANDROID_MISC_SOURCES ${SDL2_SOURCE_DIR}/src/misc/android/*.c)
|
|
|
+ file(GLOB ANDROID_MISC_SOURCES ${SDL3_SOURCE_DIR}/src/misc/android/*.c)
|
|
|
list(APPEND SOURCE_FILES ${ANDROID_MISC_SOURCES})
|
|
|
set(HAVE_SDL_MISC TRUE)
|
|
|
endif()
|
|
@@ -1138,40 +1202,43 @@ if(ANDROID)
|
|
|
# There seems to be no better way currently to set the ARM mode.
|
|
|
# see: https://issuetracker.google.com/issues/62264618
|
|
|
# Another option would be to set ARM mode to all compiled files
|
|
|
+ cmake_push_check_state(RESET)
|
|
|
+ set(CMAKE_REQUIRED_FLAGS "-Werror=unused-command-line-argument")
|
|
|
check_c_compiler_flag(-marm HAVE_ARM_MODE)
|
|
|
if(HAVE_ARM_MODE)
|
|
|
- set_source_files_properties(${SDL2_SOURCE_DIR}/src/atomic/SDL_spinlock.c PROPERTIES COMPILE_FLAGS -marm)
|
|
|
+ set_property(SOURCE "${SDL3_SOURCE_DIR}/src/atomic/SDL_spinlock.c" APPEND_STRING PROPERTY COMPILE_FLAGS " -marm")
|
|
|
endif()
|
|
|
+ cmake_pop_check_state()
|
|
|
|
|
|
- file(GLOB ANDROID_MAIN_SOURCES ${SDL2_SOURCE_DIR}/src/main/android/*.c)
|
|
|
+ file(GLOB ANDROID_MAIN_SOURCES ${SDL3_SOURCE_DIR}/src/main/android/*.c)
|
|
|
list(APPEND SDLMAIN_SOURCES ${ANDROID_MAIN_SOURCES})
|
|
|
|
|
|
if(SDL_AUDIO)
|
|
|
set(SDL_AUDIO_DRIVER_ANDROID 1)
|
|
|
- file(GLOB ANDROID_AUDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/android/*.c)
|
|
|
+ file(GLOB ANDROID_AUDIO_SOURCES ${SDL3_SOURCE_DIR}/src/audio/android/*.c)
|
|
|
list(APPEND SOURCE_FILES ${ANDROID_AUDIO_SOURCES})
|
|
|
|
|
|
set(SDL_AUDIO_DRIVER_OPENSLES 1)
|
|
|
- file(GLOB OPENSLES_AUDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/openslES/*.c)
|
|
|
+ file(GLOB OPENSLES_AUDIO_SOURCES ${SDL3_SOURCE_DIR}/src/audio/openslES/*.c)
|
|
|
list(APPEND SOURCE_FILES ${OPENSLES_AUDIO_SOURCES})
|
|
|
|
|
|
list(APPEND EXTRA_LIBS ${ANDROID_DL_LIBRARY} OpenSLES)
|
|
|
|
|
|
set(SDL_AUDIO_DRIVER_AAUDIO 1)
|
|
|
- file(GLOB AAUDIO_AUDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/aaudio/*.c)
|
|
|
+ file(GLOB AAUDIO_AUDIO_SOURCES ${SDL3_SOURCE_DIR}/src/audio/aaudio/*.c)
|
|
|
list(APPEND SOURCE_FILES ${AAUDIO_AUDIO_SOURCES})
|
|
|
|
|
|
set(HAVE_SDL_AUDIO TRUE)
|
|
|
endif()
|
|
|
if(SDL_FILESYSTEM)
|
|
|
set(SDL_FILESYSTEM_ANDROID 1)
|
|
|
- file(GLOB ANDROID_FILESYSTEM_SOURCES ${SDL2_SOURCE_DIR}/src/filesystem/android/*.c)
|
|
|
+ file(GLOB ANDROID_FILESYSTEM_SOURCES ${SDL3_SOURCE_DIR}/src/filesystem/android/*.c)
|
|
|
list(APPEND SOURCE_FILES ${ANDROID_FILESYSTEM_SOURCES})
|
|
|
set(HAVE_SDL_FILESYSTEM TRUE)
|
|
|
endif()
|
|
|
if(SDL_HAPTIC)
|
|
|
set(SDL_HAPTIC_ANDROID 1)
|
|
|
- file(GLOB ANDROID_HAPTIC_SOURCES ${SDL2_SOURCE_DIR}/src/haptic/android/*.c)
|
|
|
+ file(GLOB ANDROID_HAPTIC_SOURCES ${SDL3_SOURCE_DIR}/src/haptic/android/*.c)
|
|
|
list(APPEND SOURCE_FILES ${ANDROID_HAPTIC_SOURCES})
|
|
|
set(HAVE_SDL_HAPTIC TRUE)
|
|
|
endif()
|
|
@@ -1180,42 +1247,42 @@ if(ANDROID)
|
|
|
endif()
|
|
|
if(SDL_JOYSTICK)
|
|
|
set(SDL_JOYSTICK_ANDROID 1)
|
|
|
- file(GLOB ANDROID_JOYSTICK_SOURCES ${SDL2_SOURCE_DIR}/src/joystick/android/*.c ${SDL2_SOURCE_DIR}/src/joystick/steam/*.c)
|
|
|
+ file(GLOB ANDROID_JOYSTICK_SOURCES ${SDL3_SOURCE_DIR}/src/joystick/android/*.c ${SDL3_SOURCE_DIR}/src/joystick/steam/*.c)
|
|
|
list(APPEND SOURCE_FILES ${ANDROID_JOYSTICK_SOURCES})
|
|
|
set(HAVE_SDL_JOYSTICK TRUE)
|
|
|
endif()
|
|
|
if(SDL_LOADSO)
|
|
|
set(SDL_LOADSO_DLOPEN 1)
|
|
|
- file(GLOB LOADSO_SOURCES ${SDL2_SOURCE_DIR}/src/loadso/dlopen/*.c)
|
|
|
+ file(GLOB LOADSO_SOURCES ${SDL3_SOURCE_DIR}/src/loadso/dlopen/*.c)
|
|
|
list(APPEND SOURCE_FILES ${LOADSO_SOURCES})
|
|
|
set(HAVE_SDL_LOADSO TRUE)
|
|
|
endif()
|
|
|
if(SDL_POWER)
|
|
|
set(SDL_POWER_ANDROID 1)
|
|
|
- file(GLOB ANDROID_POWER_SOURCES ${SDL2_SOURCE_DIR}/src/power/android/*.c)
|
|
|
+ file(GLOB ANDROID_POWER_SOURCES ${SDL3_SOURCE_DIR}/src/power/android/*.c)
|
|
|
list(APPEND SOURCE_FILES ${ANDROID_POWER_SOURCES})
|
|
|
set(HAVE_SDL_POWER TRUE)
|
|
|
endif()
|
|
|
if(SDL_LOCALE)
|
|
|
- file(GLOB ANDROID_LOCALE_SOURCES ${SDL2_SOURCE_DIR}/src/locale/android/*.c)
|
|
|
+ file(GLOB ANDROID_LOCALE_SOURCES ${SDL3_SOURCE_DIR}/src/locale/android/*.c)
|
|
|
list(APPEND SOURCE_FILES ${ANDROID_LOCALE_SOURCES})
|
|
|
set(HAVE_SDL_LOCALE TRUE)
|
|
|
endif()
|
|
|
if(SDL_TIMERS)
|
|
|
set(SDL_TIMER_UNIX 1)
|
|
|
- file(GLOB TIMER_SOURCES ${SDL2_SOURCE_DIR}/src/timer/unix/*.c)
|
|
|
+ file(GLOB TIMER_SOURCES ${SDL3_SOURCE_DIR}/src/timer/unix/*.c)
|
|
|
list(APPEND SOURCE_FILES ${TIMER_SOURCES})
|
|
|
set(HAVE_SDL_TIMERS TRUE)
|
|
|
endif()
|
|
|
if(SDL_SENSOR)
|
|
|
set(SDL_SENSOR_ANDROID 1)
|
|
|
set(HAVE_SDL_SENSORS TRUE)
|
|
|
- file(GLOB ANDROID_SENSOR_SOURCES ${SDL2_SOURCE_DIR}/src/sensor/android/*.c)
|
|
|
+ file(GLOB ANDROID_SENSOR_SOURCES ${SDL3_SOURCE_DIR}/src/sensor/android/*.c)
|
|
|
list(APPEND SOURCE_FILES ${ANDROID_SENSOR_SOURCES})
|
|
|
endif()
|
|
|
if(SDL_VIDEO)
|
|
|
set(SDL_VIDEO_DRIVER_ANDROID 1)
|
|
|
- file(GLOB ANDROID_VIDEO_SOURCES ${SDL2_SOURCE_DIR}/src/video/android/*.c)
|
|
|
+ file(GLOB ANDROID_VIDEO_SOURCES ${SDL3_SOURCE_DIR}/src/video/android/*.c)
|
|
|
list(APPEND SOURCE_FILES ${ANDROID_VIDEO_SOURCES})
|
|
|
set(HAVE_SDL_VIDEO TRUE)
|
|
|
|
|
@@ -1262,42 +1329,42 @@ elseif(EMSCRIPTEN)
|
|
|
target_compile_options(sdl-build-options INTERFACE "-Wno-warn-absolute-paths")
|
|
|
|
|
|
if(SDL_MISC)
|
|
|
- file(GLOB EMSRIPTEN_MISC_SOURCES ${SDL2_SOURCE_DIR}/src/misc/emscripten/*.c)
|
|
|
+ file(GLOB EMSRIPTEN_MISC_SOURCES ${SDL3_SOURCE_DIR}/src/misc/emscripten/*.c)
|
|
|
list(APPEND SOURCE_FILES ${EMSRIPTEN_MISC_SOURCES})
|
|
|
set(HAVE_SDL_MISC TRUE)
|
|
|
endif()
|
|
|
if(SDL_AUDIO)
|
|
|
set(SDL_AUDIO_DRIVER_EMSCRIPTEN 1)
|
|
|
- file(GLOB EM_AUDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/emscripten/*.c)
|
|
|
+ file(GLOB EM_AUDIO_SOURCES ${SDL3_SOURCE_DIR}/src/audio/emscripten/*.c)
|
|
|
list(APPEND SOURCE_FILES ${EM_AUDIO_SOURCES})
|
|
|
set(HAVE_SDL_AUDIO TRUE)
|
|
|
endif()
|
|
|
if(SDL_FILESYSTEM)
|
|
|
set(SDL_FILESYSTEM_EMSCRIPTEN 1)
|
|
|
- file(GLOB EM_FILESYSTEM_SOURCES ${SDL2_SOURCE_DIR}/src/filesystem/emscripten/*.c)
|
|
|
+ file(GLOB EM_FILESYSTEM_SOURCES ${SDL3_SOURCE_DIR}/src/filesystem/emscripten/*.c)
|
|
|
list(APPEND SOURCE_FILES ${EM_FILESYSTEM_SOURCES})
|
|
|
set(HAVE_SDL_FILESYSTEM TRUE)
|
|
|
endif()
|
|
|
if(SDL_JOYSTICK)
|
|
|
set(SDL_JOYSTICK_EMSCRIPTEN 1)
|
|
|
- file(GLOB EM_JOYSTICK_SOURCES ${SDL2_SOURCE_DIR}/src/joystick/emscripten/*.c)
|
|
|
+ file(GLOB EM_JOYSTICK_SOURCES ${SDL3_SOURCE_DIR}/src/joystick/emscripten/*.c)
|
|
|
list(APPEND SOURCE_FILES ${EM_JOYSTICK_SOURCES})
|
|
|
set(HAVE_SDL_JOYSTICK TRUE)
|
|
|
endif()
|
|
|
if(SDL_POWER)
|
|
|
set(SDL_POWER_EMSCRIPTEN 1)
|
|
|
- file(GLOB EM_POWER_SOURCES ${SDL2_SOURCE_DIR}/src/power/emscripten/*.c)
|
|
|
+ file(GLOB EM_POWER_SOURCES ${SDL3_SOURCE_DIR}/src/power/emscripten/*.c)
|
|
|
list(APPEND SOURCE_FILES ${EM_POWER_SOURCES})
|
|
|
set(HAVE_SDL_POWER TRUE)
|
|
|
endif()
|
|
|
if(SDL_LOCALE)
|
|
|
- file(GLOB LOCALE_SOURCES ${SDL2_SOURCE_DIR}/src/locale/emscripten/*.c)
|
|
|
+ file(GLOB LOCALE_SOURCES ${SDL3_SOURCE_DIR}/src/locale/emscripten/*.c)
|
|
|
list(APPEND SOURCE_FILES ${LOCALE_SOURCES})
|
|
|
set(HAVE_SDL_LOCALE TRUE)
|
|
|
endif()
|
|
|
if(SDL_TIMERS)
|
|
|
set(SDL_TIMER_UNIX 1)
|
|
|
- file(GLOB TIMER_SOURCES ${SDL2_SOURCE_DIR}/src/timer/unix/*.c)
|
|
|
+ file(GLOB TIMER_SOURCES ${SDL3_SOURCE_DIR}/src/timer/unix/*.c)
|
|
|
list(APPEND SOURCE_FILES ${TIMER_SOURCES})
|
|
|
set(HAVE_SDL_TIMERS TRUE)
|
|
|
|
|
@@ -1307,7 +1374,7 @@ elseif(EMSCRIPTEN)
|
|
|
endif()
|
|
|
if(SDL_VIDEO)
|
|
|
set(SDL_VIDEO_DRIVER_EMSCRIPTEN 1)
|
|
|
- file(GLOB EM_VIDEO_SOURCES ${SDL2_SOURCE_DIR}/src/video/emscripten/*.c)
|
|
|
+ file(GLOB EM_VIDEO_SOURCES ${SDL3_SOURCE_DIR}/src/video/emscripten/*.c)
|
|
|
list(APPEND SOURCE_FILES ${EM_VIDEO_SOURCES})
|
|
|
set(HAVE_SDL_VIDEO TRUE)
|
|
|
|
|
@@ -1322,41 +1389,30 @@ elseif(EMSCRIPTEN)
|
|
|
|
|
|
CheckPTHREAD()
|
|
|
|
|
|
+ if(HAVE_LIBUNWIND_H)
|
|
|
+ list(APPEND EXTRA_TEST_LIBS unwind)
|
|
|
+ endif()
|
|
|
+
|
|
|
elseif(UNIX AND NOT APPLE AND NOT RISCOS AND NOT HAIKU)
|
|
|
if(SDL_AUDIO)
|
|
|
- if(SYSV5 OR SOLARIS OR HPUX)
|
|
|
- set(SDL_AUDIO_DRIVER_SUNAUDIO 1)
|
|
|
- file(GLOB SUN_AUDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/sun/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${SUN_AUDIO_SOURCES})
|
|
|
- set(HAVE_SDL_AUDIO TRUE)
|
|
|
- elseif(NETBSD)
|
|
|
+ if(NETBSD)
|
|
|
set(SDL_AUDIO_DRIVER_NETBSD 1)
|
|
|
- file(GLOB NETBSD_AUDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/netbsd/*.c)
|
|
|
+ file(GLOB NETBSD_AUDIO_SOURCES ${SDL3_SOURCE_DIR}/src/audio/netbsd/*.c)
|
|
|
list(APPEND SOURCE_FILES ${NETBSD_AUDIO_SOURCES})
|
|
|
set(HAVE_SDL_AUDIO TRUE)
|
|
|
- elseif(AIX)
|
|
|
- set(SDL_AUDIO_DRIVER_PAUDIO 1)
|
|
|
- file(GLOB AIX_AUDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/paudio/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${AIX_AUDIO_SOURCES})
|
|
|
- set(HAVE_SDL_AUDIO TRUE)
|
|
|
endif()
|
|
|
CheckOSS()
|
|
|
CheckALSA()
|
|
|
CheckJACK()
|
|
|
CheckPipewire()
|
|
|
CheckPulseAudio()
|
|
|
- CheckESD()
|
|
|
- CheckARTS()
|
|
|
- CheckNAS()
|
|
|
CheckSNDIO()
|
|
|
- CheckFusionSound()
|
|
|
endif()
|
|
|
|
|
|
if(SDL_VIDEO)
|
|
|
# Need to check for Raspberry PI first and add platform specific compiler flags, otherwise the test for GLES fails!
|
|
|
CheckRPI()
|
|
|
CheckX11()
|
|
|
- CheckDirectFB()
|
|
|
# Need to check for EGL first because KMSDRM and Wayland depends on it.
|
|
|
CheckEGL()
|
|
|
CheckKMSDRM()
|
|
@@ -1373,7 +1429,7 @@ elseif(UNIX AND NOT APPLE AND NOT RISCOS AND NOT HAIKU)
|
|
|
endif()
|
|
|
|
|
|
if(UNIX)
|
|
|
- file(GLOB CORE_UNIX_SOURCES ${SDL2_SOURCE_DIR}/src/core/unix/*.c)
|
|
|
+ file(GLOB CORE_UNIX_SOURCES ${SDL3_SOURCE_DIR}/src/core/unix/*.c)
|
|
|
list(APPEND SOURCE_FILES ${CORE_UNIX_SOURCES})
|
|
|
|
|
|
check_c_source_compiles("
|
|
@@ -1411,7 +1467,7 @@ elseif(UNIX AND NOT APPLE AND NOT RISCOS AND NOT HAIKU)
|
|
|
|
|
|
if(SDL_HAPTIC AND HAVE_INPUT_EVENTS)
|
|
|
set(SDL_HAPTIC_LINUX 1)
|
|
|
- file(GLOB HAPTIC_SOURCES ${SDL2_SOURCE_DIR}/src/haptic/linux/*.c)
|
|
|
+ file(GLOB HAPTIC_SOURCES ${SDL3_SOURCE_DIR}/src/haptic/linux/*.c)
|
|
|
list(APPEND SOURCE_FILES ${HAPTIC_SOURCES})
|
|
|
set(HAVE_SDL_HAPTIC TRUE)
|
|
|
endif()
|
|
@@ -1479,38 +1535,38 @@ elseif(UNIX AND NOT APPLE AND NOT RISCOS AND NOT HAIKU)
|
|
|
endif()
|
|
|
|
|
|
if(HAVE_DBUS_DBUS_H)
|
|
|
- list(APPEND SOURCE_FILES "${SDL2_SOURCE_DIR}/src/core/linux/SDL_dbus.c")
|
|
|
+ list(APPEND SOURCE_FILES "${SDL3_SOURCE_DIR}/src/core/linux/SDL_dbus.c")
|
|
|
endif()
|
|
|
|
|
|
if(SDL_USE_IME)
|
|
|
- list(APPEND SOURCE_FILES "${SDL2_SOURCE_DIR}/src/core/linux/SDL_ime.c")
|
|
|
+ list(APPEND SOURCE_FILES "${SDL3_SOURCE_DIR}/src/core/linux/SDL_ime.c")
|
|
|
endif()
|
|
|
|
|
|
if(HAVE_IBUS_IBUS_H)
|
|
|
- list(APPEND SOURCE_FILES "${SDL2_SOURCE_DIR}/src/core/linux/SDL_ibus.c")
|
|
|
+ list(APPEND SOURCE_FILES "${SDL3_SOURCE_DIR}/src/core/linux/SDL_ibus.c")
|
|
|
endif()
|
|
|
|
|
|
if(HAVE_FCITX)
|
|
|
- list(APPEND SOURCE_FILES "${SDL2_SOURCE_DIR}/src/core/linux/SDL_fcitx.c")
|
|
|
+ list(APPEND SOURCE_FILES "${SDL3_SOURCE_DIR}/src/core/linux/SDL_fcitx.c")
|
|
|
endif()
|
|
|
|
|
|
if(HAVE_LIBUDEV_H)
|
|
|
- list(APPEND SOURCE_FILES "${SDL2_SOURCE_DIR}/src/core/linux/SDL_udev.c")
|
|
|
+ list(APPEND SOURCE_FILES "${SDL3_SOURCE_DIR}/src/core/linux/SDL_udev.c")
|
|
|
endif()
|
|
|
|
|
|
if(HAVE_INPUT_EVENTS)
|
|
|
- list(APPEND SOURCE_FILES "${SDL2_SOURCE_DIR}/src/core/linux/SDL_evdev.c")
|
|
|
- list(APPEND SOURCE_FILES "${SDL2_SOURCE_DIR}/src/core/linux/SDL_evdev_kbd.c")
|
|
|
+ list(APPEND SOURCE_FILES "${SDL3_SOURCE_DIR}/src/core/linux/SDL_evdev.c")
|
|
|
+ list(APPEND SOURCE_FILES "${SDL3_SOURCE_DIR}/src/core/linux/SDL_evdev_kbd.c")
|
|
|
endif()
|
|
|
|
|
|
if(HAVE_INPUT_KBIO)
|
|
|
- list(APPEND SOURCE_FILES "${SDL2_SOURCE_DIR}/src/core/freebsd/SDL_evdev_kbd_freebsd.c")
|
|
|
+ list(APPEND SOURCE_FILES "${SDL3_SOURCE_DIR}/src/core/freebsd/SDL_evdev_kbd_freebsd.c")
|
|
|
endif()
|
|
|
|
|
|
# Always compiled for Linux, unconditionally:
|
|
|
- list(APPEND SOURCE_FILES "${SDL2_SOURCE_DIR}/src/core/linux/SDL_evdev_capabilities.c")
|
|
|
- list(APPEND SOURCE_FILES "${SDL2_SOURCE_DIR}/src/core/linux/SDL_threadprio.c")
|
|
|
- list(APPEND SOURCE_FILES "${SDL2_SOURCE_DIR}/src/core/linux/SDL_sandbox.c")
|
|
|
+ list(APPEND SOURCE_FILES "${SDL3_SOURCE_DIR}/src/core/linux/SDL_evdev_capabilities.c")
|
|
|
+ list(APPEND SOURCE_FILES "${SDL3_SOURCE_DIR}/src/core/linux/SDL_threadprio.c")
|
|
|
+ list(APPEND SOURCE_FILES "${SDL3_SOURCE_DIR}/src/core/linux/SDL_sandbox.c")
|
|
|
|
|
|
# src/core/unix/*.c is included in a generic if(UNIX) section, elsewhere.
|
|
|
endif()
|
|
@@ -1523,9 +1579,9 @@ elseif(UNIX AND NOT APPLE AND NOT RISCOS AND NOT HAIKU)
|
|
|
if(FREEBSD OR NETBSD OR OPENBSD OR BSDI)
|
|
|
CheckUSBHID()
|
|
|
endif()
|
|
|
- if(LINUX AND NOT ANDROID)
|
|
|
+ if(LINUX AND HAVE_LINUX_INPUT_H AND NOT ANDROID)
|
|
|
set(SDL_JOYSTICK_LINUX 1)
|
|
|
- file(GLOB JOYSTICK_SOURCES ${SDL2_SOURCE_DIR}/src/joystick/linux/*.c ${SDL2_SOURCE_DIR}/src/joystick/steam/*.c)
|
|
|
+ file(GLOB JOYSTICK_SOURCES ${SDL3_SOURCE_DIR}/src/joystick/linux/*.c ${SDL3_SOURCE_DIR}/src/joystick/steam/*.c)
|
|
|
list(APPEND SOURCE_FILES ${JOYSTICK_SOURCES})
|
|
|
set(HAVE_SDL_JOYSTICK TRUE)
|
|
|
endif()
|
|
@@ -1552,7 +1608,7 @@ elseif(UNIX AND NOT APPLE AND NOT RISCOS AND NOT HAIKU)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_MISC)
|
|
|
- file(GLOB MISC_SOURCES ${SDL2_SOURCE_DIR}/src/misc/unix/*.c)
|
|
|
+ file(GLOB MISC_SOURCES ${SDL3_SOURCE_DIR}/src/misc/unix/*.c)
|
|
|
list(APPEND SOURCE_FILES ${MISC_SOURCES})
|
|
|
set(HAVE_SDL_MISC TRUE)
|
|
|
endif()
|
|
@@ -1560,28 +1616,28 @@ elseif(UNIX AND NOT APPLE AND NOT RISCOS AND NOT HAIKU)
|
|
|
if(SDL_POWER)
|
|
|
if(LINUX)
|
|
|
set(SDL_POWER_LINUX 1)
|
|
|
- file(GLOB POWER_SOURCES ${SDL2_SOURCE_DIR}/src/power/linux/*.c)
|
|
|
+ file(GLOB POWER_SOURCES ${SDL3_SOURCE_DIR}/src/power/linux/*.c)
|
|
|
list(APPEND SOURCE_FILES ${POWER_SOURCES})
|
|
|
set(HAVE_SDL_POWER TRUE)
|
|
|
endif()
|
|
|
endif()
|
|
|
|
|
|
if(SDL_LOCALE)
|
|
|
- file(GLOB LOCALE_SOURCES ${SDL2_SOURCE_DIR}/src/locale/unix/*.c)
|
|
|
+ file(GLOB LOCALE_SOURCES ${SDL3_SOURCE_DIR}/src/locale/unix/*.c)
|
|
|
list(APPEND SOURCE_FILES ${LOCALE_SOURCES})
|
|
|
set(HAVE_SDL_LOCALE TRUE)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_FILESYSTEM)
|
|
|
set(SDL_FILESYSTEM_UNIX 1)
|
|
|
- file(GLOB FILESYSTEM_SOURCES ${SDL2_SOURCE_DIR}/src/filesystem/unix/*.c)
|
|
|
+ file(GLOB FILESYSTEM_SOURCES ${SDL3_SOURCE_DIR}/src/filesystem/unix/*.c)
|
|
|
list(APPEND SOURCE_FILES ${FILESYSTEM_SOURCES})
|
|
|
set(HAVE_SDL_FILESYSTEM TRUE)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_TIMERS)
|
|
|
set(SDL_TIMER_UNIX 1)
|
|
|
- file(GLOB TIMER_SOURCES ${SDL2_SOURCE_DIR}/src/timer/unix/*.c)
|
|
|
+ file(GLOB TIMER_SOURCES ${SDL3_SOURCE_DIR}/src/timer/unix/*.c)
|
|
|
list(APPEND SOURCE_FILES ${TIMER_SOURCES})
|
|
|
set(HAVE_SDL_TIMERS TRUE)
|
|
|
endif()
|
|
@@ -1611,11 +1667,11 @@ elseif(WINDOWS)
|
|
|
#include <windows.h>
|
|
|
int main(int argc, char **argv) { return 0; }" HAVE_WIN32_CC)
|
|
|
|
|
|
- file(GLOB CORE_SOURCES ${SDL2_SOURCE_DIR}/src/core/windows/*.c)
|
|
|
+ file(GLOB CORE_SOURCES ${SDL3_SOURCE_DIR}/src/core/windows/*.c)
|
|
|
list(APPEND SOURCE_FILES ${CORE_SOURCES})
|
|
|
|
|
|
if(WINDOWS_STORE)
|
|
|
- file(GLOB WINRT_SOURCE_FILES ${SDL2_SOURCE_DIR}/src/core/winrt/*.c ${SDL2_SOURCE_DIR}/src/core/winrt/*.cpp)
|
|
|
+ file(GLOB WINRT_SOURCE_FILES ${SDL3_SOURCE_DIR}/src/core/winrt/*.c ${SDL3_SOURCE_DIR}/src/core/winrt/*.cpp)
|
|
|
list(APPEND SOURCE_FILES ${WINRT_SOURCE_FILES})
|
|
|
endif()
|
|
|
|
|
@@ -1629,9 +1685,9 @@ elseif(WINDOWS)
|
|
|
|
|
|
if(SDL_MISC)
|
|
|
if(WINDOWS_STORE)
|
|
|
- file(GLOB MISC_SOURCES ${SDL2_SOURCE_DIR}/src/misc/winrt/*.cpp)
|
|
|
+ file(GLOB MISC_SOURCES ${SDL3_SOURCE_DIR}/src/misc/winrt/*.cpp)
|
|
|
else()
|
|
|
- file(GLOB MISC_SOURCES ${SDL2_SOURCE_DIR}/src/misc/windows/*.c)
|
|
|
+ file(GLOB MISC_SOURCES ${SDL3_SOURCE_DIR}/src/misc/windows/*.c)
|
|
|
endif()
|
|
|
list(APPEND SOURCE_FILES ${MISC_SOURCES})
|
|
|
set(HAVE_SDL_MISC TRUE)
|
|
@@ -1709,16 +1765,9 @@ elseif(WINDOWS)
|
|
|
check_include_file(shellscalingapi.h HAVE_SHELLSCALINGAPI_H)
|
|
|
|
|
|
if(SDL_AUDIO)
|
|
|
- if(NOT WINDOWS_STORE)
|
|
|
- set(SDL_AUDIO_DRIVER_WINMM 1)
|
|
|
- file(GLOB WINMM_AUDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/winmm/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${WINMM_AUDIO_SOURCES})
|
|
|
- set(HAVE_SDL_AUDIO TRUE)
|
|
|
- endif()
|
|
|
-
|
|
|
if(HAVE_DSOUND_H AND NOT WINDOWS_STORE)
|
|
|
set(SDL_AUDIO_DRIVER_DSOUND 1)
|
|
|
- file(GLOB DSOUND_AUDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/directsound/*.c)
|
|
|
+ file(GLOB DSOUND_AUDIO_SOURCES ${SDL3_SOURCE_DIR}/src/audio/directsound/*.c)
|
|
|
list(APPEND SOURCE_FILES ${DSOUND_AUDIO_SOURCES})
|
|
|
set(HAVE_SDL_AUDIO TRUE)
|
|
|
endif()
|
|
@@ -1726,9 +1775,9 @@ elseif(WINDOWS)
|
|
|
if(SDL_WASAPI AND HAVE_AUDIOCLIENT_H AND HAVE_MMDEVICEAPI_H)
|
|
|
set(SDL_AUDIO_DRIVER_WASAPI 1)
|
|
|
set(HAVE_WASAPI TRUE)
|
|
|
- file(GLOB WASAPI_AUDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/wasapi/*.c)
|
|
|
+ file(GLOB WASAPI_AUDIO_SOURCES ${SDL3_SOURCE_DIR}/src/audio/wasapi/*.c)
|
|
|
if(WINDOWS_STORE)
|
|
|
- list(APPEND WASAPI_AUDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/wasapi/SDL_wasapi_winrt.cpp)
|
|
|
+ list(APPEND WASAPI_AUDIO_SOURCES ${SDL3_SOURCE_DIR}/src/audio/wasapi/SDL_wasapi_winrt.cpp)
|
|
|
endif()
|
|
|
list(APPEND SOURCE_FILES ${WASAPI_AUDIO_SOURCES})
|
|
|
set(HAVE_SDL_AUDIO TRUE)
|
|
@@ -1743,13 +1792,13 @@ elseif(WINDOWS)
|
|
|
if(WINDOWS_STORE)
|
|
|
set(SDL_VIDEO_DRIVER_WINRT 1)
|
|
|
file(GLOB WIN_VIDEO_SOURCES
|
|
|
- ${SDL2_SOURCE_DIR}/src/video/winrt/*.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/video/winrt/*.cpp
|
|
|
- ${SDL2_SOURCE_DIR}/src/render/direct3d11/*.cpp
|
|
|
+ ${SDL3_SOURCE_DIR}/src/video/winrt/*.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/video/winrt/*.cpp
|
|
|
+ ${SDL3_SOURCE_DIR}/src/render/direct3d11/*.cpp
|
|
|
)
|
|
|
else()
|
|
|
set(SDL_VIDEO_DRIVER_WINDOWS 1)
|
|
|
- file(GLOB WIN_VIDEO_SOURCES ${SDL2_SOURCE_DIR}/src/video/windows/*.c)
|
|
|
+ file(GLOB WIN_VIDEO_SOURCES ${SDL3_SOURCE_DIR}/src/video/windows/*.c)
|
|
|
endif()
|
|
|
list(APPEND SOURCE_FILES ${WIN_VIDEO_SOURCES})
|
|
|
|
|
@@ -1772,38 +1821,38 @@ elseif(WINDOWS)
|
|
|
set(SDL_THREAD_GENERIC_COND_SUFFIX 1)
|
|
|
set(SDL_THREAD_WINDOWS 1)
|
|
|
list(APPEND SOURCE_FILES
|
|
|
- ${SDL2_SOURCE_DIR}/src/thread/generic/SDL_syscond.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/thread/windows/SDL_syscond_cv.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/thread/windows/SDL_sysmutex.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/thread/windows/SDL_syssem.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/thread/windows/SDL_systhread.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/thread/windows/SDL_systls.c)
|
|
|
+ ${SDL3_SOURCE_DIR}/src/thread/generic/SDL_syscond.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/thread/windows/SDL_syscond_cv.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/thread/windows/SDL_sysmutex.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/thread/windows/SDL_syssem.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/thread/windows/SDL_systhread.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/thread/windows/SDL_systls.c)
|
|
|
set(HAVE_SDL_THREADS TRUE)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_SENSOR AND HAVE_SENSORSAPI_H AND NOT WINDOWS_STORE)
|
|
|
set(SDL_SENSOR_WINDOWS 1)
|
|
|
set(HAVE_SDL_SENSORS TRUE)
|
|
|
- file(GLOB WINDOWS_SENSOR_SOURCES ${SDL2_SOURCE_DIR}/src/sensor/windows/*.c)
|
|
|
+ file(GLOB WINDOWS_SENSOR_SOURCES ${SDL3_SOURCE_DIR}/src/sensor/windows/*.c)
|
|
|
list(APPEND SOURCE_FILES ${WINDOWS_SENSOR_SOURCES})
|
|
|
endif()
|
|
|
|
|
|
if(SDL_POWER)
|
|
|
if(WINDOWS_STORE)
|
|
|
set(SDL_POWER_WINRT 1)
|
|
|
- list(APPEND SOURCE_FILES ${SDL2_SOURCE_DIR}/src/power/winrt/SDL_syspower.cpp)
|
|
|
+ list(APPEND SOURCE_FILES ${SDL3_SOURCE_DIR}/src/power/winrt/SDL_syspower.cpp)
|
|
|
else()
|
|
|
set(SDL_POWER_WINDOWS 1)
|
|
|
- list(APPEND SOURCE_FILES ${SDL2_SOURCE_DIR}/src/power/windows/SDL_syspower.c)
|
|
|
+ list(APPEND SOURCE_FILES ${SDL3_SOURCE_DIR}/src/power/windows/SDL_syspower.c)
|
|
|
set(HAVE_SDL_POWER TRUE)
|
|
|
endif()
|
|
|
endif()
|
|
|
|
|
|
if(SDL_LOCALE)
|
|
|
if(WINDOWS_STORE)
|
|
|
- file(GLOB LOCALE_SOURCES ${SDL2_SOURCE_DIR}/src/locale/winrt/*.c)
|
|
|
+ file(GLOB LOCALE_SOURCES ${SDL3_SOURCE_DIR}/src/locale/winrt/*.c)
|
|
|
else()
|
|
|
- file(GLOB LOCALE_SOURCES ${SDL2_SOURCE_DIR}/src/locale/windows/*.c)
|
|
|
+ file(GLOB LOCALE_SOURCES ${SDL3_SOURCE_DIR}/src/locale/windows/*.c)
|
|
|
endif()
|
|
|
list(APPEND SOURCE_FILES ${LOCALE_SOURCES})
|
|
|
set(HAVE_SDL_LOCALE TRUE)
|
|
@@ -1812,9 +1861,9 @@ elseif(WINDOWS)
|
|
|
if(SDL_FILESYSTEM)
|
|
|
set(SDL_FILESYSTEM_WINDOWS 1)
|
|
|
if(WINDOWS_STORE)
|
|
|
- file(GLOB FILESYSTEM_SOURCES ${SDL2_SOURCE_DIR}/src/filesystem/winrt/*.cpp)
|
|
|
+ file(GLOB FILESYSTEM_SOURCES ${SDL3_SOURCE_DIR}/src/filesystem/winrt/*.cpp)
|
|
|
else()
|
|
|
- file(GLOB FILESYSTEM_SOURCES ${SDL2_SOURCE_DIR}/src/filesystem/windows/*.c)
|
|
|
+ file(GLOB FILESYSTEM_SOURCES ${SDL3_SOURCE_DIR}/src/filesystem/windows/*.c)
|
|
|
endif()
|
|
|
list(APPEND SOURCE_FILES ${FILESYSTEM_SOURCES})
|
|
|
set(HAVE_SDL_FILESYSTEM TRUE)
|
|
@@ -1836,19 +1885,19 @@ elseif(WINDOWS)
|
|
|
|
|
|
if(SDL_TIMERS)
|
|
|
set(SDL_TIMER_WINDOWS 1)
|
|
|
- file(GLOB TIMER_SOURCES ${SDL2_SOURCE_DIR}/src/timer/windows/*.c)
|
|
|
+ file(GLOB TIMER_SOURCES ${SDL3_SOURCE_DIR}/src/timer/windows/*.c)
|
|
|
list(APPEND SOURCE_FILES ${TIMER_SOURCES})
|
|
|
set(HAVE_SDL_TIMERS TRUE)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_LOADSO)
|
|
|
set(SDL_LOADSO_WINDOWS 1)
|
|
|
- file(GLOB LOADSO_SOURCES ${SDL2_SOURCE_DIR}/src/loadso/windows/*.c)
|
|
|
+ file(GLOB LOADSO_SOURCES ${SDL3_SOURCE_DIR}/src/loadso/windows/*.c)
|
|
|
list(APPEND SOURCE_FILES ${LOADSO_SOURCES})
|
|
|
set(HAVE_SDL_LOADSO TRUE)
|
|
|
endif()
|
|
|
|
|
|
- file(GLOB CORE_SOURCES ${SDL2_SOURCE_DIR}/src/core/windows/*.c)
|
|
|
+ file(GLOB CORE_SOURCES ${SDL3_SOURCE_DIR}/src/core/windows/*.c)
|
|
|
list(APPEND SOURCE_FILES ${CORE_SOURCES})
|
|
|
|
|
|
if(SDL_VIDEO)
|
|
@@ -1877,7 +1926,7 @@ elseif(WINDOWS)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_JOYSTICK)
|
|
|
- file(GLOB JOYSTICK_SOURCES ${SDL2_SOURCE_DIR}/src/joystick/windows/*.c)
|
|
|
+ file(GLOB JOYSTICK_SOURCES ${SDL3_SOURCE_DIR}/src/joystick/windows/*.c)
|
|
|
list(APPEND SOURCE_FILES ${JOYSTICK_SOURCES})
|
|
|
|
|
|
if(NOT WINDOWS_STORE)
|
|
@@ -1900,7 +1949,7 @@ elseif(WINDOWS)
|
|
|
|
|
|
if(SDL_HAPTIC)
|
|
|
if((HAVE_DINPUT_H OR HAVE_XINPUT_H) AND NOT WINDOWS_STORE)
|
|
|
- file(GLOB HAPTIC_SOURCES ${SDL2_SOURCE_DIR}/src/haptic/windows/*.c)
|
|
|
+ file(GLOB HAPTIC_SOURCES ${SDL3_SOURCE_DIR}/src/haptic/windows/*.c)
|
|
|
if(HAVE_DINPUT_H)
|
|
|
set(SDL_HAPTIC_DINPUT 1)
|
|
|
endif()
|
|
@@ -1908,7 +1957,7 @@ elseif(WINDOWS)
|
|
|
set(SDL_HAPTIC_XINPUT 1)
|
|
|
endif()
|
|
|
else()
|
|
|
- file(GLOB HAPTIC_SOURCES ${SDL2_SOURCE_DIR}/src/haptic/dummy/*.c)
|
|
|
+ file(GLOB HAPTIC_SOURCES ${SDL3_SOURCE_DIR}/src/haptic/dummy/*.c)
|
|
|
set(SDL_HAPTIC_DUMMY 1)
|
|
|
endif()
|
|
|
list(APPEND SOURCE_FILES ${HAPTIC_SOURCES})
|
|
@@ -1916,13 +1965,13 @@ elseif(WINDOWS)
|
|
|
endif()
|
|
|
endif()
|
|
|
|
|
|
- file(GLOB VERSION_SOURCES ${SDL2_SOURCE_DIR}/src/main/windows/*.rc)
|
|
|
- file(GLOB SDLMAIN_SOURCES ${SDL2_SOURCE_DIR}/src/main/windows/*.c)
|
|
|
+ file(GLOB VERSION_SOURCES ${SDL3_SOURCE_DIR}/src/main/windows/*.rc)
|
|
|
+ file(GLOB SDLMAIN_SOURCES ${SDL3_SOURCE_DIR}/src/main/windows/*.c)
|
|
|
if(MINGW OR CYGWIN)
|
|
|
- if(NOT SDL2_DISABLE_SDL2MAIN)
|
|
|
+ if(NOT SDL3_DISABLE_SDL3MAIN)
|
|
|
list(APPEND SDL_CFLAGS "-Dmain=SDL_main")
|
|
|
- list(INSERT SDL_LIBS 0 "-lSDL2main")
|
|
|
- endif(NOT SDL2_DISABLE_SDL2MAIN)
|
|
|
+ list(INSERT SDL_LIBS 0 "-lSDL3main")
|
|
|
+ endif(NOT SDL3_DISABLE_SDL3MAIN)
|
|
|
list(INSERT SDL_LIBS 0 "-lmingw32" "-mwindows")
|
|
|
endif()
|
|
|
|
|
@@ -1942,20 +1991,20 @@ elseif(APPLE)
|
|
|
|
|
|
# Requires the darwin file implementation
|
|
|
if(SDL_FILE)
|
|
|
- file(GLOB EXTRA_SOURCES ${SDL2_SOURCE_DIR}/src/file/cocoa/*.m)
|
|
|
+ file(GLOB EXTRA_SOURCES ${SDL3_SOURCE_DIR}/src/file/cocoa/*.m)
|
|
|
list(APPEND SOURCE_FILES ${EXTRA_SOURCES})
|
|
|
set(HAVE_SDL_FILE TRUE)
|
|
|
endif()
|
|
|
|
|
|
if(IOS OR TVOS)
|
|
|
- file(GLOB SDLMAIN_SOURCES ${SDL2_SOURCE_DIR}/src/main/uikit/*.c)
|
|
|
+ file(GLOB SDLMAIN_SOURCES ${SDL3_SOURCE_DIR}/src/main/uikit/*.c)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_MISC)
|
|
|
if(IOS OR TVOS)
|
|
|
- file(GLOB MISC_SOURCES ${SDL2_SOURCE_DIR}/src/misc/ios/*.m)
|
|
|
+ file(GLOB MISC_SOURCES ${SDL3_SOURCE_DIR}/src/misc/ios/*.m)
|
|
|
else()
|
|
|
- file(GLOB MISC_SOURCES ${SDL2_SOURCE_DIR}/src/misc/macosx/*.m)
|
|
|
+ file(GLOB MISC_SOURCES ${SDL3_SOURCE_DIR}/src/misc/macosx/*.m)
|
|
|
endif()
|
|
|
list(APPEND SOURCE_FILES ${MISC_SOURCES})
|
|
|
set(HAVE_SDL_MISC TRUE)
|
|
@@ -1963,7 +2012,7 @@ elseif(APPLE)
|
|
|
|
|
|
if(SDL_AUDIO)
|
|
|
set(SDL_AUDIO_DRIVER_COREAUDIO 1)
|
|
|
- file(GLOB AUDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/coreaudio/*.m)
|
|
|
+ file(GLOB AUDIO_SOURCES ${SDL3_SOURCE_DIR}/src/audio/coreaudio/*.m)
|
|
|
list(APPEND SOURCE_FILES ${AUDIO_SOURCES})
|
|
|
set(HAVE_SDL_AUDIO TRUE)
|
|
|
set(SDL_FRAMEWORK_COREAUDIO 1)
|
|
@@ -1976,9 +2025,9 @@ elseif(APPLE)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_JOYSTICK)
|
|
|
- file(GLOB MFI_JOYSTICK_SOURCES ${SDL2_SOURCE_DIR}/src/joystick/iphoneos/*.m)
|
|
|
+ file(GLOB MFI_JOYSTICK_SOURCES ${SDL3_SOURCE_DIR}/src/joystick/iphoneos/*.m)
|
|
|
if(IOS OR TVOS)
|
|
|
- file(GLOB JOYSTICK_SOURCES ${SDL2_SOURCE_DIR}/src/joystick/steam/*.c)
|
|
|
+ file(GLOB JOYSTICK_SOURCES ${SDL3_SOURCE_DIR}/src/joystick/steam/*.c)
|
|
|
set(SDL_JOYSTICK_MFI 1)
|
|
|
if(IOS)
|
|
|
set(SDL_FRAMEWORK_COREMOTION 1)
|
|
@@ -1986,8 +2035,8 @@ elseif(APPLE)
|
|
|
set(SDL_FRAMEWORK_GAMECONTROLLER 1)
|
|
|
set(SDL_FRAMEWORK_COREHAPTICS 1)
|
|
|
else()
|
|
|
- file(GLOB JOYSTICK_SOURCES ${SDL2_SOURCE_DIR}/src/joystick/darwin/*.c)
|
|
|
- set_source_files_properties(${MFI_JOYSTICK_SOURCES} PROPERTIES COMPILE_FLAGS -fobjc-weak)
|
|
|
+ file(GLOB JOYSTICK_SOURCES ${SDL3_SOURCE_DIR}/src/joystick/darwin/*.c)
|
|
|
+ set_property(SOURCE ${MFI_JOYSTICK_SOURCES} APPEND_STRING PROPERTY COMPILE_FLAGS " -fobjc-weak")
|
|
|
check_objc_source_compiles("
|
|
|
#include <AvailabilityMacros.h>
|
|
|
#include <TargetConditionals.h>
|
|
@@ -2022,10 +2071,10 @@ elseif(APPLE)
|
|
|
|
|
|
if(SDL_HAPTIC)
|
|
|
if (IOS OR TVOS)
|
|
|
- file(GLOB HAPTIC_SOURCES ${SDL2_SOURCE_DIR}/src/haptic/dummy/*.c)
|
|
|
+ file(GLOB HAPTIC_SOURCES ${SDL3_SOURCE_DIR}/src/haptic/dummy/*.c)
|
|
|
set(SDL_HAPTIC_DUMMY 1)
|
|
|
else()
|
|
|
- file(GLOB HAPTIC_SOURCES ${SDL2_SOURCE_DIR}/src/haptic/darwin/*.c)
|
|
|
+ file(GLOB HAPTIC_SOURCES ${SDL3_SOURCE_DIR}/src/haptic/darwin/*.c)
|
|
|
set(SDL_HAPTIC_IOKIT 1)
|
|
|
set(SDL_FRAMEWORK_IOKIT 1)
|
|
|
set(SDL_FRAMEWORK_FF 1)
|
|
@@ -2036,10 +2085,10 @@ elseif(APPLE)
|
|
|
|
|
|
if(SDL_POWER)
|
|
|
if (IOS OR TVOS)
|
|
|
- file(GLOB POWER_SOURCES ${SDL2_SOURCE_DIR}/src/power/uikit/*.m)
|
|
|
+ file(GLOB POWER_SOURCES ${SDL3_SOURCE_DIR}/src/power/uikit/*.m)
|
|
|
set(SDL_POWER_UIKIT 1)
|
|
|
else()
|
|
|
- file(GLOB POWER_SOURCES ${SDL2_SOURCE_DIR}/src/power/macosx/*.c)
|
|
|
+ file(GLOB POWER_SOURCES ${SDL3_SOURCE_DIR}/src/power/macosx/*.c)
|
|
|
set(SDL_POWER_MACOSX 1)
|
|
|
set(SDL_FRAMEWORK_IOKIT 1)
|
|
|
endif()
|
|
@@ -2048,21 +2097,21 @@ elseif(APPLE)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_LOCALE)
|
|
|
- file(GLOB LOCALE_SOURCES ${SDL2_SOURCE_DIR}/src/locale/macosx/*.m)
|
|
|
+ file(GLOB LOCALE_SOURCES ${SDL3_SOURCE_DIR}/src/locale/macosx/*.m)
|
|
|
list(APPEND SOURCE_FILES ${LOCALE_SOURCES})
|
|
|
set(HAVE_SDL_LOCALE TRUE)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_TIMERS)
|
|
|
set(SDL_TIMER_UNIX 1)
|
|
|
- file(GLOB TIMER_SOURCES ${SDL2_SOURCE_DIR}/src/timer/unix/*.c)
|
|
|
+ file(GLOB TIMER_SOURCES ${SDL3_SOURCE_DIR}/src/timer/unix/*.c)
|
|
|
list(APPEND SOURCE_FILES ${TIMER_SOURCES})
|
|
|
set(HAVE_SDL_TIMERS TRUE)
|
|
|
endif(SDL_TIMERS)
|
|
|
|
|
|
if(SDL_FILESYSTEM)
|
|
|
set(SDL_FILESYSTEM_COCOA 1)
|
|
|
- file(GLOB FILESYSTEM_SOURCES ${SDL2_SOURCE_DIR}/src/filesystem/cocoa/*.m)
|
|
|
+ file(GLOB FILESYSTEM_SOURCES ${SDL3_SOURCE_DIR}/src/filesystem/cocoa/*.m)
|
|
|
list(APPEND SOURCE_FILES ${FILESYSTEM_SOURCES})
|
|
|
set(HAVE_SDL_FILESYSTEM TRUE)
|
|
|
endif()
|
|
@@ -2071,7 +2120,7 @@ elseif(APPLE)
|
|
|
if(IOS)
|
|
|
set(SDL_SENSOR_COREMOTION 1)
|
|
|
set(HAVE_SDL_SENSORS TRUE)
|
|
|
- file(GLOB SENSOR_SOURCES ${SDL2_SOURCE_DIR}/src/sensor/coremotion/*.m)
|
|
|
+ file(GLOB SENSOR_SOURCES ${SDL3_SOURCE_DIR}/src/sensor/coremotion/*.m)
|
|
|
list(APPEND SOURCE_FILES ${SENSOR_SOURCES})
|
|
|
endif()
|
|
|
endif()
|
|
@@ -2085,7 +2134,7 @@ elseif(APPLE)
|
|
|
set(SDL_FRAMEWORK_UIKIT 1)
|
|
|
set(SDL_IPHONE_KEYBOARD 1)
|
|
|
set(SDL_IPHONE_LAUNCHSCREEN 1)
|
|
|
- file(GLOB UIKITVIDEO_SOURCES ${SDL2_SOURCE_DIR}/src/video/uikit/*.m)
|
|
|
+ file(GLOB UIKITVIDEO_SOURCES ${SDL3_SOURCE_DIR}/src/video/uikit/*.m)
|
|
|
list(APPEND SOURCE_FILES ${UIKITVIDEO_SOURCES})
|
|
|
set(HAVE_SDL_VIDEO TRUE)
|
|
|
else()
|
|
@@ -2133,7 +2182,7 @@ elseif(APPLE)
|
|
|
set(HAVE_METAL TRUE)
|
|
|
endif()
|
|
|
if(SDL_RENDER_METAL)
|
|
|
- file(GLOB RENDER_METAL_SOURCES ${SDL2_SOURCE_DIR}/src/render/metal/*.m)
|
|
|
+ file(GLOB RENDER_METAL_SOURCES ${SDL3_SOURCE_DIR}/src/render/metal/*.m)
|
|
|
list(APPEND SOURCE_FILES ${RENDER_METAL_SOURCES})
|
|
|
set(SDL_VIDEO_RENDER_METAL 1)
|
|
|
set(HAVE_RENDER_METAL TRUE)
|
|
@@ -2217,27 +2266,27 @@ elseif(APPLE)
|
|
|
elseif(HAIKU)
|
|
|
if(SDL_AUDIO)
|
|
|
set(SDL_AUDIO_DRIVER_HAIKU 1)
|
|
|
- file(GLOB HAIKU_AUDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/haiku/*.cc)
|
|
|
+ file(GLOB HAIKU_AUDIO_SOURCES ${SDL3_SOURCE_DIR}/src/audio/haiku/*.cc)
|
|
|
list(APPEND SOURCE_FILES ${HAIKU_AUDIO_SOURCES})
|
|
|
set(HAVE_SDL_AUDIO TRUE)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_JOYSTICK)
|
|
|
set(SDL_JOYSTICK_HAIKU 1)
|
|
|
- file(GLOB HAIKU_JOYSTICK_SOURCES ${SDL2_SOURCE_DIR}/src/joystick/haiku/*.cc)
|
|
|
+ file(GLOB HAIKU_JOYSTICK_SOURCES ${SDL3_SOURCE_DIR}/src/joystick/haiku/*.cc)
|
|
|
list(APPEND SOURCE_FILES ${HAIKU_JOYSTICK_SOURCES})
|
|
|
set(HAVE_SDL_JOYSTICK TRUE)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_MISC)
|
|
|
- file(GLOB MISC_SOURCES ${SDL2_SOURCE_DIR}/src/misc/haiku/*.cc)
|
|
|
+ file(GLOB MISC_SOURCES ${SDL3_SOURCE_DIR}/src/misc/haiku/*.cc)
|
|
|
list(APPEND SOURCE_FILES ${MISC_SOURCES})
|
|
|
set(HAVE_SDL_MISC TRUE)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_VIDEO)
|
|
|
set(SDL_VIDEO_DRIVER_HAIKU 1)
|
|
|
- file(GLOB HAIKUVIDEO_SOURCES ${SDL2_SOURCE_DIR}/src/video/haiku/*.cc)
|
|
|
+ file(GLOB HAIKUVIDEO_SOURCES ${SDL3_SOURCE_DIR}/src/video/haiku/*.cc)
|
|
|
list(APPEND SOURCE_FILES ${HAIKUVIDEO_SOURCES})
|
|
|
set(HAVE_SDL_VIDEO TRUE)
|
|
|
|
|
@@ -2253,32 +2302,32 @@ elseif(HAIKU)
|
|
|
|
|
|
if(SDL_FILESYSTEM)
|
|
|
set(SDL_FILESYSTEM_HAIKU 1)
|
|
|
- file(GLOB FILESYSTEM_SOURCES ${SDL2_SOURCE_DIR}/src/filesystem/haiku/*.cc)
|
|
|
+ file(GLOB FILESYSTEM_SOURCES ${SDL3_SOURCE_DIR}/src/filesystem/haiku/*.cc)
|
|
|
list(APPEND SOURCE_FILES ${FILESYSTEM_SOURCES})
|
|
|
set(HAVE_SDL_FILESYSTEM TRUE)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_TIMERS)
|
|
|
set(SDL_TIMER_HAIKU 1)
|
|
|
- file(GLOB TIMER_SOURCES ${SDL2_SOURCE_DIR}/src/timer/haiku/*.c)
|
|
|
+ file(GLOB TIMER_SOURCES ${SDL3_SOURCE_DIR}/src/timer/haiku/*.c)
|
|
|
list(APPEND SOURCE_FILES ${TIMER_SOURCES})
|
|
|
set(HAVE_SDL_TIMERS TRUE)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_POWER)
|
|
|
set(SDL_POWER_HAIKU 1)
|
|
|
- file(GLOB HAIKU_POWER_SOURCES ${SDL2_SOURCE_DIR}/src/power/haiku/*.c)
|
|
|
+ file(GLOB HAIKU_POWER_SOURCES ${SDL3_SOURCE_DIR}/src/power/haiku/*.c)
|
|
|
list(APPEND SOURCE_FILES ${HAIKU_POWER_SOURCES})
|
|
|
set(HAVE_SDL_POWER TRUE)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_LOCALE)
|
|
|
- file(GLOB LOCALE_SOURCES ${SDL2_SOURCE_DIR}/src/locale/haiku/*.cc)
|
|
|
+ file(GLOB LOCALE_SOURCES ${SDL3_SOURCE_DIR}/src/locale/haiku/*.cc)
|
|
|
list(APPEND SOURCE_FILES ${LOCALE_SOURCES})
|
|
|
set(HAVE_SDL_LOCALE TRUE)
|
|
|
endif()
|
|
|
|
|
|
- file(GLOB MAIN_SOURCES ${SDL2_SOURCE_DIR}/src/main/haiku/*.cc)
|
|
|
+ file(GLOB MAIN_SOURCES ${SDL3_SOURCE_DIR}/src/main/haiku/*.cc)
|
|
|
list(APPEND SOURCE_FILES ${MAIN_SOURCES})
|
|
|
|
|
|
CheckPTHREAD()
|
|
@@ -2286,28 +2335,28 @@ elseif(HAIKU)
|
|
|
|
|
|
elseif(RISCOS)
|
|
|
if(SDL_MISC)
|
|
|
- file(GLOB MISC_SOURCES ${SDL2_SOURCE_DIR}/src/misc/riscos/*.c)
|
|
|
+ file(GLOB MISC_SOURCES ${SDL3_SOURCE_DIR}/src/misc/riscos/*.c)
|
|
|
list(APPEND SOURCE_FILES ${MISC_SOURCES})
|
|
|
set(HAVE_SDL_MISC TRUE)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_VIDEO)
|
|
|
set(SDL_VIDEO_DRIVER_RISCOS 1)
|
|
|
- file(GLOB RISCOSVIDEO_SOURCES ${SDL2_SOURCE_DIR}/src/video/riscos/*.c)
|
|
|
+ file(GLOB RISCOSVIDEO_SOURCES ${SDL3_SOURCE_DIR}/src/video/riscos/*.c)
|
|
|
list(APPEND SOURCE_FILES ${RISCOSVIDEO_SOURCES})
|
|
|
set(HAVE_SDL_VIDEO TRUE)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_FILESYSTEM)
|
|
|
set(SDL_FILESYSTEM_RISCOS 1)
|
|
|
- file(GLOB FILESYSTEM_SOURCES ${SDL2_SOURCE_DIR}/src/filesystem/riscos/*.c)
|
|
|
+ file(GLOB FILESYSTEM_SOURCES ${SDL3_SOURCE_DIR}/src/filesystem/riscos/*.c)
|
|
|
list(APPEND SOURCE_FILES ${FILESYSTEM_SOURCES})
|
|
|
set(HAVE_SDL_FILESYSTEM TRUE)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_TIMERS)
|
|
|
set(SDL_TIMER_UNIX 1)
|
|
|
- file(GLOB TIMER_SOURCES ${SDL2_SOURCE_DIR}/src/timer/unix/*.c)
|
|
|
+ file(GLOB TIMER_SOURCES ${SDL3_SOURCE_DIR}/src/timer/unix/*.c)
|
|
|
list(APPEND SOURCE_FILES ${TIMER_SOURCES})
|
|
|
set(HAVE_SDL_TIMERS TRUE)
|
|
|
|
|
@@ -2324,71 +2373,74 @@ elseif(RISCOS)
|
|
|
|
|
|
elseif(VITA)
|
|
|
# SDL_spinlock.c Needs to be compiled in ARM mode.
|
|
|
+ cmake_push_check_state(RESET)
|
|
|
+ set(CMAKE_REQUIRED_FLAGS "-Werror=unused-command-line-argument")
|
|
|
check_c_compiler_flag(-marm HAVE_ARM_MODE)
|
|
|
if(HAVE_ARM_MODE)
|
|
|
- set_source_files_properties(${SDL2_SOURCE_DIR}/src/atomic/SDL_spinlock.c PROPERTIES COMPILE_FLAGS -marm)
|
|
|
+ set_property(SOURCE "${SDL3_SOURCE_DIR}/src/atomic/SDL_spinlock.c" APPEND_STRING PROPERTY COMPILE_FLAGS " -marm")
|
|
|
endif()
|
|
|
+ cmake_pop_check_state()
|
|
|
|
|
|
if(SDL_MISC)
|
|
|
- file(GLOB MISC_SOURCES ${SDL2_SOURCE_DIR}/src/misc/vita/*.c)
|
|
|
+ file(GLOB MISC_SOURCES ${SDL3_SOURCE_DIR}/src/misc/vita/*.c)
|
|
|
list(APPEND SOURCE_FILES ${MISC_SOURCES})
|
|
|
set(HAVE_SDL_MISC TRUE)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_AUDIO)
|
|
|
set(SDL_AUDIO_DRIVER_VITA 1)
|
|
|
- file(GLOB VITA_AUDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/vita/*.c)
|
|
|
+ file(GLOB VITA_AUDIO_SOURCES ${SDL3_SOURCE_DIR}/src/audio/vita/*.c)
|
|
|
list(APPEND SOURCE_FILES ${VITA_AUDIO_SOURCES})
|
|
|
set(HAVE_SDL_AUDIO TRUE)
|
|
|
endif()
|
|
|
if(SDL_FILESYSTEM)
|
|
|
set(SDL_FILESYSTEM_VITA 1)
|
|
|
- file(GLOB VITA_FILESYSTEM_SOURCES ${SDL2_SOURCE_DIR}/src/filesystem/vita/*.c)
|
|
|
+ file(GLOB VITA_FILESYSTEM_SOURCES ${SDL3_SOURCE_DIR}/src/filesystem/vita/*.c)
|
|
|
list(APPEND SOURCE_FILES ${VITA_FILESYSTEM_SOURCES})
|
|
|
set(HAVE_SDL_FILESYSTEM TRUE)
|
|
|
endif()
|
|
|
if(SDL_JOYSTICK)
|
|
|
set(SDL_JOYSTICK_VITA 1)
|
|
|
- file(GLOB VITA_JOYSTICK_SOURCES ${SDL2_SOURCE_DIR}/src/joystick/vita/*.c)
|
|
|
+ file(GLOB VITA_JOYSTICK_SOURCES ${SDL3_SOURCE_DIR}/src/joystick/vita/*.c)
|
|
|
list(APPEND SOURCE_FILES ${VITA_JOYSTICK_SOURCES})
|
|
|
set(HAVE_SDL_JOYSTICK TRUE)
|
|
|
endif()
|
|
|
if(SDL_POWER)
|
|
|
set(SDL_POWER_VITA 1)
|
|
|
- file(GLOB VITA_POWER_SOURCES ${SDL2_SOURCE_DIR}/src/power/vita/*.c)
|
|
|
+ file(GLOB VITA_POWER_SOURCES ${SDL3_SOURCE_DIR}/src/power/vita/*.c)
|
|
|
list(APPEND SOURCE_FILES ${VITA_POWER_SOURCES})
|
|
|
set(HAVE_SDL_POWER TRUE)
|
|
|
endif()
|
|
|
if(SDL_THREADS)
|
|
|
set(SDL_THREAD_VITA 1)
|
|
|
list(APPEND SOURCE_FILES
|
|
|
- ${SDL2_SOURCE_DIR}/src/thread/vita/SDL_sysmutex.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/thread/vita/SDL_syssem.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/thread/vita/SDL_systhread.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/thread/vita/SDL_syscond.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/thread/generic/SDL_systls.c)
|
|
|
+ ${SDL3_SOURCE_DIR}/src/thread/vita/SDL_sysmutex.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/thread/vita/SDL_syssem.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/thread/vita/SDL_systhread.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/thread/vita/SDL_syscond.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/thread/generic/SDL_systls.c)
|
|
|
set(HAVE_SDL_THREADS TRUE)
|
|
|
endif()
|
|
|
if(SDL_LOCALE)
|
|
|
- file(GLOB LOCALE_SOURCES ${SDL2_SOURCE_DIR}/src/locale/vita/*.c)
|
|
|
+ file(GLOB LOCALE_SOURCES ${SDL3_SOURCE_DIR}/src/locale/vita/*.c)
|
|
|
list(APPEND SOURCE_FILES ${LOCALE_SOURCES})
|
|
|
set(HAVE_SDL_LOCALE TRUE)
|
|
|
endif()
|
|
|
if(SDL_TIMERS)
|
|
|
set(SDL_TIMER_VITA 1)
|
|
|
- file(GLOB TIMER_SOURCES ${SDL2_SOURCE_DIR}/src/timer/vita/*.c)
|
|
|
+ file(GLOB TIMER_SOURCES ${SDL3_SOURCE_DIR}/src/timer/vita/*.c)
|
|
|
list(APPEND SOURCE_FILES ${TIMER_SOURCES})
|
|
|
set(HAVE_SDL_TIMERS TRUE)
|
|
|
endif()
|
|
|
if(SDL_SENSOR)
|
|
|
set(SDL_SENSOR_VITA 1)
|
|
|
set(HAVE_SDL_SENSORS TRUE)
|
|
|
- file(GLOB VITA_SENSOR_SOURCES ${SDL2_SOURCE_DIR}/src/sensor/vita/*.c)
|
|
|
+ file(GLOB VITA_SENSOR_SOURCES ${SDL3_SOURCE_DIR}/src/sensor/vita/*.c)
|
|
|
list(APPEND SOURCE_FILES ${VITA_SENSOR_SOURCES})
|
|
|
endif()
|
|
|
if(SDL_VIDEO)
|
|
|
set(SDL_VIDEO_DRIVER_VITA 1)
|
|
|
- file(GLOB VITA_VIDEO_SOURCES ${SDL2_SOURCE_DIR}/src/video/vita/*.c)
|
|
|
+ file(GLOB VITA_VIDEO_SOURCES ${SDL3_SOURCE_DIR}/src/video/vita/*.c)
|
|
|
list(APPEND SOURCE_FILES ${VITA_VIDEO_SOURCES})
|
|
|
set(HAVE_SDL_VIDEO TRUE)
|
|
|
|
|
@@ -2479,126 +2531,126 @@ elseif(VITA)
|
|
|
|
|
|
set(HAVE_ARMSIMD TRUE)
|
|
|
# set(SDL_ARM_SIMD_BLITTERS 1)
|
|
|
-# file(GLOB ARMSIMD_SOURCES ${SDL2_SOURCE_DIR}/src/video/arm/pixman-arm-simd*.S)
|
|
|
+# file(GLOB ARMSIMD_SOURCES ${SDL3_SOURCE_DIR}/src/video/arm/pixman-arm-simd*.S)
|
|
|
# list(APPEND SOURCE_FILES ${ARMSIMD_SOURCES})
|
|
|
|
|
|
set(HAVE_ARMNEON TRUE)
|
|
|
# set(SDL_ARM_NEON_BLITTERS 1)
|
|
|
-# file(GLOB ARMNEON_SOURCES ${SDL2_SOURCE_DIR}/src/video/arm/pixman-arm-neon*.S)
|
|
|
+# file(GLOB ARMNEON_SOURCES ${SDL3_SOURCE_DIR}/src/video/arm/pixman-arm-neon*.S)
|
|
|
# list(APPEND SOURCE_FILES ${ARMNEON_SOURCES})
|
|
|
|
|
|
-# set_property(SOURCE ${SDL2_SOURCE_DIR}/src/video/arm/pixman-arm-simd-asm.S PROPERTY LANGUAGE C)
|
|
|
-# set_property(SOURCE ${SDL2_SOURCE_DIR}/src/video/arm/pixman-arm-neon-asm.S PROPERTY LANGUAGE C)
|
|
|
+# set_property(SOURCE ${SDL3_SOURCE_DIR}/src/video/arm/pixman-arm-simd-asm.S PROPERTY LANGUAGE C)
|
|
|
+# set_property(SOURCE ${SDL3_SOURCE_DIR}/src/video/arm/pixman-arm-neon-asm.S PROPERTY LANGUAGE C)
|
|
|
|
|
|
target_compile_definitions(sdl-build-options INTERFACE "-D__VITA__")
|
|
|
|
|
|
# CheckPTHREAD()
|
|
|
|
|
|
elseif(PSP)
|
|
|
- file(GLOB PSP_MAIN_SOURCES ${SDL2_SOURCE_DIR}/src/main/psp/*.c)
|
|
|
+ file(GLOB PSP_MAIN_SOURCES ${SDL3_SOURCE_DIR}/src/main/psp/*.c)
|
|
|
list(APPEND SDLMAIN_SOURCES ${PSP_MAIN_SOURCES})
|
|
|
|
|
|
if(SDL_AUDIO)
|
|
|
set(SDL_AUDIO_DRIVER_PSP 1)
|
|
|
- file(GLOB PSP_AUDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/psp/*.c)
|
|
|
+ file(GLOB PSP_AUDIO_SOURCES ${SDL3_SOURCE_DIR}/src/audio/psp/*.c)
|
|
|
list(APPEND SOURCE_FILES ${PSP_AUDIO_SOURCES})
|
|
|
set(HAVE_SDL_AUDIO TRUE)
|
|
|
endif()
|
|
|
if(SDL_FILESYSTEM)
|
|
|
set(SDL_FILESYSTEM_PSP 1)
|
|
|
- file(GLOB PSP_FILESYSTEM_SOURCES ${SDL2_SOURCE_DIR}/src/filesystem/psp/*.c)
|
|
|
+ file(GLOB PSP_FILESYSTEM_SOURCES ${SDL3_SOURCE_DIR}/src/filesystem/psp/*.c)
|
|
|
list(APPEND SOURCE_FILES ${PSP_FILESYSTEM_SOURCES})
|
|
|
set(HAVE_SDL_FILESYSTEM TRUE)
|
|
|
endif()
|
|
|
if(SDL_JOYSTICK)
|
|
|
set(SDL_JOYSTICK_PSP 1)
|
|
|
- file(GLOB PSP_JOYSTICK_SOURCES ${SDL2_SOURCE_DIR}/src/joystick/psp/*.c)
|
|
|
+ file(GLOB PSP_JOYSTICK_SOURCES ${SDL3_SOURCE_DIR}/src/joystick/psp/*.c)
|
|
|
list(APPEND SOURCE_FILES ${PSP_JOYSTICK_SOURCES})
|
|
|
set(HAVE_SDL_JOYSTICK TRUE)
|
|
|
endif()
|
|
|
if(SDL_POWER)
|
|
|
set(SDL_POWER_PSP 1)
|
|
|
- file(GLOB PSP_POWER_SOURCES ${SDL2_SOURCE_DIR}/src/power/psp/*.c)
|
|
|
+ file(GLOB PSP_POWER_SOURCES ${SDL3_SOURCE_DIR}/src/power/psp/*.c)
|
|
|
list(APPEND SOURCE_FILES ${PSP_POWER_SOURCES})
|
|
|
set(HAVE_SDL_POWER TRUE)
|
|
|
endif()
|
|
|
if(SDL_THREADS)
|
|
|
set(SDL_THREAD_PSP 1)
|
|
|
- file(GLOB PSP_THREAD_SOURCES ${SDL2_SOURCE_DIR}/src/thread/generic/SDL_systls.c ${SDL2_SOURCE_DIR}/src/thread/psp/*.c)
|
|
|
+ file(GLOB PSP_THREAD_SOURCES ${SDL3_SOURCE_DIR}/src/thread/generic/SDL_systls.c ${SDL3_SOURCE_DIR}/src/thread/psp/*.c)
|
|
|
list(APPEND SOURCE_FILES ${PSP_THREAD_SOURCES})
|
|
|
set(HAVE_SDL_THREADS TRUE)
|
|
|
endif()
|
|
|
if(SDL_TIMERS)
|
|
|
set(SDL_TIMER_PSP 1)
|
|
|
- file(GLOB PSP_TIMER_SOURCES ${SDL2_SOURCE_DIR}/src/timer/psp/*.c)
|
|
|
+ file(GLOB PSP_TIMER_SOURCES ${SDL3_SOURCE_DIR}/src/timer/psp/*.c)
|
|
|
list(APPEND SOURCE_FILES ${PSP_TIMER_SOURCES})
|
|
|
set(HAVE_SDL_TIMERS TRUE)
|
|
|
endif()
|
|
|
if(SDL_VIDEO)
|
|
|
set(SDL_VIDEO_DRIVER_PSP 1)
|
|
|
set(SDL_VIDEO_RENDER_PSP 1)
|
|
|
- file(GLOB PSP_VIDEO_SOURCES ${SDL2_SOURCE_DIR}/src/video/psp/*.c)
|
|
|
+ file(GLOB PSP_VIDEO_SOURCES ${SDL3_SOURCE_DIR}/src/video/psp/*.c)
|
|
|
list(APPEND SOURCE_FILES ${PSP_VIDEO_SOURCES})
|
|
|
set(SDL_VIDEO_OPENGL 1)
|
|
|
set(HAVE_SDL_VIDEO TRUE)
|
|
|
endif()
|
|
|
|
|
|
list(APPEND EXTRA_LIBS
|
|
|
- psppower
|
|
|
- pspctrl
|
|
|
- psphprm
|
|
|
- pspge
|
|
|
- pspgu
|
|
|
- pspdisplay
|
|
|
- pspvfpu
|
|
|
- pspaudio
|
|
|
- pspvram
|
|
|
GL
|
|
|
+ pspvram
|
|
|
+ pspaudio
|
|
|
+ pspvfpu
|
|
|
+ pspdisplay
|
|
|
+ pspgu
|
|
|
+ pspge
|
|
|
+ psphprm
|
|
|
+ pspctrl
|
|
|
+ psppower
|
|
|
)
|
|
|
- if(NOT SDL2_DISABLE_SDL2MAIN)
|
|
|
- list(INSERT SDL_LIBS 0 "-lSDL2main")
|
|
|
- endif(NOT SDL2_DISABLE_SDL2MAIN)
|
|
|
+ if(NOT SDL3_DISABLE_SDL3MAIN)
|
|
|
+ list(INSERT SDL_LIBS 0 "-lSDL3main")
|
|
|
+ endif(NOT SDL3_DISABLE_SDL3MAIN)
|
|
|
|
|
|
elseif(PS2)
|
|
|
list(APPEND EXTRA_CFLAGS "-DPS2" "-D__PS2__" "-I$ENV{PS2SDK}/ports/include" "-I$ENV{PS2DEV}/gsKit/include")
|
|
|
|
|
|
- file(GLOB PS2_MAIN_SOURCES ${SDL2_SOURCE_DIR}/src/main/ps2/*.c)
|
|
|
+ file(GLOB PS2_MAIN_SOURCES ${SDL3_SOURCE_DIR}/src/main/ps2/*.c)
|
|
|
set(SDLMAIN_SOURCES ${SDLMAIN_SOURCES} ${PS2_MAIN_SOURCES})
|
|
|
|
|
|
if(SDL_AUDIO)
|
|
|
set(SDL_AUDIO_DRIVER_PS2 1)
|
|
|
- file(GLOB PS2_AUDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/ps2/*.c)
|
|
|
+ file(GLOB PS2_AUDIO_SOURCES ${SDL3_SOURCE_DIR}/src/audio/ps2/*.c)
|
|
|
set(SOURCE_FILES ${SOURCE_FILES} ${PS2_AUDIO_SOURCES})
|
|
|
set(HAVE_SDL_AUDIO TRUE)
|
|
|
endif()
|
|
|
if(SDL_FILESYSTEM)
|
|
|
set(SDL_FILESYSTEM_PS2 1)
|
|
|
- file(GLOB PS2_FILESYSTEM_SOURCES ${SDL2_SOURCE_DIR}/src/filesystem/ps2/*.c)
|
|
|
+ file(GLOB PS2_FILESYSTEM_SOURCES ${SDL3_SOURCE_DIR}/src/filesystem/ps2/*.c)
|
|
|
list(APPEND SOURCE_FILES ${PS2_FILESYSTEM_SOURCES})
|
|
|
set(HAVE_SDL_FILESYSTEM TRUE)
|
|
|
endif()
|
|
|
if(SDL_JOYSTICK)
|
|
|
set(SDL_JOYSTICK_PS2 1)
|
|
|
- file(GLOB PS2_JOYSTICK_SOURCES ${SDL2_SOURCE_DIR}/src/joystick/ps2/*.c)
|
|
|
+ file(GLOB PS2_JOYSTICK_SOURCES ${SDL3_SOURCE_DIR}/src/joystick/ps2/*.c)
|
|
|
list(APPEND SOURCE_FILES ${PS2_JOYSTICK_SOURCES})
|
|
|
set(HAVE_SDL_JOYSTICK TRUE)
|
|
|
endif()
|
|
|
if(SDL_THREADS)
|
|
|
set(SDL_THREAD_PS2 1)
|
|
|
- file(GLOB PS2_THREAD_SOURCES ${SDL2_SOURCE_DIR}/src/thread/generic/SDL_systls.c ${SDL2_SOURCE_DIR}/src/thread/generic/SDL_sysmutex.c ${SDL2_SOURCE_DIR}/src/thread/ps2/*.c)
|
|
|
+ file(GLOB PS2_THREAD_SOURCES ${SDL3_SOURCE_DIR}/src/thread/generic/SDL_systls.c ${SDL3_SOURCE_DIR}/src/thread/generic/SDL_sysmutex.c ${SDL3_SOURCE_DIR}/src/thread/ps2/*.c)
|
|
|
list(APPEND SOURCE_FILES ${PS2_THREAD_SOURCES})
|
|
|
set(HAVE_SDL_THREADS TRUE)
|
|
|
endif()
|
|
|
if(SDL_TIMERS)
|
|
|
set(SDL_TIMER_PS2 1)
|
|
|
- file(GLOB PS2_TIMER_SOURCES ${SDL2_SOURCE_DIR}/src/timer/ps2/*.c)
|
|
|
+ file(GLOB PS2_TIMER_SOURCES ${SDL3_SOURCE_DIR}/src/timer/ps2/*.c)
|
|
|
list(APPEND SOURCE_FILES ${PS2_TIMER_SOURCES})
|
|
|
set(HAVE_SDL_TIMERS TRUE)
|
|
|
endif()
|
|
|
if(SDL_VIDEO)
|
|
|
set(SDL_VIDEO_DRIVER_PS2 1)
|
|
|
set(SDL_VIDEO_RENDER_PS2 1)
|
|
|
- file(GLOB PS2_VIDEO_SOURCES ${SDL2_SOURCE_DIR}/src/video/ps2/*.c ${SDL2_SOURCE_DIR}/src/render/ps2/*.c)
|
|
|
+ file(GLOB PS2_VIDEO_SOURCES ${SDL3_SOURCE_DIR}/src/video/ps2/*.c ${SDL3_SOURCE_DIR}/src/render/ps2/*.c)
|
|
|
list(APPEND SOURCE_FILES ${PS2_VIDEO_SOURCES})
|
|
|
set(SDL_VIDEO_OPENGL 0)
|
|
|
set(HAVE_SDL_VIDEO TRUE)
|
|
@@ -2611,74 +2663,79 @@ elseif(PS2)
|
|
|
ps2_drivers
|
|
|
)
|
|
|
|
|
|
-elseif(OS2)
|
|
|
- list(APPEND EXTRA_CFLAGS "-DOS2EMX_PLAIN_CHAR")
|
|
|
+elseif(N3DS)
|
|
|
+ file(GLOB N3DS_MAIN_SOURCES ${SDL3_SOURCE_DIR}/src/main/n3ds/*.c)
|
|
|
+ set(SDLMAIN_SOURCES ${SDLMAIN_SOURCES} ${N3DS_MAIN_SOURCES})
|
|
|
|
|
|
- file(GLOB CORE_SOURCES ${SDL2_SOURCE_DIR}/src/core/os2/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${CORE_SOURCES})
|
|
|
- if(NOT (HAVE_ICONV AND HAVE_ICONV_H))
|
|
|
- file(GLOB CORE_SOURCES ${SDL2_SOURCE_DIR}/src/core/os2/geniconv/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${CORE_SOURCES})
|
|
|
+ if(SDL_AUDIO)
|
|
|
+ set(SDL_AUDIO_DRIVER_N3DS 1)
|
|
|
+ file(GLOB N3DS_AUDIO_SOURCES ${SDL3_SOURCE_DIR}/src/audio/n3ds/*.c)
|
|
|
+ list(APPEND SOURCE_FILES ${N3DS_AUDIO_SOURCES})
|
|
|
+ set(HAVE_SDL_AUDIO TRUE)
|
|
|
endif()
|
|
|
|
|
|
- if(SDL_THREADS)
|
|
|
- set(SDL_THREAD_OS2 1)
|
|
|
- file(GLOB OS2_THREAD_SOURCES ${SDL2_SOURCE_DIR}/src/thread/os2/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${OS2_THREAD_SOURCES})
|
|
|
- set(HAVE_SDL_THREADS TRUE)
|
|
|
+ if(SDL_FILESYSTEM)
|
|
|
+ set(SDL_FILESYSTEM_N3DS 1)
|
|
|
+ file(GLOB N3DS_FILESYSTEM_SOURCES ${SDL3_SOURCE_DIR}/src/filesystem/n3ds/*.c)
|
|
|
+ list(APPEND SOURCE_FILES ${N3DS_FILESYSTEM_SOURCES})
|
|
|
+ set(HAVE_SDL_FILESYSTEM TRUE)
|
|
|
endif()
|
|
|
|
|
|
- if(SDL_TIMERS)
|
|
|
- set(SDL_TIMER_UNIX 1)
|
|
|
- file(GLOB OS2_TIMER_SOURCES ${SDL2_SOURCE_DIR}/src/timer/os2/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${OS2_TIMER_SOURCES})
|
|
|
- set(HAVE_SDL_TIMERS TRUE)
|
|
|
+ if(SDL_JOYSTICK)
|
|
|
+ set(SDL_JOYSTICK_N3DS 1)
|
|
|
+ file(GLOB N3DS_JOYSTICK_SOURCES ${SDL3_SOURCE_DIR}/src/joystick/n3ds/*.c)
|
|
|
+ list(APPEND SOURCE_FILES ${N3DS_JOYSTICK_SOURCES})
|
|
|
+ set(HAVE_SDL_JOYSTICK TRUE)
|
|
|
endif()
|
|
|
|
|
|
- if(SDL_LOADSO)
|
|
|
- set(SDL_LOADSO_OS2 1)
|
|
|
- file(GLOB OS2_LOADSO_SOURCES ${SDL2_SOURCE_DIR}/src/loadso/os2/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${OS2_LOADSO_SOURCES})
|
|
|
- set(HAVE_SDL_LOADSO TRUE)
|
|
|
+ if(SDL_POWER)
|
|
|
+ set(SDL_POWER_N3DS 1)
|
|
|
+ file(GLOB N3DS_POWER_SOURCES ${SDL3_SOURCE_DIR}/src/power/n3ds/*.c)
|
|
|
+ list(APPEND SOURCE_FILES ${N3DS_POWER_SOURCES})
|
|
|
+ set(HAVE_SDL_POWER TRUE)
|
|
|
endif()
|
|
|
|
|
|
- if(SDL_FILESYSTEM)
|
|
|
- set(SDL_FILESYSTEM_OS2 1)
|
|
|
- file(GLOB FILESYSTEM_SOURCES ${SDL2_SOURCE_DIR}/src/filesystem/os2/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${FILESYSTEM_SOURCES})
|
|
|
- set(HAVE_SDL_FILESYSTEM TRUE)
|
|
|
+ if(SDL_THREADS)
|
|
|
+ set(SDL_THREAD_N3DS 1)
|
|
|
+ file(GLOB N3DS_THREAD_SOURCES ${SDL3_SOURCE_DIR}/src/thread/n3ds/*.c)
|
|
|
+ list(APPEND SOURCE_FILES ${N3DS_THREAD_SOURCES} ${SDL3_SOURCE_DIR}/src/thread/generic/SDL_systls.c)
|
|
|
+ set(HAVE_SDL_THREADS TRUE)
|
|
|
endif()
|
|
|
|
|
|
- if(SDL_LOCALE)
|
|
|
- file(GLOB LOCALE_SOURCES ${SDL2_SOURCE_DIR}/src/locale/unix/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${LOCALE_SOURCES})
|
|
|
- set(HAVE_SDL_LOCALE TRUE)
|
|
|
+ if(SDL_TIMERS)
|
|
|
+ set(SDL_TIMER_N3DS 1)
|
|
|
+ file(GLOB N3DS_TIMER_SOURCES ${SDL3_SOURCE_DIR}/src/timer/n3ds/*.c)
|
|
|
+ list(APPEND SOURCE_FILES ${N3DS_TIMER_SOURCES})
|
|
|
+ set(HAVE_SDL_TIMERS TRUE)
|
|
|
endif()
|
|
|
|
|
|
- if(SDL_VIDEO)
|
|
|
- set(SDL_VIDEO_DRIVER_OS2 1)
|
|
|
- file(GLOB OS2_VIDEO_SOURCES ${SDL2_SOURCE_DIR}/src/video/os2/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${OS2_VIDEO_SOURCES})
|
|
|
- set(HAVE_SDL_VIDEO TRUE)
|
|
|
+ if(SDL_SENSOR)
|
|
|
+ set(SDL_SENSOR_N3DS 1)
|
|
|
+ file(GLOB N3DS_SENSOR_SOURCES ${SDL3_SOURCE_DIR}/src/sensor/n3ds/*.c)
|
|
|
+ list(APPEND SOURCE_FILES ${N3DS_SENSOR_SOURCES})
|
|
|
+ set(HAVE_SDL_SENSORS TRUE)
|
|
|
endif()
|
|
|
|
|
|
- if(SDL_AUDIO)
|
|
|
- set(SDL_AUDIO_DRIVER_OS2 1)
|
|
|
- file(GLOB OS2_AUDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/os2/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${OS2_AUDIO_SOURCES})
|
|
|
- set(HAVE_SDL_AUDIO TRUE)
|
|
|
- list(APPEND EXTRA_LIBS mmpm2)
|
|
|
+ if(SDL_VIDEO)
|
|
|
+ set(SDL_VIDEO_DRIVER_N3DS 1)
|
|
|
+ file(GLOB N3DS_VIDEO_SOURCES ${SDL3_SOURCE_DIR}/src/video/n3ds/*.c)
|
|
|
+ list(APPEND SOURCE_FILES ${N3DS_VIDEO_SOURCES})
|
|
|
+ set(HAVE_SDL_VIDEO TRUE)
|
|
|
endif()
|
|
|
|
|
|
- if(SDL_JOYSTICK)
|
|
|
- set(SDL_JOYSTICK_OS2 1)
|
|
|
- file(GLOB OS2_JOYSTICK_SOURCES ${SDL2_SOURCE_DIR}/src/joystick/os2/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${OS2_JOYSTICK_SOURCES})
|
|
|
- set(HAVE_SDL_JOYSTICK TRUE)
|
|
|
+ if(SDL_LOCALE)
|
|
|
+ file(GLOB N3DS_LOCALE_SOURCES ${SDL3_SOURCE_DIR}/src/locale/n3ds/*.c)
|
|
|
+ list(APPEND SOURCE_FILES ${N3DS_LOCALE_SOURCES})
|
|
|
+ set(HAVE_SDL_LOCALE TRUE)
|
|
|
endif()
|
|
|
|
|
|
- if(SDL_HIDAPI)
|
|
|
- CheckHIDAPI()
|
|
|
+ # Requires the n3ds file implementation
|
|
|
+ if(SDL_FILE)
|
|
|
+ file(GLOB N3DS_FILE_SOURCES ${SDL3_SOURCE_DIR}/src/file/n3ds/*.c)
|
|
|
+ list(APPEND SOURCE_FILES ${N3DS_FILE_SOURCES})
|
|
|
+ set(HAVE_SDL_FILE TRUE)
|
|
|
+ else()
|
|
|
+ message_error("SDL_FILE must be enabled to build on N3DS")
|
|
|
endif()
|
|
|
endif()
|
|
|
|
|
@@ -2701,47 +2758,47 @@ CheckLibSampleRate()
|
|
|
# src/X/*.c does not get included.
|
|
|
if(NOT HAVE_SDL_AUDIO)
|
|
|
set(SDL_AUDIO_DRIVER_DUMMY 1)
|
|
|
- file(GLOB AUDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/dummy/*.c)
|
|
|
+ file(GLOB AUDIO_SOURCES ${SDL3_SOURCE_DIR}/src/audio/dummy/*.c)
|
|
|
list(APPEND SOURCE_FILES ${AUDIO_SOURCES})
|
|
|
endif()
|
|
|
if(NOT HAVE_SDL_VIDEO)
|
|
|
set(SDL_VIDEO_DRIVER_DUMMY 1)
|
|
|
- file(GLOB VIDEO_SOURCES ${SDL2_SOURCE_DIR}/src/video/dummy/*.c)
|
|
|
+ file(GLOB VIDEO_SOURCES ${SDL3_SOURCE_DIR}/src/video/dummy/*.c)
|
|
|
list(APPEND SOURCE_FILES ${VIDEO_SOURCES})
|
|
|
endif()
|
|
|
if(NOT HAVE_SDL_JOYSTICK)
|
|
|
set(SDL_JOYSTICK_DUMMY 1)
|
|
|
- file(GLOB JOYSTICK_SOURCES ${SDL2_SOURCE_DIR}/src/joystick/dummy/*.c)
|
|
|
+ file(GLOB JOYSTICK_SOURCES ${SDL3_SOURCE_DIR}/src/joystick/dummy/*.c)
|
|
|
list(APPEND SOURCE_FILES ${JOYSTICK_SOURCES})
|
|
|
endif()
|
|
|
if(NOT HAVE_SDL_HAPTIC)
|
|
|
set(SDL_HAPTIC_DUMMY 1)
|
|
|
- file(GLOB HAPTIC_SOURCES ${SDL2_SOURCE_DIR}/src/haptic/dummy/*.c)
|
|
|
+ file(GLOB HAPTIC_SOURCES ${SDL3_SOURCE_DIR}/src/haptic/dummy/*.c)
|
|
|
list(APPEND SOURCE_FILES ${HAPTIC_SOURCES})
|
|
|
endif()
|
|
|
if(NOT HAVE_SDL_SENSORS)
|
|
|
set(SDL_SENSOR_DUMMY 1)
|
|
|
- file(GLOB SENSORS_SOURCES ${SDL2_SOURCE_DIR}/src/sensor/dummy/*.c)
|
|
|
+ file(GLOB SENSORS_SOURCES ${SDL3_SOURCE_DIR}/src/sensor/dummy/*.c)
|
|
|
list(APPEND SOURCE_FILES ${SENSORS_SOURCES})
|
|
|
endif()
|
|
|
if(NOT HAVE_SDL_LOADSO)
|
|
|
set(SDL_LOADSO_DUMMY 1)
|
|
|
- file(GLOB LOADSO_SOURCES ${SDL2_SOURCE_DIR}/src/loadso/dummy/*.c)
|
|
|
+ file(GLOB LOADSO_SOURCES ${SDL3_SOURCE_DIR}/src/loadso/dummy/*.c)
|
|
|
list(APPEND SOURCE_FILES ${LOADSO_SOURCES})
|
|
|
endif()
|
|
|
if(NOT HAVE_SDL_FILESYSTEM)
|
|
|
set(SDL_FILESYSTEM_DUMMY 1)
|
|
|
- file(GLOB FILESYSTEM_SOURCES ${SDL2_SOURCE_DIR}/src/filesystem/dummy/*.c)
|
|
|
+ file(GLOB FILESYSTEM_SOURCES ${SDL3_SOURCE_DIR}/src/filesystem/dummy/*.c)
|
|
|
list(APPEND SOURCE_FILES ${FILESYSTEM_SOURCES})
|
|
|
endif()
|
|
|
if(NOT HAVE_SDL_LOCALE)
|
|
|
set(SDL_LOCALE_DUMMY 1)
|
|
|
- file(GLOB LOCALE_SOURCES ${SDL2_SOURCE_DIR}/src/locale/dummy/*.c)
|
|
|
+ file(GLOB LOCALE_SOURCES ${SDL3_SOURCE_DIR}/src/locale/dummy/*.c)
|
|
|
list(APPEND SOURCE_FILES ${LOCALE_SOURCES})
|
|
|
endif()
|
|
|
if(NOT HAVE_SDL_MISC)
|
|
|
set(SDL_MISC_DUMMY 1)
|
|
|
- file(GLOB MISC_SOURCES ${SDL2_SOURCE_DIR}/src/misc/dummy/*.c)
|
|
|
+ file(GLOB MISC_SOURCES ${SDL3_SOURCE_DIR}/src/misc/dummy/*.c)
|
|
|
list(APPEND SOURCE_FILES ${MISC_SOURCES})
|
|
|
endif()
|
|
|
|
|
@@ -2750,7 +2807,7 @@ if(NOT HAVE_SDL_THREADS)
|
|
|
# The emscripten platform has been carefully vetted to work without threads
|
|
|
if (EMSCRIPTEN)
|
|
|
set(SDL_THREADS_DISABLED 1)
|
|
|
- file(GLOB THREADS_SOURCES ${SDL2_SOURCE_DIR}/src/thread/generic/*.c)
|
|
|
+ file(GLOB THREADS_SOURCES ${SDL3_SOURCE_DIR}/src/thread/generic/*.c)
|
|
|
list(APPEND SOURCE_FILES ${THREADS_SOURCES})
|
|
|
else()
|
|
|
message_error("Threads are needed by many SDL subsystems and may not be disabled")
|
|
@@ -2758,12 +2815,12 @@ if(NOT HAVE_SDL_THREADS)
|
|
|
endif()
|
|
|
if(NOT HAVE_SDL_TIMERS)
|
|
|
set(SDL_TIMER_DUMMY 1)
|
|
|
- file(GLOB TIMER_SOURCES ${SDL2_SOURCE_DIR}/src/timer/dummy/*.c)
|
|
|
+ file(GLOB TIMER_SOURCES ${SDL3_SOURCE_DIR}/src/timer/dummy/*.c)
|
|
|
list(APPEND SOURCE_FILES ${TIMER_SOURCES})
|
|
|
endif()
|
|
|
|
|
|
if(NOT SDLMAIN_SOURCES)
|
|
|
- file(GLOB SDLMAIN_SOURCES ${SDL2_SOURCE_DIR}/src/main/dummy/*.c)
|
|
|
+ file(GLOB SDLMAIN_SOURCES ${SDL3_SOURCE_DIR}/src/main/dummy/*.c)
|
|
|
endif()
|
|
|
|
|
|
# Append the -MMD -MT flags
|
|
@@ -2775,15 +2832,15 @@ endif()
|
|
|
|
|
|
# config variables may contain generator expression, so we need to generate SDL_config.h in 2 steps:
|
|
|
# 1. replace all `#cmakedefine`'s and `@abc@`
|
|
|
-configure_file("${SDL2_SOURCE_DIR}/include/SDL_config.h.cmake"
|
|
|
- "${SDL2_BINARY_DIR}/SDL_config.h.intermediate")
|
|
|
+configure_file("${SDL3_SOURCE_DIR}/include/SDL_config.h.cmake"
|
|
|
+ "${SDL3_BINARY_DIR}/SDL_config.h.intermediate")
|
|
|
# 2. Create the "include-config-${CMAKE_BUILD_TYPE}" folder (fails on older CMake versions when it does not exist)
|
|
|
string(TOLOWER "${CMAKE_BUILD_TYPE}" lower_build_type)
|
|
|
execute_process(COMMAND ${CMAKE_COMMAND} -E make_directory "${CMAKE_CURRENT_BINARY_DIR}/include-config-${lower_build_type}")
|
|
|
# 3. generate SDL_config in an build_type-dependent folder (which should be first in the include search path)
|
|
|
file(GENERATE
|
|
|
- OUTPUT "${SDL2_BINARY_DIR}/include-config-$<LOWER_CASE:$<CONFIG>>/SDL_config.h"
|
|
|
- INPUT "${SDL2_BINARY_DIR}/SDL_config.h.intermediate")
|
|
|
+ OUTPUT "${SDL3_BINARY_DIR}/include-config-$<LOWER_CASE:$<CONFIG>>/SDL_config.h"
|
|
|
+ INPUT "${SDL3_BINARY_DIR}/SDL_config.h.intermediate")
|
|
|
|
|
|
# Prepare the flags and remove duplicates
|
|
|
if(EXTRA_LDFLAGS)
|
|
@@ -2799,103 +2856,121 @@ listtostr(EXTRA_CFLAGS _EXTRA_CFLAGS)
|
|
|
set(EXTRA_CFLAGS ${_EXTRA_CFLAGS})
|
|
|
|
|
|
# Compat helpers for the configuration files
|
|
|
+
|
|
|
+if(EXISTS "${PROJECT_SOURCE_DIR}/VERSION.txt")
|
|
|
+ file(READ "${PROJECT_SOURCE_DIR}/VERSION.txt" SDL_SOURCE_VERSION)
|
|
|
+ string(STRIP "${SDL_SOURCE_VERSION}" SDL_SOURCE_VERSION)
|
|
|
+endif()
|
|
|
+
|
|
|
find_package(Git)
|
|
|
if(Git_FOUND)
|
|
|
execute_process(COMMAND
|
|
|
- "${GIT_EXECUTABLE}" remote get-url origin
|
|
|
- WORKING_DIRECTORY "${CMAKE_SOURCE_DIR}"
|
|
|
- RESULT_VARIABLE GIT_URL_STATUS
|
|
|
- OUTPUT_VARIABLE GIT_URL
|
|
|
- ERROR_QUIET OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
|
-
|
|
|
- execute_process(COMMAND
|
|
|
- "${GIT_EXECUTABLE}" rev-list --max-count=1 HEAD~..
|
|
|
- WORKING_DIRECTORY "${CMAKE_SOURCE_DIR}"
|
|
|
+ "${GIT_EXECUTABLE}" describe --always --tags --long
|
|
|
+ WORKING_DIRECTORY "${PROJECT_SOURCE_DIR}"
|
|
|
RESULT_VARIABLE GIT_REVISION_STATUS
|
|
|
OUTPUT_VARIABLE GIT_REVISION
|
|
|
ERROR_QUIET OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
|
+else()
|
|
|
+ set(GIT_REVISION_STATUS 1)
|
|
|
+ set(GIT_REVISION "")
|
|
|
+endif()
|
|
|
|
|
|
- if(GIT_URL_STATUS EQUAL 0 OR GIT_REVISION_STATUS EQUAL 0)
|
|
|
- set(SDL_REVISION "${GIT_URL}@${GIT_REVISION}")
|
|
|
+if(SDL_SOURCE_VERSION)
|
|
|
+ set(SDL_REVISION "SDL-${SDL_SOURCE_VERSION}")
|
|
|
+elseif(GIT_REVISION_STATUS EQUAL 0)
|
|
|
+ if(GIT_REVISION MATCHES "^[0-9a-f]+$")
|
|
|
+ # Just a truncated sha1, so prefix it with the version number
|
|
|
+ set(SDL_REVISION "SDL-${SDL_VERSION}-g${GIT_REVISION}")
|
|
|
else()
|
|
|
- set(SDL_REVISION "")
|
|
|
+ # e.g. release-2.24.0-542-g96361fc47
|
|
|
+ set(SDL_REVISION "SDL-${GIT_REVISION}")
|
|
|
endif()
|
|
|
else()
|
|
|
- set(SDL_REVISION "")
|
|
|
+ set(SDL_REVISION "SDL-${SDL_VERSION}-no-vcs")
|
|
|
endif()
|
|
|
|
|
|
-configure_file("${SDL2_SOURCE_DIR}/include/SDL_revision.h.cmake"
|
|
|
- "${SDL2_BINARY_DIR}/include/SDL_revision.h")
|
|
|
+configure_file("${SDL3_SOURCE_DIR}/include/SDL_revision.h.cmake"
|
|
|
+ "${SDL3_BINARY_DIR}/include/SDL_revision.h")
|
|
|
|
|
|
-# Copy all non-generated headers to "${SDL2_BINARY_DIR}/include"
|
|
|
+# Copy all non-generated headers to "${SDL3_BINARY_DIR}/include"
|
|
|
# This is done to avoid the inclusion of a pre-generated SDL_config.h
|
|
|
-file(GLOB SDL2_INCLUDE_FILES ${SDL2_SOURCE_DIR}/include/*.h)
|
|
|
-set(SDL2_COPIED_INCLUDE_FILES)
|
|
|
-foreach(_hdr IN LISTS SDL2_INCLUDE_FILES)
|
|
|
+file(GLOB SDL3_INCLUDE_FILES ${SDL3_SOURCE_DIR}/include/*.h)
|
|
|
+set(SDL3_COPIED_INCLUDE_FILES)
|
|
|
+foreach(_hdr IN LISTS SDL3_INCLUDE_FILES)
|
|
|
if(_hdr MATCHES ".*(SDL_config|SDL_revision).*")
|
|
|
- list(REMOVE_ITEM SDL2_INCLUDE_FILES "${_hdr}")
|
|
|
+ list(REMOVE_ITEM SDL3_INCLUDE_FILES "${_hdr}")
|
|
|
else()
|
|
|
get_filename_component(_name "${_hdr}" NAME)
|
|
|
- set(_bin_hdr "${SDL2_BINARY_DIR}/include/${_name}")
|
|
|
- list(APPEND SDL2_COPIED_INCLUDE_FILES "${_bin_hdr}")
|
|
|
+ set(_bin_hdr "${SDL3_BINARY_DIR}/include/${_name}")
|
|
|
+ list(APPEND SDL3_COPIED_INCLUDE_FILES "${_bin_hdr}")
|
|
|
add_custom_command(OUTPUT "${_bin_hdr}"
|
|
|
COMMAND ${CMAKE_COMMAND} -E copy_if_different "${_hdr}" "${_bin_hdr}"
|
|
|
DEPENDS "${_hdr}")
|
|
|
endif()
|
|
|
endforeach()
|
|
|
-list(APPEND SDL_GENERATED_HEADERS ${SDL2_COPIED_INCLUDE_FILES})
|
|
|
+list(APPEND SDL_GENERATED_HEADERS ${SDL3_COPIED_INCLUDE_FILES})
|
|
|
|
|
|
-if(NOT WINDOWS OR CYGWIN OR MINGW)
|
|
|
+if(CMAKE_STATIC_LIBRARY_PREFIX STREQUAL "" AND CMAKE_STATIC_LIBRARY_SUFFIX STREQUAL ".lib")
|
|
|
+ # Avoid conflict between the dll import library and the static library
|
|
|
+ set(sdl_static_libname "SDL3-static")
|
|
|
+else()
|
|
|
+ set(sdl_static_libname "SDL3")
|
|
|
+endif()
|
|
|
|
|
|
- set(prefix ${CMAKE_INSTALL_PREFIX})
|
|
|
- file(RELATIVE_PATH bin_prefix_relpath "${CMAKE_INSTALL_FULL_BINDIR}" "${CMAKE_INSTALL_PREFIX}")
|
|
|
+set(prefix ${CMAKE_INSTALL_PREFIX})
|
|
|
+file(RELATIVE_PATH bin_prefix_relpath "${CMAKE_INSTALL_FULL_BINDIR}" "${CMAKE_INSTALL_PREFIX}")
|
|
|
|
|
|
- set(exec_prefix "\${prefix}")
|
|
|
- set(libdir "\${exec_prefix}/${CMAKE_INSTALL_LIBDIR}")
|
|
|
- set(bindir "\${exec_prefix}/${CMAKE_INSTALL_BINDIR}")
|
|
|
- set(includedir "\${prefix}/${CMAKE_INSTALL_INCLUDEDIR}")
|
|
|
- if(SDL_STATIC)
|
|
|
- set(ENABLE_STATIC_TRUE "")
|
|
|
- set(ENABLE_STATIC_FALSE "#")
|
|
|
- else()
|
|
|
- set(ENABLE_STATIC_TRUE "#")
|
|
|
- set(ENABLE_STATIC_FALSE "")
|
|
|
- endif()
|
|
|
- if(SDL_SHARED)
|
|
|
- set(PKGCONFIG_LIBS_PRIV "
|
|
|
+set(exec_prefix "\${prefix}")
|
|
|
+set(libdir "\${exec_prefix}/${CMAKE_INSTALL_LIBDIR}")
|
|
|
+set(bindir "\${exec_prefix}/${CMAKE_INSTALL_BINDIR}")
|
|
|
+set(includedir "\${prefix}/${CMAKE_INSTALL_INCLUDEDIR}")
|
|
|
+if(SDL_STATIC)
|
|
|
+ set(ENABLE_STATIC_TRUE "")
|
|
|
+ set(ENABLE_STATIC_FALSE "#")
|
|
|
+else()
|
|
|
+ set(ENABLE_STATIC_TRUE "#")
|
|
|
+ set(ENABLE_STATIC_FALSE "")
|
|
|
+endif()
|
|
|
+if(SDL_SHARED)
|
|
|
+ set(PKGCONFIG_LIBS_PRIV "
|
|
|
Libs.private:")
|
|
|
- set(ENABLE_SHARED_TRUE "")
|
|
|
- set(ENABLE_SHARED_FALSE "#")
|
|
|
- else()
|
|
|
- set(PKGCONFIG_LIBS_PRIV "")
|
|
|
- set(ENABLE_SHARED_TRUE "#")
|
|
|
- set(ENABLE_SHARED_FALSE "")
|
|
|
- endif()
|
|
|
-
|
|
|
- # Clean up the different lists
|
|
|
- listtostr(EXTRA_LIBS _EXTRA_LIBS "-l")
|
|
|
- set(SDL_STATIC_LIBS ${SDL_LIBS} ${EXTRA_LDFLAGS} ${_EXTRA_LIBS})
|
|
|
- list(REMOVE_DUPLICATES SDL_STATIC_LIBS)
|
|
|
- listtostr(SDL_STATIC_LIBS _SDL_STATIC_LIBS)
|
|
|
- set(SDL_STATIC_LIBS ${_SDL_STATIC_LIBS})
|
|
|
- listtostr(SDL_LIBS _SDL_LIBS)
|
|
|
- set(SDL_LIBS ${_SDL_LIBS})
|
|
|
- listtostr(SDL_CFLAGS _SDL_CFLAGS "")
|
|
|
- set(SDL_CFLAGS ${_SDL_CFLAGS})
|
|
|
-
|
|
|
- # MESSAGE(STATUS "SDL_LIBS: ${SDL_LIBS}")
|
|
|
- # MESSAGE(STATUS "SDL_STATIC_LIBS: ${SDL_STATIC_LIBS}")
|
|
|
-
|
|
|
- configure_file("${SDL2_SOURCE_DIR}/sdl2.pc.in"
|
|
|
- "${SDL2_BINARY_DIR}/sdl2.pc" @ONLY)
|
|
|
- configure_file("${SDL2_SOURCE_DIR}/sdl2-config.in"
|
|
|
- "${SDL2_BINARY_DIR}/sdl2-config")
|
|
|
- configure_file("${SDL2_SOURCE_DIR}/sdl2-config.in"
|
|
|
- "${SDL2_BINARY_DIR}/sdl2-config" @ONLY)
|
|
|
- configure_file("${SDL2_SOURCE_DIR}/SDL2.spec.in"
|
|
|
- "${SDL2_BINARY_DIR}/SDL2.spec" @ONLY)
|
|
|
+ set(ENABLE_SHARED_TRUE "")
|
|
|
+ set(ENABLE_SHARED_FALSE "#")
|
|
|
+else()
|
|
|
+ set(PKGCONFIG_LIBS_PRIV "")
|
|
|
+ set(ENABLE_SHARED_TRUE "#")
|
|
|
+ set(ENABLE_SHARED_FALSE "")
|
|
|
endif()
|
|
|
|
|
|
+# Clean up the different lists
|
|
|
+listtostr(EXTRA_LIBS _EXTRA_LIBS "-l")
|
|
|
+set(SDL_STATIC_LIBS ${SDL_LIBS} ${EXTRA_LDFLAGS} ${_EXTRA_LIBS})
|
|
|
+list(REMOVE_DUPLICATES SDL_STATIC_LIBS)
|
|
|
+listtostr(SDL_STATIC_LIBS _SDL_STATIC_LIBS)
|
|
|
+set(SDL_STATIC_LIBS ${_SDL_STATIC_LIBS})
|
|
|
+listtostr(SDL_LIBS _SDL_LIBS)
|
|
|
+set(SDL_LIBS ${_SDL_LIBS})
|
|
|
+listtostr(SDL_CFLAGS _SDL_CFLAGS "")
|
|
|
+set(SDL_CFLAGS ${_SDL_CFLAGS})
|
|
|
+string(REGEX REPLACE "-lSDL3( |$)" "-l${sdl_static_libname} " SDL_STATIC_LIBS "${SDL_STATIC_LIBS}")
|
|
|
+if(NOT SDL_SHARED)
|
|
|
+ string(REGEX REPLACE "-lSDL3( |$)" "-l${sdl_static_libname} " SDL_LIBS "${SDL_LIBS}")
|
|
|
+endif()
|
|
|
+
|
|
|
+if(SDL_STATIC AND SDL_SHARED AND NOT sdl_static_libname STREQUAL "SDL3")
|
|
|
+ message(STATUS "\"pkg-config --static --libs sdl3\" will return invalid information")
|
|
|
+endif()
|
|
|
+
|
|
|
+# MESSAGE(STATUS "SDL_LIBS: ${SDL_LIBS}")
|
|
|
+# MESSAGE(STATUS "SDL_STATIC_LIBS: ${SDL_STATIC_LIBS}")
|
|
|
+
|
|
|
+configure_file("${SDL3_SOURCE_DIR}/sdl3.pc.in"
|
|
|
+ "${SDL3_BINARY_DIR}/sdl3.pc" @ONLY)
|
|
|
+configure_file("${SDL3_SOURCE_DIR}/sdl3-config.in"
|
|
|
+ "${SDL3_BINARY_DIR}/sdl3-config" @ONLY)
|
|
|
+configure_file("${SDL3_SOURCE_DIR}/SDL3.spec.in"
|
|
|
+ "${SDL3_BINARY_DIR}/SDL3.spec" @ONLY)
|
|
|
+
|
|
|
macro(check_add_debug_flag FLAG SUFFIX)
|
|
|
check_c_compiler_flag(${FLAG} HAS_C_FLAG_${SUFFIX})
|
|
|
if (HAS_C_FLAG_${SUFFIX})
|
|
@@ -2961,13 +3036,30 @@ if (SDL_ASAN)
|
|
|
endif()
|
|
|
endif()
|
|
|
|
|
|
+if(SDL_CCACHE)
|
|
|
+ cmake_minimum_required(VERSION 3.4)
|
|
|
+ find_program(CCACHE_BINARY ccache)
|
|
|
+ if(CCACHE_BINARY)
|
|
|
+ set(CMAKE_C_COMPILER_LAUNCHER ${CCACHE_BINARY})
|
|
|
+ set(CMAKE_CXX_COMPILER_LAUNCHER ${CCACHE_BINARY})
|
|
|
+ set(CMAKE_OBJC_COMPILER_LAUNCHER ${CCACHE_BINARY})
|
|
|
+ set(HAVE_CCACHE ON)
|
|
|
+ else()
|
|
|
+ set(HAVE_CCACHE OFF)
|
|
|
+ endif()
|
|
|
+endif()
|
|
|
+
|
|
|
+if(SDL_TESTS)
|
|
|
+ set(HAVE_TESTS ON)
|
|
|
+endif()
|
|
|
+
|
|
|
# Create target that collects all all generated include files.
|
|
|
add_custom_target(sdl_headers_copy
|
|
|
DEPENDS ${SDL_GENERATED_HEADERS})
|
|
|
|
|
|
##### Info output #####
|
|
|
message(STATUS "")
|
|
|
-message(STATUS "SDL2 was configured with the following options:")
|
|
|
+message(STATUS "SDL3 was configured with the following options:")
|
|
|
message(STATUS "")
|
|
|
message(STATUS "Platform: ${CMAKE_SYSTEM}")
|
|
|
message(STATUS "64-bit: ${ARCH_64}")
|
|
@@ -3034,27 +3126,27 @@ endif()
|
|
|
# Ensure that the extra cflags are used at compile time
|
|
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${EXTRA_CFLAGS} ${EXTRA_CFLAGS_BUILD}")
|
|
|
|
|
|
-if(NOT WINDOWS_STORE AND NOT SDL2_DISABLE_SDL2MAIN)
|
|
|
+if(NOT WINDOWS_STORE AND NOT SDL3_DISABLE_SDL3MAIN)
|
|
|
# Build SDLmain
|
|
|
- add_library(SDL2main STATIC ${SDLMAIN_SOURCES})
|
|
|
- add_dependencies(SDL2main sdl_headers_copy)
|
|
|
+ add_library(SDL3main STATIC ${SDLMAIN_SOURCES})
|
|
|
+ add_dependencies(SDL3main sdl_headers_copy)
|
|
|
# alias target for in-tree builds
|
|
|
- add_library(SDL2::SDL2main ALIAS SDL2main)
|
|
|
- target_include_directories(SDL2main BEFORE PRIVATE "${SDL2_BINARY_DIR}/include" PRIVATE "${SDL2_BINARY_DIR}/include-config-$<LOWER_CASE:$<CONFIG>>")
|
|
|
- target_include_directories(SDL2main PUBLIC "$<BUILD_INTERFACE:${SDL2_BINARY_DIR}/include>" $<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}> $<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}/SDL2>)
|
|
|
+ add_library(SDL3::SDL3main ALIAS SDL3main)
|
|
|
+ target_include_directories(SDL3main BEFORE PRIVATE "${SDL3_BINARY_DIR}/include" PRIVATE "${SDL3_BINARY_DIR}/include-config-$<LOWER_CASE:$<CONFIG>>")
|
|
|
+ target_include_directories(SDL3main PUBLIC "$<BUILD_INTERFACE:${SDL3_BINARY_DIR}/include>" $<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}> $<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}/SDL3>)
|
|
|
if (WIN32)
|
|
|
- target_link_libraries(SDL2main PRIVATE shell32)
|
|
|
+ target_link_libraries(SDL3main PRIVATE shell32)
|
|
|
endif()
|
|
|
if(MINGW OR CYGWIN)
|
|
|
cmake_minimum_required(VERSION 3.13)
|
|
|
if(CMAKE_SIZEOF_VOID_P EQUAL 4)
|
|
|
- target_link_options(SDL2main PUBLIC "$<$<STREQUAL:$<TARGET_PROPERTY:TYPE>,EXECUTABLE>:-Wl,--undefined=_WinMain@16>")
|
|
|
+ target_link_options(SDL3main PUBLIC "$<$<STREQUAL:$<TARGET_PROPERTY:TYPE>,EXECUTABLE>:-Wl,--undefined=_WinMain@16>")
|
|
|
else()
|
|
|
- target_link_options(SDL2main PUBLIC "$<$<STREQUAL:$<TARGET_PROPERTY:TYPE>,EXECUTABLE>:-Wl,--undefined=WinMain>")
|
|
|
+ target_link_options(SDL3main PUBLIC "$<$<STREQUAL:$<TARGET_PROPERTY:TYPE>,EXECUTABLE>:-Wl,--undefined=WinMain>")
|
|
|
endif()
|
|
|
endif()
|
|
|
if (NOT ANDROID)
|
|
|
- set_target_properties(SDL2main PROPERTIES DEBUG_POSTFIX "${SDL_CMAKE_DEBUG_POSTFIX}")
|
|
|
+ set_target_properties(SDL3main PROPERTIES DEBUG_POSTFIX "${SDL_CMAKE_DEBUG_POSTFIX}")
|
|
|
endif()
|
|
|
endif()
|
|
|
|
|
@@ -3070,96 +3162,105 @@ if(PS2)
|
|
|
target_compile_options(sdl-build-options INTERFACE "-Wno-error=declaration-after-statement")
|
|
|
endif()
|
|
|
|
|
|
+if(APPLE)
|
|
|
+ foreach(SOURCE_FILE ${SOURCE_FILES})
|
|
|
+ get_filename_component(FILE_EXTENSION ${SOURCE_FILE} EXT)
|
|
|
+ if(FILE_EXTENSION STREQUAL "m")
|
|
|
+ set_property(SOURCE ${SOURCE_FILE} APPEND_STRING PROPERTY COMPILE_FLAGS " -x objective-c")
|
|
|
+ endif()
|
|
|
+ endforeach()
|
|
|
+endif()
|
|
|
+
|
|
|
if(SDL_SHARED)
|
|
|
- add_library(SDL2 SHARED ${SOURCE_FILES} ${VERSION_SOURCES})
|
|
|
- add_dependencies(SDL2 sdl_headers_copy)
|
|
|
+ add_library(SDL3 SHARED ${SOURCE_FILES} ${VERSION_SOURCES})
|
|
|
+ add_dependencies(SDL3 sdl_headers_copy)
|
|
|
# alias target for in-tree builds
|
|
|
- add_library(SDL2::SDL2 ALIAS SDL2)
|
|
|
- set_target_properties(SDL2 PROPERTIES POSITION_INDEPENDENT_CODE TRUE)
|
|
|
+ add_library(SDL3::SDL3 ALIAS SDL3)
|
|
|
+ set_target_properties(SDL3 PROPERTIES POSITION_INDEPENDENT_CODE TRUE)
|
|
|
+ if(NOT SDL_LIBC)
|
|
|
+ check_cpu_architecture(x86 HAS_X86)
|
|
|
+ if(HAS_X86)
|
|
|
+ # FIXME: should be added for all architectures (missing symbols for ARM)
|
|
|
+ target_link_libraries(SDL3 PRIVATE "-nodefaultlib:MSVCRT")
|
|
|
+ endif()
|
|
|
+ endif()
|
|
|
if(APPLE)
|
|
|
# FIXME: Remove SOVERSION in SDL3
|
|
|
- set_target_properties(SDL2 PROPERTIES
|
|
|
+ set_target_properties(SDL3 PROPERTIES
|
|
|
MACOSX_RPATH 1
|
|
|
SOVERSION 0
|
|
|
- OUTPUT_NAME "SDL2-${LT_RELEASE}")
|
|
|
+ OUTPUT_NAME "SDL3-${LT_RELEASE}")
|
|
|
elseif(UNIX AND NOT ANDROID)
|
|
|
- set_target_properties(SDL2 PROPERTIES
|
|
|
+ set_target_properties(SDL3 PROPERTIES
|
|
|
VERSION ${LT_VERSION}
|
|
|
SOVERSION ${LT_MAJOR}
|
|
|
- OUTPUT_NAME "SDL2-${LT_RELEASE}")
|
|
|
+ OUTPUT_NAME "SDL3-${LT_RELEASE}")
|
|
|
else()
|
|
|
if(WINDOWS OR CYGWIN)
|
|
|
- set_target_properties(SDL2 PROPERTIES
|
|
|
+ set_target_properties(SDL3 PROPERTIES
|
|
|
DEFINE_SYMBOL DLL_EXPORT)
|
|
|
- elseif(OS2)
|
|
|
- set_target_properties(SDL2 PROPERTIES
|
|
|
- DEFINE_SYMBOL BUILD_SDL)
|
|
|
endif()
|
|
|
- set_target_properties(SDL2 PROPERTIES
|
|
|
+ set_target_properties(SDL3 PROPERTIES
|
|
|
VERSION ${SDL_VERSION}
|
|
|
SOVERSION ${LT_REVISION}
|
|
|
- OUTPUT_NAME "SDL2")
|
|
|
+ OUTPUT_NAME "SDL3")
|
|
|
endif()
|
|
|
# Note: The clang toolset for Visual Studio does not support /NODEFAULTLIB.
|
|
|
if(MSVC AND NOT SDL_LIBC AND NOT MSVC_CLANG AND NOT CMAKE_GENERATOR_PLATFORM STREQUAL "ARM")
|
|
|
# Don't try to link with the default set of libraries.
|
|
|
if(NOT WINDOWS_STORE)
|
|
|
- set_target_properties(SDL2 PROPERTIES LINK_FLAGS_RELEASE "/NODEFAULTLIB")
|
|
|
- set_target_properties(SDL2 PROPERTIES LINK_FLAGS_DEBUG "/NODEFAULTLIB")
|
|
|
+ set_target_properties(SDL3 PROPERTIES LINK_FLAGS_RELEASE "/NODEFAULTLIB")
|
|
|
+ set_target_properties(SDL3 PROPERTIES LINK_FLAGS_DEBUG "/NODEFAULTLIB")
|
|
|
endif()
|
|
|
- set_target_properties(SDL2 PROPERTIES STATIC_LIBRARY_FLAGS "/NODEFAULTLIB")
|
|
|
+ set_target_properties(SDL3 PROPERTIES STATIC_LIBRARY_FLAGS "/NODEFAULTLIB")
|
|
|
endif()
|
|
|
# FIXME: if CMAKE_VERSION >= 3.13, use target_link_options for EXTRA_LDFLAGS
|
|
|
- target_link_libraries(SDL2 PRIVATE ${EXTRA_LIBS} ${EXTRA_LDFLAGS} ${EXTRA_LDFLAGS_BUILD})
|
|
|
- target_include_directories(SDL2 PUBLIC
|
|
|
- "$<BUILD_INTERFACE:${SDL2_BINARY_DIR}/include>"
|
|
|
- "$<BUILD_INTERFACE:${SDL2_BINARY_DIR}/include-config-$<LOWER_CASE:$<CONFIG>>>"
|
|
|
+ target_link_libraries(SDL3 PRIVATE ${EXTRA_LIBS} ${EXTRA_LDFLAGS} ${EXTRA_LDFLAGS_BUILD})
|
|
|
+ target_include_directories(SDL3 PUBLIC
|
|
|
+ "$<BUILD_INTERFACE:${SDL3_BINARY_DIR}/include>"
|
|
|
+ "$<BUILD_INTERFACE:${SDL3_BINARY_DIR}/include-config-$<LOWER_CASE:$<CONFIG>>>"
|
|
|
"$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}>"
|
|
|
- "$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}/SDL2>")
|
|
|
+ "$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}/SDL3>")
|
|
|
# This picks up all the compiler options and such we've accumulated up to here.
|
|
|
- target_link_libraries(SDL2 PRIVATE $<BUILD_INTERFACE:sdl-build-options>)
|
|
|
+ target_link_libraries(SDL3 PRIVATE $<BUILD_INTERFACE:sdl-build-options>)
|
|
|
if(MINGW OR CYGWIN)
|
|
|
if(NOT CMAKE_VERSION VERSION_LESS "3.13")
|
|
|
- target_link_options(SDL2 PRIVATE -static-libgcc)
|
|
|
+ target_link_options(SDL3 PRIVATE -static-libgcc)
|
|
|
endif()
|
|
|
endif()
|
|
|
if(NOT ANDROID)
|
|
|
- set_target_properties(SDL2 PROPERTIES DEBUG_POSTFIX "${SDL_CMAKE_DEBUG_POSTFIX}")
|
|
|
+ set_target_properties(SDL3 PROPERTIES DEBUG_POSTFIX "${SDL_CMAKE_DEBUG_POSTFIX}")
|
|
|
endif()
|
|
|
# Use `Compatible Interface Properties` to allow consumers to enforce a shared/static library
|
|
|
- set_property(TARGET SDL2 PROPERTY INTERFACE_SDL2_SHARED TRUE)
|
|
|
- set_property(TARGET SDL2 APPEND PROPERTY COMPATIBLE_INTERFACE_BOOL SDL2_SHARED)
|
|
|
+ set_property(TARGET SDL3 PROPERTY INTERFACE_SDL3_SHARED TRUE)
|
|
|
+ set_property(TARGET SDL3 APPEND PROPERTY COMPATIBLE_INTERFACE_BOOL SDL3_SHARED)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_STATIC)
|
|
|
- add_library(SDL2-static STATIC ${SOURCE_FILES})
|
|
|
- add_dependencies(SDL2-static sdl_headers_copy)
|
|
|
+ add_library(SDL3-static STATIC ${SOURCE_FILES})
|
|
|
+ add_dependencies(SDL3-static sdl_headers_copy)
|
|
|
# alias target for in-tree builds
|
|
|
- add_library(SDL2::SDL2-static ALIAS SDL2-static)
|
|
|
- if(MSVC OR (WATCOM AND (WIN32 OR OS2)))
|
|
|
- # Avoid conflict between the dll import library and the static library
|
|
|
- set_target_properties(SDL2-static PROPERTIES OUTPUT_NAME "SDL2-static")
|
|
|
- else()
|
|
|
- set_target_properties(SDL2-static PROPERTIES OUTPUT_NAME "SDL2")
|
|
|
- endif()
|
|
|
- set_target_properties(SDL2-static PROPERTIES POSITION_INDEPENDENT_CODE "${SDL_STATIC_PIC}")
|
|
|
- target_compile_definitions(SDL2-static PRIVATE SDL_STATIC_LIB)
|
|
|
+ add_library(SDL3::SDL3-static ALIAS SDL3-static)
|
|
|
+ set_target_properties(SDL3-static PROPERTIES
|
|
|
+ OUTPUT_NAME "${sdl_static_libname}"
|
|
|
+ POSITION_INDEPENDENT_CODE "${SDL_STATIC_PIC}")
|
|
|
+ target_compile_definitions(SDL3-static PRIVATE SDL_STATIC_LIB)
|
|
|
# TODO: Win32 platforms keep the same suffix .lib for import and static
|
|
|
# libraries - do we need to consider this?
|
|
|
- target_link_libraries(SDL2-static PRIVATE ${EXTRA_LIBS} ${EXTRA_LDFLAGS})
|
|
|
- target_include_directories(SDL2-static PUBLIC
|
|
|
- "$<BUILD_INTERFACE:${SDL2_BINARY_DIR}/include>"
|
|
|
- "$<BUILD_INTERFACE:${SDL2_BINARY_DIR}/include-config-$<LOWER_CASE:$<CONFIG>>>"
|
|
|
+ target_link_libraries(SDL3-static PRIVATE ${EXTRA_LIBS} ${EXTRA_LDFLAGS})
|
|
|
+ target_include_directories(SDL3-static PUBLIC
|
|
|
+ "$<BUILD_INTERFACE:${SDL3_BINARY_DIR}/include>"
|
|
|
+ "$<BUILD_INTERFACE:${SDL3_BINARY_DIR}/include-config-$<LOWER_CASE:$<CONFIG>>>"
|
|
|
"$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}>"
|
|
|
- "$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}/SDL2>")
|
|
|
+ "$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}/SDL3>")
|
|
|
# This picks up all the compiler options and such we've accumulated up to here.
|
|
|
- target_link_libraries(SDL2-static PRIVATE $<BUILD_INTERFACE:sdl-build-options>)
|
|
|
+ target_link_libraries(SDL3-static PRIVATE $<BUILD_INTERFACE:sdl-build-options>)
|
|
|
if(NOT ANDROID)
|
|
|
- set_target_properties(SDL2-static PROPERTIES DEBUG_POSTFIX "${SDL_CMAKE_DEBUG_POSTFIX}")
|
|
|
+ set_target_properties(SDL3-static PROPERTIES DEBUG_POSTFIX "${SDL_CMAKE_DEBUG_POSTFIX}")
|
|
|
endif()
|
|
|
# Use `Compatible Interface Properties` to allow consumers to enforce a shared/static library
|
|
|
- set_property(TARGET SDL2-static PROPERTY INTERFACE_SDL2_SHARED FALSE)
|
|
|
- set_property(TARGET SDL2-static APPEND PROPERTY COMPATIBLE_INTERFACE_BOOL SDL2_SHARED)
|
|
|
+ set_property(TARGET SDL3-static PROPERTY INTERFACE_SDL3_SHARED FALSE)
|
|
|
+ set_property(TARGET SDL3-static APPEND PROPERTY COMPATIBLE_INTERFACE_BOOL SDL3_SHARED)
|
|
|
endif()
|
|
|
|
|
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -DSDL_BUILD_MAJOR_VERSION=${SDL_MAJOR_VERSION}")
|
|
@@ -3169,45 +3270,45 @@ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -DSDL_BUILD_MICRO_VERSION=${SDL_MICRO_VERSIO
|
|
|
##### Tests #####
|
|
|
|
|
|
if(SDL_TEST)
|
|
|
- file(GLOB TEST_SOURCES ${SDL2_SOURCE_DIR}/src/test/*.c)
|
|
|
- add_library(SDL2_test STATIC ${TEST_SOURCES})
|
|
|
- add_dependencies(SDL2_test sdl_headers_copy)
|
|
|
- add_library(SDL2::SDL2test ALIAS SDL2_test)
|
|
|
- set_target_properties(SDL2_test PROPERTIES
|
|
|
- EXPORT_NAME SDL2test)
|
|
|
- target_include_directories(SDL2_test PUBLIC
|
|
|
- "$<BUILD_INTERFACE:${SDL2_BINARY_DIR}/include>"
|
|
|
- "$<BUILD_INTERFACE:${SDL2_BINARY_DIR}/include-config-$<LOWER_CASE:$<CONFIG>>>"
|
|
|
+ file(GLOB TEST_SOURCES ${SDL3_SOURCE_DIR}/src/test/*.c)
|
|
|
+ add_library(SDL3_test STATIC ${TEST_SOURCES})
|
|
|
+ add_dependencies(SDL3_test sdl_headers_copy)
|
|
|
+ add_library(SDL3::SDL3test ALIAS SDL3_test)
|
|
|
+ set_target_properties(SDL3_test PROPERTIES
|
|
|
+ EXPORT_NAME SDL3test)
|
|
|
+ target_include_directories(SDL3_test PUBLIC
|
|
|
+ "$<BUILD_INTERFACE:${SDL3_BINARY_DIR}/include>"
|
|
|
+ "$<BUILD_INTERFACE:${SDL3_BINARY_DIR}/include-config-$<LOWER_CASE:$<CONFIG>>>"
|
|
|
"$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}>"
|
|
|
- "$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}/SDL2>")
|
|
|
- target_link_libraries(SDL2_test PRIVATE ${EXTRA_TEST_LIBS})
|
|
|
+ "$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}/SDL3>")
|
|
|
+ target_link_libraries(SDL3_test PRIVATE ${EXTRA_TEST_LIBS})
|
|
|
endif()
|
|
|
|
|
|
##### Installation targets #####
|
|
|
-if(NOT SDL2_DISABLE_INSTALL)
|
|
|
+if(NOT SDL3_DISABLE_INSTALL)
|
|
|
if(SDL_SHARED)
|
|
|
- install(TARGETS SDL2 EXPORT SDL2Targets
|
|
|
+ install(TARGETS SDL3 EXPORT SDL3Targets
|
|
|
LIBRARY DESTINATION "${CMAKE_INSTALL_LIBDIR}"
|
|
|
ARCHIVE DESTINATION "${CMAKE_INSTALL_LIBDIR}"
|
|
|
RUNTIME DESTINATION "${CMAKE_INSTALL_BINDIR}")
|
|
|
endif()
|
|
|
|
|
|
- if(NOT WINDOWS_STORE AND NOT SDL2_DISABLE_SDL2MAIN)
|
|
|
- install(TARGETS SDL2main EXPORT SDL2mainTargets
|
|
|
+ if(NOT WINDOWS_STORE AND NOT SDL3_DISABLE_SDL3MAIN)
|
|
|
+ install(TARGETS SDL3main EXPORT SDL3mainTargets
|
|
|
LIBRARY DESTINATION "${CMAKE_INSTALL_LIBDIR}"
|
|
|
ARCHIVE DESTINATION "${CMAKE_INSTALL_LIBDIR}"
|
|
|
RUNTIME DESTINATION "${CMAKE_INSTALL_BINDIR}")
|
|
|
endif()
|
|
|
|
|
|
if(SDL_STATIC)
|
|
|
- install(TARGETS SDL2-static EXPORT SDL2staticTargets
|
|
|
+ install(TARGETS SDL3-static EXPORT SDL3staticTargets
|
|
|
LIBRARY DESTINATION "${CMAKE_INSTALL_LIBDIR}"
|
|
|
ARCHIVE DESTINATION "${CMAKE_INSTALL_LIBDIR}"
|
|
|
RUNTIME DESTINATION "${CMAKE_INSTALL_BINDIR}")
|
|
|
endif()
|
|
|
|
|
|
if(SDL_TEST)
|
|
|
- install(TARGETS SDL2_test EXPORT SDL2testTargets
|
|
|
+ install(TARGETS SDL3_test EXPORT SDL3testTargets
|
|
|
LIBRARY DESTINATION "${CMAKE_INSTALL_LIBDIR}"
|
|
|
ARCHIVE DESTINATION "${CMAKE_INSTALL_LIBDIR}"
|
|
|
RUNTIME DESTINATION "${CMAKE_INSTALL_BINDIR}")
|
|
@@ -3215,83 +3316,86 @@ if(NOT SDL2_DISABLE_INSTALL)
|
|
|
|
|
|
##### Export files #####
|
|
|
if (WINDOWS AND NOT MINGW)
|
|
|
- set(PKG_PREFIX "cmake")
|
|
|
+ set(SDL_INSTALL_CMAKEDIR_DEFAULT "cmake")
|
|
|
+ set(LICENSES_PREFIX "licenses/SDL3")
|
|
|
else ()
|
|
|
- set(PKG_PREFIX "${CMAKE_INSTALL_LIBDIR}/cmake/SDL2")
|
|
|
+ set(SDL_INSTALL_CMAKEDIR_DEFAULT "${CMAKE_INSTALL_LIBDIR}/cmake/SDL3")
|
|
|
+ set(LICENSES_PREFIX "${CMAKE_INSTALL_DATAROOTDIR}/licenses/${PROJECT_NAME}")
|
|
|
endif ()
|
|
|
+ set(SDL_INSTALL_CMAKEDIR "${SDL_INSTALL_CMAKEDIR_DEFAULT}" CACHE STRING "Location where to install SDL3Config.cmake")
|
|
|
|
|
|
include(CMakePackageConfigHelpers)
|
|
|
- configure_package_config_file(SDL2Config.cmake.in "${CMAKE_CURRENT_BINARY_DIR}/SDL2Config.cmake"
|
|
|
+ configure_package_config_file(SDL3Config.cmake.in "${CMAKE_CURRENT_BINARY_DIR}/SDL3Config.cmake"
|
|
|
PATH_VARS CMAKE_INSTALL_PREFIX CMAKE_INSTALL_FULL_BINDIR CMAKE_INSTALL_FULL_INCLUDEDIR CMAKE_INSTALL_FULL_LIBDIR
|
|
|
- INSTALL_DESTINATION ${PKG_PREFIX}
|
|
|
+ INSTALL_DESTINATION "${SDL_INSTALL_CMAKEDIR}"
|
|
|
)
|
|
|
- write_basic_package_version_file("${CMAKE_CURRENT_BINARY_DIR}/SDL2ConfigVersion.cmake"
|
|
|
+ write_basic_package_version_file("${CMAKE_CURRENT_BINARY_DIR}/SDL3ConfigVersion.cmake"
|
|
|
VERSION ${SDL_VERSION}
|
|
|
COMPATIBILITY AnyNewerVersion
|
|
|
)
|
|
|
|
|
|
if(SDL_SHARED)
|
|
|
- install(EXPORT SDL2Targets
|
|
|
- FILE SDL2Targets.cmake
|
|
|
- NAMESPACE SDL2::
|
|
|
- DESTINATION ${PKG_PREFIX}
|
|
|
+ install(EXPORT SDL3Targets
|
|
|
+ FILE SDL3Targets.cmake
|
|
|
+ NAMESPACE SDL3::
|
|
|
+ DESTINATION "${SDL_INSTALL_CMAKEDIR}"
|
|
|
)
|
|
|
if(ANDROID AND NOT CMAKE_VERSION VERSION_LESS 3.7)
|
|
|
- install(EXPORT_ANDROID_MK SDL2Targets
|
|
|
- DESTINATION "${CMAKE_INSTALL_DATAROOTDIR}/ndk-modules/SDL2")
|
|
|
+ install(EXPORT_ANDROID_MK SDL3Targets
|
|
|
+ DESTINATION "${CMAKE_INSTALL_DATAROOTDIR}/ndk-modules/SDL3")
|
|
|
endif()
|
|
|
endif()
|
|
|
|
|
|
- if(NOT WINDOWS_STORE AND NOT SDL2_DISABLE_SDL2MAIN)
|
|
|
- install(EXPORT SDL2mainTargets
|
|
|
- FILE SDL2mainTargets.cmake
|
|
|
- NAMESPACE SDL2::
|
|
|
- DESTINATION ${PKG_PREFIX}
|
|
|
+ if(NOT WINDOWS_STORE AND NOT SDL3_DISABLE_SDL3MAIN)
|
|
|
+ install(EXPORT SDL3mainTargets
|
|
|
+ FILE SDL3mainTargets.cmake
|
|
|
+ NAMESPACE SDL3::
|
|
|
+ DESTINATION "${SDL_INSTALL_CMAKEDIR}"
|
|
|
)
|
|
|
if(ANDROID AND NOT CMAKE_VERSION VERSION_LESS 3.7)
|
|
|
- install(EXPORT_ANDROID_MK SDL2mainTargets
|
|
|
- DESTINATION "${CMAKE_INSTALL_DATAROOTDIR}/ndk-modules/SDL2main")
|
|
|
+ install(EXPORT_ANDROID_MK SDL3mainTargets
|
|
|
+ DESTINATION "${CMAKE_INSTALL_DATAROOTDIR}/ndk-modules/SDL3main")
|
|
|
endif()
|
|
|
endif()
|
|
|
|
|
|
if(SDL_STATIC)
|
|
|
- install(EXPORT SDL2staticTargets
|
|
|
- FILE SDL2staticTargets.cmake
|
|
|
- NAMESPACE SDL2::
|
|
|
- DESTINATION ${PKG_PREFIX}
|
|
|
+ install(EXPORT SDL3staticTargets
|
|
|
+ FILE SDL3staticTargets.cmake
|
|
|
+ NAMESPACE SDL3::
|
|
|
+ DESTINATION "${SDL_INSTALL_CMAKEDIR}"
|
|
|
)
|
|
|
if(ANDROID AND NOT CMAKE_VERSION VERSION_LESS 3.7)
|
|
|
- install(EXPORT_ANDROID_MK SDL2staticTargets
|
|
|
- DESTINATION "${CMAKE_INSTALL_DATAROOTDIR}/ndk-modules/SDL2-static")
|
|
|
+ install(EXPORT_ANDROID_MK SDL3staticTargets
|
|
|
+ DESTINATION "${CMAKE_INSTALL_DATAROOTDIR}/ndk-modules/SDL3-static")
|
|
|
endif()
|
|
|
endif()
|
|
|
|
|
|
if(SDL_TEST)
|
|
|
- install(EXPORT SDL2testTargets
|
|
|
- FILE SDL2testTargets.cmake
|
|
|
- NAMESPACE SDL2::
|
|
|
- DESTINATION ${PKG_PREFIX}
|
|
|
+ install(EXPORT SDL3testTargets
|
|
|
+ FILE SDL3testTargets.cmake
|
|
|
+ NAMESPACE SDL3::
|
|
|
+ DESTINATION "${SDL_INSTALL_CMAKEDIR}"
|
|
|
)
|
|
|
if(ANDROID AND NOT CMAKE_VERSION VERSION_LESS 3.7)
|
|
|
- install(EXPORT_ANDROID_MK SDL2testTargets
|
|
|
- DESTINATION "${CMAKE_INSTALL_DATAROOTDIR}/ndk-modules/SDL2test")
|
|
|
+ install(EXPORT_ANDROID_MK SDL3testTargets
|
|
|
+ DESTINATION "${CMAKE_INSTALL_DATAROOTDIR}/ndk-modules/SDL3test")
|
|
|
endif()
|
|
|
endif()
|
|
|
|
|
|
install(
|
|
|
FILES
|
|
|
- ${CMAKE_CURRENT_BINARY_DIR}/SDL2Config.cmake
|
|
|
- ${CMAKE_CURRENT_BINARY_DIR}/SDL2ConfigVersion.cmake
|
|
|
- DESTINATION ${PKG_PREFIX}
|
|
|
+ ${CMAKE_CURRENT_BINARY_DIR}/SDL3Config.cmake
|
|
|
+ ${CMAKE_CURRENT_BINARY_DIR}/SDL3ConfigVersion.cmake
|
|
|
+ DESTINATION "${SDL_INSTALL_CMAKEDIR}"
|
|
|
COMPONENT Devel
|
|
|
)
|
|
|
|
|
|
install(
|
|
|
FILES
|
|
|
- ${SDL2_INCLUDE_FILES}
|
|
|
- "${SDL2_BINARY_DIR}/include/SDL_revision.h"
|
|
|
- "${SDL2_BINARY_DIR}/include-config-$<LOWER_CASE:$<CONFIG>>/SDL_config.h"
|
|
|
- DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/SDL2)
|
|
|
+ ${SDL3_INCLUDE_FILES}
|
|
|
+ "${SDL3_BINARY_DIR}/include/SDL_revision.h"
|
|
|
+ "${SDL3_BINARY_DIR}/include-config-$<LOWER_CASE:$<CONFIG>>/SDL_config.h"
|
|
|
+ DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/SDL3)
|
|
|
|
|
|
string(TOUPPER "${CMAKE_BUILD_TYPE}" UPPER_BUILD_TYPE)
|
|
|
if (UPPER_BUILD_TYPE MATCHES DEBUG)
|
|
@@ -3300,35 +3404,35 @@ if(NOT SDL2_DISABLE_INSTALL)
|
|
|
set(SOPOSTFIX "")
|
|
|
endif()
|
|
|
|
|
|
+ install(FILES "LICENSE.txt" DESTINATION "${LICENSES_PREFIX}")
|
|
|
+ if(FREEBSD)
|
|
|
+ # FreeBSD uses ${PREFIX}/libdata/pkgconfig
|
|
|
+ install(FILES ${SDL3_BINARY_DIR}/sdl3.pc DESTINATION "libdata/pkgconfig")
|
|
|
+ else()
|
|
|
+ install(FILES ${SDL3_BINARY_DIR}/sdl3.pc
|
|
|
+ DESTINATION "${CMAKE_INSTALL_LIBDIR}/pkgconfig")
|
|
|
+ endif()
|
|
|
if(NOT (WINDOWS OR CYGWIN) OR MINGW)
|
|
|
if(SDL_SHARED)
|
|
|
set(SOEXT ${CMAKE_SHARED_LIBRARY_SUFFIX}) # ".so", ".dylib", etc.
|
|
|
- get_target_property(SONAME SDL2 OUTPUT_NAME)
|
|
|
- if(NOT ANDROID AND NOT MINGW AND NOT OS2)
|
|
|
+ get_target_property(SONAME SDL3 OUTPUT_NAME)
|
|
|
+ if(NOT ANDROID AND NOT MINGW)
|
|
|
install(CODE "
|
|
|
execute_process(COMMAND ${CMAKE_COMMAND} -E create_symlink
|
|
|
- \"lib${SONAME}${SOPOSTFIX}${SOEXT}\" \"libSDL2${SOPOSTFIX}${SOEXT}\"
|
|
|
- WORKING_DIRECTORY \"${SDL2_BINARY_DIR}\")")
|
|
|
- install(FILES ${SDL2_BINARY_DIR}/libSDL2${SOPOSTFIX}${SOEXT} DESTINATION "${CMAKE_INSTALL_LIBDIR}")
|
|
|
+ \"lib${SONAME}${SOPOSTFIX}${SOEXT}\" \"libSDL3${SOPOSTFIX}${SOEXT}\"
|
|
|
+ WORKING_DIRECTORY \"${SDL3_BINARY_DIR}\")")
|
|
|
+ install(FILES ${SDL3_BINARY_DIR}/libSDL3${SOPOSTFIX}${SOEXT} DESTINATION "${CMAKE_INSTALL_LIBDIR}")
|
|
|
endif()
|
|
|
endif()
|
|
|
- if(FREEBSD)
|
|
|
- # FreeBSD uses ${PREFIX}/libdata/pkgconfig
|
|
|
- install(FILES ${SDL2_BINARY_DIR}/sdl2.pc DESTINATION "libdata/pkgconfig")
|
|
|
- else()
|
|
|
- install(FILES ${SDL2_BINARY_DIR}/sdl2.pc
|
|
|
- DESTINATION "${CMAKE_INSTALL_LIBDIR}/pkgconfig")
|
|
|
- endif()
|
|
|
- install(PROGRAMS ${SDL2_BINARY_DIR}/sdl2-config DESTINATION "${CMAKE_INSTALL_BINDIR}")
|
|
|
+ install(PROGRAMS ${SDL3_BINARY_DIR}/sdl3-config DESTINATION "${CMAKE_INSTALL_BINDIR}")
|
|
|
# TODO: what about the .spec file? Is it only needed for RPM creation?
|
|
|
- install(FILES "${SDL2_SOURCE_DIR}/sdl2.m4" DESTINATION "${CMAKE_INSTALL_DATAROOTDIR}/aclocal")
|
|
|
- install(FILES "LICENSE.txt" DESTINATION "${CMAKE_INSTALL_DATAROOTDIR}/licenses/${PROJECT_NAME}")
|
|
|
+ install(FILES "${SDL3_SOURCE_DIR}/sdl3.m4" DESTINATION "${CMAKE_INSTALL_DATAROOTDIR}/aclocal")
|
|
|
endif()
|
|
|
endif()
|
|
|
|
|
|
##### Uninstall target #####
|
|
|
|
|
|
-if(NOT SDL2_DISABLE_UNINSTALL)
|
|
|
+if(NOT SDL3_DISABLE_UNINSTALL)
|
|
|
if(NOT TARGET uninstall)
|
|
|
configure_file(
|
|
|
"${CMAKE_CURRENT_SOURCE_DIR}/cmake_uninstall.cmake.in"
|
|
@@ -3343,6 +3447,7 @@ endif()
|
|
|
##### Tests subproject (must appear after the install/uninstall targets) #####
|
|
|
|
|
|
if(SDL_TESTS)
|
|
|
+ set(HAVE_TESTS ON)
|
|
|
enable_testing()
|
|
|
add_subdirectory(test)
|
|
|
endif()
|
|
@@ -3350,7 +3455,7 @@ endif()
|
|
|
##### Fix Objective C builds #####
|
|
|
set(CMAKE_OBJC_FLAGS "${CMAKE_OBJC_FLAGS} ${CMAKE_C_FLAGS}")
|
|
|
|
|
|
-# Make sure SDL2::SDL2 always exists
|
|
|
-if(TARGET SDL2::SDL2-static AND NOT TARGET SDL2::SDL2)
|
|
|
- add_library(SDL2::SDL2 ALIAS SDL2-static)
|
|
|
+# Make sure SDL3::SDL3 always exists
|
|
|
+if(TARGET SDL3::SDL3-static AND NOT TARGET SDL3::SDL3)
|
|
|
+ add_library(SDL3::SDL3 ALIAS SDL3-static)
|
|
|
endif()
|