mirror of
https://git.freebsd.org/ports.git
synced 2025-05-12 23:31:50 -04:00
emulators/{,libretro-}ppsspp{,-qt5}: Fix build with miniupnpc-2.2.8
Upstream bug report: https://github.com/hrydgard/ppsspp/issues/19333 While here fix plist error in libretro-ppsspp and pet portclippy. PR: 280298
This commit is contained in:
parent
16e74f6766
commit
57569e0b98
4 changed files with 69 additions and 46 deletions
|
@ -1,9 +1,9 @@
|
||||||
PORTREVISION= 0
|
PORTREVISION= 1
|
||||||
PKGNAMEPREFIX= libretro-
|
PKGNAMEPREFIX= libretro-
|
||||||
|
|
||||||
MASTERDIR= ${.CURDIR}/../ppsspp
|
MASTERDIR= ${.CURDIR}/../ppsspp
|
||||||
|
|
||||||
OPTIONS_SLAVE= LIBRETRO
|
OPTIONS_EXCLUDE= ${OPTIONS_DEFINE}
|
||||||
OPTIONS_EXCLUDE=${OPTIONS_DEFINE}
|
OPTIONS_SLAVE= LIBRETRO
|
||||||
|
|
||||||
.include "${MASTERDIR}/Makefile"
|
.include "${MASTERDIR}/Makefile"
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
PORTREVISION= 0
|
PORTREVISION= 1
|
||||||
PKGNAMESUFFIX= -qt5
|
PKGNAMESUFFIX= -qt5
|
||||||
|
|
||||||
MASTERDIR= ${.CURDIR}/../ppsspp
|
MASTERDIR= ${.CURDIR}/../ppsspp
|
||||||
|
|
||||||
OPTIONS_SLAVE= QT5
|
|
||||||
# XXX No VULKAN per https://github.com/hrydgard/ppsspp/blob/v1.10/Qt/QtMain.cpp#L711-L712
|
# XXX No VULKAN per https://github.com/hrydgard/ppsspp/blob/v1.10/Qt/QtMain.cpp#L711-L712
|
||||||
OPTIONS_EXCLUDE=${OPTIONS_DEFINE}
|
OPTIONS_EXCLUDE= ${OPTIONS_DEFINE}
|
||||||
|
OPTIONS_SLAVE= QT5
|
||||||
|
|
||||||
.include "${MASTERDIR}/Makefile"
|
.include "${MASTERDIR}/Makefile"
|
||||||
|
|
|
@ -26,6 +26,7 @@ LIB_DEPENDS= libzip.so:archivers/libzip \
|
||||||
libminiupnpc.so:net/miniupnpc
|
libminiupnpc.so:net/miniupnpc
|
||||||
RUN_DEPENDS= xdg-open:devel/xdg-utils
|
RUN_DEPENDS= xdg-open:devel/xdg-utils
|
||||||
|
|
||||||
|
USES= cmake compiler:c++11-lib gl localbase:ldflags pkgconfig
|
||||||
USE_GITHUB= yes
|
USE_GITHUB= yes
|
||||||
GH_ACCOUNT= hrydgard
|
GH_ACCOUNT= hrydgard
|
||||||
GH_TUPLE?= hrydgard:glslang:8.13.3743-948-gb34f619e:glslang/ext/glslang \
|
GH_TUPLE?= hrydgard:glslang:8.13.3743-948-gb34f619e:glslang/ext/glslang \
|
||||||
|
@ -37,68 +38,65 @@ GH_TUPLE?= hrydgard:glslang:8.13.3743-948-gb34f619e:glslang/ext/glslang \
|
||||||
Kingcom:filesystem:v1.3.2-12-g3f1c185:filesystem/ext/armips/ext/filesystem \
|
Kingcom:filesystem:v1.3.2-12-g3f1c185:filesystem/ext/armips/ext/filesystem \
|
||||||
RetroAchievements:rcheevos:v11.0.0-26-ge7989c3:rcheevos/ext/rcheevos \
|
RetroAchievements:rcheevos:v11.0.0-26-ge7989c3:rcheevos/ext/rcheevos \
|
||||||
Tencent:rapidjson:v1.1.0-415-g73063f50:rapidjson/ext/rapidjson
|
Tencent:rapidjson:v1.1.0-415-g73063f50:rapidjson/ext/rapidjson
|
||||||
|
|
||||||
CONFLICTS_INSTALL= ${PORTNAME}-*
|
|
||||||
|
|
||||||
USES= cmake compiler:c++11-lib gl localbase:ldflags pkgconfig shared-mime-info
|
|
||||||
EXCLUDE= libzip zlib
|
EXCLUDE= libzip zlib
|
||||||
EXTRACT_AFTER_ARGS=${EXCLUDE:S,^,--exclude ,}
|
|
||||||
USE_GL= glew opengl
|
USE_GL= glew opengl
|
||||||
CMAKE_ON= ${FFMPEG LIBZIP MINIUPNPC SNAPPY ZSTD:L:S/^/USE_SYSTEM_/} USE_VULKAN_DISPLAY_KHR
|
CMAKE_ON= ${FFMPEG LIBZIP MINIUPNPC SNAPPY ZSTD:L:S/^/USE_SYSTEM_/} USE_VULKAN_DISPLAY_KHR
|
||||||
CMAKE_OFF= USE_DISCORD
|
CMAKE_OFF= USE_DISCORD
|
||||||
LDFLAGS+= -Wl,--as-needed # ICE/SM/X11/Xext, Qt5Network
|
LDFLAGS+= -Wl,--as-needed # ICE/SM/X11/Xext, Qt5Network
|
||||||
|
CONFLICTS_INSTALL= ${PORTNAME}-*
|
||||||
|
DESKTOP_ENTRIES= "PPSSPP" \
|
||||||
|
"" \
|
||||||
|
"${PORTNAME}" \
|
||||||
|
"${PORTNAME} %f" \
|
||||||
|
"Game;Emulator;" \
|
||||||
|
""
|
||||||
|
EXTRACT_AFTER_ARGS= ${EXCLUDE:S,^,--exclude ,}
|
||||||
SUB_FILES= pkg-message
|
SUB_FILES= pkg-message
|
||||||
PORTDATA= assets
|
PORTDATA= assets
|
||||||
|
|
||||||
DESKTOP_ENTRIES="PPSSPP" \
|
OPTIONS_DEFINE= VULKAN
|
||||||
"" \
|
OPTIONS_DEFAULT= VULKAN
|
||||||
"${PORTNAME}" \
|
OPTIONS_SINGLE= GUI
|
||||||
"${PORTNAME} %f" \
|
|
||||||
"Game;Emulator;" \
|
|
||||||
""
|
|
||||||
|
|
||||||
OPTIONS_DEFINE= VULKAN
|
|
||||||
OPTIONS_DEFAULT=VULKAN
|
|
||||||
OPTIONS_SINGLE= GUI
|
|
||||||
OPTIONS_SINGLE_GUI= LIBRETRO QT5 SDL
|
OPTIONS_SINGLE_GUI= LIBRETRO QT5 SDL
|
||||||
OPTIONS_SLAVE?= SDL
|
|
||||||
OPTIONS_EXCLUDE:= ${OPTIONS_EXCLUDE} ${OPTIONS_SINGLE_GUI}
|
OPTIONS_EXCLUDE:= ${OPTIONS_EXCLUDE} ${OPTIONS_SINGLE_GUI}
|
||||||
|
OPTIONS_SLAVE?= SDL
|
||||||
|
|
||||||
LIBRETRO_DESC= libretro core for games/retroarch
|
LIBRETRO_DESC= libretro core for games/retroarch
|
||||||
|
VULKAN_DESC= Vulkan renderer
|
||||||
|
LIBRETRO_LIB_DEPENDS= libpng.so:graphics/png
|
||||||
LIBRETRO_CMAKE_BOOL= LIBRETRO
|
LIBRETRO_CMAKE_BOOL= LIBRETRO
|
||||||
LIBRETRO_PLIST_FILES= lib/libretro/${PORTNAME}_libretro.so
|
LIBRETRO_PLIST_FILES= lib/libretro/${PORTNAME}_libretro.so
|
||||||
LIBRETRO_VARS= CONFLICTS_INSTALL= DESKTOP_ENTRIES= PLIST= PORTDATA= PKGMESSAGE= SUB_FILES=
|
LIBRETRO_VARS= CONFLICTS_INSTALL= DESKTOP_ENTRIES= PLIST= PORTDATA= PKGMESSAGE= SUB_FILES=
|
||||||
QT5_USES= elfctl qt:5 sdl
|
QT5_LIB_DEPENDS= libpng.so:graphics/png
|
||||||
QT5_USE= QT=qmake:build,buildtools:build,linguisttools:build,gui,multimedia,opengl,widgets
|
QT5_USES= desktop-file-utils elfctl qt:5 shared-mime-info sdl
|
||||||
QT5_USE+= SDL=sdl2 # audio, joystick
|
QT5_USE= QT=qmake:build,buildtools:build,linguisttools:build,core,gui,multimedia,opengl,widgets
|
||||||
QT5_CMAKE_BOOL= USING_QT_UI
|
QT5_USE+= SDL=sdl2 # audio, joystick
|
||||||
QT5_VARS= EXENAME=PPSSPPQt ELF_FEATURES=+wxneeded:PPSSPPQt
|
QT5_CMAKE_BOOL= USING_QT_UI
|
||||||
|
QT5_VARS= EXENAME=PPSSPPQt ELF_FEATURES=+wxneeded:PPSSPPQt
|
||||||
SDL_CATEGORIES= wayland
|
SDL_CATEGORIES= wayland
|
||||||
SDL_BUILD_DEPENDS= png>=1.6:graphics/png
|
|
||||||
SDL_LIB_DEPENDS= libpng.so:graphics/png
|
SDL_LIB_DEPENDS= libpng.so:graphics/png
|
||||||
SDL_USES= elfctl sdl
|
SDL_USES= elfctl shared-mime-info sdl
|
||||||
SDL_USE= SDL=sdl2
|
SDL_USE= SDL=sdl2
|
||||||
SDL_VARS= EXENAME=PPSSPPSDL ELF_FEATURES=+wxneeded:PPSSPPSDL
|
SDL_VARS= EXENAME=PPSSPPSDL ELF_FEATURES=+wxneeded:PPSSPPSDL
|
||||||
VULKAN_DESC= Vulkan renderer
|
|
||||||
VULKAN_RUN_DEPENDS= ${LOCALBASE}/lib/libvulkan.so:graphics/vulkan-loader
|
VULKAN_RUN_DEPENDS= ${LOCALBASE}/lib/libvulkan.so:graphics/vulkan-loader
|
||||||
|
|
||||||
post-patch:
|
post-patch:
|
||||||
@${REINPLACE_CMD} -e 's/Linux/${OPSYS}/' \
|
@${REINPLACE_CMD} -e 's/Linux/${OPSYS}/' ${WRKSRC}/assets/gamecontrollerdb.txt
|
||||||
${WRKSRC}/assets/gamecontrollerdb.txt
|
@${REINPLACE_CMD} -e 's,/usr/share,${PREFIX}/share,' ${WRKSRC}/UI/NativeApp.cpp
|
||||||
@${REINPLACE_CMD} -e 's,/usr/share,${PREFIX}/share,' \
|
@${REINPLACE_CMD} -e 's/"unknown"/"${DISTVERSIONFULL}"/' ${WRKSRC}/git-version.cmake
|
||||||
${WRKSRC}/UI/NativeApp.cpp
|
|
||||||
@${REINPLACE_CMD} -e 's/"unknown"/"${DISTVERSIONFULL}"/' \
|
|
||||||
${WRKSRC}/git-version.cmake
|
|
||||||
|
|
||||||
do-install-QT5-on do-install-SDL-on:
|
|
||||||
${MV} ${STAGEDIR}${PREFIX}/bin/${EXENAME} \
|
|
||||||
${STAGEDIR}${PREFIX}/bin/${PORTNAME}
|
|
||||||
${INSTALL_MAN} ${_DISTDIR}/${PORTNAME}.1 \
|
|
||||||
${STAGEDIR}${PREFIX}/share/man/man1
|
|
||||||
|
|
||||||
do-install-LIBRETRO-on:
|
do-install-LIBRETRO-on:
|
||||||
${MKDIR} ${STAGEDIR}${PREFIX}/${LIBRETRO_PLIST_FILES:H}
|
${MKDIR} ${STAGEDIR}${PREFIX}/${LIBRETRO_PLIST_FILES:H}
|
||||||
${INSTALL_LIB} ${BUILD_WRKSRC}/lib/${LIBRETRO_PLIST_FILES:T} \
|
${INSTALL_LIB} ${BUILD_WRKSRC}/lib/${LIBRETRO_PLIST_FILES:T} \
|
||||||
${STAGEDIR}${PREFIX}/${LIBRETRO_PLIST_FILES:H}
|
${STAGEDIR}${PREFIX}/${LIBRETRO_PLIST_FILES:H}
|
||||||
|
.if ${OPTIONS_SLAVE} == LIBRETRO
|
||||||
|
. for d in applications icons man mime ${PORTNAME}
|
||||||
|
${RM} -r ${STAGEDIR}${PREFIX}/share/${d}
|
||||||
|
. endfor
|
||||||
|
.endif
|
||||||
|
|
||||||
|
do-install-QT5-on do-install-SDL-on:
|
||||||
|
${MV} ${STAGEDIR}${PREFIX}/bin/${EXENAME} ${STAGEDIR}${PREFIX}/bin/${PORTNAME}
|
||||||
|
${INSTALL_MAN} ${_DISTDIR}/${PORTNAME}.1 ${STAGEDIR}${PREFIX}/share/man/man1
|
||||||
|
|
||||||
.include <bsd.port.mk>
|
.include <bsd.port.mk>
|
||||||
|
|
25
emulators/ppsspp/files/patch-Core_Util_PortManager.cpp
Normal file
25
emulators/ppsspp/files/patch-Core_Util_PortManager.cpp
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
--- Core/Util/PortManager.cpp.orig 2024-02-04 13:08:02 UTC
|
||||||
|
+++ Core/Util/PortManager.cpp
|
||||||
|
@@ -161,7 +161,21 @@ bool PortManager::Initialize(const unsigned int timeou
|
||||||
|
|
||||||
|
// Get LAN IP address that connects to the router
|
||||||
|
char lanaddr[64] = "unset";
|
||||||
|
- int status = UPNP_GetValidIGD(devlist, urls, datas, lanaddr, sizeof(lanaddr)); //possible "status" values, 0 = NO IGD found, 1 = A valid connected IGD has been found, 2 = A valid IGD has been found but it reported as not connected, 3 = an UPnP device has been found but was not recognized as an IGD
|
||||||
|
+/*
|
||||||
|
+possible "status" values:
|
||||||
|
+-1 = Internal error
|
||||||
|
+ 0 = NO IGD found
|
||||||
|
+ 1 = A valid connected IGD has been found
|
||||||
|
+ 2 = A valid connected IGD has been found but its IP address is reserved (non routable)
|
||||||
|
+ 3 = A valid IGD has been found but it reported as not connected
|
||||||
|
+ 4 = an UPnP device has been found but was not recognized as an IGD
|
||||||
|
+*/
|
||||||
|
+ int status =
|
||||||
|
+#if (MINIUPNPC_API_VERSION >= 18)
|
||||||
|
+ UPNP_GetValidIGD(devlist, urls, datas, lanaddr, sizeof(lanaddr), nullptr, 0);
|
||||||
|
+#else
|
||||||
|
+ UPNP_GetValidIGD(devlist, urls, datas, lanaddr, sizeof(lanaddr));
|
||||||
|
+#endif
|
||||||
|
m_lanip = std::string(lanaddr);
|
||||||
|
INFO_LOG(SCENET, "PortManager - Detected LAN IP: %s", m_lanip.c_str());
|
||||||
|
|
Loading…
Add table
Reference in a new issue