Merge pull request #137447 from mikroskeem/eduke32-macos

This commit is contained in:
Sandro 2021-09-12 15:58:08 +02:00 committed by GitHub
commit 4a56ed7a78
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 43 additions and 12 deletions

View File

@ -1,6 +1,8 @@
{ lib, stdenv, fetchurl, makeWrapper, pkg-config, nasm, makeDesktopItem
, alsa-lib, flac, gtk2, libvorbis, libvpx, libGLU, libGL
, SDL2, SDL2_mixer }:
, SDL2, SDL2_mixer
, AGL, Cocoa, GLUT, OpenGL
}:
let
desktopItem = makeDesktopItem {
@ -16,21 +18,37 @@ let
in stdenv.mkDerivation rec {
pname = "eduke32";
version = "20210722";
rev = "9484";
revExtra = "f3fea8c15";
version = "20210910";
rev = "9603";
revExtra = "6c289cce4";
src = fetchurl {
url = "http://dukeworld.duke4.net/eduke32/synthesis/${version}-${rev}-${revExtra}/eduke32_src_${version}-${rev}-${revExtra}.tar.xz";
sha256 = "0fdl2i465cl5x7129772ksx97lvim98m9009q5cfmf6scagj9pvz";
url = "https://dukeworld.com/eduke32/synthesis/${version}-${rev}-${revExtra}/eduke32_src_${version}-${rev}-${revExtra}.tar.xz";
sha256 = "sha256-/NQMsmT9z2N3KWBrP8hlGngQKJUgSP+vrNoFqJscRCk=";
};
buildInputs = [ alsa-lib flac gtk2 libvorbis libvpx libGL libGLU SDL2 SDL2_mixer ];
buildInputs = [
flac
libvorbis
libvpx
SDL2
SDL2_mixer
] ++ lib.optionals stdenv.isLinux [
alsa-lib
gtk2
libGL
libGLU
] ++ lib.optionals stdenv.isDarwin [
AGL
Cocoa
GLUT
OpenGL
];
nativeBuildInputs = [ makeWrapper pkg-config ]
++ lib.optional (stdenv.hostPlatform.system == "i686-linux") nasm;
postPatch = ''
postPatch = lib.optionalString stdenv.isLinux ''
substituteInPlace source/build/src/glbuild.cpp \
--replace libGLU.so ${libGLU}/lib/libGLU.so
@ -44,6 +62,9 @@ in stdenv.mkDerivation rec {
makeFlags = [
"SDLCONFIG=${SDL2}/bin/sdl2-config"
] ++ lib.optionals stdenv.isDarwin [
# broken, see: https://github.com/NixOS/nixpkgs/issues/19098
"LTO=0"
];
enableParallelBuilding = true;
@ -52,7 +73,7 @@ in stdenv.mkDerivation rec {
runHook preInstall
install -Dm755 -t $out/bin eduke32 mapster32
'' + lib.optionalString stdenv.isLinux ''
makeWrapper $out/bin/eduke32 $out/bin/${wrapper} \
--set-default EDUKE32_DATA_DIR /var/lib/games/eduke32 \
--add-flags '-g "$EDUKE32_DATA_DIR/DUKE3D.GRP"'
@ -60,7 +81,16 @@ in stdenv.mkDerivation rec {
cp -rv ${desktopItem}/share $out
substituteInPlace $out/share/applications/eduke32.desktop \
--subst-var out
'' + lib.optionalString stdenv.isDarwin ''
mkdir -p $out/Applications/EDuke32.app/Contents/MacOS
mkdir -p $out/Applications/Mapster32.app/Contents/MacOS
cp -r platform/Apple/bundles/EDuke32.app/* $out/Applications/EDuke32.app/
cp -r platform/Apple/bundles/Mapster32.app/* $out/Applications/Mapster32.app/
ln -sf $out/bin/eduke32 $out/Applications/EDuke32.app/Contents/MacOS/eduke32
ln -sf $out/bin/mapster32 $out/Applications/Mapster32.app/Contents/MacOS/mapster32
'' + ''
runHook postInstall
'';
@ -68,8 +98,7 @@ in stdenv.mkDerivation rec {
description = "Enhanched port of Duke Nukem 3D for various platforms";
homepage = "http://eduke32.com";
license = licenses.gpl2Plus;
maintainers = with maintainers; [ sander ];
# Darwin is untested (supported by upstream)
maintainers = with maintainers; [ mikroskeem sander ];
platforms = platforms.all;
};
}

View File

@ -29494,7 +29494,9 @@ with pkgs;
ecwolf = callPackage ../games/ecwolf { };
eduke32 = callPackage ../games/eduke32 { };
eduke32 = callPackage ../games/eduke32 {
inherit (darwin.apple_sdk.frameworks) AGL Cocoa GLUT OpenGL;
};
egoboo = callPackage ../games/egoboo { };