citra: remove package
This commit is contained in:
parent
ef72e8b3a9
commit
9b90f685e5
@ -1,45 +0,0 @@
|
|||||||
{ branch
|
|
||||||
, qt6Packages
|
|
||||||
, fetchFromGitHub
|
|
||||||
, fetchurl
|
|
||||||
}:
|
|
||||||
|
|
||||||
let
|
|
||||||
# Fetched from https://api.citra-emu.org/gamedb
|
|
||||||
# Please make sure to update this when updating citra!
|
|
||||||
compat-list = fetchurl {
|
|
||||||
name = "citra-compat-list";
|
|
||||||
url = "https://web.archive.org/web/20231111133415/https://api.citra-emu.org/gamedb";
|
|
||||||
hash = "sha256-J+zqtWde5NgK2QROvGewtXGRAWUTNSKHNMG6iu9m1fU=";
|
|
||||||
};
|
|
||||||
in {
|
|
||||||
nightly = qt6Packages.callPackage ./generic.nix rec {
|
|
||||||
pname = "citra-nightly";
|
|
||||||
version = "2088";
|
|
||||||
|
|
||||||
src = fetchFromGitHub {
|
|
||||||
owner = "citra-emu";
|
|
||||||
repo = "citra-nightly";
|
|
||||||
rev = "nightly-${version}";
|
|
||||||
sha256 = "0l9w4i0zbafcv2s6pd1zqb11vh0i7gzwbqnzlz9al6ihwbsgbj3k";
|
|
||||||
fetchSubmodules = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
inherit branch compat-list;
|
|
||||||
};
|
|
||||||
|
|
||||||
canary = qt6Packages.callPackage ./generic.nix rec {
|
|
||||||
pname = "citra-canary";
|
|
||||||
version = "2766";
|
|
||||||
|
|
||||||
src = fetchFromGitHub {
|
|
||||||
owner = "citra-emu";
|
|
||||||
repo = "citra-canary";
|
|
||||||
rev = "canary-${version}";
|
|
||||||
sha256 = "1gm3ajphpzwhm3qnchsx77jyl51za8yw3r0j0h8idf9y1ilcjvi4";
|
|
||||||
fetchSubmodules = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
inherit branch compat-list;
|
|
||||||
};
|
|
||||||
}.${branch}
|
|
@ -1,149 +0,0 @@
|
|||||||
{ pname
|
|
||||||
, version
|
|
||||||
, src
|
|
||||||
, branch
|
|
||||||
, compat-list
|
|
||||||
|
|
||||||
, lib
|
|
||||||
, stdenv
|
|
||||||
, cmake
|
|
||||||
, boost
|
|
||||||
, pkg-config
|
|
||||||
, catch2_3
|
|
||||||
, cpp-jwt
|
|
||||||
, cryptopp
|
|
||||||
, enet
|
|
||||||
, ffmpeg
|
|
||||||
, fmt
|
|
||||||
, gamemode
|
|
||||||
, glslang
|
|
||||||
, httplib
|
|
||||||
, inih
|
|
||||||
, libusb1
|
|
||||||
, nlohmann_json
|
|
||||||
, openal
|
|
||||||
, openssl
|
|
||||||
, SDL2
|
|
||||||
, soundtouch
|
|
||||||
, spirv-tools
|
|
||||||
, zstd
|
|
||||||
, vulkan-headers
|
|
||||||
, vulkan-loader
|
|
||||||
, enableSdl2Frontend ? true
|
|
||||||
, enableQt ? true, qtbase, qtmultimedia, qtwayland, wrapQtAppsHook
|
|
||||||
, enableQtTranslation ? enableQt, qttools
|
|
||||||
, enableWebService ? true
|
|
||||||
, enableCubeb ? true, cubeb
|
|
||||||
, useDiscordRichPresence ? false, rapidjson
|
|
||||||
}:
|
|
||||||
stdenv.mkDerivation {
|
|
||||||
inherit pname version src;
|
|
||||||
|
|
||||||
nativeBuildInputs = [
|
|
||||||
cmake
|
|
||||||
pkg-config
|
|
||||||
ffmpeg
|
|
||||||
glslang
|
|
||||||
] ++ lib.optionals enableQt [ wrapQtAppsHook ];
|
|
||||||
|
|
||||||
buildInputs = [
|
|
||||||
boost
|
|
||||||
catch2_3
|
|
||||||
cpp-jwt
|
|
||||||
cryptopp
|
|
||||||
# intentionally omitted: dynarmic - prefer vendored version for compatibility
|
|
||||||
enet
|
|
||||||
fmt
|
|
||||||
httplib
|
|
||||||
inih
|
|
||||||
libusb1
|
|
||||||
nlohmann_json
|
|
||||||
openal
|
|
||||||
openssl
|
|
||||||
SDL2
|
|
||||||
soundtouch
|
|
||||||
spirv-tools
|
|
||||||
vulkan-headers
|
|
||||||
# intentionally omitted: xbyak - prefer vendored version for compatibility
|
|
||||||
zstd
|
|
||||||
] ++ lib.optionals enableQt [ qtbase qtmultimedia qtwayland ]
|
|
||||||
++ lib.optional enableQtTranslation qttools
|
|
||||||
++ lib.optional enableCubeb cubeb
|
|
||||||
++ lib.optional useDiscordRichPresence rapidjson;
|
|
||||||
|
|
||||||
cmakeFlags = [
|
|
||||||
(lib.cmakeBool "USE_SYSTEM_LIBS" true)
|
|
||||||
|
|
||||||
(lib.cmakeBool "DISABLE_SYSTEM_DYNARMIC" true)
|
|
||||||
(lib.cmakeBool "DISABLE_SYSTEM_GLSLANG" true) # The following imported targets are referenced, but are missing: SPIRV-Tools-opt
|
|
||||||
(lib.cmakeBool "DISABLE_SYSTEM_LODEPNG" true) # Not packaged in nixpkgs
|
|
||||||
(lib.cmakeBool "DISABLE_SYSTEM_VMA" true)
|
|
||||||
(lib.cmakeBool "DISABLE_SYSTEM_XBYAK" true)
|
|
||||||
|
|
||||||
# We don't want to bother upstream with potentially outdated compat reports
|
|
||||||
(lib.cmakeBool "CITRA_ENABLE_COMPATIBILITY_REPORTING" true)
|
|
||||||
(lib.cmakeBool "ENABLE_COMPATIBILITY_LIST_DOWNLOAD" false) # We provide this deterministically
|
|
||||||
|
|
||||||
(lib.cmakeBool "ENABLE_SDL2_FRONTEND" enableSdl2Frontend)
|
|
||||||
(lib.cmakeBool "ENABLE_QT" enableQt)
|
|
||||||
(lib.cmakeBool "ENABLE_QT_TRANSLATION" enableQtTranslation)
|
|
||||||
(lib.cmakeBool "ENABLE_WEB_SERVICE" enableWebService)
|
|
||||||
(lib.cmakeBool "ENABLE_CUBEB" enableCubeb)
|
|
||||||
(lib.cmakeBool "USE_DISCORD_PRESENCE" useDiscordRichPresence)
|
|
||||||
];
|
|
||||||
|
|
||||||
# causes redefinition of _FORTIFY_SOURCE
|
|
||||||
hardeningDisable = [ "fortify3" ];
|
|
||||||
|
|
||||||
postPatch = let
|
|
||||||
branchCaptialized = (lib.toUpper (lib.substring 0 1 branch) + lib.substring 1 (-1) branch);
|
|
||||||
in ''
|
|
||||||
# Fix file not found when looking in var/empty instead of opt
|
|
||||||
mkdir externals/dynarmic/src/dynarmic/ir/var
|
|
||||||
ln -s ../opt externals/dynarmic/src/dynarmic/ir/var/empty
|
|
||||||
|
|
||||||
# Prep compatibilitylist
|
|
||||||
ln -s ${compat-list} ./dist/compatibility_list/compatibility_list.json
|
|
||||||
|
|
||||||
# We already know the submodules are present
|
|
||||||
substituteInPlace CMakeLists.txt \
|
|
||||||
--replace "check_submodules_present()" ""
|
|
||||||
|
|
||||||
# Add versions
|
|
||||||
echo 'set(BUILD_FULLNAME "${branchCaptialized} ${version}")' >> CMakeModules/GenerateBuildInfo.cmake
|
|
||||||
|
|
||||||
# Add gamemode
|
|
||||||
substituteInPlace externals/gamemode/include/gamemode_client.h --replace "libgamemode.so.0" "${lib.getLib gamemode}/lib/libgamemode.so.0"
|
|
||||||
'';
|
|
||||||
|
|
||||||
postInstall = let
|
|
||||||
libs = lib.makeLibraryPath [ vulkan-loader ];
|
|
||||||
in lib.optionalString enableSdl2Frontend ''
|
|
||||||
wrapProgram "$out/bin/citra" \
|
|
||||||
--prefix LD_LIBRARY_PATH : ${libs}
|
|
||||||
'' + lib.optionalString enableQt ''
|
|
||||||
qtWrapperArgs+=(
|
|
||||||
--prefix LD_LIBRARY_PATH : ${libs}
|
|
||||||
)
|
|
||||||
'';
|
|
||||||
|
|
||||||
meta = with lib; {
|
|
||||||
broken = (stdenv.isLinux && stdenv.isAarch64);
|
|
||||||
homepage = "https://citra-emu.org";
|
|
||||||
description = "The ${branch} branch of an open-source emulator for the Nintendo 3DS";
|
|
||||||
longDescription = ''
|
|
||||||
A Nintendo 3DS Emulator written in C++
|
|
||||||
Using the nightly branch is recommended for general usage.
|
|
||||||
Using the canary branch is recommended if you would like to try out
|
|
||||||
experimental features, with a cost of stability.
|
|
||||||
'';
|
|
||||||
mainProgram = if enableQt then "citra-qt" else "citra";
|
|
||||||
platforms = platforms.linux;
|
|
||||||
license = licenses.gpl2Plus;
|
|
||||||
maintainers = with maintainers; [
|
|
||||||
abbradar
|
|
||||||
ashley
|
|
||||||
ivar
|
|
||||||
];
|
|
||||||
};
|
|
||||||
}
|
|
@ -1,84 +0,0 @@
|
|||||||
#! /usr/bin/env nix-shell
|
|
||||||
#! nix-shell -i bash -p nix nix-prefetch-git coreutils curl jq gnused
|
|
||||||
|
|
||||||
set -euo pipefail
|
|
||||||
|
|
||||||
# Will be replaced with the actual branch when running this from passthru.updateScript
|
|
||||||
BRANCH="@branch@"
|
|
||||||
|
|
||||||
if [[ ! "$(basename $PWD)" = "citra" ]]; then
|
|
||||||
echo "error: Script must be ran from citra's directory!"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
getLocalVersion() {
|
|
||||||
pushd ../../../.. >/dev/null
|
|
||||||
nix eval --raw -f default.nix "$1".version
|
|
||||||
popd >/dev/null
|
|
||||||
}
|
|
||||||
|
|
||||||
getLocalHash() {
|
|
||||||
pushd ../../../.. >/dev/null
|
|
||||||
nix eval --raw -f default.nix "$1".src.drvAttrs.outputHash
|
|
||||||
popd >/dev/null
|
|
||||||
}
|
|
||||||
|
|
||||||
updateNightly() {
|
|
||||||
OLD_NIGHTLY_VERSION="$(getLocalVersion "citra-nightly")"
|
|
||||||
OLD_NIGHTLY_HASH="$(getLocalHash "citra-nightly")"
|
|
||||||
|
|
||||||
NEW_NIGHTLY_VERSION="$(curl -s ${GITHUB_TOKEN:+-u ":$GITHUB_TOKEN"} \
|
|
||||||
"https://api.github.com/repos/citra-emu/citra-nightly/releases?per_page=1" | jq -r '.[0].name' | cut -d"-" -f2 | cut -d" " -f2)"
|
|
||||||
|
|
||||||
if [[ "${OLD_NIGHTLY_VERSION}" = "${NEW_NIGHTLY_VERSION}" ]]; then
|
|
||||||
echo "citra-nightly is already up to date!"
|
|
||||||
|
|
||||||
[ "$KEEP_GOING" ] && return || exit
|
|
||||||
else
|
|
||||||
echo "citra-nightly: ${OLD_NIGHTLY_VERSION} -> ${NEW_NIGHTLY_VERSION}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo " Fetching source code..."
|
|
||||||
|
|
||||||
NEW_NIGHTLY_HASH="$(nix-prefetch-git --quiet --fetch-submodules --rev "nightly-${NEW_NIGHTLY_VERSION}" "https://github.com/citra-emu/citra-nightly" | jq -r '.sha256')"
|
|
||||||
|
|
||||||
echo " Successfully fetched. hash: ${NEW_NIGHTLY_HASH}"
|
|
||||||
|
|
||||||
sed -i "s|${OLD_NIGHTLY_VERSION}|${NEW_NIGHTLY_VERSION}|" ./default.nix
|
|
||||||
sed -i "s|${OLD_NIGHTLY_HASH}|${NEW_NIGHTLY_HASH}|" ./default.nix
|
|
||||||
}
|
|
||||||
|
|
||||||
updateCanary() {
|
|
||||||
OLD_CANARY_VERSION="$(getLocalVersion "citra-canary")"
|
|
||||||
OLD_CANARY_HASH="$(getLocalHash "citra-canary")"
|
|
||||||
|
|
||||||
NEW_CANARY_VERSION="$(curl -s ${GITHUB_TOKEN:+-u ":$GITHUB_TOKEN"} \
|
|
||||||
"https://api.github.com/repos/citra-emu/citra-canary/releases?per_page=1" | jq -r '.[0].name' | cut -d"-" -f2 | cut -d" " -f1)"
|
|
||||||
|
|
||||||
if [[ "${OLD_CANARY_VERSION}" = "${NEW_CANARY_VERSION}" ]]; then
|
|
||||||
echo "citra-canary is already up to date!"
|
|
||||||
|
|
||||||
[ "$KEEP_GOING" ] && return || exit
|
|
||||||
else
|
|
||||||
echo "citra-canary: ${OLD_CANARY_VERSION} -> ${NEW_CANARY_VERSION}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo " Fetching source code..."
|
|
||||||
|
|
||||||
NEW_CANARY_HASH="$(nix-prefetch-git --quiet --fetch-submodules --rev "canary-${NEW_CANARY_VERSION}" "https://github.com/citra-emu/citra-canary" | jq -r '.sha256')"
|
|
||||||
|
|
||||||
echo " Successfully fetched. hash: ${NEW_CANARY_HASH}"
|
|
||||||
|
|
||||||
sed -i "s|${OLD_CANARY_VERSION}|${NEW_CANARY_VERSION}|" ./default.nix
|
|
||||||
sed -i "s|${OLD_CANARY_HASH}|${NEW_CANARY_HASH}|" ./default.nix
|
|
||||||
}
|
|
||||||
|
|
||||||
if [[ "$BRANCH" = "nightly" ]]; then
|
|
||||||
updateNightly
|
|
||||||
elif [[ "$BRANCH" = "early-access" ]]; then
|
|
||||||
updateCanary
|
|
||||||
else
|
|
||||||
KEEP_GOING=1
|
|
||||||
updateNightly
|
|
||||||
updateCanary
|
|
||||||
fi
|
|
@ -161,7 +161,9 @@ mapAliases ({
|
|||||||
chrome-gnome-shell = gnome-browser-connector; # Added 2022-07-27
|
chrome-gnome-shell = gnome-browser-connector; # Added 2022-07-27
|
||||||
chromiumBeta = throw "'chromiumBeta' has been removed due to the lack of maintenance in nixpkgs. Consider using 'chromium' instead."; # Added 2023-10-18
|
chromiumBeta = throw "'chromiumBeta' has been removed due to the lack of maintenance in nixpkgs. Consider using 'chromium' instead."; # Added 2023-10-18
|
||||||
chromiumDev = throw "'chromiumDev' has been removed due to the lack of maintenance in nixpkgs. Consider using 'chromium' instead."; # Added 2023-10-18
|
chromiumDev = throw "'chromiumDev' has been removed due to the lack of maintenance in nixpkgs. Consider using 'chromium' instead."; # Added 2023-10-18
|
||||||
citra = citra-nightly; # added 2022-05-17
|
citra = throw "citra has been removed from nixpkgs, as it has been taken down upstream"; # added 2024-03-04
|
||||||
|
citra-nightly = throw "citra-nightly has been removed from nixpkgs, as it has been taken down upstream"; # added 2024-03-04
|
||||||
|
citra-canary = throw "citra-canary has been removed from nixpkgs, as it has been taken down upstream"; # added 2024-03-04
|
||||||
clang-ocl = throw "'clang-ocl' has been replaced with 'rocmPackages.clang-ocl'"; # Added 2023-10-08
|
clang-ocl = throw "'clang-ocl' has been replaced with 'rocmPackages.clang-ocl'"; # Added 2023-10-08
|
||||||
inherit (libsForQt5.mauiPackages) clip; # added 2022-05-17
|
inherit (libsForQt5.mauiPackages) clip; # added 2022-05-17
|
||||||
collada-dom = opencollada; # added 2024-02-21
|
collada-dom = opencollada; # added 2024-02-21
|
||||||
@ -1220,11 +1222,11 @@ mapAliases ({
|
|||||||
yafaray-core = libyafaray; # Added 2022-09-23
|
yafaray-core = libyafaray; # Added 2022-09-23
|
||||||
yarn2nix-moretea-openssl_1_1 = throw "'yarn2nix-moretea-openssl_1_1' has been removed."; # Added 2023-02-04
|
yarn2nix-moretea-openssl_1_1 = throw "'yarn2nix-moretea-openssl_1_1' has been removed."; # Added 2023-02-04
|
||||||
yubikey-manager4 = throw "yubikey-manager4 has been removed, since it is no longer required by yubikey-manager-qt. Please update to yubikey-manager."; # Added 2024-01-14
|
yubikey-manager4 = throw "yubikey-manager4 has been removed, since it is no longer required by yubikey-manager-qt. Please update to yubikey-manager."; # Added 2024-01-14
|
||||||
yuzu-ea = throw "yuzu-ea has been removed from nixpkgs, as it has been deleted upstream"; # Added 2024-03-04
|
yuzu-ea = throw "yuzu-ea has been removed from nixpkgs, as it has been taken down upstream"; # Added 2024-03-04
|
||||||
yuzu-early-access = throw "yuzu-early-access has been removed from nixpkgs, as it has been deleted upstream"; # Added 2024-03-04
|
yuzu-early-access = throw "yuzu-early-access has been removed from nixpkgs, as it has been taken down upstream"; # Added 2024-03-04
|
||||||
yuzu = throw "yuzu has been removed from nixpkgs, as it has been deleted upstream"; # Added 2024-03-04
|
yuzu = throw "yuzu has been removed from nixpkgs, as it has been taken down upstream"; # Added 2024-03-04
|
||||||
yuzu-mainline = throw "yuzu-mainline has been removed from nixpkgs, as it has been deleted upstream"; # Added 2024-03-04
|
yuzu-mainline = throw "yuzu-mainline has been removed from nixpkgs, as it has been taken down upstream"; # Added 2024-03-04
|
||||||
yuzuPackages = throw "yuzuPackages has been removed from nixpkgs, as it has been deleted upstream"; # Added 2024-03-04
|
yuzuPackages = throw "yuzuPackages has been removed from nixpkgs, as it has been taken down upstream"; # Added 2024-03-04
|
||||||
|
|
||||||
### Z ###
|
### Z ###
|
||||||
|
|
||||||
|
@ -2648,14 +2648,6 @@ with pkgs;
|
|||||||
|
|
||||||
webfontkitgenerator = callPackage ../applications/misc/webfontkitgenerator { };
|
webfontkitgenerator = callPackage ../applications/misc/webfontkitgenerator { };
|
||||||
|
|
||||||
citra-canary = callPackage ../applications/emulators/citra {
|
|
||||||
branch = "canary";
|
|
||||||
};
|
|
||||||
|
|
||||||
citra-nightly = callPackage ../applications/emulators/citra {
|
|
||||||
branch = "nightly";
|
|
||||||
};
|
|
||||||
|
|
||||||
collapseos-cvm = callPackage ../applications/emulators/collapseos-cvm { };
|
collapseos-cvm = callPackage ../applications/emulators/collapseos-cvm { };
|
||||||
|
|
||||||
coltrane = callPackage ../applications/misc/coltrane { };
|
coltrane = callPackage ../applications/misc/coltrane { };
|
||||||
|
Loading…
Reference in New Issue
Block a user