aboutsummaryrefslogtreecommitdiff
path: root/vcpkg/ports/sdl2
diff options
context:
space:
mode:
Diffstat (limited to 'vcpkg/ports/sdl2')
-rw-r--r--vcpkg/ports/sdl2/alsa-dep-fix.patch14
-rw-r--r--vcpkg/ports/sdl2/cxx-linkage-pkgconfig.diff24
-rw-r--r--vcpkg/ports/sdl2/deps.patch13
-rw-r--r--vcpkg/ports/sdl2/portfile.cmake125
-rw-r--r--vcpkg/ports/sdl2/usage8
-rw-r--r--vcpkg/ports/sdl2/vcpkg.json74
6 files changed, 258 insertions, 0 deletions
diff --git a/vcpkg/ports/sdl2/alsa-dep-fix.patch b/vcpkg/ports/sdl2/alsa-dep-fix.patch
new file mode 100644
index 0000000..5ee6eef
--- /dev/null
+++ b/vcpkg/ports/sdl2/alsa-dep-fix.patch
@@ -0,0 +1,14 @@
+diff --git a/SDL2Config.cmake.in b/SDL2Config.cmake.in
+index cc8bcf26d..ead829767 100644
+--- a/SDL2Config.cmake.in
++++ b/SDL2Config.cmake.in
+@@ -35,7 +35,8 @@ include("${CMAKE_CURRENT_LIST_DIR}/sdlfind.cmake")
+
+ set(SDL_ALSA @SDL_ALSA@)
+ set(SDL_ALSA_SHARED @SDL_ALSA_SHARED@)
+-if(SDL_ALSA AND NOT SDL_ALSA_SHARED AND TARGET SDL2::SDL2-static)
++if(SDL_ALSA)
++ set(CMAKE_REQUIRE_FIND_PACKAGE_ALSA 1)
+ sdlFindALSA()
+ endif()
+ unset(SDL_ALSA)
diff --git a/vcpkg/ports/sdl2/cxx-linkage-pkgconfig.diff b/vcpkg/ports/sdl2/cxx-linkage-pkgconfig.diff
new file mode 100644
index 0000000..beaed42
--- /dev/null
+++ b/vcpkg/ports/sdl2/cxx-linkage-pkgconfig.diff
@@ -0,0 +1,24 @@
+diff --git a/CMakeLists.txt b/CMakeLists.txt
+index 2a91824..a8e9de4 100644
+--- a/CMakeLists.txt
++++ b/CMakeLists.txt
+@@ -3162,6 +3162,19 @@ 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})
++if("${SOURCE_FILES};" MATCHES "[.]cpp;")
++ set(FAKE_CXX_LINKAGE "")
++ foreach(lib IN LISTS CMAKE_CXX_IMPLICIT_LINK_LIBRARIES)
++ if(lib IN_LIST CMAKE_C_IMPLICIT_LINK_LIBRARIES)
++ continue()
++ elseif(EXISTS "${lib}")
++ string(APPEND FAKE_CXX_LINKAGE " ${CMAKE_LINK_LIBRARY_FILE_FLAG}${lib}")
++ else()
++ string(APPEND FAKE_CXX_LINKAGE " ${CMAKE_LINK_LIBRARY_FLAG}${lib}")
++ endif()
++ endforeach()
++ string(APPEND SDL_STATIC_LIBS "${FAKE_CXX_LINKAGE}")
++endif()
+ listtostr(SDL_LIBS _SDL_LIBS)
+ set(SDL_LIBS ${_SDL_LIBS})
+ listtostr(SDL_CFLAGS _SDL_CFLAGS "")
diff --git a/vcpkg/ports/sdl2/deps.patch b/vcpkg/ports/sdl2/deps.patch
new file mode 100644
index 0000000..a8637d8
--- /dev/null
+++ b/vcpkg/ports/sdl2/deps.patch
@@ -0,0 +1,13 @@
+diff --git a/cmake/sdlchecks.cmake b/cmake/sdlchecks.cmake
+index 65a98efbe..2f99f28f1 100644
+--- a/cmake/sdlchecks.cmake
++++ b/cmake/sdlchecks.cmake
+@@ -352,7 +352,7 @@ endmacro()
+ # - HAVE_SDL_LOADSO opt
+ macro(CheckLibSampleRate)
+ if(SDL_LIBSAMPLERATE)
+- find_package(SampleRate QUIET)
++ find_package(SampleRate CONFIG REQUIRED)
+ if(SampleRate_FOUND AND TARGET SampleRate::samplerate)
+ set(HAVE_LIBSAMPLERATE TRUE)
+ set(HAVE_LIBSAMPLERATE_H TRUE)
diff --git a/vcpkg/ports/sdl2/portfile.cmake b/vcpkg/ports/sdl2/portfile.cmake
new file mode 100644
index 0000000..521e88b
--- /dev/null
+++ b/vcpkg/ports/sdl2/portfile.cmake
@@ -0,0 +1,125 @@
+vcpkg_from_github(
+ OUT_SOURCE_PATH SOURCE_PATH
+ REPO libsdl-org/SDL
+ REF "release-${VERSION}"
+ SHA512 d5622d6bb7266f7942a7b8ad43e8a22524893bf0c2ea1af91204838d9b78d32768843f6faa248757427b8404b8c6443776d4afa6b672cd8571a4e0c03a829383
+ HEAD_REF main
+ PATCHES
+ deps.patch
+ alsa-dep-fix.patch
+ cxx-linkage-pkgconfig.diff
+)
+
+string(COMPARE EQUAL "${VCPKG_LIBRARY_LINKAGE}" "static" SDL_STATIC)
+string(COMPARE EQUAL "${VCPKG_LIBRARY_LINKAGE}" "dynamic" SDL_SHARED)
+string(COMPARE EQUAL "${VCPKG_CRT_LINKAGE}" "static" FORCE_STATIC_VCRT)
+
+vcpkg_check_features(OUT_FEATURE_OPTIONS FEATURE_OPTIONS
+ FEATURES
+ alsa SDL_ALSA
+ dbus SDL_DBUS
+ ibus SDL_IBUS
+ samplerate SDL_LIBSAMPLERATE
+ vulkan SDL_VULKAN
+ wayland SDL_WAYLAND
+ x11 SDL_X11
+)
+
+if ("x11" IN_LIST FEATURES)
+ message(WARNING "You will need to install Xorg dependencies to use feature x11:\nsudo apt install libx11-dev libxft-dev libxext-dev\n")
+endif()
+if ("wayland" IN_LIST FEATURES)
+ message(WARNING "You will need to install Wayland dependencies to use feature wayland:\nsudo apt install libwayland-dev libxkbcommon-dev libegl1-mesa-dev\n")
+endif()
+if ("ibus" IN_LIST FEATURES)
+ message(WARNING "You will need to install ibus dependencies to use feature ibus:\nsudo apt install libibus-1.0-dev\n")
+endif()
+
+if(VCPKG_TARGET_IS_UWP)
+ set(configure_opts WINDOWS_USE_MSBUILD)
+endif()
+
+vcpkg_cmake_configure(
+ SOURCE_PATH "${SOURCE_PATH}"
+ ${configure_opts}
+ OPTIONS ${FEATURE_OPTIONS}
+ -DSDL_STATIC=${SDL_STATIC}
+ -DSDL_SHARED=${SDL_SHARED}
+ -DSDL_FORCE_STATIC_VCRT=${FORCE_STATIC_VCRT}
+ -DSDL_LIBC=ON
+ -DSDL_TEST=OFF
+ -DSDL_INSTALL_CMAKEDIR=cmake
+ -DCMAKE_DISABLE_FIND_PACKAGE_Git=ON
+ -DSDL_LIBSAMPLERATE_SHARED=OFF
+ MAYBE_UNUSED_VARIABLES
+ SDL_FORCE_STATIC_VCRT
+)
+
+vcpkg_cmake_install()
+vcpkg_cmake_config_fixup(CONFIG_PATH cmake)
+
+file(REMOVE_RECURSE
+ "${CURRENT_PACKAGES_DIR}/debug/include"
+ "${CURRENT_PACKAGES_DIR}/debug/share"
+ "${CURRENT_PACKAGES_DIR}/bin/sdl2-config"
+ "${CURRENT_PACKAGES_DIR}/debug/bin/sdl2-config"
+ "${CURRENT_PACKAGES_DIR}/SDL2.framework"
+ "${CURRENT_PACKAGES_DIR}/debug/SDL2.framework"
+ "${CURRENT_PACKAGES_DIR}/share/licenses"
+ "${CURRENT_PACKAGES_DIR}/share/aclocal"
+)
+
+file(GLOB BINS "${CURRENT_PACKAGES_DIR}/debug/bin/*" "${CURRENT_PACKAGES_DIR}/bin/*")
+if(NOT BINS)
+ file(REMOVE_RECURSE
+ "${CURRENT_PACKAGES_DIR}/bin"
+ "${CURRENT_PACKAGES_DIR}/debug/bin"
+ )
+endif()
+
+if(VCPKG_TARGET_IS_WINDOWS AND NOT VCPKG_TARGET_IS_UWP AND NOT VCPKG_TARGET_IS_MINGW)
+ if(NOT DEFINED VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "release")
+ file(MAKE_DIRECTORY "${CURRENT_PACKAGES_DIR}/lib/manual-link")
+ file(RENAME "${CURRENT_PACKAGES_DIR}/lib/SDL2main.lib" "${CURRENT_PACKAGES_DIR}/lib/manual-link/SDL2main.lib")
+ endif()
+ if(NOT DEFINED VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "debug")
+ file(MAKE_DIRECTORY "${CURRENT_PACKAGES_DIR}/debug/lib/manual-link")
+ file(RENAME "${CURRENT_PACKAGES_DIR}/debug/lib/SDL2maind.lib" "${CURRENT_PACKAGES_DIR}/debug/lib/manual-link/SDL2maind.lib")
+ endif()
+
+ file(GLOB SHARE_FILES "${CURRENT_PACKAGES_DIR}/share/sdl2/*.cmake")
+ foreach(SHARE_FILE ${SHARE_FILES})
+ vcpkg_replace_string("${SHARE_FILE}" "lib/SDL2main" "lib/manual-link/SDL2main" IGNORE_UNCHANGED)
+ endforeach()
+endif()
+
+vcpkg_copy_pdbs()
+
+set(DYLIB_COMPATIBILITY_VERSION_REGEX "set\\(DYLIB_COMPATIBILITY_VERSION (.+)\\)")
+set(DYLIB_CURRENT_VERSION_REGEX "set\\(DYLIB_CURRENT_VERSION (.+)\\)")
+file(STRINGS "${SOURCE_PATH}/CMakeLists.txt" DYLIB_COMPATIBILITY_VERSION REGEX ${DYLIB_COMPATIBILITY_VERSION_REGEX})
+file(STRINGS "${SOURCE_PATH}/CMakeLists.txt" DYLIB_CURRENT_VERSION REGEX ${DYLIB_CURRENT_VERSION_REGEX})
+string(REGEX REPLACE ${DYLIB_COMPATIBILITY_VERSION_REGEX} "\\1" DYLIB_COMPATIBILITY_VERSION "${DYLIB_COMPATIBILITY_VERSION}")
+string(REGEX REPLACE ${DYLIB_CURRENT_VERSION_REGEX} "\\1" DYLIB_CURRENT_VERSION "${DYLIB_CURRENT_VERSION}")
+
+if(NOT DEFINED VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "debug" AND NOT VCPKG_TARGET_IS_ANDROID)
+ vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/debug/lib/pkgconfig/sdl2.pc" "-lSDL2main" "-lSDL2maind" IGNORE_UNCHANGED)
+ vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/debug/lib/pkgconfig/sdl2.pc" "-lSDL2 " "-lSDL2d " IGNORE_UNCHANGED)
+ vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/debug/lib/pkgconfig/sdl2.pc" "-lSDL2-static " "-lSDL2-staticd " IGNORE_UNCHANGED)
+endif()
+
+if(VCPKG_TARGET_IS_UWP)
+ if(NOT DEFINED VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "release")
+ vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/lib/pkgconfig/sdl2.pc" "$<$<CONFIG:Debug>:d>.lib" "")
+ vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/lib/pkgconfig/sdl2.pc" "-l-nodefaultlib:" "-nodefaultlib:")
+ endif()
+ if(NOT DEFINED VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "debug")
+ vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/debug/lib/pkgconfig/sdl2.pc" "$<$<CONFIG:Debug>:d>.lib" "d")
+ vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/debug/lib/pkgconfig/sdl2.pc" "-l-nodefaultlib:" "-nodefaultlib:")
+ endif()
+endif()
+
+vcpkg_fixup_pkgconfig()
+
+file(INSTALL "${CMAKE_CURRENT_LIST_DIR}/usage" DESTINATION "${CURRENT_PACKAGES_DIR}/share/${PORT}")
+vcpkg_install_copyright(FILE_LIST "${SOURCE_PATH}/LICENSE.txt")
diff --git a/vcpkg/ports/sdl2/usage b/vcpkg/ports/sdl2/usage
new file mode 100644
index 0000000..1cddcd4
--- /dev/null
+++ b/vcpkg/ports/sdl2/usage
@@ -0,0 +1,8 @@
+sdl2 provides CMake targets:
+
+ find_package(SDL2 CONFIG REQUIRED)
+ target_link_libraries(main
+ PRIVATE
+ $<TARGET_NAME_IF_EXISTS:SDL2::SDL2main>
+ $<IF:$<TARGET_EXISTS:SDL2::SDL2>,SDL2::SDL2,SDL2::SDL2-static>
+ )
diff --git a/vcpkg/ports/sdl2/vcpkg.json b/vcpkg/ports/sdl2/vcpkg.json
new file mode 100644
index 0000000..ea55a04
--- /dev/null
+++ b/vcpkg/ports/sdl2/vcpkg.json
@@ -0,0 +1,74 @@
+{
+ "name": "sdl2",
+ "version": "2.32.10",
+ "description": "Simple DirectMedia Layer is a cross-platform development library designed to provide low level access to audio, keyboard, mouse, joystick, and graphics hardware via OpenGL and Direct3D.",
+ "homepage": "https://www.libsdl.org/download-2.0.php",
+ "license": "Zlib",
+ "dependencies": [
+ {
+ "name": "vcpkg-cmake",
+ "host": true
+ },
+ {
+ "name": "vcpkg-cmake-config",
+ "host": true
+ }
+ ],
+ "default-features": [
+ {
+ "name": "dbus",
+ "platform": "linux"
+ },
+ {
+ "name": "ibus",
+ "platform": "linux"
+ },
+ {
+ "name": "wayland",
+ "platform": "linux"
+ },
+ {
+ "name": "x11",
+ "platform": "linux"
+ }
+ ],
+ "features": {
+ "alsa": {
+ "description": "Support for alsa audio",
+ "dependencies": [
+ "alsa"
+ ]
+ },
+ "dbus": {
+ "description": "Build with D-Bus support",
+ "dependencies": [
+ {
+ "name": "dbus",
+ "default-features": false,
+ "platform": "linux"
+ }
+ ]
+ },
+ "ibus": {
+ "description": "Build with ibus IME support",
+ "supports": "linux"
+ },
+ "samplerate": {
+ "description": "Use libsamplerate for audio rate conversion",
+ "dependencies": [
+ "libsamplerate"
+ ]
+ },
+ "vulkan": {
+ "description": "Vulkan functionality for SDL"
+ },
+ "wayland": {
+ "description": "Build with Wayland support",
+ "supports": "linux"
+ },
+ "x11": {
+ "description": "Build with X11 support",
+ "supports": "!windows"
+ }
+ }
+}