git: c14f535ae56a - main - devel/sdl20: switch to cmake
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Tue, 14 May 2024 01:45:29 UTC
The branch main has been updated by amdmi3: URL: https://cgit.FreeBSD.org/ports/commit/?id=c14f535ae56adee7545d94077b4e04f2884c2137 commit c14f535ae56adee7545d94077b4e04f2884c2137 Author: Dmitry Marakasov <amdmi3@FreeBSD.org> AuthorDate: 2024-05-07 18:22:18 +0000 Commit: Dmitry Marakasov <amdmi3@FreeBSD.org> CommitDate: 2024-05-14 01:44:10 +0000 devel/sdl20: switch to cmake PR: 278353 Submitted by: diizzy --- devel/sdl20/Makefile | 194 +++++++++++++-------------------- devel/sdl20/files/patch-CMakeLists.txt | 49 +++++++++ devel/sdl20/files/patch-sdl2-config.in | 12 ++ devel/sdl20/pkg-plist | 15 ++- 4 files changed, 148 insertions(+), 122 deletions(-) diff --git a/devel/sdl20/Makefile b/devel/sdl20/Makefile index ab3b429e5ca0..8c3c594503e4 100644 --- a/devel/sdl20/Makefile +++ b/devel/sdl20/Makefile @@ -13,52 +13,25 @@ WWW= https://www.libsdl.org/ \ LICENSE= ZLIB LICENSE_FILE= ${WRKSRC}/LICENSE.txt -GNU_CONFIGURE= yes -USES= gmake iconv libtool localbase:ldflags pathfix pkgconfig -USE_CSTD= c99 +USES= cmake iconv pkgconfig +CMAKE_OFF= SDL_ARTS \ + SDL_CCACHE \ + SDL_ESD \ + SDL_LIBICONV \ + SDL_RPATH +CMAKE_ON= CMAKE_DISABLE_FIND_PACKAGE_Git USE_LDCONFIG= yes -CONFIGURE_ARGS= --disable-arts \ - --disable-esd \ - --disable-rpath -.if defined(MACHINE_CPU) && ${MACHINE_CPU:Mmmx} -CONFIGURE_ARGS+= --enable-mmx -.else -CONFIGURE_ARGS+= --disable-mmx -.endif -.if defined(MACHINE_CPU) && ${MACHINE_CPU:M3dnow} -CONFIGURE_ARGS+= --enable-3dnow -.else -CONFIGURE_ARGS+= --disable-3dnow -.endif -.if defined(MACHINE_CPU) && ${MACHINE_CPU:Msse} -CONFIGURE_ARGS+= --enable-sse -.else -CONFIGURE_ARGS+= --disable-sse -.endif -.if defined(MACHINE_CPU) && ${MACHINE_CPU:Msse2} -CONFIGURE_ARGS+= --enable-sse2 -.else -CONFIGURE_ARGS+= --disable-sse2 -.endif -.if defined(MACHINE_CPU) && ${MACHINE_CPU:Msse3} -CONFIGURE_ARGS+= --enable-sse3 -.else -CONFIGURE_ARGS+= --disable-sse3 -.endif - -MAKE_ENV= V=1 - PORTSCOUT= limitw:1,even -OPTIONS_DEFINE= ASM CSD DBUS FCITX IBUS JOYSTICK HIDAPI \ +OPTIONS_DEFINE= CSD DBUS FCITX IBUS JOYSTICK HIDAPI \ SAMPLERATE UDEV OPTIONS_GROUP= AUDIO VIDEO OPTIONS_GROUP_AUDIO= ALSA JACK NAS OSS PIPEWIRE PULSEAUDIO SNDIO -OPTIONS_GROUP_VIDEO= KMSDRM OPENGL OPENGLES1 OPENGLES2 VULKAN \ +OPTIONS_GROUP_VIDEO= KMSDRM OPENGL OPENGLES VULKAN \ WAYLAND X11 -OPTIONS_DEFAULT= ASM JOYSTICK OSS KMSDRM OPENGL \ - OPENGLES1 OPENGLES2 VULKAN WAYLAND X11 +OPTIONS_DEFAULT= JOYSTICK OSS KMSDRM OPENGL \ + OPENGLES VULKAN WAYLAND X11 OPTIONS_DEFINE_powerpc= ALTIVEC OPTIONS_DEFINE_powerpc64= ALTIVEC OPTIONS_DEFAULT_powerpc= ALTIVEC @@ -73,102 +46,87 @@ HIDAPI_DESC= Use HIDAPI for low level joystick drivers IBUS_DESC= IBus support JOYSTICK_DESC= Joystick and haptic support KMSDRM_DESC= KMSDRM display support -OPENGLES1_DESC= OpenGL ES 1.x rendering support -OPENGLES2_DESC= OpenGL ES 2.x rendering support +OPENGLES_DESC= OpenGL ES rendering support UDEV_DESC= Use udev for input device detection VULKAN_DESC= Vulkan rendering support -ALSA_CONFIGURE_ENABLE= alsa alsa-shared -ALSA_LIB_DEPENDS= libasound.so:audio/alsa-lib - -ALTIVEC_CONFIGURE_ENABLE= altivec - -ASM_CONFIGURE_ENABLE= assembly +ALSA_LIB_DEPENDS= libasound.so:audio/alsa-lib +ALSA_CMAKE_BOOL= SDL_ALSA +ALSA_CMAKE_BOOL_OFF= CMAKE_DISABLE_FIND_PACKAGE_ALSA -CSD_CONFIGURE_ENABLE= libdecor libdecor-shared -CSD_LIB_DEPENDS= libdecor-0.so:x11-toolkits/libdecor -CSD_IMPLIES= WAYLAND +ALTIVEC_CMAKE_BOOL= SDL_ALTIVEC -DBUS_LIB_DEPENDS= libdbus-1.so:devel/dbus -DBUS_CONFIGURE_ENABLE= dbus +CSD_LIB_DEPENDS= libdecor-0.so:x11-toolkits/libdecor +CSD_CMAKE_BOOL= SDL_WAYLAND_LIBDECOR +CSD_IMPLIES= WAYLAND -FCITX_LIB_DEPENDS= libfcitx-config.so:chinese/fcitx -FCITX_CONFIGURE_ENABLE= fcitx -FCITX_IMPLIES= DBUS +DBUS_LIB_DEPENDS= libdbus-1.so:devel/dbus +DBUS_CMAKE_BOOL= SDL_DBUS -HIDAPI_CONFIGURE_ENABLE= hidapi -HIDAPI_IMPLIES= JOYSTICK +FCITX_LIB_DEPENDS= libfcitx-config.so:chinese/fcitx +FCITX_IMPLIES= DBUS -IBUS_LIB_DEPENDS= libibus-1.0.so:textproc/ibus -IBUS_CONFIGURE_ENABLE= ibus -IBUS_IMPLIES= DBUS +HIDAPI_CMAKE_BOOL= SDL_HIDAPI +HIDAPI_IMPLIES= JOYSTICK -JACK_CONFIGURE_ENABLE= jack jack-shared -JACK_LIB_DEPENDS= libjack.so:audio/jack +IBUS_LIB_DEPENDS= libibus-1.0.so:textproc/ibus +IBUS_CMAKE_BOOL= SDL_IBUS +IBUS_IMPLIES= DBUS -JOYSTICK_CONFIGURE_ENABLE= joystick haptic -JOYSTICK_BUILD_DEPENDS= ${LOCALBASE}/include/linux/input.h:devel/evdev-proto -JOYSTICK_LIB_DEPENDS= libinotify.so:devel/libinotify +JACK_LIB_DEPENDS= libjack.so:audio/jack +JACK_CMAKE_BOOL= SDL_JACK -KMSDRM_CONFIGURE_ENABLE= video-kmsdrm kmsdrm-shared -KMSDRM_USES= gl -KMSDRM_USE= GL=gbm +JOYSTICK_BUILD_DEPENDS= ${LOCALBASE}/include/linux/input.h:devel/evdev-proto +JOYSTICK_LIB_DEPENDS= libinotify.so:devel/libinotify +JOYSTICK_CMAKE_BOOL= SDL_HIDAPI_JOYSTICK SDL_HIDAPI_LIBUSB SDL_VIRTUAL_JOYSTICK -NAS_CONFIGURE_ENABLE= nas nas-shared -NAS_LIB_DEPENDS= libaudio.so:audio/nas +KMSDRM_USES= gl +KMSDRM_USE= GL=gbm +KMSDRM_CMAKE_BOOL= SDL_KMSDRM -OPENGL_CONFIGURE_ENABLE= video-opengl -OPENGL_USES= gl -OPENGL_USE= GL=opengl +NAS_LIB_DEPENDS= libaudio.so:audio/nas +NAS_CMAKE_BOOL= SDL_NAS -OPENGLES1_CONFIGURE_ENABLE= video-opengles1 -OPENGLES1_USES= gl -OPENGLES1_USE= GL=egl,glesv1 -OPENGLES1_IMPLIES= OPENGLES +OPENGL_USES= gl +OPENGL_USE= GL=opengl +OPENGL_CMAKE_BOOL= SDL_OPENGL -OPENGLES2_CONFIGURE_ENABLE= video-opengles2 -OPENGLES2_USES= gl -OPENGLES2_USE= GL=egl,glesv2 -OPENGLES2_IMPLIES= OPENGLES +OPENGLES_USES= gl +OPENGLES_USE= GL=egl,glesv1,glesv2 +OPENGLES_CMAKE_BOOL= SDL_OPENGLES -OSS_CONFIGURE_ENABLE= oss +OSS_CMAKE_BOOL= SDL_OSS -PIPEWIRE_CONFIGURE_ENABLE= pipewire pipewire-shared -PIPEWIRE_LIB_DEPENDS= libpipewire-0.3.so:multimedia/pipewire +PIPEWIRE_LIB_DEPENDS= libpipewire-0.3.so:multimedia/pipewire +PIPEWIRE_CMAKE_BOOL= SDL_PIPEWIRE -PULSEAUDIO_CONFIGURE_ENABLE= pulseaudio pulseaudio-shared -PULSEAUDIO_LIB_DEPENDS= libpulse.so:audio/pulseaudio +PULSEAUDIO_LIB_DEPENDS= libpulse.so:audio/pulseaudio +PULSEAUDIO_CMAKE_BOOL= SDL_PULSEAUDIO -SAMPLERATE_CONFIGURE_ENABLE= libsamplerate libsamplerate-shared -SAMPLERATE_LIB_DEPENDS= libsamplerate.so:audio/libsamplerate +SAMPLERATE_LIB_DEPENDS= libsamplerate.so:audio/libsamplerate +SAMPLERATE_CMAKE_BOOL= SDL_LIBSAMPLERATE +SAMPLERATE_BOOL_OFF= CMAKE_DISABLE_FIND_PACKAGE_SampleRate -SNDIO_CONFIGURE_ENABLE= sndio sndio-shared -SNDIO_LIB_DEPENDS= libsndio.so:audio/sndio +SNDIO_LIB_DEPENDS= libsndio.so:audio/sndio +SNDIO_CMAKE_BOOL= SDL_SNDIO -UDEV_CONFIGURE_ENABLE= libudev -UDEV_LIB_DEPENDS= libudev.so:devel/libudev-devd -UDEV_BUILD_DEPENDS= ${LOCALBASE}/include/linux/input.h:devel/evdev-proto +UDEV_BUILD_DEPENDS= ${LOCALBASE}/include/linux/input.h:devel/evdev-proto +UDEV_LIB_DEPENDS= libudev.so:devel/libudev-devd +UDEV_CMAKE_BOOL= SDL_LIBUDEV -VULKAN_CONFIGURE_ENABLE= video-vulkan -VULKAN_LIB_DEPENDS= libvulkan.so:graphics/vulkan-loader +VULKAN_LIB_DEPENDS= libvulkan.so:graphics/vulkan-loader +VULKAN_CMAKE_BOOL= SDL_VULKAN -WAYLAND_CONFIGURE_ENABLE= video-wayland wayland-shared video-wayland-qt-touch -WAYLAND_BUILD_DEPENDS= wayland-protocols>0:graphics/wayland-protocols \ - ${LOCALBASE}/include/linux/input.h:devel/evdev-proto -WAYLAND_LIB_DEPENDS= libwayland-egl.so:graphics/wayland \ - libxkbcommon.so:x11/libxkbcommon -WAYLAND_IMPLIES= OPENGLES2 +WAYLAND_BUILD_DEPENDS= wayland-protocols>0:graphics/wayland-protocols \ + ${LOCALBASE}/include/linux/input.h:devel/evdev-proto +WAYLAND_LIB_DEPENDS= libwayland-egl.so:graphics/wayland \ + libxkbcommon.so:x11/libxkbcommon +WAYLAND_CMAKE_BOOL= SDL_WAYLAND +WAYLAND_IMPLIES= OPENGLES -X11_CONFIGURE_ENABLE= video-x11 x11-shared \ - video-x11-xcursor \ - video-x11-xdbe \ - video-x11-xinput \ - video-x11-xfixes \ - video-x11-xrandr \ - video-x11-scrnsaver \ - video-x11-xshape -X11_USES= xorg -X11_USE= XORG=xcursor,xext,xi,xfixes,xrandr,xscrnsaver +X11_USES= xorg +X11_USE= XORG=x11,xcursor,xext,xi,xfixes,xrandr,xscrnsaver +X11_CMAKE_BOOL= SDL_X11 .include <bsd.port.options.mk> @@ -178,16 +136,12 @@ BUILD_DEPENDS+= ${LOCALBASE}/bin/as:devel/binutils CFLAGS+= -B${LOCALBASE}/bin -no-integrated-as .endif -.include <bsd.port.pre.mk> - -.if !empty(ICONV_LIB) -CONFIGURE_ARGS+= ac_cv_lib_iconv_iconv_open=yes ac_cv_func_iconv=yes -.endif - post-patch: - @${REINPLACE_CMD} -e 's/-liconv/${ICONV_LIB}/g' ${WRKSRC}/configure + @${REINPLACE_CMD} -e '/dep_option.*Dynamically load/ s|ON|OFF|' \ + ${WRKSRC}/CMakeLists.txt -post-install: - @${STRIP_CMD} ${STAGEDIR}${PREFIX}/lib/libSDL2.so +post-patch-FCITX-off: + @${REINPLACE_CMD} -e 's|HAVE_FCITX TRUE|HAVE_FCITX FALSE|g' \ + ${WRKSRC}/CMakeLists.txt -.include <bsd.port.post.mk> +.include <bsd.port.mk> diff --git a/devel/sdl20/files/patch-CMakeLists.txt b/devel/sdl20/files/patch-CMakeLists.txt new file mode 100644 index 000000000000..10acb6ef7a95 --- /dev/null +++ b/devel/sdl20/files/patch-CMakeLists.txt @@ -0,0 +1,49 @@ +--- CMakeLists.txt.orig 2024-05-01 16:16:27 UTC ++++ CMakeLists.txt +@@ -404,12 +404,12 @@ set_option(SDL_ASSEMBLY "Enable assembly ro + 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) + set_option(SDL_ASSEMBLY "Enable assembly routines" ${OPT_DEF_ASM}) +-dep_option(SDL_SSEMATH "Allow GCC to use SSE floating point math" ON "SDL_ASSEMBLY;SDL_CPU_X86 OR SDL_CPU_X64" OFF) ++#[[ dep_option(SDL_SSEMATH "Allow GCC to use SSE floating point math" ON "SDL_ASSEMBLY;SDL_CPU_X86 OR SDL_CPU_X64" OFF) + dep_option(SDL_SSE "Use SSE assembly routines" ON "SDL_ASSEMBLY;SDL_CPU_X86 OR SDL_CPU_X64" OFF) + dep_option(SDL_SSE2 "Use SSE2 assembly routines" ON "SDL_ASSEMBLY;SDL_CPU_X86 OR SDL_CPU_X64" OFF) + dep_option(SDL_SSE3 "Use SSE3 assembly routines" ON "SDL_ASSEMBLY;SDL_CPU_X86 OR SDL_CPU_X64" OFF) + dep_option(SDL_MMX "Use MMX assembly routines" ON "SDL_ASSEMBLY;SDL_CPU_X86 OR SDL_CPU_X64" OFF) +-dep_option(SDL_3DNOW "Use 3Dnow! MMX assembly routines" ON "SDL_ASSEMBLY;SDL_CPU_X86 OR SDL_CPU_X64" OFF) ++dep_option(SDL_3DNOW "Use 3Dnow! MMX assembly routines" ON "SDL_ASSEMBLY;SDL_CPU_X86 OR SDL_CPU_X64" OFF) ]] + dep_option(SDL_ALTIVEC "Use Altivec assembly routines" ON "SDL_ASSEMBLY" OFF) + dep_option(SDL_ARMSIMD "Use SIMD assembly blitters on ARM" OFF "SDL_ASSEMBLY;SDL_CPU_ARM32" OFF) + dep_option(SDL_ARMNEON "Use NEON assembly blitters on ARM" OFF "SDL_ASSEMBLY;SDL_CPU_ARM32" OFF) +@@ -758,7 +758,7 @@ if(SDL_ASSEMBLY) + # TODO: Those all seem to be quite GCC specific - needs to be + # reworked for better compiler support + set(HAVE_ASSEMBLY TRUE) +- if(SDL_MMX) ++#[[ if(SDL_MMX) + set(CMAKE_REQUIRED_FLAGS "-mmmx") + check_c_source_compiles(" + #ifdef __MINGW32__ +@@ -881,7 +881,7 @@ if(SDL_ASSEMBLY) + endif() + else() + set(HAVE_SSEMATH TRUE) +- endif() ++ endif() ]] + + check_include_file("immintrin.h" HAVE_IMMINTRIN_H) + +@@ -1613,9 +1613,11 @@ elseif(UNIX AND NOT APPLE AND NOT RISCOS AND NOT HAIKU + endif() + + if(FREEBSD AND NOT HAVE_INOTIFY) +- pkg_search_module(INOTIFY libinotify) +- if(INOTIFY_FOUND) ++ pkg_search_module(PC_INOTIFY libinotify) ++ if(PC_INOTIFY_FOUND) + set(HAVE_INOTIFY 1) ++ find_path(INOTIFY_INCLUDE_DIRS NAMES sys/inotify.h REQUIRED HINTS ${PC_INOTIFY_INCLUDE_DIRS}) ++ find_library(INOTIFY_LIBRARIES NAMES inotify REQUIRED HINTS ${PC_INOTIFY_LIBRARY_DIRS}) + target_include_directories(sdl-build-options INTERFACE "${INOTIFY_INCLUDE_DIRS}") + list(APPEND EXTRA_LIBS ${INOTIFY_LIBRARIES}) + endif() diff --git a/devel/sdl20/files/patch-sdl2-config.in b/devel/sdl20/files/patch-sdl2-config.in new file mode 100644 index 000000000000..fdadb030965a --- /dev/null +++ b/devel/sdl20/files/patch-sdl2-config.in @@ -0,0 +1,12 @@ +TODO: fix all ports which require this and remove this patch +--- sdl2-config.in.orig 2024-04-14 09:17:31 UTC ++++ sdl2-config.in +@@ -46,7 +46,7 @@ while test $# -gt 0; do + echo @SDL_VERSION@ + ;; + --cflags) +- echo -I@includedir@/SDL2 @SDL_CFLAGS@ ++ echo -I@includedir@ -I@includedir@/SDL2 @SDL_CFLAGS@ + ;; + @ENABLE_SHARED_TRUE@ --libs) + @ENABLE_SHARED_TRUE@ echo -L@libdir@ @SDL_RLD_FLAGS@ @SDL_LIBS@ diff --git a/devel/sdl20/pkg-plist b/devel/sdl20/pkg-plist index c3bb57301925..a43cfa386ca9 100644 --- a/devel/sdl20/pkg-plist +++ b/devel/sdl20/pkg-plist @@ -7,6 +7,7 @@ include/SDL2/SDL_bits.h include/SDL2/SDL_blendmode.h include/SDL2/SDL_clipboard.h include/SDL2/SDL_config.h +include/SDL2/SDL_copying.h include/SDL2/SDL_cpuinfo.h include/SDL2/SDL_egl.h include/SDL2/SDL_endian.h @@ -77,8 +78,18 @@ include/SDL2/SDL_video.h include/SDL2/SDL_vulkan.h include/SDL2/begin_code.h include/SDL2/close_code.h -lib/cmake/SDL2/sdl2-config-version.cmake -lib/cmake/SDL2/sdl2-config.cmake +lib/cmake/SDL2/SDL2Config.cmake +lib/cmake/SDL2/SDL2ConfigVersion.cmake +lib/cmake/SDL2/SDL2Targets-%%CMAKE_BUILD_TYPE%%.cmake +lib/cmake/SDL2/SDL2Targets.cmake +lib/cmake/SDL2/SDL2mainTargets-%%CMAKE_BUILD_TYPE%%.cmake +lib/cmake/SDL2/SDL2mainTargets.cmake +lib/cmake/SDL2/SDL2staticTargets-%%CMAKE_BUILD_TYPE%%.cmake +lib/cmake/SDL2/SDL2staticTargets.cmake +lib/cmake/SDL2/SDL2testTargets-%%CMAKE_BUILD_TYPE%%.cmake +lib/cmake/SDL2/SDL2testTargets.cmake +lib/cmake/SDL2/sdlfind.cmake +lib/libSDL2-2.0.so lib/libSDL2-2.0.so.0 lib/libSDL2-2.0.so.0.3000.3 lib/libSDL2.a