SDL, SDL2: cleanup and cross-pollinate with useful changes to either expression

This commit is contained in:
Jan Malakhovski 2018-03-05 17:30:34 +00:00
parent d3c3364bfa
commit 6166027ca8
2 changed files with 70 additions and 52 deletions

View File

@ -1,4 +1,4 @@
{ stdenv, fetchurl, fetchpatch, pkgconfig, audiofile, libcap, libiconv { stdenv, lib, fetchurl, fetchpatch, pkgconfig, audiofile, libcap, libiconv
, openglSupport ? false, libGL, libGLU , openglSupport ? false, libGL, libGLU
, alsaSupport ? true, alsaLib , alsaSupport ? true, alsaLib
, x11Support ? hostPlatform == buildPlatform, libXext, libICE, libXrandr , x11Support ? hostPlatform == buildPlatform, libXext, libICE, libXrandr
@ -7,13 +7,32 @@
, hostPlatform, buildPlatform , hostPlatform, buildPlatform
}: }:
# OSS is no longer supported, for it's much crappier than ALSA and # NOTE: When editing this expression see if the same change applies to
# PulseAudio. # SDL2 expression too
assert hostPlatform.isLinux -> alsaSupport || pulseaudioSupport;
with lib;
assert !stdenv.isDarwin -> alsaSupport || pulseaudioSupport;
assert openglSupport -> (stdenv.isDarwin || x11Support && libGL != null && libGLU != null);
let let
inherit (stdenv.lib) optional optionals;
# XXX: By default, SDL wants to dlopen() PulseAudio, in which case
# we must arrange to add it to its RPATH; however, `patchelf' seems
# to fail at doing this, hence `--disable-pulseaudio-shared'.
configureFlagsFun = attrs: [
"--disable-oss"
"--disable-video-x11-xme"
"--disable-x11-shared"
"--disable-alsa-shared"
"--enable-rpath"
"--disable-pulseaudio-shared"
"--disable-osmesa-shared"
] ++ optional (!x11Support) "--without-x"
++ optional alsaSupport "--with-alsa-prefix=${attrs.alsaLib.out}/lib";
in in
stdenv.mkDerivation rec { stdenv.mkDerivation rec {
name = "SDL-${version}"; name = "SDL-${version}";
version = "1.2.15"; version = "1.2.15";
@ -29,35 +48,27 @@ stdenv.mkDerivation rec {
nativeBuildInputs = [ pkgconfig ]; nativeBuildInputs = [ pkgconfig ];
# Since `libpulse*.la' contain `-lgdbm', PulseAudio must be propagated. # Since `libpulse*.la' contain `-lgdbm', PulseAudio must be propagated.
propagatedBuildInputs = propagatedBuildInputs = [ ]
optionals x11Support [ libXext libICE libXrandr ] ++ ++ optionals x11Support [ libXext libICE libXrandr ]
optional alsaSupport alsaLib ++ ++ optional stdenv.isLinux libcap
optional stdenv.isLinux libcap ++ ++ optionals openglSupport [ libGL libGLU ]
optionals openglSupport [ libGL libGLU ] ++ ++ optional alsaSupport alsaLib
optional pulseaudioSupport libpulseaudio ++ ++ optional pulseaudioSupport libpulseaudio
optional stdenv.isDarwin Cocoa; ++ optional stdenv.isDarwin Cocoa;
buildInputs = let buildInputs = [ libiconv ]
notMingw = !hostPlatform.isMinGW; ++ optional (!hostPlatform.isMinGW) audiofile
in optional notMingw audiofile ++ optionals stdenv.isDarwin [ AudioUnit CoreAudio CoreServices Kernel OpenGL ];
++ optionals stdenv.isDarwin [ OpenGL CoreAudio CoreServices AudioUnit Kernel ]
++ [ libiconv ];
# XXX: By default, SDL wants to dlopen() PulseAudio, in which case configureFlags = configureFlagsFun { inherit alsaLib; };
# we must arrange to add it to its RPATH; however, `patchelf' seems
# to fail at doing this, hence `--disable-pulseaudio-shared'. crossAttrs = {
configureFlags = [ configureFlags = configureFlagsFun { alsaLib = alsaLib.crossDrv; };
"--disable-oss" };
"--disable-video-x11-xme"
"--disable-x11-shared"
"--disable-alsa-shared"
"--enable-rpath"
"--disable-pulseaudio-shared"
"--disable-osmesa-shared"
] ++ optional (!x11Support) "--without-x"
++ optional (alsaSupport && hostPlatform != buildPlatform) "--with-alsa-prefix=${alsaLib.out}/lib";
patches = [ patches = [
./find-headers.patch
# Fix window resizing issues, e.g. for xmonad # Fix window resizing issues, e.g. for xmonad
# Ticket: http://bugzilla.libsdl.org/show_bug.cgi?id=1430 # Ticket: http://bugzilla.libsdl.org/show_bug.cgi?id=1430
(fetchpatch { (fetchpatch {
@ -97,10 +108,11 @@ stdenv.mkDerivation rec {
url = "http://hg.libsdl.org/SDL/raw-rev/bbfb41c13a87"; url = "http://hg.libsdl.org/SDL/raw-rev/bbfb41c13a87";
sha256 = "1336g7waaf1c8yhkz11xbs500h8bmvabh4h437ax8l1xdwcppfxv"; sha256 = "1336g7waaf1c8yhkz11xbs500h8bmvabh4h437ax8l1xdwcppfxv";
}) })
./find-headers.patch
]; ];
postFixup = ''moveToOutput share/aclocal "$dev" ''; postInstall = ''
moveToOutput share/aclocal "$dev"
'';
setupHook = ./setup-hook.sh; setupHook = ./setup-hook.sh;

View File

@ -11,19 +11,27 @@
, libiconv , libiconv
}: }:
# OSS is no longer supported, for it's much crappier than ALSA and # NOTE: When editing this expression see if the same change applies to
# PulseAudio. # SDL expression too
assert !stdenv.isDarwin -> alsaSupport || pulseaudioSupport;
assert openglSupport -> (stdenv.isDarwin || libGL != null && x11Support); with lib;
assert !stdenv.isDarwin -> alsaSupport || pulseaudioSupport;
assert openglSupport -> (stdenv.isDarwin || x11Support && libGL != null);
let let
# XXX: By default, SDL wants to dlopen() PulseAudio, in which case
# we must arrange to add it to its RPATH; however, `patchelf' seems
# to fail at doing this, hence `--disable-pulseaudio-shared'.
configureFlagsFun = attrs: [ configureFlagsFun = attrs: [
"--disable-oss" "--disable-x11-shared" "--disable-wayland-shared" "--disable-oss" "--disable-x11-shared" "--disable-wayland-shared"
"--disable-pulseaudio-shared" "--disable-alsa-shared" "--disable-pulseaudio-shared" "--disable-alsa-shared"
] ++ lib.optional alsaSupport "--with-alsa-prefix=${attrs.alsaLib.out}/lib" ] ++ optional alsaSupport "--with-alsa-prefix=${attrs.alsaLib.out}/lib"
++ lib.optional (!x11Support) "--without-x"; ++ optional (!x11Support) "--without-x";
in in
stdenv.mkDerivation rec { stdenv.mkDerivation rec {
name = "SDL2-${version}"; name = "SDL2-${version}";
version = "2.0.7"; version = "2.0.7";
@ -34,24 +42,25 @@ stdenv.mkDerivation rec {
}; };
outputs = [ "out" "dev" ]; outputs = [ "out" "dev" ];
outputBin = "dev"; # sdl-config
patches = [ ./find-headers.patch ]; patches = [ ./find-headers.patch ];
nativeBuildInputs = [ pkgconfig ]; nativeBuildInputs = [ pkgconfig ];
# Since `libpulse*.la' contain `-lgdbm', PulseAudio must be propagated. # Since `libpulse*.la' contain `-lgdbm', PulseAudio must be propagated.
propagatedBuildInputs = lib.optionals x11Support [ libICE libXi libXScrnSaver libXcursor libXinerama libXext libXrandr libXxf86vm ] ++ propagatedBuildInputs = [ libiconv ]
lib.optionals waylandSupport [ wayland wayland-protocols libxkbcommon ] ++ ++ optionals x11Support [ libICE libXi libXScrnSaver libXcursor libXinerama libXext libXrandr libXxf86vm ]
lib.optional pulseaudioSupport libpulseaudio ++ optionals waylandSupport [ wayland wayland-protocols libxkbcommon ]
++ [ libiconv ]; ++ optional pulseaudioSupport libpulseaudio;
buildInputs = [ audiofile ] ++ buildInputs = [ audiofile ]
lib.optional openglSupport libGL ++ ++ optional openglSupport libGL
lib.optional alsaSupport alsaLib ++ ++ optional alsaSupport alsaLib
lib.optional dbusSupport dbus ++ ++ optional dbusSupport dbus
lib.optional udevSupport udev ++ ++ optional udevSupport udev
lib.optional ibusSupport ibus ++ ++ optional ibusSupport ibus
lib.optionals stdenv.isDarwin [ AudioUnit Cocoa CoreAudio CoreServices ForceFeedback OpenGL ]; ++ optionals stdenv.isDarwin [ AudioUnit Cocoa CoreAudio CoreServices ForceFeedback OpenGL ];
# https://bugzilla.libsdl.org/show_bug.cgi?id=1431 # https://bugzilla.libsdl.org/show_bug.cgi?id=1431
dontDisableStatic = true; dontDisableStatic = true;
@ -60,9 +69,6 @@ stdenv.mkDerivation rec {
# pointer-constraints-unstable-v1-client-protocol.h: No such file or directory # pointer-constraints-unstable-v1-client-protocol.h: No such file or directory
enableParallelBuilding = false; enableParallelBuilding = false;
# XXX: By default, SDL wants to dlopen() PulseAudio, in which case
# we must arrange to add it to its RPATH; however, `patchelf' seems
# to fail at doing this, hence `--disable-pulseaudio-shared'.
configureFlags = configureFlagsFun { inherit alsaLib; }; configureFlags = configureFlagsFun { inherit alsaLib; };
crossAttrs = { crossAttrs = {