Skip to content

Commit

Permalink
Merge pull request #36237 from DarkScythe97/retroarch
Browse files Browse the repository at this point in the history
retroarch: 1.6.0 -> 1.7.1
  • Loading branch information
LnL7 committed Mar 4, 2018
2 parents 691307e + 6a92260 commit 95eb92a
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 37 deletions.
63 changes: 27 additions & 36 deletions pkgs/misc/emulators/retroarch/default.nix
@@ -1,61 +1,52 @@
{ stdenv, fetchFromGitHub, makeDesktopItem, coreutils, which, pkgconfig
{ stdenv, fetchFromGitHub, which, pkgconfig, makeWrapper
, ffmpeg, mesa, freetype, libxml2, python34
, libobjc, AppKit, Foundation
, alsaLib ? null
, libpulseaudio ? null
, libv4l ? null
, libX11 ? null
, libXdmcp ? null
, libXext ? null
, libXxf86vm ? null
, SDL2 ? null
, udev ? null
, enableNvidiaCgToolkit ? false, nvidia_cg_toolkit ? null
, alsaLib ? null, libv4l ? null
, udev ? null, libX11 ? null, libXext ? null, libXxf86vm ? null
, libXdmcp ? null, SDL ? null, libpulseaudio ? null
, withVulkan ? stdenv.isLinux, vulkan-loader ? null
}:

with stdenv.lib;

let
desktopItem = makeDesktopItem {
name = "retroarch";
exec = "retroarch";
icon = "retroarch";
comment = "Multi-Engine Platform";
desktopName = "RetroArch";
genericName = "Libretro Frontend";
categories = "Game;Emulator;";
#keywords = "multi;engine;emulator;xmb;";
};
in

stdenv.mkDerivation rec {
name = "retroarch-bare-${version}";
version = "1.6.0";
version = "1.7.1";

src = fetchFromGitHub {
owner = "libretro";
repo = "RetroArch";
sha256 = "1ym2kws58fbavkc3giz5xqaqiqqdbf7wrz7y7iw53p1bnkc3l8yi";
sha256 = "0qv8ci76f5kwv5b49ijgpc6jdfp6sm21fw5hq06mq6ygyiy9vdzf";
rev = "v${version}";
};

nativeBuildInputs = [ pkgconfig ];
buildInputs = [ ffmpeg mesa freetype libxml2 coreutils python34 which SDL ]
++ optional enableNvidiaCgToolkit nvidia_cg_toolkit
++ optionals stdenv.isLinux [ udev alsaLib libX11 libXext libXxf86vm libXdmcp libv4l libpulseaudio ];

configureScript = "sh configure";
nativeBuildInputs = [ pkgconfig ]
++ optional withVulkan [ makeWrapper ];

patchPhase = ''
export GLOBAL_CONFIG_DIR=$out/etc
sed -e 's#/bin/true#${coreutils}/bin/true#' -i qb/qb.libs.sh
'';
buildInputs = [ ffmpeg freetype libxml2 mesa python34 SDL2 which ]
++ optional enableNvidiaCgToolkit nvidia_cg_toolkit
++ optional withVulkan [ vulkan-loader ]
++ optionals stdenv.isDarwin [ libobjc AppKit Foundation ]
++ optionals stdenv.isLinux [ alsaLib libpulseaudio libv4l libX11
libXdmcp libXext libXxf86vm udev ];

postInstall = ''
mkdir -p $out/share/icons/hicolor/scalable/apps
cp -p -T ./media/retroarch.svg $out/share/icons/hicolor/scalable/apps/retroarch.svg
enableParallelBuilding = true;

mkdir -p "$out/share/applications"
cp ${desktopItem}/share/applications/* $out/share/applications
postInstall = optional withVulkan ''
wrapProgram $out/bin/retroarch --prefix LD_LIBRARY_PATH ':' ${vulkan-loader}/lib
'';

enableParallelBuilding = true;
preFixup = "rm $out/bin/retroarch-cg2glsl";

meta = {
homepage = http://libretro.org/;
homepage = https://libretro.com;
description = "Multi-platform emulator frontend for libretro cores";
license = licenses.gpl3;
platforms = platforms.all;
Expand Down
5 changes: 4 additions & 1 deletion pkgs/top-level/all-packages.nix
Expand Up @@ -20367,7 +20367,10 @@ with pkgs;

redprl = callPackage ../applications/science/logic/redprl { };

retroarchBare = callPackage ../misc/emulators/retroarch { };
retroarchBare = callPackage ../misc/emulators/retroarch {
inherit (darwin) libobjc;
inherit (darwin.apple_sdk.frameworks) AppKit Foundation;
};

retroarch = wrapRetroArch { retroarch = retroarchBare; };

Expand Down

0 comments on commit 95eb92a

Please sign in to comment.