diff options
author | Samuel Bauer <samuel.bauer@yahoo.fr> | 2023-07-13 08:45:10 +0200 |
---|---|---|
committer | Samuel Bauer <samuel.bauer@yahoo.fr> | 2023-07-13 08:45:10 +0200 |
commit | ea9dcb07de341f6a6ebed1c1815d50f58ea48d45 (patch) | |
tree | a3f6d477258d46cfaea5982c702bc278fe7083c0 /games-emulation | |
parent | games-emulation/yuzu: allow =dev-util/glslang-1.3.250 (diff) | |
download | guru-ea9dcb07de341f6a6ebed1c1815d50f58ea48d45.tar.gz guru-ea9dcb07de341f6a6ebed1c1815d50f58ea48d45.tar.bz2 guru-ea9dcb07de341f6a6ebed1c1815d50f58ea48d45.zip |
games-emulation/citra: depend on qt6
Signed-off-by: Samuel Bauer <samuel.bauer@yahoo.fr>
Diffstat (limited to 'games-emulation')
-rw-r--r-- | games-emulation/citra/citra-9999.ebuild | 81 | ||||
-rw-r--r-- | games-emulation/citra/metadata.xml | 2 |
2 files changed, 46 insertions, 37 deletions
diff --git a/games-emulation/citra/citra-9999.ebuild b/games-emulation/citra/citra-9999.ebuild index 819b844f6..3c78946d3 100644 --- a/games-emulation/citra/citra-9999.ebuild +++ b/games-emulation/citra/citra-9999.ebuild @@ -9,31 +9,26 @@ DESCRIPTION="A Nintendo 3DS Emulator" HOMEPAGE="https://citra-emu.org" EGIT_REPO_URI="https://github.com/citra-emu/citra" EGIT_SUBMODULES=( - 'catch2' 'discord-rpc' 'dynarmic' 'libyuv' - 'lodepng' 'nihstro' 'soundtouch' 'xbyak' + 'catch2' 'dds-ktx' 'discord-rpc' 'dynarmic' 'library-headers' 'libyuv' + 'lodepng' 'nihstro' 'sirit' 'soundtouch' 'vma' 'xbyak' ) LICENSE="GPL-2" SLOT="0" KEYWORDS="" -IUSE="cubeb +hle-sound nls +qt5 sdl +system-libfmt +telemetry video" +IUSE="cubeb nls openal +gui sdl +system-libfmt +telemetry" RDEPEND=" cubeb? ( media-libs/cubeb ) - !hle-sound? ( media-libs/fdk-aac ) - hle-sound? ( media-video/ffmpeg[fdk] ) - qt5? ( nls? ( dev-qt/linguist ) - dev-qt/qtgui:5 - dev-qt/qtmultimedia:5 - dev-qt/qtnetwork:5 - dev-qt/qtopengl:5 - dev-qt/qtwidgets:5 ) + media-video/ffmpeg:=[fdk] + gui? ( nls? ( dev-qt/qttools:6[linguist] ) + dev-qt/qtbase:6[widgets,gui,opengl,network] + dev-qt/qtmultimedia:6 ) sdl? ( media-libs/libsdl2 >=dev-libs/inih-52 ) system-libfmt? ( >=dev-libs/libfmt-9:= ) - video? ( media-video/ffmpeg:= ) >=dev-libs/openssl-1.1:= app-arch/zstd dev-libs/boost:= @@ -47,12 +42,15 @@ BDEPEND=" dev-cpp/cpp-httplib dev-cpp/cpp-jwt dev-cpp/robin-map" -REQUIRED_USE="|| ( qt5 sdl )" +REQUIRED_USE="|| ( gui sdl )" src_unpack() { if ! use system-libfmt; then EGIT_SUBMODULES+=( 'fmt' ) fi + if use openal; then + EGIT_SUBMODULES+=( 'openal-soft' ) + fi git-r3_src_unpack cp -a "${S}"/externals/xbyak "${S}"/externals/dynarmic/externals/ || die @@ -78,24 +76,17 @@ src_prepare() { # Fix boost unbundling sed -i -e '/(-DBOOST_ERROR_CODE_HEADER_ONLY/,/)/d' CMakeLists.txt || die - sed -i -e '/^# Boost/,/boost)$/d' externals/CMakeLists.txt || die - - # Unbundle libressl (TODO rework scopes, find_package(OpenSSL is called 5 times) - sed -i -e '$afind_package(OpenSSL 1.1)\nset(OPENSSL_LIBRARIES OpenSSL::SSL OpenSSL::Crypto PARENT_SCOPE)' \ - CMakeLists.txt || die - sed -i -e 's/# LibreSSL/find_package(OpenSSL 1.1)\nif (NOT OPENSSL_FOUND)\n/' \ - -e 's/-DHAVE_INET_NTOP)$/&\nendif()\n/' externals/CMakeLists.txt || die - sed -i -e '/get_directory_property(OPENSSL_LIBS/,/)/d' \ - -e 's/OPENSSL_LIBS/OPENSSL_LIBRARIES/' \ - src/web_service/CMakeLists.txt \ - src/core/CMakeLists.txt || die - sed -i -e 's/{PLATFORM_LIBRARIES}/& OpenSSL::SSL OpenSSL::Crypto/' \ - src/{citra,citra_qt,dedicated_room,tests}/CMakeLists.txt || die - sed -i -e '1ifind_package(OpenSSL 1.1)' src/{citra,citra_qt,dedicated_room,tests}/CMakeLists.txt || die + sed -i -e '/^# Boost/,/boost_iostreams PUBLIC/d' externals/CMakeLists.txt || die + sed -i -e '/^#define BOOST_STACKTRACE_USE_BACKTRACE/d' \ + src/common/logging/backend.cpp || die + sed -i -e 's/ backtrace//' src/common/CMakeLists.txt || die - if use system-libfmt; then # Unbundle libfmt + # Unbundle libfmt + if use system-libfmt; then sed -i -e '/fmt/d' externals/CMakeLists.txt || die sed -i -e '/find_package(Threads/afind_package(fmt)' CMakeLists.txt || die + else + sed -i -e '/FMT_INSTALL/d' externals/dynarmic/externals/CMakeLists.txt || die fi # Unbundle teakra @@ -119,7 +110,7 @@ src_prepare() { -e '1ifind_package(PkgConfig REQUIRED)\npkg_check_modules(CRYPTOPP REQUIRED libcryptopp)' \ src/dedicated_room/CMakeLists.txt \ src/core/CMakeLists.txt || die - sed -i -e '/^# Crypto++/,/set(CRYPTOPP_COMPILE_DEFINITIONS/d' externals/CMakeLists.txt || die + sed -i -e '/^# Crypto++/,/add_subdirectory(cryptopp-cmake)/d' externals/CMakeLists.txt || die # Unbundle cubeb sed -i -e '/CUBEB/,/endif()/d' externals/CMakeLists.txt || die @@ -131,30 +122,50 @@ src_prepare() { sed -i -e '/# httplib/,/target_link_libraries(httplib/d' externals/CMakeLists.txt || die # Unbundle cpp-jwt - sed -i -e '/# cpp-jwt/,/CPP_JWT_USE_VENDORED_NLOHMANN_JSON/d' externals/CMakeLists.txt || die + sed -i -e '/cpp-jwt/d' externals/CMakeLists.txt || die sed -i -e 's/ cpp-jwt/ ssl crypto/' src/web_service/CMakeLists.txt || die # Unbundle xbyak sed -i -e '/^install(/,/^)$/d' externals/xbyak/CMakeLists.txt || die + # glslang + sed -i -e '/^# glslang/,/(glslang)/d' externals/CMakeLists.txt || die + sed -i -e 's:SPIRV/GlslangToSpv.h:glslang/&:' src/video_core/renderer_vulkan/vk_shader_util.cpp || die + sed -i -e '/target_include_directories(vulkan-headers/d' externals/CMakeLists.txt || die + # Do not install dynarmic sed -i -e '/^# Install/,$d' externals/dynarmic/CMakeLists.txt || die + # Do not install zydis + sed -i '/^install(FILES/,/^install(DIRECTORY/d' \ + externals/dynarmic/externals/zydis/CMakeLists.txt || die + sed -i -e '/MCL_INSTALL/d' externals/dynarmic/externals/CMakeLists.txt || die + + # do not trigger flags + sed -i -e 's/-Werror//' externals/sirit/CMakeLists.txt externals/dynarmic/CMakeLists.txt || die + sed -i -e 's/Wuninitialized/Wno-uninitialized/' externals/catch2/CMake/CatchMiscFunctions.cmake \ + externals/dynarmic/externals/catch/CMake/CatchMiscFunctions.cmake || die + sed -i -e '/-Werror/d' src/CMakeLists.txt externals/dynarmic/externals/mcl/CMakeLists.txt externals/dynarmic/externals/catch/CMake/CatchMiscFunctions.cmake externals/catch2/CMake/CatchMiscFunctions.cmake + cmake_src_prepare } src_configure() { local mycmakeargs=( -DBUILD_SHARED_LIBS=OFF + -DCOMPILE_WITH_DWARF=OFF -DENABLE_CUBEB=$(usex cubeb) - -DENABLE_FFMPEG_AUDIO_DECODER=$(usex hle-sound) - -DENABLE_FFMPEG_VIDEO_DUMPER=$(usex video) - -DENABLE_QT=$(usex qt5) - -DENABLE_QT_TRANSLATION=$(use qt5 && usex nls || echo OFF) + -DENABLE_MF=ON + -DENABLE_OPENAL=$(usex openal) + -DENABLE_QT=$(usex gui) + -DENABLE_QT_TRANSLATION=$(use gui && usex nls || echo OFF) -DENABLE_SDL2=$(usex sdl) -DENABLE_WEB_SERVICE=$(usex telemetry) - -DGENERATE_QT_TRANSLATION=$(use qt5 && usex nls || echo OFF) + -DGENERATE_QT_TRANSLATION=$(use gui && usex nls || echo OFF) + -DSIRIT_USE_SYSTEM_SPIRV_HEADERS=ON -DUSE_SYSTEM_BOOST=ON + -DUSE_SYSTEM_LIBUSB=ON + -DUSE_SYSTEM_OPENSSL=ON -DUSE_SYSTEM_SDL2=ON ) cmake_src_configure diff --git a/games-emulation/citra/metadata.xml b/games-emulation/citra/metadata.xml index b1b0ebcf7..50f72750d 100644 --- a/games-emulation/citra/metadata.xml +++ b/games-emulation/citra/metadata.xml @@ -7,9 +7,7 @@ </maintainer> <use> <flag name="cubeb">Enables the cubeb audio backend</flag> - <flag name="hle-sound">Enable HLE sound via FFmpeg audio (AAC) decoder</flag> <flag name="system-libfmt">Use system libfmt</flag> <flag name="telemetry">Enable web services (telemetry, etc.)</flag> - <flag name="video">Enable FFmpeg video dumper</flag> </use> </pkgmetadata> |