SDL: Refactor package and fix Darwin cross-builds.
First of all, this needs two upstream patches for supporting OS X 10.9, also the cross-gcc doesn't accept -fpascal-strings, so drop the flag. And except putting all configure flags into a multiline string, we're now using a list, which is easier when it comes to handling optional components. As X isn't used on recent Mac OS X versions and Windows, I'm temporarily using --without-x for cross-builds until we have a better way to check for those things. Also, don't add audiofile to buildInputs if we're cross-compiling for MinGW. Signed-off-by: aszlig <aszlig@redmoonstudios.org>
This commit is contained in:
parent
cdaced58ae
commit
6998a866a8
@ -7,21 +7,13 @@
|
|||||||
|
|
||||||
# OSS is no longer supported, for it's much crappier than ALSA and
|
# OSS is no longer supported, for it's much crappier than ALSA and
|
||||||
# PulseAudio.
|
# PulseAudio.
|
||||||
assert alsaSupport || pulseaudioSupport;
|
assert !(stdenv ? cross) -> alsaSupport || pulseaudioSupport;
|
||||||
|
|
||||||
assert openglSupport -> (mesa != null && x11Support);
|
assert openglSupport -> (mesa != null && x11Support);
|
||||||
assert x11Support -> (x11 != null && libXrandr != null);
|
assert x11Support -> (x11 != null && libXrandr != null);
|
||||||
assert alsaSupport -> alsaLib != null;
|
assert alsaSupport -> alsaLib != null;
|
||||||
assert pulseaudioSupport -> pulseaudio != null;
|
assert pulseaudioSupport -> pulseaudio != null;
|
||||||
|
|
||||||
let
|
|
||||||
configureFlagsFun = attrs: ''
|
|
||||||
--disable-oss --disable-video-x11-xme
|
|
||||||
--disable-x11-shared --disable-alsa-shared --enable-rpath --disable-pulseaudio-shared
|
|
||||||
--disable-osmesa-shared
|
|
||||||
${if alsaSupport then "--with-alsa-prefix=${attrs.alsaLib}/lib" else ""}
|
|
||||||
'';
|
|
||||||
in
|
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
version = "1.2.15";
|
version = "1.2.15";
|
||||||
name = "SDL-${version}";
|
name = "SDL-${version}";
|
||||||
@ -35,17 +27,42 @@ stdenv.mkDerivation rec {
|
|||||||
propagatedBuildInputs = stdenv.lib.optionals x11Support [ x11 libXrandr ] ++
|
propagatedBuildInputs = stdenv.lib.optionals x11Support [ x11 libXrandr ] ++
|
||||||
stdenv.lib.optional pulseaudioSupport pulseaudio;
|
stdenv.lib.optional pulseaudioSupport pulseaudio;
|
||||||
|
|
||||||
buildInputs = [ pkgconfig audiofile ] ++
|
buildInputs = let
|
||||||
|
notMingw = !(stdenv ? cross) || stdenv.cross.libc != "msvcrt";
|
||||||
|
in stdenv.lib.optional notMingw audiofile;
|
||||||
|
|
||||||
|
nativeBuildInputs = [ pkgconfig ] ++
|
||||||
stdenv.lib.optional openglSupport [ mesa ] ++
|
stdenv.lib.optional openglSupport [ mesa ] ++
|
||||||
stdenv.lib.optional alsaSupport alsaLib;
|
stdenv.lib.optional alsaSupport alsaLib;
|
||||||
|
|
||||||
# XXX: By default, SDL wants to dlopen() PulseAudio, in which case
|
# XXX: By default, SDL wants to dlopen() PulseAudio, in which case
|
||||||
# we must arrange to add it to its RPATH; however, `patchelf' seems
|
# we must arrange to add it to its RPATH; however, `patchelf' seems
|
||||||
# to fail at doing this, hence `--disable-pulseaudio-shared'.
|
# to fail at doing this, hence `--disable-pulseaudio-shared'.
|
||||||
configureFlags = configureFlagsFun { inherit alsaLib; };
|
configureFlags = [
|
||||||
|
"--disable-oss"
|
||||||
|
"--disable-video-x11-xme"
|
||||||
|
"--disable-x11-shared"
|
||||||
|
"--disable-alsa-shared"
|
||||||
|
"--enable-rpath"
|
||||||
|
"--disable-pulseaudio-shared"
|
||||||
|
"--disable-osmesa-shared"
|
||||||
|
] ++ stdenv.lib.optionals (stdenv ? cross) ([
|
||||||
|
"--without-x"
|
||||||
|
] ++ stdenv.lib.optional alsaSupport "--with-alsa-prefix=${alsaLib}/lib");
|
||||||
|
|
||||||
crossAttrs = {
|
crossAttrs =stdenv.lib.optionalAttrs (stdenv.cross.libc == "libSystem") {
|
||||||
configureFlags = configureFlagsFun { alsaLib = alsaLib.crossDrv; };
|
patches = let
|
||||||
|
f = rev: sha256: fetchurl {
|
||||||
|
url = "http://hg.libsdl.org/SDL/raw-rev/${rev}";
|
||||||
|
inherit sha256;
|
||||||
|
};
|
||||||
|
in [
|
||||||
|
(f "e9466ead70e5" "0ygir3k83d0vxp7s3k48jn3j8n2bnv9wm6613wpx3ybnjrxabrip")
|
||||||
|
(f "bbfb41c13a87" "17v29ybjifvka19m8qf14rjc43nfdwk9v9inaizznarhb17amlnv")
|
||||||
|
];
|
||||||
|
postPatch = ''
|
||||||
|
sed -i -e 's/ *-fpascal-strings//' configure
|
||||||
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
passthru = {inherit openglSupport;};
|
passthru = {inherit openglSupport;};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user