|
@@ -1,8 +1,11 @@
|
|
|
+include(CMakeParseArguments)
|
|
|
macro(FindLibraryAndSONAME _LIB)
|
|
|
+ cmake_parse_arguments(FLAS "" "" "LIBDIRS" ${ARGN})
|
|
|
+
|
|
|
string(TOUPPER ${_LIB} _UPPERLNAME)
|
|
|
string(REGEX REPLACE "\\-" "_" _LNAME "${_UPPERLNAME}")
|
|
|
|
|
|
- find_library(${_LNAME}_LIB ${_LIB})
|
|
|
+ find_library(${_LNAME}_LIB ${_LIB} PATHS ${FLAS_LIBDIRS})
|
|
|
if(${_LNAME}_LIB)
|
|
|
# reduce the library name for shared linking
|
|
|
|
|
@@ -59,21 +62,13 @@ macro(CheckOSS)
|
|
|
check_c_source_compiles("
|
|
|
#include <sys/soundcard.h>
|
|
|
int main(int argc, char **argv) { int arg = SNDCTL_DSP_SETFRAGMENT; return 0; }" HAVE_OSS_SYS_SOUNDCARD_H)
|
|
|
- if(NOT HAVE_OSS_SYS_SOUNDCARD_H)
|
|
|
- check_c_source_compiles("
|
|
|
- #include <soundcard.h>
|
|
|
- int main(int argc, char **argv) { int arg = SNDCTL_DSP_SETFRAGMENT; return 0; }" HAVE_OSS_SOUNDCARD_H)
|
|
|
- endif()
|
|
|
|
|
|
- if(HAVE_OSS_SYS_SOUNDCARD_H OR HAVE_OSS_SOUNDCARD_H)
|
|
|
+ if(HAVE_OSS_SYS_SOUNDCARD_H)
|
|
|
set(HAVE_OSS TRUE)
|
|
|
- file(GLOB OSS_SOURCES ${SDL2_SOURCE_DIR}/src/audio/dsp/*.c)
|
|
|
- if(HAVE_OSS_SOUNDCARD_H)
|
|
|
- set(SDL_AUDIO_DRIVER_OSS_SOUNDCARD_H 1)
|
|
|
- endif()
|
|
|
+ file(GLOB OSS_SOURCES ${SDL3_SOURCE_DIR}/src/audio/dsp/*.c)
|
|
|
set(SDL_AUDIO_DRIVER_OSS 1)
|
|
|
list(APPEND SOURCE_FILES ${OSS_SOURCES})
|
|
|
- if(NETBSD OR OPENBSD)
|
|
|
+ if(NETBSD)
|
|
|
list(APPEND EXTRA_LIBS ossaudio)
|
|
|
endif()
|
|
|
set(HAVE_SDL_AUDIO TRUE)
|
|
@@ -94,7 +89,7 @@ macro(CheckALSA)
|
|
|
endif()
|
|
|
if(HAVE_LIBASOUND)
|
|
|
set(HAVE_ALSA TRUE)
|
|
|
- file(GLOB ALSA_SOURCES ${SDL2_SOURCE_DIR}/src/audio/alsa/*.c)
|
|
|
+ file(GLOB ALSA_SOURCES ${SDL3_SOURCE_DIR}/src/audio/alsa/*.c)
|
|
|
list(APPEND SOURCE_FILES ${ALSA_SOURCES})
|
|
|
set(SDL_AUDIO_DRIVER_ALSA 1)
|
|
|
if(SDL_ALSA_SHARED AND NOT HAVE_SDL_LOADSO)
|
|
@@ -122,14 +117,14 @@ macro(CheckPipewire)
|
|
|
pkg_check_modules(PKG_PIPEWIRE libpipewire-0.3>=0.3.20)
|
|
|
if(PKG_PIPEWIRE_FOUND)
|
|
|
set(HAVE_PIPEWIRE TRUE)
|
|
|
- file(GLOB PIPEWIRE_SOURCES ${SDL2_SOURCE_DIR}/src/audio/pipewire/*.c)
|
|
|
+ file(GLOB PIPEWIRE_SOURCES ${SDL3_SOURCE_DIR}/src/audio/pipewire/*.c)
|
|
|
list(APPEND SOURCE_FILES ${PIPEWIRE_SOURCES})
|
|
|
set(SDL_AUDIO_DRIVER_PIPEWIRE 1)
|
|
|
list(APPEND EXTRA_CFLAGS ${PKG_PIPEWIRE_CFLAGS})
|
|
|
if(SDL_PIPEWIRE_SHARED AND NOT HAVE_SDL_LOADSO)
|
|
|
message_warn("You must have SDL_LoadObject() support for dynamic Pipewire loading")
|
|
|
endif()
|
|
|
- FindLibraryAndSONAME("pipewire-0.3")
|
|
|
+ FindLibraryAndSONAME("pipewire-0.3" LIBDIRS ${PKG_PIPEWIRE_LIBRARY_DIRS})
|
|
|
if(SDL_PIPEWIRE_SHARED AND PIPEWIRE_0.3_LIB AND HAVE_SDL_LOADSO)
|
|
|
set(SDL_AUDIO_DRIVER_PIPEWIRE_DYNAMIC "\"${PIPEWIRE_0.3_LIB_SONAME}\"")
|
|
|
set(HAVE_PIPEWIRE_SHARED TRUE)
|
|
@@ -151,14 +146,14 @@ macro(CheckPulseAudio)
|
|
|
pkg_check_modules(PKG_PULSEAUDIO libpulse-simple)
|
|
|
if(PKG_PULSEAUDIO_FOUND)
|
|
|
set(HAVE_PULSEAUDIO TRUE)
|
|
|
- file(GLOB PULSEAUDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/pulseaudio/*.c)
|
|
|
+ file(GLOB PULSEAUDIO_SOURCES ${SDL3_SOURCE_DIR}/src/audio/pulseaudio/*.c)
|
|
|
list(APPEND SOURCE_FILES ${PULSEAUDIO_SOURCES})
|
|
|
set(SDL_AUDIO_DRIVER_PULSEAUDIO 1)
|
|
|
list(APPEND EXTRA_CFLAGS ${PKG_PULSEAUDIO_CFLAGS})
|
|
|
if(SDL_PULSEAUDIO_SHARED AND NOT HAVE_SDL_LOADSO)
|
|
|
message_warn("You must have SDL_LoadObject() support for dynamic PulseAudio loading")
|
|
|
endif()
|
|
|
- FindLibraryAndSONAME("pulse-simple")
|
|
|
+ FindLibraryAndSONAME("pulse-simple" LIBDIRS ${PKG_PULSEAUDIO_LIBRARY_DIRS})
|
|
|
if(SDL_PULSEAUDIO_SHARED AND PULSE_SIMPLE_LIB AND HAVE_SDL_LOADSO)
|
|
|
set(SDL_AUDIO_DRIVER_PULSEAUDIO_DYNAMIC "\"${PULSE_SIMPLE_LIB_SONAME}\"")
|
|
|
set(HAVE_PULSEAUDIO_SHARED TRUE)
|
|
@@ -173,149 +168,26 @@ endmacro()
|
|
|
# Requires:
|
|
|
# - PkgCheckModules
|
|
|
# Optional:
|
|
|
-# - SDL_JACK_SHARED opt
|
|
|
-# - HAVE_SDL_LOADSO opt
|
|
|
-macro(CheckJACK)
|
|
|
- if(SDL_JACK)
|
|
|
- pkg_check_modules(PKG_JACK jack)
|
|
|
- if(PKG_JACK_FOUND)
|
|
|
- set(HAVE_JACK TRUE)
|
|
|
- file(GLOB JACK_SOURCES ${SDL2_SOURCE_DIR}/src/audio/jack/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${JACK_SOURCES})
|
|
|
- set(SDL_AUDIO_DRIVER_JACK 1)
|
|
|
- list(APPEND EXTRA_CFLAGS ${PKG_JACK_CFLAGS})
|
|
|
- if(SDL_JACK_SHARED AND NOT HAVE_SDL_LOADSO)
|
|
|
- message_warn("You must have SDL_LoadObject() support for dynamic JACK audio loading")
|
|
|
- endif()
|
|
|
- FindLibraryAndSONAME("jack")
|
|
|
- if(SDL_JACK_SHARED AND JACK_LIB AND HAVE_SDL_LOADSO)
|
|
|
- set(SDL_AUDIO_DRIVER_JACK_DYNAMIC "\"${JACK_LIB_SONAME}\"")
|
|
|
- set(HAVE_JACK_SHARED TRUE)
|
|
|
- else()
|
|
|
- list(APPEND EXTRA_LDFLAGS ${PKG_JACK_LDFLAGS})
|
|
|
- endif()
|
|
|
- set(HAVE_SDL_AUDIO TRUE)
|
|
|
- endif()
|
|
|
- endif()
|
|
|
-endmacro()
|
|
|
-
|
|
|
-# Requires:
|
|
|
-# - PkgCheckModules
|
|
|
-# Optional:
|
|
|
-# - SDL_ESD_SHARED opt
|
|
|
-# - HAVE_SDL_LOADSO opt
|
|
|
-macro(CheckESD)
|
|
|
- if(SDL_ESD)
|
|
|
- pkg_check_modules(PKG_ESD esound)
|
|
|
- if(PKG_ESD_FOUND)
|
|
|
- set(HAVE_ESD TRUE)
|
|
|
- file(GLOB ESD_SOURCES ${SDL2_SOURCE_DIR}/src/audio/esd/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${ESD_SOURCES})
|
|
|
- set(SDL_AUDIO_DRIVER_ESD 1)
|
|
|
- list(APPEND EXTRA_CFLAGS ${PKG_ESD_CFLAGS})
|
|
|
- if(SDL_ESD_SHARED AND NOT HAVE_SDL_LOADSO)
|
|
|
- message_warn("You must have SDL_LoadObject() support for dynamic ESD loading")
|
|
|
- endif()
|
|
|
- FindLibraryAndSONAME(esd)
|
|
|
- if(SDL_ESD_SHARED AND ESD_LIB AND HAVE_SDL_LOADSO)
|
|
|
- set(SDL_AUDIO_DRIVER_ESD_DYNAMIC "\"${ESD_LIB_SONAME}\"")
|
|
|
- set(HAVE_ESD_SHARED TRUE)
|
|
|
- else()
|
|
|
- list(APPEND EXTRA_LDFLAGS ${PKG_ESD_LDFLAGS})
|
|
|
- endif()
|
|
|
- set(HAVE_SDL_AUDIO TRUE)
|
|
|
- endif()
|
|
|
- endif()
|
|
|
-endmacro()
|
|
|
-
|
|
|
-# Requires:
|
|
|
-# - n/a
|
|
|
-# Optional:
|
|
|
-# - SDL_ARTS_SHARED opt
|
|
|
-# - HAVE_SDL_LOADSO opt
|
|
|
-macro(CheckARTS)
|
|
|
- if(SDL_ARTS)
|
|
|
- find_program(ARTS_CONFIG arts-config)
|
|
|
- if(ARTS_CONFIG)
|
|
|
- execute_process(CMD_ARTSCFLAGS ${ARTS_CONFIG} --cflags
|
|
|
- OUTPUT_VARIABLE ARTS_CFLAGS OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
|
- list(APPEND EXTRA_CFLAGS ${ARTS_CFLAGS})
|
|
|
- execute_process(CMD_ARTSLIBS ${ARTS_CONFIG} --libs
|
|
|
- OUTPUT_VARIABLE ARTS_LIBS OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
|
- file(GLOB ARTS_SOURCES ${SDL2_SOURCE_DIR}/src/audio/arts/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${ARTS_SOURCES})
|
|
|
- set(SDL_AUDIO_DRIVER_ARTS 1)
|
|
|
- set(HAVE_ARTS TRUE)
|
|
|
- if(SDL_ARTS_SHARED AND NOT HAVE_SDL_LOADSO)
|
|
|
- message_warn("You must have SDL_LoadObject() support for dynamic ARTS loading")
|
|
|
- endif()
|
|
|
- FindLibraryAndSONAME(artsc)
|
|
|
- if(SDL_ARTS_SHARED AND ARTSC_LIB AND HAVE_SDL_LOADSO)
|
|
|
- # TODO
|
|
|
- set(SDL_AUDIO_DRIVER_ARTS_DYNAMIC "\"${ARTSC_LIB_SONAME}\"")
|
|
|
- set(HAVE_ARTS_SHARED TRUE)
|
|
|
- else()
|
|
|
- list(APPEND EXTRA_LDFLAGS ${ARTS_LIBS})
|
|
|
- endif()
|
|
|
- set(HAVE_SDL_AUDIO TRUE)
|
|
|
- endif()
|
|
|
- endif()
|
|
|
-endmacro()
|
|
|
-
|
|
|
-# Requires:
|
|
|
-# - n/a
|
|
|
-# Optional:
|
|
|
-# - SDL_NAS_SHARED opt
|
|
|
-# - HAVE_SDL_LOADSO opt
|
|
|
-macro(CheckNAS)
|
|
|
- if(SDL_NAS)
|
|
|
- # TODO: set include paths properly, so the NAS headers are found
|
|
|
- check_include_file(audio/audiolib.h HAVE_NAS_H)
|
|
|
- find_library(D_NAS_LIB audio)
|
|
|
- if(HAVE_NAS_H AND D_NAS_LIB)
|
|
|
- set(HAVE_NAS TRUE)
|
|
|
- file(GLOB NAS_SOURCES ${SDL2_SOURCE_DIR}/src/audio/nas/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${NAS_SOURCES})
|
|
|
- set(SDL_AUDIO_DRIVER_NAS 1)
|
|
|
- if(SDL_NAS_SHARED AND NOT HAVE_SDL_LOADSO)
|
|
|
- message_warn("You must have SDL_LoadObject() support for dynamic NAS loading")
|
|
|
- endif()
|
|
|
- FindLibraryAndSONAME("audio")
|
|
|
- if(SDL_NAS_SHARED AND AUDIO_LIB AND HAVE_SDL_LOADSO)
|
|
|
- set(SDL_AUDIO_DRIVER_NAS_DYNAMIC "\"${AUDIO_LIB_SONAME}\"")
|
|
|
- set(HAVE_NAS_SHARED TRUE)
|
|
|
- else()
|
|
|
- list(APPEND EXTRA_LIBS ${D_NAS_LIB})
|
|
|
- endif()
|
|
|
- set(HAVE_SDL_AUDIO TRUE)
|
|
|
- endif()
|
|
|
- endif()
|
|
|
-endmacro()
|
|
|
-
|
|
|
-# Requires:
|
|
|
-# - n/a
|
|
|
-# Optional:
|
|
|
# - SDL_SNDIO_SHARED opt
|
|
|
# - HAVE_SDL_LOADSO opt
|
|
|
macro(CheckSNDIO)
|
|
|
if(SDL_SNDIO)
|
|
|
- # TODO: set include paths properly, so the sndio headers are found
|
|
|
- check_include_file(sndio.h HAVE_SNDIO_H)
|
|
|
- find_library(D_SNDIO_LIB sndio)
|
|
|
- if(HAVE_SNDIO_H AND D_SNDIO_LIB)
|
|
|
+ pkg_check_modules(PKG_SNDIO sndio)
|
|
|
+ if(PKG_SNDIO_FOUND)
|
|
|
set(HAVE_SNDIO TRUE)
|
|
|
- file(GLOB SNDIO_SOURCES ${SDL2_SOURCE_DIR}/src/audio/sndio/*.c)
|
|
|
+ file(GLOB SNDIO_SOURCES ${SDL3_SOURCE_DIR}/src/audio/sndio/*.c)
|
|
|
list(APPEND SOURCE_FILES ${SNDIO_SOURCES})
|
|
|
set(SDL_AUDIO_DRIVER_SNDIO 1)
|
|
|
+ list(APPEND EXTRA_CFLAGS ${PKG_SNDIO_CFLAGS})
|
|
|
if(SDL_SNDIO_SHARED AND NOT HAVE_SDL_LOADSO)
|
|
|
message_warn("You must have SDL_LoadObject() support for dynamic sndio loading")
|
|
|
endif()
|
|
|
- FindLibraryAndSONAME("sndio")
|
|
|
+ FindLibraryAndSONAME("sndio" LIBDIRS ${PKG_SNDIO_LIBRARY_DIRS})
|
|
|
if(SDL_SNDIO_SHARED AND SNDIO_LIB AND HAVE_SDL_LOADSO)
|
|
|
set(SDL_AUDIO_DRIVER_SNDIO_DYNAMIC "\"${SNDIO_LIB_SONAME}\"")
|
|
|
set(HAVE_SNDIO_SHARED TRUE)
|
|
|
else()
|
|
|
- list(APPEND EXTRA_LIBS ${D_SNDIO_LIB})
|
|
|
+ list(APPEND EXTRA_LIBS ${PKG_SNDIO_LDFLAGS})
|
|
|
endif()
|
|
|
set(HAVE_SDL_AUDIO TRUE)
|
|
|
endif()
|
|
@@ -325,26 +197,26 @@ endmacro()
|
|
|
# Requires:
|
|
|
# - PkgCheckModules
|
|
|
# Optional:
|
|
|
-# - FUSIONSOUND_SHARED opt
|
|
|
+# - SDL_JACK_SHARED opt
|
|
|
# - HAVE_SDL_LOADSO opt
|
|
|
-macro(CheckFusionSound)
|
|
|
- if(FUSIONSOUND)
|
|
|
- pkg_check_modules(PKG_FUSIONSOUND fusionsound>=1.0.0)
|
|
|
- if(PKG_FUSIONSOUND_FOUND)
|
|
|
- set(HAVE_FUSIONSOUND TRUE)
|
|
|
- file(GLOB FUSIONSOUND_SOURCES ${SDL2_SOURCE_DIR}/src/audio/fusionsound/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${FUSIONSOUND_SOURCES})
|
|
|
- set(SDL_AUDIO_DRIVER_FUSIONSOUND 1)
|
|
|
- list(APPEND EXTRA_CFLAGS ${PKG_FUSIONSOUND_CFLAGS})
|
|
|
- if(FUSIONSOUND_SHARED AND NOT HAVE_SDL_LOADSO)
|
|
|
- message_warn("You must have SDL_LoadObject() support for dynamic FusionSound loading")
|
|
|
+macro(CheckJACK)
|
|
|
+ if(SDL_JACK)
|
|
|
+ pkg_check_modules(PKG_JACK jack)
|
|
|
+ if(PKG_JACK_FOUND)
|
|
|
+ set(HAVE_JACK TRUE)
|
|
|
+ file(GLOB JACK_SOURCES ${SDL3_SOURCE_DIR}/src/audio/jack/*.c)
|
|
|
+ list(APPEND SOURCE_FILES ${JACK_SOURCES})
|
|
|
+ set(SDL_AUDIO_DRIVER_JACK 1)
|
|
|
+ list(APPEND EXTRA_CFLAGS ${PKG_JACK_CFLAGS})
|
|
|
+ if(SDL_JACK_SHARED AND NOT HAVE_SDL_LOADSO)
|
|
|
+ message_warn("You must have SDL_LoadObject() support for dynamic JACK audio loading")
|
|
|
endif()
|
|
|
- FindLibraryAndSONAME("fusionsound")
|
|
|
- if(FUSIONSOUND_SHARED AND FUSIONSOUND_LIB AND HAVE_SDL_LOADSO)
|
|
|
- set(SDL_AUDIO_DRIVER_FUSIONSOUND_DYNAMIC "\"${FUSIONSOUND_LIB_SONAME}\"")
|
|
|
- set(HAVE_FUSIONSOUND_SHARED TRUE)
|
|
|
+ FindLibraryAndSONAME("jack" LIBDIRS ${PKG_JACK_LIBRARY_DIRS})
|
|
|
+ if(SDL_JACK_SHARED AND JACK_LIB AND HAVE_SDL_LOADSO)
|
|
|
+ set(SDL_AUDIO_DRIVER_JACK_DYNAMIC "\"${JACK_LIB_SONAME}\"")
|
|
|
+ set(HAVE_JACK_SHARED TRUE)
|
|
|
else()
|
|
|
- list(APPEND EXTRA_LDFLAGS ${PKG_FUSIONSOUND_LDFLAGS})
|
|
|
+ list(APPEND EXTRA_LDFLAGS ${PKG_JACK_LDFLAGS})
|
|
|
endif()
|
|
|
set(HAVE_SDL_AUDIO TRUE)
|
|
|
endif()
|
|
@@ -370,7 +242,7 @@ macro(CheckLibSampleRate)
|
|
|
get_property(_samplerate_type TARGET SampleRate::samplerate PROPERTY TYPE)
|
|
|
if(_samplerate_type STREQUAL "SHARED_LIBRARY")
|
|
|
set(HAVE_LIBSAMPLERATE_SHARED TRUE)
|
|
|
- if(WIN32 OR OS2)
|
|
|
+ if(WIN32)
|
|
|
set(SDL_LIBSAMPLERATE_DYNAMIC "\"$<TARGET_FILE_NAME:SampleRate::samplerate>\"")
|
|
|
else()
|
|
|
set(SDL_LIBSAMPLERATE_DYNAMIC "\"$<TARGET_SONAME_FILE_NAME:SampleRate::samplerate>\"")
|
|
@@ -448,7 +320,7 @@ macro(CheckX11)
|
|
|
set(HAVE_X11 TRUE)
|
|
|
set(HAVE_SDL_VIDEO TRUE)
|
|
|
|
|
|
- file(GLOB X11_SOURCES ${SDL2_SOURCE_DIR}/src/video/x11/*.c)
|
|
|
+ file(GLOB X11_SOURCES ${SDL3_SOURCE_DIR}/src/video/x11/*.c)
|
|
|
list(APPEND SOURCE_FILES ${X11_SOURCES})
|
|
|
set(SDL_VIDEO_DRIVER_X11 1)
|
|
|
|
|
@@ -635,9 +507,11 @@ endmacro()
|
|
|
# - HAVE_SDL_LOADSO opt
|
|
|
macro(CheckWayland)
|
|
|
if(SDL_WAYLAND)
|
|
|
- pkg_check_modules(WAYLAND "wayland-client>=1.18" wayland-egl wayland-cursor egl "xkbcommon>=0.5.0")
|
|
|
+ set(WAYLAND_FOUND FALSE)
|
|
|
+ pkg_check_modules(PKG_WAYLAND "wayland-client>=1.18" wayland-egl wayland-cursor egl "xkbcommon>=0.5.0")
|
|
|
|
|
|
- if(WAYLAND_FOUND)
|
|
|
+ if(PKG_WAYLAND_FOUND)
|
|
|
+ set(WAYLAND_FOUND TRUE)
|
|
|
find_program(WAYLAND_SCANNER NAMES wayland-scanner REQUIRED)
|
|
|
execute_process(
|
|
|
COMMAND ${WAYLAND_SCANNER} --version
|
|
@@ -660,23 +534,23 @@ macro(CheckWayland)
|
|
|
endif()
|
|
|
|
|
|
if(WAYLAND_FOUND)
|
|
|
- target_link_directories(sdl-build-options INTERFACE "${WAYLAND_LIBRARY_DIRS}")
|
|
|
- target_include_directories(sdl-build-options INTERFACE "${WAYLAND_INCLUDE_DIRS}")
|
|
|
+ target_link_directories(sdl-build-options INTERFACE "${PKG_WAYLAND_LIBRARY_DIRS}")
|
|
|
+ target_include_directories(sdl-build-options INTERFACE "${PKG_WAYLAND_INCLUDE_DIRS}")
|
|
|
|
|
|
set(HAVE_WAYLAND TRUE)
|
|
|
set(HAVE_SDL_VIDEO TRUE)
|
|
|
|
|
|
- file(GLOB WAYLAND_SOURCES ${SDL2_SOURCE_DIR}/src/video/wayland/*.c)
|
|
|
+ file(GLOB WAYLAND_SOURCES ${SDL3_SOURCE_DIR}/src/video/wayland/*.c)
|
|
|
list(APPEND SOURCE_FILES ${WAYLAND_SOURCES})
|
|
|
|
|
|
# We have to generate some protocol interface code for some unstable Wayland features.
|
|
|
file(MAKE_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/wayland-generated-protocols")
|
|
|
target_include_directories(sdl-build-options INTERFACE "${CMAKE_CURRENT_BINARY_DIR}/wayland-generated-protocols")
|
|
|
|
|
|
- file(GLOB WAYLAND_PROTOCOLS_XML RELATIVE "${SDL2_SOURCE_DIR}/wayland-protocols/" "${SDL2_SOURCE_DIR}/wayland-protocols/*.xml")
|
|
|
+ file(GLOB WAYLAND_PROTOCOLS_XML RELATIVE "${SDL3_SOURCE_DIR}/wayland-protocols/" "${SDL3_SOURCE_DIR}/wayland-protocols/*.xml")
|
|
|
foreach(_XML ${WAYLAND_PROTOCOLS_XML})
|
|
|
string(REGEX REPLACE "\\.xml$" "" _PROTL "${_XML}")
|
|
|
- WaylandProtocolGen("${WAYLAND_SCANNER}" "${WAYLAND_SCANNER_CODE_MODE}" "${SDL2_SOURCE_DIR}/wayland-protocols/${_XML}" "${_PROTL}")
|
|
|
+ WaylandProtocolGen("${WAYLAND_SCANNER}" "${WAYLAND_SCANNER_CODE_MODE}" "${SDL3_SOURCE_DIR}/wayland-protocols/${_XML}" "${_PROTL}")
|
|
|
endforeach()
|
|
|
|
|
|
if(SDL_WAYLAND_QT_TOUCH)
|
|
@@ -687,10 +561,10 @@ macro(CheckWayland)
|
|
|
if(SDL_WAYLAND_SHARED AND NOT HAVE_SDL_LOADSO)
|
|
|
message_warn("You must have SDL_LoadObject() support for dynamic Wayland loading")
|
|
|
endif()
|
|
|
- FindLibraryAndSONAME(wayland-client)
|
|
|
- FindLibraryAndSONAME(wayland-egl)
|
|
|
- FindLibraryAndSONAME(wayland-cursor)
|
|
|
- FindLibraryAndSONAME(xkbcommon)
|
|
|
+ FindLibraryAndSONAME(wayland-client LIBDIRS ${PKG_WAYLAND_LIBRARY_DIRS})
|
|
|
+ FindLibraryAndSONAME(wayland-egl LIBDIRS ${PKG_WAYLAND_LIBRARY_DIRS})
|
|
|
+ FindLibraryAndSONAME(wayland-cursor LIBDIRS ${PKG_WAYLAND_LIBRARY_DIRS})
|
|
|
+ FindLibraryAndSONAME(xkbcommon LIBDIRS ${PKG_WAYLAND_LIBRARY_DIRS})
|
|
|
if(SDL_WAYLAND_SHARED AND WAYLAND_CLIENT_LIB AND WAYLAND_EGL_LIB AND WAYLAND_CURSOR_LIB AND XKBCOMMON_LIB AND HAVE_SDL_LOADSO)
|
|
|
set(SDL_VIDEO_DRIVER_WAYLAND_DYNAMIC "\"${WAYLAND_CLIENT_LIB_SONAME}\"")
|
|
|
set(SDL_VIDEO_DRIVER_WAYLAND_DYNAMIC_EGL "\"${WAYLAND_EGL_LIB_SONAME}\"")
|
|
@@ -698,25 +572,25 @@ macro(CheckWayland)
|
|
|
set(SDL_VIDEO_DRIVER_WAYLAND_DYNAMIC_XKBCOMMON "\"${XKBCOMMON_LIB_SONAME}\"")
|
|
|
set(HAVE_WAYLAND_SHARED TRUE)
|
|
|
else()
|
|
|
- list(APPEND EXTRA_LIBS ${WAYLAND_LIBRARIES})
|
|
|
+ list(APPEND EXTRA_LIBS ${PKG_WAYLAND_LIBRARIES})
|
|
|
endif()
|
|
|
|
|
|
if(SDL_WAYLAND_LIBDECOR)
|
|
|
- pkg_check_modules(LIBDECOR libdecor-0)
|
|
|
- if(LIBDECOR_FOUND)
|
|
|
+ pkg_check_modules(PKG_LIBDECOR libdecor-0)
|
|
|
+ if(PKG_LIBDECOR_FOUND)
|
|
|
set(HAVE_WAYLAND_LIBDECOR TRUE)
|
|
|
set(HAVE_LIBDECOR_H 1)
|
|
|
- target_link_directories(sdl-build-options INTERFACE "${LIBDECOR_LIBRARY_DIRS}")
|
|
|
- target_include_directories(sdl-build-options INTERFACE "${LIBDECOR_INCLUDE_DIRS}")
|
|
|
+ target_link_directories(sdl-build-options INTERFACE "${PKG_LIBDECOR_LIBRARY_DIRS}")
|
|
|
+ target_include_directories(sdl-build-options INTERFACE "${PKG_LIBDECOR_INCLUDE_DIRS}")
|
|
|
if(SDL_WAYLAND_LIBDECOR_SHARED AND NOT HAVE_SDL_LOADSO)
|
|
|
message_warn("You must have SDL_LoadObject() support for dynamic libdecor loading")
|
|
|
endif()
|
|
|
- FindLibraryAndSONAME(decor-0)
|
|
|
+ FindLibraryAndSONAME(decor-0 LIBDIRS ${PKG_LIBDECOR_LIBRARY_DIRS})
|
|
|
if(SDL_WAYLAND_LIBDECOR_SHARED AND DECOR_0_LIB AND HAVE_SDL_LOADSO)
|
|
|
- set(HAVE_LIBDECOR_SHARED TRUE)
|
|
|
+ set(HAVE_WAYLAND_LIBDECOR_SHARED TRUE)
|
|
|
set(SDL_VIDEO_DRIVER_WAYLAND_DYNAMIC_LIBDECOR "\"${DECOR_0_LIB_SONAME}\"")
|
|
|
else()
|
|
|
- list(APPEND EXTRA_LIBS ${LIBDECOR_LIBRARIES})
|
|
|
+ list(APPEND EXTRA_LIBS ${PKG_LIBDECOR_LIBRARIES})
|
|
|
endif()
|
|
|
endif()
|
|
|
endif()
|
|
@@ -735,7 +609,7 @@ macro(CheckCOCOA)
|
|
|
set(HAVE_COCOA TRUE)
|
|
|
endif()
|
|
|
if(HAVE_COCOA)
|
|
|
- file(GLOB COCOA_SOURCES ${SDL2_SOURCE_DIR}/src/video/cocoa/*.m)
|
|
|
+ file(GLOB COCOA_SOURCES ${SDL3_SOURCE_DIR}/src/video/cocoa/*.m)
|
|
|
list(APPEND SOURCE_FILES ${COCOA_SOURCES})
|
|
|
set(SDL_VIDEO_DRIVER_COCOA 1)
|
|
|
set(HAVE_SDL_VIDEO TRUE)
|
|
@@ -743,37 +617,6 @@ macro(CheckCOCOA)
|
|
|
endif()
|
|
|
endmacro()
|
|
|
|
|
|
-# Requires:
|
|
|
-# - PkgCheckModules
|
|
|
-# Optional:
|
|
|
-# - DIRECTFB_SHARED opt
|
|
|
-# - HAVE_SDL_LOADSO opt
|
|
|
-macro(CheckDirectFB)
|
|
|
- if(SDL_DIRECTFB)
|
|
|
- pkg_check_modules(PKG_DIRECTFB directfb>=1.0.0)
|
|
|
- if(PKG_DIRECTFB_FOUND)
|
|
|
- set(HAVE_DIRECTFB TRUE)
|
|
|
- file(GLOB DIRECTFB_SOURCES ${SDL2_SOURCE_DIR}/src/video/directfb/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${DIRECTFB_SOURCES})
|
|
|
- set(SDL_VIDEO_DRIVER_DIRECTFB 1)
|
|
|
- set(SDL_VIDEO_RENDER_DIRECTFB 1)
|
|
|
- list(APPEND EXTRA_CFLAGS ${PKG_DIRECTFB_CFLAGS})
|
|
|
- list(APPEND SDL_CFLAGS ${PKG_DIRECTFB_CFLAGS})
|
|
|
- if(SDL_DIRECTFB_SHARED AND NOT HAVE_SDL_LOADSO)
|
|
|
- message_warn("You must have SDL_LoadObject() support for dynamic DirectFB loading")
|
|
|
- endif()
|
|
|
- FindLibraryAndSONAME("directfb")
|
|
|
- if(SDL_DIRECTFB_SHARED AND DIRECTFB_LIB AND HAVE_SDL_LOADSO)
|
|
|
- set(SDL_VIDEO_DRIVER_DIRECTFB_DYNAMIC "\"${DIRECTFB_LIB_SONAME}\"")
|
|
|
- set(HAVE_DIRECTFB_SHARED TRUE)
|
|
|
- else()
|
|
|
- list(APPEND EXTRA_LDFLAGS ${PKG_DIRECTFB_LDFLAGS})
|
|
|
- endif()
|
|
|
- set(HAVE_SDL_VIDEO TRUE)
|
|
|
- endif()
|
|
|
- endif()
|
|
|
-endmacro()
|
|
|
-
|
|
|
# Requires:
|
|
|
# - n/a
|
|
|
macro(CheckVivante)
|
|
@@ -790,7 +633,7 @@ macro(CheckVivante)
|
|
|
set(HAVE_VIVANTE TRUE)
|
|
|
set(HAVE_SDL_VIDEO TRUE)
|
|
|
|
|
|
- file(GLOB VIVANTE_SOURCES ${SDL2_SOURCE_DIR}/src/video/vivante/*.c)
|
|
|
+ file(GLOB VIVANTE_SOURCES ${SDL3_SOURCE_DIR}/src/video/vivante/*.c)
|
|
|
list(APPEND SOURCE_FILES ${VIVANTE_SOURCES})
|
|
|
set(SDL_VIDEO_DRIVER_VIVANTE 1)
|
|
|
if(HAVE_VIVANTE_VDK)
|
|
@@ -909,7 +752,7 @@ macro(CheckPTHREAD)
|
|
|
set(PTHREAD_LDFLAGS "-lpthread")
|
|
|
elseif(OPENBSD)
|
|
|
set(PTHREAD_CFLAGS "-D_REENTRANT")
|
|
|
- set(PTHREAD_LDFLAGS "-pthread")
|
|
|
+ set(PTHREAD_LDFLAGS "-lpthread")
|
|
|
elseif(SOLARIS)
|
|
|
set(PTHREAD_CFLAGS "-D_REENTRANT")
|
|
|
set(PTHREAD_LDFLAGS "-pthread -lposix4")
|
|
@@ -1004,17 +847,17 @@ macro(CheckPTHREAD)
|
|
|
endif()
|
|
|
|
|
|
set(SOURCE_FILES ${SOURCE_FILES}
|
|
|
- ${SDL2_SOURCE_DIR}/src/thread/pthread/SDL_systhread.c
|
|
|
- ${SDL2_SOURCE_DIR}/src/thread/pthread/SDL_sysmutex.c # Can be faked, if necessary
|
|
|
- ${SDL2_SOURCE_DIR}/src/thread/pthread/SDL_syscond.c # Can be faked, if necessary
|
|
|
- ${SDL2_SOURCE_DIR}/src/thread/pthread/SDL_systls.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/thread/pthread/SDL_systhread.c
|
|
|
+ ${SDL3_SOURCE_DIR}/src/thread/pthread/SDL_sysmutex.c # Can be faked, if necessary
|
|
|
+ ${SDL3_SOURCE_DIR}/src/thread/pthread/SDL_syscond.c # Can be faked, if necessary
|
|
|
+ ${SDL3_SOURCE_DIR}/src/thread/pthread/SDL_systls.c
|
|
|
)
|
|
|
if(HAVE_PTHREADS_SEM)
|
|
|
set(SOURCE_FILES ${SOURCE_FILES}
|
|
|
- ${SDL2_SOURCE_DIR}/src/thread/pthread/SDL_syssem.c)
|
|
|
+ ${SDL3_SOURCE_DIR}/src/thread/pthread/SDL_syssem.c)
|
|
|
else()
|
|
|
set(SOURCE_FILES ${SOURCE_FILES}
|
|
|
- ${SDL2_SOURCE_DIR}/src/thread/generic/SDL_syssem.c)
|
|
|
+ ${SDL3_SOURCE_DIR}/src/thread/generic/SDL_syssem.c)
|
|
|
endif()
|
|
|
set(HAVE_SDL_THREADS TRUE)
|
|
|
endif()
|
|
@@ -1151,7 +994,7 @@ macro(CheckUSBHID)
|
|
|
set(SDL_HAVE_MACHINE_JOYSTICK_H 1)
|
|
|
endif()
|
|
|
set(SDL_JOYSTICK_USBHID 1)
|
|
|
- file(GLOB BSD_JOYSTICK_SOURCES ${SDL2_SOURCE_DIR}/src/joystick/bsd/*.c)
|
|
|
+ file(GLOB BSD_JOYSTICK_SOURCES ${SDL3_SOURCE_DIR}/src/joystick/bsd/*.c)
|
|
|
list(APPEND SOURCE_FILES ${BSD_JOYSTICK_SOURCES})
|
|
|
list(APPEND EXTRA_CFLAGS ${USB_CFLAGS})
|
|
|
list(APPEND EXTRA_LIBS ${USB_LIBS})
|
|
@@ -1168,19 +1011,17 @@ macro(CheckHIDAPI)
|
|
|
if(SDL_HIDAPI)
|
|
|
if(SDL_HIDAPI_LIBUSB)
|
|
|
set(HAVE_LIBUSB FALSE)
|
|
|
- pkg_check_modules(LIBUSB libusb-1.0)
|
|
|
- if(LIBUSB_FOUND)
|
|
|
- check_include_file(libusb.h HAVE_LIBUSB_H ${LIBUSB_CFLAGS})
|
|
|
+ pkg_check_modules(PKG_LIBUSB libusb-1.0)
|
|
|
+ if(PKG_LIBUSB_FOUND)
|
|
|
+ check_include_file(libusb.h HAVE_LIBUSB_H ${PKG_LIBUSB_CFLAGS})
|
|
|
if(HAVE_LIBUSB_H)
|
|
|
set(HAVE_LIBUSB TRUE)
|
|
|
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${LIBUSB_CFLAGS}")
|
|
|
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${PKG_LIBUSB_CFLAGS}")
|
|
|
if(HIDAPI_ONLY_LIBUSB)
|
|
|
- list(APPEND EXTRA_LIBS ${LIBUSB_LIBRARIES})
|
|
|
- elseif(OS2)
|
|
|
- set(SDL_LIBUSB_DYNAMIC "\"usb100.dll\"")
|
|
|
+ list(APPEND EXTRA_LIBS ${PKG_LIBUSB_LIBRARIES})
|
|
|
else()
|
|
|
# libusb is loaded dynamically, so don't add it to EXTRA_LIBS
|
|
|
- FindLibraryAndSONAME("usb-1.0")
|
|
|
+ FindLibraryAndSONAME("usb-1.0" LIBDIRS ${PKG_LIBUSB_LIBRARY_DIRS})
|
|
|
if(USB_1.0_LIB)
|
|
|
set(SDL_LIBUSB_DYNAMIC "\"${USB_1.0_LIB_SONAME}\"")
|
|
|
endif()
|
|
@@ -1195,10 +1036,10 @@ macro(CheckHIDAPI)
|
|
|
|
|
|
if(HAVE_HIDAPI)
|
|
|
if(ANDROID)
|
|
|
- list(APPEND SOURCE_FILES ${SDL2_SOURCE_DIR}/src/hidapi/android/hid.cpp)
|
|
|
+ list(APPEND SOURCE_FILES ${SDL3_SOURCE_DIR}/src/hidapi/android/hid.cpp)
|
|
|
endif()
|
|
|
if(IOS OR TVOS)
|
|
|
- list(APPEND SOURCE_FILES ${SDL2_SOURCE_DIR}/src/hidapi/ios/hid.m)
|
|
|
+ list(APPEND SOURCE_FILES ${SDL3_SOURCE_DIR}/src/hidapi/ios/hid.m)
|
|
|
set(SDL_FRAMEWORK_COREBLUETOOTH 1)
|
|
|
endif()
|
|
|
set(HAVE_SDL_HIDAPI TRUE)
|
|
@@ -1207,7 +1048,7 @@ macro(CheckHIDAPI)
|
|
|
set(SDL_JOYSTICK_HIDAPI 1)
|
|
|
set(HAVE_SDL_JOYSTICK TRUE)
|
|
|
set(HAVE_HIDAPI_JOYSTICK TRUE)
|
|
|
- file(GLOB HIDAPI_JOYSTICK_SOURCES ${SDL2_SOURCE_DIR}/src/joystick/hidapi/*.c)
|
|
|
+ file(GLOB HIDAPI_JOYSTICK_SOURCES ${SDL3_SOURCE_DIR}/src/joystick/hidapi/*.c)
|
|
|
list(APPEND SOURCE_FILES ${HIDAPI_JOYSTICK_SOURCES})
|
|
|
endif()
|
|
|
else()
|
|
@@ -1248,7 +1089,7 @@ macro(CheckRPI)
|
|
|
if(SDL_VIDEO AND HAVE_RPI)
|
|
|
set(HAVE_SDL_VIDEO TRUE)
|
|
|
set(SDL_VIDEO_DRIVER_RPI 1)
|
|
|
- file(GLOB VIDEO_RPI_SOURCES ${SDL2_SOURCE_DIR}/src/video/raspberry/*.c)
|
|
|
+ file(GLOB VIDEO_RPI_SOURCES ${SDL3_SOURCE_DIR}/src/video/raspberry/*.c)
|
|
|
list(APPEND SOURCE_FILES ${VIDEO_RPI_SOURCES})
|
|
|
list(APPEND EXTRA_LIBS ${VIDEO_RPI_LIBRARIES})
|
|
|
# !!! FIXME: shouldn't be using CMAKE_C_FLAGS, right?
|
|
@@ -1266,19 +1107,17 @@ endmacro()
|
|
|
# - HAVE_SDL_LOADSO opt
|
|
|
macro(CheckKMSDRM)
|
|
|
if(SDL_KMSDRM)
|
|
|
- pkg_check_modules(KMSDRM libdrm gbm egl)
|
|
|
- if(KMSDRM_FOUND AND HAVE_OPENGL_EGL)
|
|
|
- link_directories(
|
|
|
- ${KMSDRM_LIBRARY_DIRS}
|
|
|
- )
|
|
|
- target_include_directories(sdl-build-options INTERFACE "${KMSDRM_INCLUDE_DIRS}")
|
|
|
+ pkg_check_modules(PKG_KMSDRM libdrm gbm egl)
|
|
|
+ if(PKG_KMSDRM_FOUND AND HAVE_OPENGL_EGL)
|
|
|
+ target_link_directories(sdl-build-options INTERFACE ${PKG_KMSDRM_LIBRARY_DIRS})
|
|
|
+ target_include_directories(sdl-build-options INTERFACE "${PKG_KMSDRM_INCLUDE_DIRS}")
|
|
|
set(HAVE_KMSDRM TRUE)
|
|
|
set(HAVE_SDL_VIDEO TRUE)
|
|
|
|
|
|
- file(GLOB KMSDRM_SOURCES ${SDL2_SOURCE_DIR}/src/video/kmsdrm/*.c)
|
|
|
+ file(GLOB KMSDRM_SOURCES ${SDL3_SOURCE_DIR}/src/video/kmsdrm/*.c)
|
|
|
list(APPEND SOURCE_FILES ${KMSDRM_SOURCES})
|
|
|
|
|
|
- list(APPEND EXTRA_CFLAGS ${KMSDRM_CFLAGS})
|
|
|
+ list(APPEND EXTRA_CFLAGS ${PKG_KMSDRM_CFLAGS})
|
|
|
|
|
|
set(SDL_VIDEO_DRIVER_KMSDRM 1)
|
|
|
|
|
@@ -1286,13 +1125,13 @@ macro(CheckKMSDRM)
|
|
|
message_warn("You must have SDL_LoadObject() support for dynamic KMS/DRM loading")
|
|
|
endif()
|
|
|
if(SDL_KMSDRM_SHARED AND HAVE_SDL_LOADSO)
|
|
|
- FindLibraryAndSONAME(drm)
|
|
|
- FindLibraryAndSONAME(gbm)
|
|
|
+ FindLibraryAndSONAME(drm LIBDIRS ${PKG_KMSDRM_LIBRARY_DIRS})
|
|
|
+ FindLibraryAndSONAME(gbm LIBDIRS ${PKG_KMSDRM_LIBRARY_DIRS})
|
|
|
set(SDL_VIDEO_DRIVER_KMSDRM_DYNAMIC "\"${DRM_LIB_SONAME}\"")
|
|
|
set(SDL_VIDEO_DRIVER_KMSDRM_DYNAMIC_GBM "\"${GBM_LIB_SONAME}\"")
|
|
|
set(HAVE_KMSDRM_SHARED TRUE)
|
|
|
else()
|
|
|
- list(APPEND EXTRA_LIBS ${KMSDRM_LIBRARIES})
|
|
|
+ list(APPEND EXTRA_LIBS ${PKG_KMSDRM_LIBRARIES})
|
|
|
endif()
|
|
|
endif()
|
|
|
endif()
|