|
@@ -1,11 +1,12 @@
|
|
|
macro(FindLibraryAndSONAME _LIB)
|
|
|
- cmake_parse_arguments(FLAS "" "" "LIBDIRS" ${ARGN})
|
|
|
+ cmake_parse_arguments(_FLAS "" "" "LIBDIRS" ${ARGN})
|
|
|
|
|
|
string(TOUPPER ${_LIB} _UPPERLNAME)
|
|
|
string(REGEX REPLACE "\\-" "_" _LNAME "${_UPPERLNAME}")
|
|
|
|
|
|
- find_library(${_LNAME}_LIB ${_LIB} PATHS ${FLAS_LIBDIRS})
|
|
|
+ find_library(${_LNAME}_LIB ${_LIB} PATHS ${_FLAS_LIBDIRS})
|
|
|
|
|
|
+ # FIXME: fail FindLibraryAndSONAME when library is not shared.
|
|
|
if(${_LNAME}_LIB MATCHES ".*\\${CMAKE_SHARED_LIBRARY_SUFFIX}.*" AND NOT ${_LNAME}_LIB MATCHES ".*\\${CMAKE_STATIC_LIBRARY_SUFFIX}.*")
|
|
|
set(${_LNAME}_SHARED TRUE)
|
|
|
else()
|
|
@@ -16,6 +17,7 @@ macro(FindLibraryAndSONAME _LIB)
|
|
|
# reduce the library name for shared linking
|
|
|
|
|
|
get_filename_component(_LIB_REALPATH ${${_LNAME}_LIB} REALPATH) # resolves symlinks
|
|
|
+ get_filename_component(_LIB_LIBDIR ${_LIB_REALPATH} DIRECTORY)
|
|
|
get_filename_component(_LIB_JUSTNAME ${_LIB_REALPATH} NAME)
|
|
|
|
|
|
if(APPLE)
|
|
@@ -24,20 +26,20 @@ macro(FindLibraryAndSONAME _LIB)
|
|
|
string(REGEX REPLACE "(\\.[0-9]*)\\.[0-9\\.]*$" "\\1" _LIB_REGEXD "${_LIB_JUSTNAME}")
|
|
|
endif()
|
|
|
|
|
|
- get_filename_component(${_LNAME}_LIBDIR ${${_LNAME}_LIB} DIRECTORY)
|
|
|
-
|
|
|
- SET(_DEBUG_FindSONAME FALSE)
|
|
|
- if(_DEBUG_FindSONAME)
|
|
|
- message_warn("DYNLIB OUTPUTVAR: ${_LIB} ... ${_LNAME}_LIB")
|
|
|
- message_warn("DYNLIB ORIGINAL LIB: ${_LIB} ... ${${_LNAME}_LIB}")
|
|
|
- message_warn("DYNLIB REALPATH LIB: ${_LIB} ... ${_LIB_REALPATH}")
|
|
|
- message_warn("DYNLIB JUSTNAME LIB: ${_LIB} ... ${_LIB_JUSTNAME}")
|
|
|
- message_warn("DYNLIB REGEX'd LIB: ${_LIB} ... ${_LIB_REGEXD}")
|
|
|
+ if(NOT EXISTS "${_LIB_LIBDIR}/${_LIB_REGEXD}")
|
|
|
+ set(_LIB_REGEXD "${_LIB_JUSTNAME}")
|
|
|
endif()
|
|
|
+ set(${_LNAME}_LIBDIR "${_LIB_LIBDIR}")
|
|
|
|
|
|
message(STATUS "dynamic lib${_LIB} -> ${_LIB_REGEXD}")
|
|
|
set(${_LNAME}_LIB_SONAME ${_LIB_REGEXD})
|
|
|
endif()
|
|
|
+
|
|
|
+ message(DEBUG "DYNLIB OUTPUTVAR: ${_LIB} ... ${_LNAME}_LIB")
|
|
|
+ message(DEBUG "DYNLIB ORIGINAL LIB: ${_LIB} ... ${${_LNAME}_LIB}")
|
|
|
+ message(DEBUG "DYNLIB REALPATH LIB: ${_LIB} ... ${_LIB_REALPATH}")
|
|
|
+ message(DEBUG "DYNLIB JUSTNAME LIB: ${_LIB} ... ${_LIB_JUSTNAME}")
|
|
|
+ message(DEBUG "DYNLIB SONAME LIB: ${_LIB} ... ${_LIB_REGEXD}")
|
|
|
endmacro()
|
|
|
|
|
|
macro(CheckDLOPEN)
|
|
@@ -48,7 +50,7 @@ macro(CheckDLOPEN)
|
|
|
check_symbol_exists(dlopen "dlfcn.h" HAVE_DLOPEN_IN_LIBDL)
|
|
|
cmake_pop_check_state()
|
|
|
if(HAVE_DLOPEN_IN_LIBDL)
|
|
|
- list(APPEND SDL_EXTRA_LIBS dl)
|
|
|
+ sdl_link_dependency(dl LIBS dl)
|
|
|
endif()
|
|
|
endif()
|
|
|
if(HAVE_DLOPEN_IN_LIBC OR HAVE_DLOPEN_IN_LIBDL)
|
|
@@ -73,11 +75,10 @@ macro(CheckOSS)
|
|
|
|
|
|
if(HAVE_OSS_SYS_SOUNDCARD_H)
|
|
|
set(HAVE_OSS TRUE)
|
|
|
- file(GLOB OSS_SOURCES ${SDL3_SOURCE_DIR}/src/audio/dsp/*.c)
|
|
|
+ sdl_glob_sources(${SDL3_SOURCE_DIR}/src/audio/dsp/*.c)
|
|
|
set(SDL_AUDIO_DRIVER_OSS 1)
|
|
|
- list(APPEND SOURCE_FILES ${OSS_SOURCES})
|
|
|
if(NETBSD)
|
|
|
- list(APPEND SDL_EXTRA_LIBS ossaudio)
|
|
|
+ sdl_link_dependency(oss LIBS ossaudio)
|
|
|
endif()
|
|
|
set(HAVE_SDL_AUDIO TRUE)
|
|
|
endif()
|
|
@@ -91,10 +92,10 @@ endmacro()
|
|
|
# - HAVE_SDL_LOADSO opt
|
|
|
macro(CheckALSA)
|
|
|
if(SDL_ALSA)
|
|
|
- sdlFindALSA()
|
|
|
+ set(ALSA_PKG_CONFIG_SPEC "alsa")
|
|
|
+ find_package(ALSA MODULE)
|
|
|
if(ALSA_FOUND)
|
|
|
- file(GLOB ALSA_SOURCES "${SDL3_SOURCE_DIR}/src/audio/alsa/*.c")
|
|
|
- list(APPEND SOURCE_FILES ${ALSA_SOURCES})
|
|
|
+ sdl_glob_sources("${SDL3_SOURCE_DIR}/src/audio/alsa/*.c")
|
|
|
set(SDL_AUDIO_DRIVER_ALSA 1)
|
|
|
set(HAVE_ALSA TRUE)
|
|
|
set(HAVE_ALSA_SHARED FALSE)
|
|
@@ -102,7 +103,7 @@ macro(CheckALSA)
|
|
|
if(HAVE_SDL_LOADSO)
|
|
|
FindLibraryAndSONAME("asound")
|
|
|
if(ASOUND_LIB AND ASOUND_SHARED)
|
|
|
- target_include_directories(sdl-build-options INTERFACE $<TARGET_PROPERTY:ALSA::ALSA,INTERFACE_INCLUDE_DIRECTORIES>)
|
|
|
+ sdl_link_dependency(alsa INCLUDES $<TARGET_PROPERTY:ALSA::ALSA,INTERFACE_INCLUDE_DIRECTORIES>)
|
|
|
set(SDL_AUDIO_DRIVER_ALSA_DYNAMIC "\"${ASOUND_LIB_SONAME}\"")
|
|
|
set(HAVE_ALSA_SHARED TRUE)
|
|
|
else()
|
|
@@ -113,8 +114,9 @@ macro(CheckALSA)
|
|
|
endif()
|
|
|
endif()
|
|
|
if(NOT HAVE_ALSA_SHARED)
|
|
|
- list(APPEND SDL_CMAKE_DEPENDS ALSA::ALSA)
|
|
|
+ #FIXME: remove this line and property generate sdl3.pc
|
|
|
list(APPEND SDL_PC_PRIVATE_REQUIRES alsa)
|
|
|
+ sdl_link_dependency(alsa LIBS ALSA::ALSA CMAKE_MODULE ALSA PKG_CONFIG_SPECS "${ALSA_PKG_CONFIG_SPEC}")
|
|
|
endif()
|
|
|
set(HAVE_SDL_AUDIO TRUE)
|
|
|
endif()
|
|
@@ -130,26 +132,26 @@ endmacro()
|
|
|
# - SDL_PIPEWIRE_SHARED opt
|
|
|
# - HAVE_SDL_LOADSO opt
|
|
|
macro(CheckPipewire)
|
|
|
- if(SDL_PIPEWIRE)
|
|
|
- pkg_check_modules(PKG_PIPEWIRE libpipewire-0.3>=0.3.20)
|
|
|
- if(PKG_PIPEWIRE_FOUND)
|
|
|
- set(HAVE_PIPEWIRE TRUE)
|
|
|
- file(GLOB PIPEWIRE_SOURCES ${SDL3_SOURCE_DIR}/src/audio/pipewire/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${PIPEWIRE_SOURCES})
|
|
|
- set(SDL_AUDIO_DRIVER_PIPEWIRE 1)
|
|
|
- target_include_directories(sdl-build-options SYSTEM INTERFACE ${PKG_PIPEWIRE_INCLUDE_DIRS})
|
|
|
- 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" 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)
|
|
|
- else()
|
|
|
- list(APPEND SDL_EXTRA_LDFLAGS ${PKG_PIPEWIRE_LDFLAGS})
|
|
|
- endif()
|
|
|
- set(HAVE_SDL_AUDIO TRUE)
|
|
|
- endif()
|
|
|
+ if(SDL_PIPEWIRE)
|
|
|
+ set(PipeWire_PKG_CONFIG_SPEC libpipewire-0.3>=0.3.20)
|
|
|
+ pkg_check_modules(PC_PIPEWIRE IMPORTED_TARGET ${PipeWire_PKG_CONFIG_SPEC})
|
|
|
+ if(PC_PIPEWIRE_FOUND)
|
|
|
+ set(HAVE_PIPEWIRE TRUE)
|
|
|
+ sdl_glob_sources("${SDL3_SOURCE_DIR}/src/audio/pipewire/*.c")
|
|
|
+ set(SDL_AUDIO_DRIVER_PIPEWIRE 1)
|
|
|
+ if(SDL_PIPEWIRE_SHARED AND NOT HAVE_SDL_LOADSO)
|
|
|
+ message(WARNING "You must have SDL_LoadObject() support for dynamic PipeWire loading")
|
|
|
+ endif()
|
|
|
+ FindLibraryAndSONAME("pipewire-0.3" LIBDIRS ${PC_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)
|
|
|
+ sdl_link_dependency(pipewire INCLUDES $<TARGET_PROPERTY:PkgConfig::PC_PIPEWIRE,INTERFACE_INCLUDE_DIRECTORIES>)
|
|
|
+ else()
|
|
|
+ sdl_link_dependency(pipewire LIBS PkgConfig::PC_PIPEWIRE PKG_CONFIG_PREFIX PC_PIPEWIRE PKG_CONFIG_SPECS ${PipeWire_PKG_CONFIG_SPEC})
|
|
|
+ endif()
|
|
|
+ set(HAVE_SDL_AUDIO TRUE)
|
|
|
+ endif()
|
|
|
endif()
|
|
|
endmacro()
|
|
|
|
|
@@ -160,22 +162,22 @@ endmacro()
|
|
|
# - HAVE_SDL_LOADSO opt
|
|
|
macro(CheckPulseAudio)
|
|
|
if(SDL_PULSEAUDIO)
|
|
|
- pkg_check_modules(PKG_PULSEAUDIO libpulse>=5.0)
|
|
|
- if(PKG_PULSEAUDIO_FOUND)
|
|
|
+ set(PulseAudio_PKG_CONFIG_SPEC "libpulse>=5.0")
|
|
|
+ pkg_check_modules(PC_PULSEAUDIO IMPORTED_TARGET ${PulseAudio_PKG_CONFIG_SPEC})
|
|
|
+ if(PC_PULSEAUDIO_FOUND)
|
|
|
set(HAVE_PULSEAUDIO TRUE)
|
|
|
- file(GLOB PULSEAUDIO_SOURCES ${SDL3_SOURCE_DIR}/src/audio/pulseaudio/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${PULSEAUDIO_SOURCES})
|
|
|
+ sdl_glob_sources("${SDL3_SOURCE_DIR}/src/audio/pulseaudio/*.c")
|
|
|
set(SDL_AUDIO_DRIVER_PULSEAUDIO 1)
|
|
|
- target_include_directories(sdl-build-options SYSTEM INTERFACE ${PKG_PULSEAUDIO_INCLUDE_DIRS})
|
|
|
if(SDL_PULSEAUDIO_SHARED AND NOT HAVE_SDL_LOADSO)
|
|
|
- message_warn("You must have SDL_LoadObject() support for dynamic PulseAudio loading")
|
|
|
+ message(WARNING "You must have SDL_LoadObject() support for dynamic PulseAudio loading")
|
|
|
endif()
|
|
|
- FindLibraryAndSONAME("pulse" LIBDIRS ${PKG_PULSEAUDIO_LIBRARY_DIRS})
|
|
|
+ FindLibraryAndSONAME("pulse" LIBDIRS ${PC_PULSEAUDIO_LIBRARY_DIRS})
|
|
|
if(SDL_PULSEAUDIO_SHARED AND PULSE_LIB AND HAVE_SDL_LOADSO)
|
|
|
set(SDL_AUDIO_DRIVER_PULSEAUDIO_DYNAMIC "\"${PULSE_LIB_SONAME}\"")
|
|
|
set(HAVE_PULSEAUDIO_SHARED TRUE)
|
|
|
+ sdl_link_dependency(pulseaudio INCLUDES $<TARGET_PROPERTY:PkgConfig::PC_PULSEAUDIO,INTERFACE_INCLUDE_DIRECTORIES>)
|
|
|
else()
|
|
|
- list(APPEND SDL_EXTRA_LDFLAGS ${PKG_PULSEAUDIO_LDFLAGS})
|
|
|
+ sdl_link_dependency(pulseaudio LIBS PkgConfig::PC_PULSEAUDIO PKG_CONFIG_PREFIX PC_PULSEAUDIO PKG_CONFIG_SPECS "${PulseAudio_PKG_CONFIG_SPEC}")
|
|
|
endif()
|
|
|
set(HAVE_SDL_AUDIO TRUE)
|
|
|
endif()
|
|
@@ -189,22 +191,22 @@ endmacro()
|
|
|
# - HAVE_SDL_LOADSO opt
|
|
|
macro(CheckJACK)
|
|
|
if(SDL_JACK)
|
|
|
- pkg_check_modules(PKG_JACK jack)
|
|
|
- if(PKG_JACK_FOUND)
|
|
|
+ set(Jack_PKG_CONFIG_SPEC jack)
|
|
|
+ pkg_check_modules(PC_JACK IMPORTED_TARGET ${Jack_PKG_CONFIG_SPEC})
|
|
|
+ if(PC_JACK_FOUND)
|
|
|
set(HAVE_JACK TRUE)
|
|
|
- file(GLOB JACK_SOURCES ${SDL3_SOURCE_DIR}/src/audio/jack/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${JACK_SOURCES})
|
|
|
+ sdl_glob_sources("${SDL3_SOURCE_DIR}/src/audio/jack/*.c")
|
|
|
set(SDL_AUDIO_DRIVER_JACK 1)
|
|
|
- target_include_directories(sdl-build-options SYSTEM INTERFACE ${PKG_JACK_INCLUDE_DIRS})
|
|
|
if(SDL_JACK_SHARED AND NOT HAVE_SDL_LOADSO)
|
|
|
- message_warn("You must have SDL_LoadObject() support for dynamic JACK audio loading")
|
|
|
+ message(WARNING "You must have SDL_LoadObject() support for dynamic JACK audio loading")
|
|
|
endif()
|
|
|
- FindLibraryAndSONAME("jack" LIBDIRS ${PKG_JACK_LIBRARY_DIRS})
|
|
|
+ FindLibraryAndSONAME("jack" LIBDIRS ${PC_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)
|
|
|
+ sdl_link_dependency(jack INCLUDES $<TARGET_PROPERTY:PkgConfig::PC_JACK,INTERFACE_INCLUDE_DIRECTORIES>)
|
|
|
else()
|
|
|
- list(APPEND SDL_EXTRA_LDFLAGS ${PKG_JACK_LDFLAGS})
|
|
|
+ sdl_link_dependency(jack LIBS PkgConfig::PC_JACK PKG_CONFIG_PREFIX PC_JACK PKG_CONFIG_SPECS ${Jack_PKG_CONFIG_SPEC})
|
|
|
endif()
|
|
|
set(HAVE_SDL_AUDIO TRUE)
|
|
|
endif()
|
|
@@ -218,22 +220,22 @@ endmacro()
|
|
|
# - HAVE_SDL_LOADSO opt
|
|
|
macro(CheckSNDIO)
|
|
|
if(SDL_SNDIO)
|
|
|
- pkg_check_modules(PKG_SNDIO sndio)
|
|
|
- if(PKG_SNDIO_FOUND)
|
|
|
+ set(SndIO_PKG_CONFIG_SPEC sndio)
|
|
|
+ pkg_check_modules(PC_SNDIO IMPORTED_TARGET ${SndIO_PKG_CONFIG_SPEC})
|
|
|
+ if(PC_SNDIO_FOUND)
|
|
|
set(HAVE_SNDIO TRUE)
|
|
|
- file(GLOB SNDIO_SOURCES ${SDL3_SOURCE_DIR}/src/audio/sndio/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${SNDIO_SOURCES})
|
|
|
+ sdl_glob_sources("${SDL3_SOURCE_DIR}/src/audio/sndio/*.c")
|
|
|
set(SDL_AUDIO_DRIVER_SNDIO 1)
|
|
|
- target_include_directories(sdl-build-options INTERFACE ${PKG_SNDIO_INCLUDE_DIRS})
|
|
|
if(SDL_SNDIO_SHARED AND NOT HAVE_SDL_LOADSO)
|
|
|
- message_warn("You must have SDL_LoadObject() support for dynamic sndio loading")
|
|
|
+ message(WARNING "You must have SDL_LoadObject() support for dynamic sndio loading")
|
|
|
endif()
|
|
|
- FindLibraryAndSONAME("sndio" LIBDIRS ${PKG_SNDIO_LIBRARY_DIRS})
|
|
|
+ FindLibraryAndSONAME("sndio" LIBDIRS ${PC_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)
|
|
|
+ sdl_include_directories(PRIVATE SYSTEM $<TARGET_PROPERTY:PkgConfig::PC_SNDIO,INTERFACE_INCLUDE_DIRECTORIES>)
|
|
|
else()
|
|
|
- list(APPEND SDL_EXTRA_LIBS ${PKG_SNDIO_LDFLAGS})
|
|
|
+ sdl_link_dependency(sndio LIBS PkgConfig::PC_SNDIO PKG_CONFIG_PREFIX PC_SNDIO PKG_CONFIG_SPECS ${SndIO_PKG_CONFIG_SPEC})
|
|
|
endif()
|
|
|
set(HAVE_SDL_AUDIO TRUE)
|
|
|
endif()
|
|
@@ -248,14 +250,26 @@ endmacro()
|
|
|
macro(CheckX11)
|
|
|
cmake_push_check_state()
|
|
|
if(SDL_X11)
|
|
|
+ set(X11_PKG_CONFIG_SPEC x11)
|
|
|
+ set(Xext_PKG_CONFIG_SPEC xext)
|
|
|
+ set(Xcursor_PKG_CONFIG_SPEC xcursor)
|
|
|
+ set(Xi_PKG_CONFIG_SPEC xi)
|
|
|
+ set(Xfixes_PKG_CONFIG_SPEC xfixes)
|
|
|
+ set(Xrandr_PKG_CONFIG_SPEC xrandr)
|
|
|
+ set(Xrender_PKG_CONFIG_SPEC xrender)
|
|
|
+ set(Xss_PKG_CONFIG_SPEC xscrnsaver)
|
|
|
+
|
|
|
+ find_package(X11)
|
|
|
+
|
|
|
foreach(_LIB X11 Xext Xcursor Xi Xfixes Xrandr Xrender Xss)
|
|
|
- FindLibraryAndSONAME("${_LIB}")
|
|
|
+ get_filename_component(_libdir "${X11_${_LIB}_LIB}" DIRECTORY)
|
|
|
+ FindLibraryAndSONAME("${_LIB}" LIBDIRS ${_libdir})
|
|
|
endforeach()
|
|
|
|
|
|
- set(X11_dirs)
|
|
|
- find_path(X_INCLUDEDIR
|
|
|
+ find_path(X11_INCLUDEDIR
|
|
|
NAMES X11/Xlib.h
|
|
|
PATHS
|
|
|
+ ${X11_INCLUDE_DIR}
|
|
|
/usr/pkg/xorg/include
|
|
|
/usr/X11R6/include
|
|
|
/usr/X11R7/include
|
|
@@ -267,31 +281,30 @@ macro(CheckX11)
|
|
|
/opt/X11/include
|
|
|
)
|
|
|
|
|
|
- if(X_INCLUDEDIR)
|
|
|
- target_include_directories(sdl-build-options INTERFACE "${X_INCLUDEDIR}")
|
|
|
- list(APPEND CMAKE_REQUIRED_INCLUDES ${X_INCLUDEDIR})
|
|
|
+ if(X11_INCLUDEDIR)
|
|
|
+ sdl_include_directories(PRIVATE SYSTEM "${X11_INCLUDEDIR}")
|
|
|
+ list(APPEND CMAKE_REQUIRED_INCLUDES ${X11_INCLUDEDIR})
|
|
|
endif()
|
|
|
|
|
|
- find_file(HAVE_XCURSOR_H NAMES "X11/Xcursor/Xcursor.h" HINTS "${X_INCLUDEDIR}")
|
|
|
- find_file(HAVE_XINPUT2_H NAMES "X11/extensions/XInput2.h" HINTS "${X_INCLUDEDIR}")
|
|
|
- find_file(HAVE_XRANDR_H NAMES "X11/extensions/Xrandr.h" HINTS "${X_INCLUDEDIR}")
|
|
|
- find_file(HAVE_XFIXES_H_ NAMES "X11/extensions/Xfixes.h" HINTS "${X_INCLUDEDIR}")
|
|
|
- find_file(HAVE_XRENDER_H NAMES "X11/extensions/Xrender.h" HINTS "${X_INCLUDEDIR}")
|
|
|
- find_file(HAVE_XSS_H NAMES "X11/extensions/scrnsaver.h" HINTS "${X_INCLUDEDIR}")
|
|
|
- find_file(HAVE_XSHAPE_H NAMES "X11/extensions/shape.h" HINTS "${X_INCLUDEDIR}")
|
|
|
- find_file(HAVE_XDBE_H NAMES "X11/extensions/Xdbe.h" HINTS "${X_INCLUDEDIR}")
|
|
|
- find_file(HAVE_XEXT_H NAMES "X11/extensions/Xext.h" HINTS "${X_INCLUDEDIR}")
|
|
|
+ find_file(HAVE_XCURSOR_H NAMES "X11/Xcursor/Xcursor.h" HINTS "${X11_INCLUDEDIR}")
|
|
|
+ find_file(HAVE_XINPUT2_H NAMES "X11/extensions/XInput2.h" HINTS "${X11_INCLUDEDIR}")
|
|
|
+ find_file(HAVE_XRANDR_H NAMES "X11/extensions/Xrandr.h" HINTS "${X11_INCLUDEDIR}")
|
|
|
+ find_file(HAVE_XFIXES_H_ NAMES "X11/extensions/Xfixes.h" HINTS "${X11_INCLUDEDIR}")
|
|
|
+ find_file(HAVE_XRENDER_H NAMES "X11/extensions/Xrender.h" HINTS "${X11_INCLUDEDIR}")
|
|
|
+ find_file(HAVE_XSS_H NAMES "X11/extensions/scrnsaver.h" HINTS "${X11_INCLUDEDIR}")
|
|
|
+ find_file(HAVE_XSHAPE_H NAMES "X11/extensions/shape.h" HINTS "${X11_INCLUDEDIR}")
|
|
|
+ find_file(HAVE_XDBE_H NAMES "X11/extensions/Xdbe.h" HINTS "${X11_INCLUDEDIR}")
|
|
|
+ find_file(HAVE_XEXT_H NAMES "X11/extensions/Xext.h" HINTS "${X11_INCLUDEDIR}")
|
|
|
|
|
|
if(X11_LIB)
|
|
|
if(NOT HAVE_XEXT_H)
|
|
|
- message_error("Missing Xext.h, maybe you need to install the libxext-dev package?")
|
|
|
+ message(FATAL_ERROR "Missing Xext.h, maybe you need to install the libxext-dev package?")
|
|
|
endif()
|
|
|
|
|
|
set(HAVE_X11 TRUE)
|
|
|
set(HAVE_SDL_VIDEO TRUE)
|
|
|
|
|
|
- file(GLOB X11_SOURCES ${SDL3_SOURCE_DIR}/src/video/x11/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${X11_SOURCES})
|
|
|
+ sdl_glob_sources("${SDL3_SOURCE_DIR}/src/video/x11/*.c")
|
|
|
set(SDL_VIDEO_DRIVER_X11 1)
|
|
|
|
|
|
# !!! FIXME: why is this disabled for Apple?
|
|
@@ -303,16 +316,16 @@ macro(CheckX11)
|
|
|
if(NOT HAVE_SHMAT_IN_LIBC)
|
|
|
check_library_exists(ipc shmat "" HAVE_SHMAT_IN_LIBIPC)
|
|
|
if(HAVE_SHMAT_IN_LIBIPC)
|
|
|
- list(APPEND SDL_EXTRA_LIBS ipc)
|
|
|
+ sdl_link_dependency(x11_ipc LIBS ipc)
|
|
|
endif()
|
|
|
if(NOT HAVE_SHMAT_IN_LIBIPC)
|
|
|
- target_compile_definitions(sdl-build-options INTERFACE "NO_SHARED_MEMORY")
|
|
|
+ sdl_compile_definitions(PRIVATE "NO_SHARED_MEMORY")
|
|
|
endif()
|
|
|
endif()
|
|
|
|
|
|
if(SDL_X11_SHARED)
|
|
|
if(NOT HAVE_SDL_LOADSO)
|
|
|
- message_warn("You must have SDL_LoadObject() support for dynamic X11 loading")
|
|
|
+ message(WARNING "You must have SDL_LoadObject() support for dynamic X11 loading")
|
|
|
set(HAVE_X11_SHARED FALSE)
|
|
|
else()
|
|
|
set(HAVE_X11_SHARED TRUE)
|
|
@@ -321,21 +334,19 @@ macro(CheckX11)
|
|
|
if(HAVE_X11_SHARED)
|
|
|
set(SDL_VIDEO_DRIVER_X11_DYNAMIC "\"${X11_LIB_SONAME}\"")
|
|
|
else()
|
|
|
- list(APPEND SDL_EXTRA_LDFLAGS "-L${X11_LIBDIR}")
|
|
|
- list(APPEND SDL_EXTRA_LIBS X11)
|
|
|
+ sdl_link_dependency(x11 LIBS X11::X11 CMAKE_MODULE X11 PKG_CONFIG_SPECS ${X11_PKG_CONFIG_SPEC})
|
|
|
endif()
|
|
|
endif()
|
|
|
if(XEXT_LIB)
|
|
|
if(HAVE_X11_SHARED)
|
|
|
set(SDL_VIDEO_DRIVER_X11_DYNAMIC_XEXT "\"${XEXT_LIB_SONAME}\"")
|
|
|
else()
|
|
|
- list(APPEND SDL_EXTRA_LDFLAGS "-L${XEXT_LIBDIR}")
|
|
|
- list(APPEND SDL_EXTRA_LIBS Xext)
|
|
|
+ sdl_link_dependency(xext LIBS X11::Xext CMAKE_MODULE X11 PKG_CONFIG_SPECS ${Xext_PKG_CONFIG_SPEC})
|
|
|
endif()
|
|
|
endif()
|
|
|
else()
|
|
|
- list(APPEND SDL_EXTRA_LDFLAGS "-L${X11_LIBDIR}" "-L${XEXT_LIBDIR}")
|
|
|
- list(APPEND SDL_EXTRA_LIBS X11 Xext)
|
|
|
+ sdl_link_dependency(x11 LIBS X11::X11 CMAKE_MODULE X11 PKG_CONFIG_SPECS ${X11_PKG_CONFIG_SPEC})
|
|
|
+ sdl_link_dependency(xext LIBS X11::Xext CMAKE_MODULE X11 PKG_CONFIG_SPECS ${Xext_PKG_CONFIG_SPEC})
|
|
|
endif()
|
|
|
|
|
|
list(APPEND CMAKE_REQUIRED_LIBRARIES ${X11_LIB})
|
|
@@ -361,8 +372,7 @@ macro(CheckX11)
|
|
|
if(HAVE_X11_SHARED)
|
|
|
set(SDL_VIDEO_DRIVER_X11_DYNAMIC_XCURSOR "\"${XCURSOR_LIB_SONAME}\"")
|
|
|
else()
|
|
|
- list(APPEND SDL_EXTRA_LDFLAGS "-L${XCURSOR_LIBDIR}")
|
|
|
- list(APPEND SDL_EXTRA_LIBS Xcursor)
|
|
|
+ sdl_link_dependency(xcursor LIBS X11::Xcursor CMAKE_MODULE X11 PKG_CONFIG_SPECS ${Xcursor_PKG_CONFIG_SPEC})
|
|
|
endif()
|
|
|
set(SDL_VIDEO_DRIVER_X11_XCURSOR 1)
|
|
|
endif()
|
|
@@ -377,8 +387,7 @@ macro(CheckX11)
|
|
|
if(HAVE_X11_SHARED)
|
|
|
set(SDL_VIDEO_DRIVER_X11_DYNAMIC_XINPUT2 "\"${XI_LIB_SONAME}\"")
|
|
|
else()
|
|
|
- list(APPEND SDL_EXTRA_LDFLAGS "-L${XI_LIBDIR}")
|
|
|
- list(APPEND SDL_EXTRA_LIBS Xi)
|
|
|
+ sdl_link_dependency(xi LIBS X11::Xi CMAKE_MODULE X11 PKG_CONFIG_SPECS ${Xi_PKG_CONFIG_SPEC})
|
|
|
endif()
|
|
|
set(SDL_VIDEO_DRIVER_X11_XINPUT2 1)
|
|
|
|
|
@@ -412,8 +421,7 @@ macro(CheckX11)
|
|
|
if(HAVE_X11_SHARED)
|
|
|
set(SDL_VIDEO_DRIVER_X11_DYNAMIC_XFIXES "\"${XFIXES_LIB_SONAME}\"")
|
|
|
else()
|
|
|
- list(APPEND SDL_EXTRA_LDFLAGS "-L${XFIXES_LIBDIR}")
|
|
|
- list(APPEND SDL_EXTRA_LIBS Xfixes)
|
|
|
+ sdl_link_dependency(xfixes LIBS X11::Xfixes CMAKE_MODULE X11 PKG_CONFIG_SPECS ${Xfixes_PKG_CONFIG_SPEC})
|
|
|
endif()
|
|
|
set(SDL_VIDEO_DRIVER_X11_XFIXES 1)
|
|
|
set(HAVE_X11_XFIXES TRUE)
|
|
@@ -423,8 +431,7 @@ macro(CheckX11)
|
|
|
if(HAVE_X11_SHARED)
|
|
|
set(SDL_VIDEO_DRIVER_X11_DYNAMIC_XRANDR "\"${XRANDR_LIB_SONAME}\"")
|
|
|
else()
|
|
|
- list(APPEND SDL_EXTRA_LDFLAGS "-L${XRANDR_LIBDIR}")
|
|
|
- list(APPEND SDL_EXTRA_LIBS Xrandr)
|
|
|
+ sdl_link_dependency(xrandr LIBS X11::Xrandr CMAKE_MODULE X11 PKG_CONFIG_SPECS ${Xrandr_PKG_CONFIG_SPEC})
|
|
|
endif()
|
|
|
set(SDL_VIDEO_DRIVER_X11_XRANDR 1)
|
|
|
set(HAVE_X11_XRANDR TRUE)
|
|
@@ -434,8 +441,7 @@ macro(CheckX11)
|
|
|
if(HAVE_X11_SHARED)
|
|
|
set(SDL_VIDEO_DRIVER_X11_DYNAMIC_XSS "\"${XSS_LIB_SONAME}\"")
|
|
|
else()
|
|
|
- list(APPEND SDL_EXTRA_LDFLAGS "-L${XSS_LIBDIR}")
|
|
|
- list(APPEND SDL_EXTRA_LIBS Xss)
|
|
|
+ sdl_link_dependency(xss LIBS X11::Xss CMAKE_MODULE X11 PKG_CONFIG_SPECS ${Xss_PKG_CONFIG_SPEC})
|
|
|
endif()
|
|
|
set(SDL_VIDEO_DRIVER_X11_XSCRNSAVER 1)
|
|
|
set(HAVE_X11_XSCRNSAVER TRUE)
|
|
@@ -449,7 +455,7 @@ macro(CheckX11)
|
|
|
endif()
|
|
|
if(NOT HAVE_X11)
|
|
|
# Prevent Mesa from including X11 headers
|
|
|
- target_compile_definitions(sdl-build-options INTERFACE "MESA_EGL_NO_X11_HEADERS" "EGL_NO_X11")
|
|
|
+ sdl_compile_definitions(PRIVATE "MESA_EGL_NO_X11_HEADERS" "EGL_NO_X11")
|
|
|
endif()
|
|
|
cmake_pop_check_state()
|
|
|
endmacro()
|
|
@@ -472,8 +478,7 @@ macro(WaylandProtocolGen _SCANNER _CODE_MODE _XML _PROTL)
|
|
|
ARGS "${_CODE_MODE}" "${_XML}" "${_WAYLAND_PROT_C_CODE}"
|
|
|
)
|
|
|
|
|
|
- list(APPEND SDL_GENERATED_HEADERS "${_WAYLAND_PROT_H_CODE}")
|
|
|
- list(APPEND SOURCE_FILES "${_WAYLAND_PROT_C_CODE}")
|
|
|
+ sdl_sources("${_WAYLAND_PROT_C_CODE}")
|
|
|
endmacro()
|
|
|
|
|
|
# Requires:
|
|
@@ -484,97 +489,95 @@ endmacro()
|
|
|
# - HAVE_SDL_LOADSO opt
|
|
|
macro(CheckWayland)
|
|
|
if(SDL_WAYLAND)
|
|
|
- set(WAYLAND_FOUND FALSE)
|
|
|
- pkg_check_modules(PKG_WAYLAND "wayland-client>=1.18" wayland-egl wayland-cursor egl "xkbcommon>=0.5.0")
|
|
|
+ set(WAYLAND_PKG_CONFIG_SPEC "wayland-client>=1.18" wayland-egl wayland-cursor egl "xkbcommon>=0.5.0")
|
|
|
+ pkg_check_modules(PC_WAYLAND IMPORTED_TARGET ${WAYLAND_PKG_CONFIG_SPEC})
|
|
|
+ find_program(WAYLAND_SCANNER NAMES wayland-scanner)
|
|
|
|
|
|
- if(PKG_WAYLAND_FOUND)
|
|
|
- set(WAYLAND_FOUND TRUE)
|
|
|
- find_program(WAYLAND_SCANNER NAMES wayland-scanner REQUIRED)
|
|
|
+ set(WAYLAND_FOUND FALSE)
|
|
|
+ if(PC_WAYLAND_FOUND AND WAYLAND_SCANNER)
|
|
|
execute_process(
|
|
|
COMMAND ${WAYLAND_SCANNER} --version
|
|
|
RESULT_VARIABLE WAYLAND_SCANNER_VERSION_RC
|
|
|
- ERROR_VARIABLE WAYLAND_SCANNER_VERSION
|
|
|
+ ERROR_VARIABLE WAYLAND_SCANNER_VERSION_STDERR
|
|
|
ERROR_STRIP_TRAILING_WHITESPACE
|
|
|
)
|
|
|
if(NOT WAYLAND_SCANNER_VERSION_RC EQUAL 0)
|
|
|
- message(FATAL "Failed to get wayland-scanner version")
|
|
|
- set(WAYLAND_FOUND FALSE)
|
|
|
- endif()
|
|
|
- string(REPLACE "wayland-scanner " "" WAYLAND_SCANNER_VERSION ${WAYLAND_SCANNER_VERSION})
|
|
|
-
|
|
|
- string(COMPARE LESS ${WAYLAND_SCANNER_VERSION} "1.15.0" WAYLAND_SCANNER_PRE_1_15)
|
|
|
- if(WAYLAND_SCANNER_PRE_1_15)
|
|
|
- set(WAYLAND_SCANNER_CODE_MODE "code")
|
|
|
+ message(WARNING "Failed to get wayland-scanner version")
|
|
|
else()
|
|
|
- set(WAYLAND_SCANNER_CODE_MODE "private-code")
|
|
|
+ if(WAYLAND_SCANNER_VERSION_STDERR MATCHES [[([0-9.]+)$]])
|
|
|
+ set(WAYLAND_FOUND TRUE)
|
|
|
+ set(WAYLAND_SCANNER_VERSION ${CMAKE_MATCH_1})
|
|
|
+ if(WAYLAND_SCANNER_VERSION VERSION_LESS "1.15.0")
|
|
|
+ set(WAYLAND_SCANNER_CODE_MODE "code")
|
|
|
+ else()
|
|
|
+ set(WAYLAND_SCANNER_CODE_MODE "private-code")
|
|
|
+ endif()
|
|
|
+ endif()
|
|
|
endif()
|
|
|
endif()
|
|
|
|
|
|
if(WAYLAND_FOUND)
|
|
|
- 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 ${SDL3_SOURCE_DIR}/src/video/wayland/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${WAYLAND_SOURCES})
|
|
|
+ sdl_glob_sources("${SDL3_SOURCE_DIR}/src/video/wayland/*.c")
|
|
|
|
|
|
# We have to generate some protocol interface code for some unstable Wayland features.
|
|
|
- file(MAKE_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/wayland-generated-protocols")
|
|
|
- # Prepend to include path to make sure it they override installed protocol headers
|
|
|
- target_include_directories(sdl-build-options SYSTEM BEFORE INTERFACE "${CMAKE_CURRENT_BINARY_DIR}/wayland-generated-protocols")
|
|
|
+ file(MAKE_DIRECTORY "${SDL3_BINARY_DIR}/wayland-generated-protocols")
|
|
|
+ # Prepend to include path to make sure they override installed protocol headers
|
|
|
+ sdl_include_directories(PRIVATE SYSTEM BEFORE "${SDL3_BINARY_DIR}/wayland-generated-protocols")
|
|
|
|
|
|
file(GLOB WAYLAND_PROTOCOLS_XML RELATIVE "${SDL3_SOURCE_DIR}/wayland-protocols/" "${SDL3_SOURCE_DIR}/wayland-protocols/*.xml")
|
|
|
- foreach(_XML ${WAYLAND_PROTOCOLS_XML})
|
|
|
+ foreach(_XML IN LISTS WAYLAND_PROTOCOLS_XML)
|
|
|
string(REGEX REPLACE "\\.xml$" "" _PROTL "${_XML}")
|
|
|
WaylandProtocolGen("${WAYLAND_SCANNER}" "${WAYLAND_SCANNER_CODE_MODE}" "${SDL3_SOURCE_DIR}/wayland-protocols/${_XML}" "${_PROTL}")
|
|
|
endforeach()
|
|
|
|
|
|
if(SDL_WAYLAND_QT_TOUCH)
|
|
|
- set(HAVE_WAYLAND_QT_TOUCH TRUE)
|
|
|
- set(SDL_VIDEO_DRIVER_WAYLAND_QT_TOUCH 1)
|
|
|
+ set(HAVE_WAYLAND_QT_TOUCH TRUE)
|
|
|
+ set(SDL_VIDEO_DRIVER_WAYLAND_QT_TOUCH 1)
|
|
|
endif()
|
|
|
|
|
|
if(SDL_WAYLAND_SHARED AND NOT HAVE_SDL_LOADSO)
|
|
|
- message_warn("You must have SDL_LoadObject() support for dynamic Wayland loading")
|
|
|
+ message(WARNING "You must have SDL_LoadObject() support for dynamic Wayland loading")
|
|
|
endif()
|
|
|
- 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})
|
|
|
+ FindLibraryAndSONAME(wayland-client LIBDIRS ${PC_WAYLAND_LIBRARY_DIRS})
|
|
|
+ FindLibraryAndSONAME(wayland-egl LIBDIRS ${PC_WAYLAND_LIBRARY_DIRS})
|
|
|
+ FindLibraryAndSONAME(wayland-cursor LIBDIRS ${PC_WAYLAND_LIBRARY_DIRS})
|
|
|
+ FindLibraryAndSONAME(xkbcommon LIBDIRS ${PC_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}\"")
|
|
|
set(SDL_VIDEO_DRIVER_WAYLAND_DYNAMIC_CURSOR "\"${WAYLAND_CURSOR_LIB_SONAME}\"")
|
|
|
set(SDL_VIDEO_DRIVER_WAYLAND_DYNAMIC_XKBCOMMON "\"${XKBCOMMON_LIB_SONAME}\"")
|
|
|
set(HAVE_WAYLAND_SHARED TRUE)
|
|
|
+ sdl_link_dependency(wayland INCLUDES $<TARGET_PROPERTY:PkgConfig::PC_WAYLAND,INTERFACE_INCLUDE_DIRECTORIES>)
|
|
|
else()
|
|
|
- list(APPEND SDL_EXTRA_LIBS ${PKG_WAYLAND_LIBRARIES})
|
|
|
+ sdl_link_dependency(wayland LIBS PkgConfig::PC_WAYLAND PKG_CONFIG_PREFIX PC_WAYLAND PKG_CONFIG_SPECS ${WAYLAND_PKG_CONFIG_SPEC})
|
|
|
endif()
|
|
|
|
|
|
if(SDL_WAYLAND_LIBDECOR)
|
|
|
- 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 "${PKG_LIBDECOR_LIBRARY_DIRS}")
|
|
|
- target_include_directories(sdl-build-options SYSTEM 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 LIBDIRS ${PKG_LIBDECOR_LIBRARY_DIRS})
|
|
|
- if(SDL_WAYLAND_LIBDECOR_SHARED AND DECOR_0_LIB AND HAVE_SDL_LOADSO)
|
|
|
- set(HAVE_WAYLAND_LIBDECOR_SHARED TRUE)
|
|
|
- set(SDL_VIDEO_DRIVER_WAYLAND_DYNAMIC_LIBDECOR "\"${DECOR_0_LIB_SONAME}\"")
|
|
|
- else()
|
|
|
- list(APPEND SDL_EXTRA_LIBS ${PKG_LIBDECOR_LIBRARIES})
|
|
|
+ set(LibDecor_PKG_CONFIG_SPEC libdecor-0)
|
|
|
+ pkg_check_modules(PC_LIBDECOR IMPORTED_TARGET ${LibDecor_PKG_CONFIG_SPEC})
|
|
|
+ if(PC_LIBDECOR_FOUND)
|
|
|
+ # Version 0.1.2 or higher is needed for suspended window state and statically linked min/max getters.
|
|
|
+ if(PC_LIBDECOR_VERSION VERSION_GREATER_EQUAL "0.1.2")
|
|
|
+ set(SDL_HAVE_LIBDECOR_VER_0_1_2 1)
|
|
|
+ set(LibDecor_PKG_CONFIG_SPEC "libdecor-0>=0.1.2")
|
|
|
+ endif()
|
|
|
+ set(HAVE_WAYLAND_LIBDECOR TRUE)
|
|
|
+ set(HAVE_LIBDECOR_H 1)
|
|
|
+ if(SDL_WAYLAND_LIBDECOR_SHARED AND NOT HAVE_SDL_LOADSO)
|
|
|
+ message(WARNING "You must have SDL_LoadObject() support for dynamic libdecor loading")
|
|
|
+ endif()
|
|
|
+ FindLibraryAndSONAME(decor-0 LIBDIRS ${PC_LIBDECOR_LIBRARY_DIRS})
|
|
|
+ if(SDL_WAYLAND_LIBDECOR_SHARED AND DECOR_0_LIB AND HAVE_SDL_LOADSO)
|
|
|
+ set(HAVE_WAYLAND_LIBDECOR_SHARED TRUE)
|
|
|
+ set(SDL_VIDEO_DRIVER_WAYLAND_DYNAMIC_LIBDECOR "\"${DECOR_0_LIB_SONAME}\"")
|
|
|
+ sdl_link_dependency(libdecor INCLUDES $<TARGET_PROPERTY:PkgConfig::PC_LIBDECOR,INTERFACE_INCLUDE_DIRECTORIES>)
|
|
|
+ else()
|
|
|
+ sdl_link_dependency(libdecor LIBS PkgConfig::PC_LIBDECOR PKG_CONFIG_PREFIX PC_LIBDECOR PKG_CONFIG_SPECS ${LibDecor_PKG_CONFIG_SPEC})
|
|
|
endif()
|
|
|
-
|
|
|
- # Version 0.1.2 or higher is needed for suspended window state and statically linked min/max getters.
|
|
|
- if (PKG_LIBDECOR_VERSION VERSION_GREATER_EQUAL "0.1.2")
|
|
|
- set(SDL_HAVE_LIBDECOR_VER_0_1_2 1)
|
|
|
- endif ()
|
|
|
endif()
|
|
|
endif()
|
|
|
|
|
@@ -592,8 +595,7 @@ macro(CheckCOCOA)
|
|
|
set(HAVE_COCOA TRUE)
|
|
|
endif()
|
|
|
if(HAVE_COCOA)
|
|
|
- file(GLOB COCOA_SOURCES ${SDL3_SOURCE_DIR}/src/video/cocoa/*.m)
|
|
|
- list(APPEND SOURCE_FILES ${COCOA_SOURCES})
|
|
|
+ sdl_glob_sources("${SDL3_SOURCE_DIR}/src/video/cocoa/*.m")
|
|
|
set(SDL_VIDEO_DRIVER_COCOA 1)
|
|
|
set(HAVE_SDL_VIDEO TRUE)
|
|
|
endif()
|
|
@@ -616,18 +618,18 @@ macro(CheckVivante)
|
|
|
set(HAVE_VIVANTE TRUE)
|
|
|
set(HAVE_SDL_VIDEO TRUE)
|
|
|
|
|
|
- file(GLOB VIVANTE_SOURCES ${SDL3_SOURCE_DIR}/src/video/vivante/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${VIVANTE_SOURCES})
|
|
|
+ sdl_glob_sources("${SDL3_SOURCE_DIR}/src/video/vivante/*.c")
|
|
|
set(SDL_VIDEO_DRIVER_VIVANTE 1)
|
|
|
+ # FIXME: Use Find module
|
|
|
if(HAVE_VIVANTE_VDK)
|
|
|
set(SDL_VIDEO_DRIVER_VIVANTE_VDK 1)
|
|
|
find_library(VIVANTE_LIBRARY REQUIRED NAMES VIVANTE vivante drm_vivante)
|
|
|
find_library(VIVANTE_VDK_LIBRARY VDK REQUIRED)
|
|
|
- list(APPEND SDL_EXTRA_LIBS ${VIVANTE_LIBRARY} ${VIVANTE_VDK_LIBRARY})
|
|
|
+ sdl_link_dependency(vivante LIBS ${VIVANTE_LIBRARY} ${VIVANTE_VDK_LIBRARY})
|
|
|
else()
|
|
|
- target_compile_definitions(sdl-build-options INTERFACE "LINUX;EGL_API_FB")
|
|
|
- list(APPEND SDL_PC_CFLAGS -DLINUX -DEGL_API_FB)
|
|
|
- list(APPEND SDL_EXTRA_LIBS EGL)
|
|
|
+ # these defines are needed when including the system EGL headers, which SDL does
|
|
|
+ sdl_compile_definitions(PUBLIC "LINUX" "EGL_API_FB")
|
|
|
+ sdl_link_dependency(vivante LIBS EGL)
|
|
|
endif(HAVE_VIVANTE_VDK)
|
|
|
endif()
|
|
|
endif()
|
|
@@ -649,9 +651,10 @@ endmacro()
|
|
|
# Requires:
|
|
|
# - PkgCheckModules
|
|
|
macro(CheckEGL)
|
|
|
- if (SDL_OPENGL OR SDL_OPENGLES)
|
|
|
- pkg_check_modules(EGL egl)
|
|
|
- set(CMAKE_REQUIRED_DEFINITIONS "${CMAKE_REQUIRED_DEFINITIONS} ${EGL_CFLAGS}")
|
|
|
+ if(SDL_OPENGL OR SDL_OPENGLES)
|
|
|
+ cmake_push_check_state()
|
|
|
+ find_package(OpenGL MODULE)
|
|
|
+ list(APPEND CMAKE_REQUIRED_INCLUDES ${OPENGL_EGL_INCLUDE_DIRS})
|
|
|
check_c_source_compiles("
|
|
|
#define EGL_API_FB
|
|
|
#define MESA_EGL_NO_X11_HEADERS
|
|
@@ -659,8 +662,10 @@ macro(CheckEGL)
|
|
|
#include <EGL/egl.h>
|
|
|
#include <EGL/eglext.h>
|
|
|
int main (int argc, char** argv) { return 0; }" HAVE_OPENGL_EGL)
|
|
|
+ cmake_pop_check_state()
|
|
|
if(HAVE_OPENGL_EGL)
|
|
|
set(SDL_VIDEO_OPENGL_EGL 1)
|
|
|
+ sdl_link_dependency(egl INCLUDES ${OPENGL_EGL_INCLUDE_DIRS})
|
|
|
endif()
|
|
|
endif()
|
|
|
endmacro()
|
|
@@ -689,21 +694,28 @@ macro(CheckOpenGLES)
|
|
|
#include <GLES/glext.h>
|
|
|
int main (int argc, char** argv) { return 0; }" HAVE_OPENGLES_V1)
|
|
|
if(HAVE_OPENGLES_V1)
|
|
|
- set(HAVE_OPENGLES TRUE)
|
|
|
- set(SDL_VIDEO_OPENGL_ES 1)
|
|
|
+ set(HAVE_OPENGLES TRUE)
|
|
|
+ set(SDL_VIDEO_OPENGL_ES 1)
|
|
|
endif()
|
|
|
check_c_source_compiles("
|
|
|
- #include <GLES2/gl2.h>
|
|
|
- #include <GLES2/gl2ext.h>
|
|
|
- int main (int argc, char** argv) { return 0; }" HAVE_OPENGLES_V2)
|
|
|
+ #include <GLES2/gl2.h>
|
|
|
+ #include <GLES2/gl2ext.h>
|
|
|
+ int main (int argc, char** argv) { return 0; }" HAVE_OPENGLES_V2)
|
|
|
if(HAVE_OPENGLES_V2)
|
|
|
- set(HAVE_OPENGLES TRUE)
|
|
|
- set(SDL_VIDEO_OPENGL_ES2 1)
|
|
|
- set(SDL_VIDEO_RENDER_OGL_ES2 1)
|
|
|
+ set(HAVE_OPENGLES TRUE)
|
|
|
+ set(SDL_VIDEO_OPENGL_ES2 1)
|
|
|
+ set(SDL_VIDEO_RENDER_OGL_ES2 1)
|
|
|
endif()
|
|
|
endif()
|
|
|
endmacro()
|
|
|
|
|
|
+macro(CheckVulkan)
|
|
|
+ if(SDL_VULKAN)
|
|
|
+ set(SDL_VIDEO_VULKAN 1)
|
|
|
+ set(HAVE_VULKAN TRUE)
|
|
|
+ endif()
|
|
|
+endmacro()
|
|
|
+
|
|
|
# Requires:
|
|
|
# - EGL
|
|
|
macro(CheckQNXScreen)
|
|
@@ -713,9 +725,8 @@ macro(CheckQNXScreen)
|
|
|
int main (int argc, char** argv) { return 0; }" HAVE_QNX_SCREEN)
|
|
|
if(HAVE_QNX_SCREEN)
|
|
|
set(SDL_VIDEO_DRIVER_QNX 1)
|
|
|
- file(GLOB QNX_VIDEO_SOURCES ${SDL3_SOURCE_DIR}/src/video/qnx/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${QNX_VIDEO_SOURCES})
|
|
|
- list(APPEND SDL_EXTRA_LIBS screen EGL)
|
|
|
+ sdl_glob_sources("${SDL3_SOURCE_DIR}/src/video/qnx/*.c")
|
|
|
+ sdl_link_dependency(qnxscreen LIBS screen EGL)
|
|
|
endif()
|
|
|
endif()
|
|
|
endmacro()
|
|
@@ -779,20 +790,19 @@ macro(CheckPTHREAD)
|
|
|
endif()
|
|
|
|
|
|
# Run some tests
|
|
|
- set(CMAKE_REQUIRED_FLAGS "${CMAKE_REQUIRED_FLAGS} ${PTHREAD_CFLAGS} ${PTHREAD_LDFLAGS}")
|
|
|
+ string(APPEND CMAKE_REQUIRED_FLAGS " ${PTHREAD_CFLAGS} ${PTHREAD_LDFLAGS}")
|
|
|
check_c_source_compiles("
|
|
|
- #include <pthread.h>
|
|
|
- int main(int argc, char** argv) {
|
|
|
- pthread_attr_t type;
|
|
|
- pthread_attr_init(&type);
|
|
|
- return 0;
|
|
|
- }" HAVE_PTHREADS)
|
|
|
+ #include <pthread.h>
|
|
|
+ int main(int argc, char** argv) {
|
|
|
+ pthread_attr_t type;
|
|
|
+ pthread_attr_init(&type);
|
|
|
+ return 0;
|
|
|
+ }" HAVE_PTHREADS)
|
|
|
if(HAVE_PTHREADS)
|
|
|
set(SDL_THREAD_PTHREAD 1)
|
|
|
separate_arguments(PTHREAD_CFLAGS)
|
|
|
- target_compile_options(sdl-build-options INTERFACE ${PTHREAD_CFLAGS})
|
|
|
- list(APPEND SDL_EXTRA_LDFLAGS ${PTHREAD_LDFLAGS})
|
|
|
- list(APPEND SDL_PC_CFLAGS ${PTHREAD_CFLAGS})
|
|
|
+ sdl_compile_options(PRIVATE ${PTHREAD_CFLAGS})
|
|
|
+ sdl_link_dependency(pthread LINK_OPTIONS ${PTHREAD_LDFLAGS})
|
|
|
|
|
|
check_c_source_compiles("
|
|
|
#include <pthread.h>
|
|
@@ -850,19 +860,17 @@ macro(CheckPTHREAD)
|
|
|
endif()
|
|
|
endif()
|
|
|
|
|
|
- set(SOURCE_FILES ${SOURCE_FILES}
|
|
|
- ${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_sysrwlock.c # Can be faked, if necessary
|
|
|
- ${SDL3_SOURCE_DIR}/src/thread/pthread/SDL_systls.c
|
|
|
- )
|
|
|
+ sdl_sources(
|
|
|
+ "${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_sysrwlock.c" # Can be faked, if necessary
|
|
|
+ "${SDL3_SOURCE_DIR}/src/thread/pthread/SDL_systls.c"
|
|
|
+ )
|
|
|
if(HAVE_PTHREADS_SEM)
|
|
|
- set(SOURCE_FILES ${SOURCE_FILES}
|
|
|
- ${SDL3_SOURCE_DIR}/src/thread/pthread/SDL_syssem.c)
|
|
|
+ sdl_sources("${SDL3_SOURCE_DIR}/src/thread/pthread/SDL_syssem.c")
|
|
|
else()
|
|
|
- set(SOURCE_FILES ${SOURCE_FILES}
|
|
|
- ${SDL3_SOURCE_DIR}/src/thread/generic/SDL_syssem.c)
|
|
|
+ sdl_sources("${SDL3_SOURCE_DIR}/src/thread/generic/SDL_syssem.c")
|
|
|
endif()
|
|
|
set(HAVE_SDL_THREADS TRUE)
|
|
|
endif()
|
|
@@ -887,7 +895,7 @@ macro(CheckUSBHID)
|
|
|
|
|
|
check_include_file(libusbhid.h HAVE_LIBUSBHID_H)
|
|
|
if(HAVE_LIBUSBHID_H)
|
|
|
- set(USB_CFLAGS "${USB_CFLAGS} -DHAVE_LIBUSBHID_H")
|
|
|
+ string(APPEND USB_CFLAGS " -DHAVE_LIBUSBHID_H")
|
|
|
endif()
|
|
|
set(USB_LIBS ${USB_LIBS} usbhid)
|
|
|
else()
|
|
@@ -897,7 +905,7 @@ macro(CheckUSBHID)
|
|
|
endif()
|
|
|
check_include_file(libusb.h HAVE_LIBUSB_H)
|
|
|
if(HAVE_LIBUSB_H)
|
|
|
- set(USB_CFLAGS "${USB_CFLAGS} -DHAVE_LIBUSB_H")
|
|
|
+ string(APPEND USB_CFLAGS " -DHAVE_LIBUSB_H")
|
|
|
endif()
|
|
|
check_library_exists(usb hid_init "" LIBUSB)
|
|
|
if(LIBUSB)
|
|
@@ -905,7 +913,7 @@ macro(CheckUSBHID)
|
|
|
endif()
|
|
|
endif()
|
|
|
|
|
|
- set(CMAKE_REQUIRED_FLAGS "${CMAKE_REQUIRED_FLAGS} ${USB_CFLAGS}")
|
|
|
+ string(APPEND CMAKE_REQUIRED_FLAGS " ${USB_CFLAGS}")
|
|
|
list(APPEND CMAKE_REQUIRED_LIBRARIES ${USB_LIBS})
|
|
|
check_c_source_compiles("
|
|
|
#include <sys/types.h>
|
|
@@ -958,7 +966,7 @@ macro(CheckUSBHID)
|
|
|
return 0;
|
|
|
}" HAVE_USBHID_UCR_DATA)
|
|
|
if(HAVE_USBHID_UCR_DATA)
|
|
|
- set(USB_CFLAGS "${USB_CFLAGS} -DUSBHID_UCR_DATA")
|
|
|
+ string(APPEND USB_CFLAGS " -DUSBHID_UCR_DATA")
|
|
|
endif()
|
|
|
|
|
|
check_c_source_compiles("
|
|
@@ -986,7 +994,7 @@ macro(CheckUSBHID)
|
|
|
return 0;
|
|
|
}" HAVE_USBHID_NEW)
|
|
|
if(HAVE_USBHID_NEW)
|
|
|
- set(USB_CFLAGS "${USB_CFLAGS} -DUSBHID_NEW")
|
|
|
+ string(APPEND USB_CFLAGS " -DUSBHID_NEW")
|
|
|
endif()
|
|
|
|
|
|
check_c_source_compiles("
|
|
@@ -999,13 +1007,12 @@ macro(CheckUSBHID)
|
|
|
set(SDL_HAVE_MACHINE_JOYSTICK_H 1)
|
|
|
endif()
|
|
|
set(SDL_JOYSTICK_USBHID 1)
|
|
|
- file(GLOB BSD_JOYSTICK_SOURCES ${SDL3_SOURCE_DIR}/src/joystick/bsd/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${BSD_JOYSTICK_SOURCES})
|
|
|
+ sdl_glob_sources("${SDL3_SOURCE_DIR}/src/joystick/bsd/*.c")
|
|
|
separate_arguments(USB_CFLAGS)
|
|
|
- target_compile_options(sdl-build-options INTERFACE ${USB_CFLAGS})
|
|
|
- list(APPEND SDL_EXTRA_LIBS ${USB_LIBS})
|
|
|
+ sdl_compile_options(PRIVATE ${USB_CFLAGS})
|
|
|
+ #FIXME: properly add usb libs with pkg-config or whatever
|
|
|
+ sdl_link_dependency(usbhid LIBS ${USB_LIBS})
|
|
|
set(HAVE_SDL_JOYSTICK TRUE)
|
|
|
-
|
|
|
endif()
|
|
|
cmake_pop_check_state()
|
|
|
endmacro()
|
|
@@ -1016,20 +1023,25 @@ macro(CheckHIDAPI)
|
|
|
if(SDL_HIDAPI)
|
|
|
if(SDL_HIDAPI_LIBUSB)
|
|
|
set(HAVE_LIBUSB FALSE)
|
|
|
- pkg_check_modules(PKG_LIBUSB libusb-1.0)
|
|
|
- if(PKG_LIBUSB_FOUND)
|
|
|
- check_include_file(libusb.h HAVE_LIBUSB_H ${PKG_LIBUSB_CFLAGS})
|
|
|
+
|
|
|
+ set(LibUSB_PKG_CONFIG_SPEC libusb-1.0)
|
|
|
+ pkg_check_modules(PC_LIBUSB IMPORTED_TARGET ${LibUSB_PKG_CONFIG_SPEC})
|
|
|
+ if(PC_LIBUSB_FOUND)
|
|
|
+ cmake_push_check_state()
|
|
|
+ list(APPEND CMAKE_REQUIRED_INCLUDES ${LibUSB_INCLUDE_DIRS})
|
|
|
+ check_include_file(libusb.h HAVE_LIBUSB_H)
|
|
|
+ cmake_pop_check_state()
|
|
|
if(HAVE_LIBUSB_H)
|
|
|
set(HAVE_LIBUSB TRUE)
|
|
|
- target_include_directories(sdl-build-options SYSTEM INTERFACE ${PKG_LIBUSB_INCLUDE_DIRS})
|
|
|
if(HIDAPI_ONLY_LIBUSB)
|
|
|
- list(APPEND SDL_EXTRA_LIBS ${PKG_LIBUSB_LIBRARIES})
|
|
|
+ sdl_link_dependency(hidapi LIBS PkgConfig::PC_LIBUSB PKG_CONFIG_PREFIX PC_LIBUSB PKG_CONFIG_SPECS ${LibUSB_PKG_CONFIG_SPEC})
|
|
|
else()
|
|
|
- # libusb is loaded dynamically, so don't add it to SDL_EXTRA_LIBS
|
|
|
- FindLibraryAndSONAME("usb-1.0" LIBDIRS ${PKG_LIBUSB_LIBRARY_DIRS})
|
|
|
+ # libusb is loaded dynamically, so don't add link to it
|
|
|
+ FindLibraryAndSONAME("usb-1.0" LIBDIRS ${PC_LIBUSB_LIBRARY_DIRS})
|
|
|
if(USB_1.0_LIB)
|
|
|
set(SDL_LIBUSB_DYNAMIC "\"${USB_1.0_LIB_SONAME}\"")
|
|
|
endif()
|
|
|
+ sdl_link_dependency(hidapi INCLUDES $<TARGET_PROPERTY:LibUSB::LibUSB,INTERFACE_INCLUDE_DIRECTORIES>)
|
|
|
endif()
|
|
|
endif()
|
|
|
endif()
|
|
@@ -1041,10 +1053,10 @@ macro(CheckHIDAPI)
|
|
|
|
|
|
if(HAVE_HIDAPI)
|
|
|
if(ANDROID)
|
|
|
- list(APPEND SOURCE_FILES ${SDL3_SOURCE_DIR}/src/hidapi/android/hid.cpp)
|
|
|
+ sdl_sources("${SDL3_SOURCE_DIR}/src/hidapi/android/hid.cpp")
|
|
|
endif()
|
|
|
if(IOS OR TVOS)
|
|
|
- list(APPEND SOURCE_FILES ${SDL3_SOURCE_DIR}/src/hidapi/ios/hid.m)
|
|
|
+ sdl_sources("${SDL3_SOURCE_DIR}/src/hidapi/ios/hid.m")
|
|
|
set(SDL_FRAMEWORK_COREBLUETOOTH 1)
|
|
|
endif()
|
|
|
set(HAVE_SDL_HIDAPI TRUE)
|
|
@@ -1053,8 +1065,7 @@ macro(CheckHIDAPI)
|
|
|
set(SDL_JOYSTICK_HIDAPI 1)
|
|
|
set(HAVE_SDL_JOYSTICK TRUE)
|
|
|
set(HAVE_HIDAPI_JOYSTICK TRUE)
|
|
|
- file(GLOB HIDAPI_JOYSTICK_SOURCES ${SDL3_SOURCE_DIR}/src/joystick/hidapi/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${HIDAPI_JOYSTICK_SOURCES})
|
|
|
+ sdl_glob_sources("${SDL3_SOURCE_DIR}/src/joystick/hidapi/*.c")
|
|
|
endif()
|
|
|
else()
|
|
|
set(SDL_HIDAPI_DISABLED 1)
|
|
@@ -1068,38 +1079,18 @@ endmacro()
|
|
|
# - n/a
|
|
|
macro(CheckRPI)
|
|
|
if(SDL_RPI)
|
|
|
- pkg_check_modules(VIDEO_RPI bcm_host brcmegl)
|
|
|
- if (NOT VIDEO_RPI_FOUND)
|
|
|
- set(VIDEO_RPI_INCLUDE_DIRS "/opt/vc/include" "/opt/vc/include/interface/vcos/pthreads" "/opt/vc/include/interface/vmcs_host/linux/" )
|
|
|
- set(VIDEO_RPI_LIBRARY_DIRS "/opt/vc/lib" )
|
|
|
- set(VIDEO_RPI_LIBRARIES bcm_host )
|
|
|
- set(VIDEO_RPI_LDFLAGS "-Wl,-rpath,/opt/vc/lib")
|
|
|
- endif()
|
|
|
- listtostr(VIDEO_RPI_INCLUDE_DIRS VIDEO_RPI_INCLUDE_FLAGS "-I")
|
|
|
- separate_arguments(VIDEO_RPI_INCLUDE_FLAGS)
|
|
|
- listtostr(VIDEO_RPI_LIBRARY_DIRS VIDEO_RPI_LIBRARY_FLAGS "-L")
|
|
|
- separate_arguments(VIDEO_RPI_LIBRARY_FLAGS)
|
|
|
-
|
|
|
- cmake_push_check_state()
|
|
|
- set(CMAKE_REQUIRED_FLAGS "${CMAKE_REQUIRED_FLAGS} ${VIDEO_RPI_INCLUDE_FLAGS} ${VIDEO_RPI_LIBRARY_FLAGS}")
|
|
|
- list(APPEND CMAKE_REQUIRED_LIBRARIES ${VIDEO_RPI_LIBRARIES})
|
|
|
- check_c_source_compiles("
|
|
|
- #include <bcm_host.h>
|
|
|
- #include <EGL/eglplatform.h>
|
|
|
- int main(int argc, char **argv) {
|
|
|
- EGL_DISPMANX_WINDOW_T window;
|
|
|
- bcm_host_init();
|
|
|
- }" HAVE_RPI)
|
|
|
- cmake_pop_check_state()
|
|
|
-
|
|
|
- if(SDL_VIDEO AND HAVE_RPI)
|
|
|
- set(HAVE_SDL_VIDEO TRUE)
|
|
|
- set(SDL_VIDEO_DRIVER_RPI 1)
|
|
|
- file(GLOB VIDEO_RPI_SOURCES ${SDL3_SOURCE_DIR}/src/video/raspberry/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${VIDEO_RPI_SOURCES})
|
|
|
- list(APPEND SDL_EXTRA_LIBS ${VIDEO_RPI_LIBRARIES})
|
|
|
- target_compile_options(sdl-build-options INTERFACE ${VIDEO_RPI_INCLUDE_FLAGS})
|
|
|
- list(APPEND SDL_EXTRA_LDFLAGS ${VIDEO_RPI_LIBRARY_FLAGS} ${VIDEO_RPI_LDFLAGS})
|
|
|
+ # presence of bcm_host means raspberry pi
|
|
|
+ find_package(RPi_BcmHost)
|
|
|
+ if(RPi_BcmHost_FOUND)
|
|
|
+ set(HAVE_RPI TRUE)
|
|
|
+ sdl_link_dependency(rpi LIBS RPi_BcmHost::RPi_BcmHost CMAKE_MODULE RPi_BcmHost PKG_CONFIG_SPECS ${RPi_BcmHost_PKG_CONFIG_SPEC})
|
|
|
+ find_package(RPi_BrcmEGL)
|
|
|
+ if(SDL_VIDEO AND RPi_BrcmEGL_FOUND)
|
|
|
+ set(HAVE_SDL_VIDEO TRUE)
|
|
|
+ set(SDL_VIDEO_DRIVER_RPI 1)
|
|
|
+ sdl_glob_sources("${SDL3_SOURCE_DIR}/src/video/raspberry/*.c")
|
|
|
+ sdl_link_dependency(rpi-video LIBS RPi_BrcmEGL::RPi_BrcmEGL CMAKE_MODULE RPi_BrcmEGL PKG_CONFIG_SPECS ${RPi_BrcmEGL_PKG_CONFIG_SPEC})
|
|
|
+ endif()
|
|
|
endif()
|
|
|
endif()
|
|
|
endmacro()
|
|
@@ -1108,8 +1099,9 @@ endmacro()
|
|
|
# - n/a
|
|
|
macro(CheckROCKCHIP)
|
|
|
if(SDL_ROCKCHIP)
|
|
|
- pkg_check_modules(VIDEO_ROCKCHIP mali)
|
|
|
- if (VIDEO_ROCKCHIP_FOUND)
|
|
|
+ set(MALI_PKG_CONFIG_SPEC mali)
|
|
|
+ pkg_check_modules(PC_MALI QUIET ${MALI_PKG_CONFIG_SPEC})
|
|
|
+ if(PC_MALI_FOUND)
|
|
|
set(HAVE_ROCKCHIP TRUE)
|
|
|
endif()
|
|
|
if(SDL_VIDEO AND HAVE_ROCKCHIP)
|
|
@@ -1127,31 +1119,36 @@ endmacro()
|
|
|
# - HAVE_SDL_LOADSO opt
|
|
|
macro(CheckKMSDRM)
|
|
|
if(SDL_KMSDRM)
|
|
|
- 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(PKG_CONFIG_LIBDRM_SPEC libdrm)
|
|
|
+ set(PKG_CONFIG_GBM_SPEC gbm)
|
|
|
+ pkg_check_modules(PC_LIBDRM IMPORTED_TARGET ${PKG_CONFIG_LIBDRM_SPEC})
|
|
|
+ pkg_check_modules(PC_GBM IMPORTED_TARGET ${PKG_CONFIG_GBM_SPEC})
|
|
|
+ if(PC_LIBDRM_FOUND AND PC_GBM_FOUND AND HAVE_OPENGL_EGL)
|
|
|
set(HAVE_KMSDRM TRUE)
|
|
|
set(HAVE_SDL_VIDEO TRUE)
|
|
|
|
|
|
- file(GLOB KMSDRM_SOURCES ${SDL3_SOURCE_DIR}/src/video/kmsdrm/*.c)
|
|
|
- list(APPEND SOURCE_FILES ${KMSDRM_SOURCES})
|
|
|
-
|
|
|
- target_include_directories(sdl-build-options SYSTEM INTERFACE ${PKG_KMSDRM_INCLUDE_DIRS})
|
|
|
+ sdl_glob_sources("${SDL3_SOURCE_DIR}/src/video/kmsdrm/*.c")
|
|
|
|
|
|
set(SDL_VIDEO_DRIVER_KMSDRM 1)
|
|
|
|
|
|
if(SDL_KMSDRM_SHARED AND NOT HAVE_SDL_LOADSO)
|
|
|
- message_warn("You must have SDL_LoadObject() support for dynamic KMS/DRM loading")
|
|
|
+ message(WARNING "You must have SDL_LoadObject() support for dynamic KMS/DRM loading")
|
|
|
endif()
|
|
|
+ set(HAVE_KMSDRM_SHARED FALSE)
|
|
|
if(SDL_KMSDRM_SHARED AND HAVE_SDL_LOADSO)
|
|
|
- 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 SDL_EXTRA_LIBS ${PKG_KMSDRM_LIBRARIES})
|
|
|
+ FindLibraryAndSONAME(drm LIBDIRS ${PC_LIBDRM_LIBRARY_DIRS})
|
|
|
+ FindLibraryAndSONAME(gbm LIBDIRS ${PC_GBM_LIBRARY_DIRS})
|
|
|
+ if(DRM_LIB AND DRM_SHARED AND GBM_LIB AND GBM_SHARED)
|
|
|
+ set(SDL_VIDEO_DRIVER_KMSDRM_DYNAMIC "\"${DRM_LIB_SONAME}\"")
|
|
|
+ set(SDL_VIDEO_DRIVER_KMSDRM_DYNAMIC_GBM "\"${GBM_LIB_SONAME}\"")
|
|
|
+ set(HAVE_KMSDRM_SHARED TRUE)
|
|
|
+ sdl_link_dependency(kmsdrm-drm INCLUDES $<TARGET_PROPERTY:PkgConfig::PC_LIBDRM,INTERFACE_INCLUDE_DIRECTORIES>)
|
|
|
+ sdl_link_dependency(kmsdrm-gbm INCLUDES $<TARGET_PROPERTY:PkgConfig::PC_GBM,INTERFACE_INCLUDE_DIRECTORIES>)
|
|
|
+ endif()
|
|
|
+ endif()
|
|
|
+ if(NOT HAVE_KMSDRM_SHARED)
|
|
|
+ sdl_link_dependency(kmsdrm-libdrm LIBS PkgConfig::PC_LIBDRM PKG_CONFIG_PREFIX PC_LIBDRM PKG_CONFIG_SPECS ${PKG_CONFIG_LIBDRM_SPEC})
|
|
|
+ sdl_link_dependency(kmsdrm-gbm LIBS PkgConfig::PC_GBM PKG_CONFIG_PREFIX PC_GBM PKG_CONFIG_SPECS ${PKG_CONFIG_GBM_SPEC})
|
|
|
endif()
|
|
|
endif()
|
|
|
endif()
|
|
@@ -1159,13 +1156,62 @@ endmacro()
|
|
|
|
|
|
macro(CheckLibUDev)
|
|
|
if(SDL_LIBUDEV)
|
|
|
- check_include_file("libudev.h" have_libudev_header)
|
|
|
- if(have_libudev_header)
|
|
|
+ check_include_file("libudev.h" HAVE_LIBUDEV_HEADER)
|
|
|
+ if(HAVE_LIBUDEV_HEADER)
|
|
|
set(HAVE_LIBUDEV_H TRUE)
|
|
|
FindLibraryAndSONAME(udev)
|
|
|
if(UDEV_LIB_SONAME)
|
|
|
set(SDL_UDEV_DYNAMIC "\"${UDEV_LIB_SONAME}\"")
|
|
|
+ set(HAVE_LIBUDEV TRUE)
|
|
|
+ endif()
|
|
|
+ endif()
|
|
|
+ endif()
|
|
|
+endmacro()
|
|
|
+
|
|
|
+macro(CheckLibUnwind)
|
|
|
+ if(TARGET SDL3_test)
|
|
|
+ set(found_libunwind FALSE)
|
|
|
+ set(_libunwind_src "#include <libunwind.h>\nint main() {unw_context_t context; unw_getcontext(&context); return 0;}")
|
|
|
+
|
|
|
+ if(NOT found_libunwind)
|
|
|
+ cmake_push_check_state()
|
|
|
+ check_c_source_compiles("${_libunwind_src}" LIBC_HAS_WORKING_LIBUNWIND)
|
|
|
+ cmake_pop_check_state()
|
|
|
+ if(LIBC_HAS_WORKING_LIBUNWIND)
|
|
|
+ set(found_libunwind TRUE)
|
|
|
+ target_compile_definitions(SDL3_test PRIVATE HAVE_LIBUNWIND_H)
|
|
|
endif()
|
|
|
endif()
|
|
|
+
|
|
|
+ if(NOT found_libunwind)
|
|
|
+ cmake_push_check_state()
|
|
|
+ list(APPEND CMAKE_REQUIRED_LIBRARIES "unwind")
|
|
|
+ check_c_source_compiles("${_libunwind_src}" LIBUNWIND_HAS_WORKINGLIBUNWIND)
|
|
|
+ cmake_pop_check_state()
|
|
|
+ if(LIBUNWIND_HAS_WORKINGLIBUNWIND)
|
|
|
+ set(found_libunwind TRUE)
|
|
|
+ sdl_test_link_dependency(UNWIND LIBS unwind)
|
|
|
+ endif()
|
|
|
+ endif()
|
|
|
+
|
|
|
+ if(NOT found_libunwind)
|
|
|
+ set(LibUnwind_PKG_CONFIG_SPEC libunwind libunwind-generic)
|
|
|
+ pkg_check_modules(PC_LIBUNWIND IMPORTED_TARGET ${LibUnwind_PKG_CONFIG_SPEC})
|
|
|
+ if(PC_LIBUNWIND_FOUND)
|
|
|
+ cmake_push_check_state()
|
|
|
+ list(APPEND CMAKE_REQUIRED_LIBRARIES ${PC_LIBUNWIND_LIBRARIES})
|
|
|
+ list(APPEND CMAKE_REQUIRED_INCLUDES ${PC_LIBUNWIND_INCLUDE_DIRS})
|
|
|
+ check_c_source_compiles("${_libunwind_src}" PC_LIBUNWIND_HAS_WORKING_LIBUNWIND)
|
|
|
+ cmake_pop_check_state()
|
|
|
+ if(PC_LIBUNWIND_HAS_WORKING_LIBUNWIND)
|
|
|
+ set(found_libunwind TRUE)
|
|
|
+ sdl_test_link_dependency(UNWIND LIBS PkgConfig::PC_LIBUNWIND PKG_CONFIG_PREFIX PC_LIBUNWIND PKG_CONFIG_SPECS ${LibUnwind_PKG_CONFIG_SPEC})
|
|
|
+ endif()
|
|
|
+ endif()
|
|
|
+ endif()
|
|
|
+
|
|
|
+ if(found_libunwind)
|
|
|
+ target_compile_definitions(SDL3_test PRIVATE HAVE_LIBUNWIND_H)
|
|
|
+ endif()
|
|
|
endif()
|
|
|
endmacro()
|