Merge pull request #33070 from lheckemann/vdrift-fix

vdrift: fix build, allow parallel building
This commit is contained in:
Michael Raskin 2018-01-27 21:54:52 +00:00 committed by GitHub
commit 96be241536
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 81 additions and 32 deletions

View File

@ -0,0 +1,27 @@
From 7ebe252a8488a63675d1c50c0faa1bdc5ff97889 Mon Sep 17 00:00:00 2001
From: Linus Heckemann <git@sphalerite.org>
Date: Fri, 5 Jan 2018 21:27:28 +0100
Subject: [PATCH] Ignore missing data for installation
This is for packaging vdrift separately from its data in nixpkgs.
---
SConstruct | 3 ---
1 file changed, 3 deletions(-)
diff --git a/SConstruct b/SConstruct
index 4394de0b..beef29a4 100644
--- a/SConstruct
+++ b/SConstruct
@@ -511,9 +511,6 @@ env.Alias(target = 'bin-package', source = bin_archive)
#----------------#
Export(['env', 'version', 'src_dir', 'bin_dir'])
if 'install' in COMMAND_LINE_TARGETS:
- if not os.path.isfile('data/SConscript'):
- raise 'VDrift data not found. Please make sure data is placed in vdrift directory. See README.md and http://wiki.vdrift.net.'
- SConscript('data/SConscript')
# desktop appdata installation
install_desktop = env.Install(env['destdir'] + env['prefix'] + '/share/applications', 'vdrift.desktop')
install_appdata = env.Install(env['destdir'] + env['prefix'] + '/share/appdata', 'vdrift.appdata.xml')
--
2.15.0

View File

@ -1,41 +1,60 @@
{ stdenv, fetchFromGitHub, fetchsvn, pkgconfig, scons, mesa, SDL2, SDL2_image, libvorbis,
bullet, curl, gettext }:
{ stdenv, fetchFromGitHub, fetchsvn, pkgconfig, scons, mesa, SDL2, SDL2_image
, libvorbis, bullet, curl, gettext, writeTextFile, writeShellScriptBin
stdenv.mkDerivation rec {
version = "2014-10-20";
name = "vdrift-${version}";
src = fetchFromGitHub {
owner = "VDrift";
repo = "vdrift";
rev = version;
sha256 = "09yny5qzdrpffq3xhqwfymsracwsxwmdd5xa8bxx9a56hhxbak2l";
};
data = fetchsvn {
, data ? fetchsvn {
url = "svn://svn.code.sf.net/p/vdrift/code/vdrift-data";
rev = 1386;
sha256 = "0ka6zir9hg0md5p03dl461jkvbk05ywyw233hnc3ka6shz3vazi1";
}
}:
let
version = "git";
bin = stdenv.mkDerivation {
name = "vdrift-${version}";
src = fetchFromGitHub {
owner = "vdrift";
repo = "vdrift";
rev = "12d444ed18395be8827a21b96cc7974252fce6d1";
sha256 = "001wq3c4n9wzxqfpq40b1jcl16sxbqv2zbkpy9rq2wf9h417q6hg";
};
nativeBuildInputs = [ pkgconfig ];
buildInputs = [ scons mesa SDL2 SDL2_image libvorbis bullet curl gettext ];
patches = [ ./0001-Ignore-missing-data-for-installation.patch ];
buildPhase = ''
sed -i -e s,/usr/local,$out, SConstruct
export CXXFLAGS="$(pkg-config --cflags SDL2_image)"
scons -j$NIX_BUILD_CORES
'';
installPhase = "scons install";
meta = {
description = "Car racing game";
homepage = http://vdrift.net/;
license = stdenv.lib.licenses.gpl2Plus;
maintainers = with stdenv.lib.maintainers; [viric];
platforms = stdenv.lib.platforms.linux;
};
};
nativeBuildInputs = [ pkgconfig ];
buildInputs = [ scons mesa SDL2 SDL2_image libvorbis bullet curl gettext ];
buildPhase = ''
cp -r --reflink=auto $data data
chmod -R +w data
sed -i -e s,/usr/local,$out, SConstruct
export CXXFLAGS="$(pkg-config --cflags SDL2_image)"
scons
wrappedName = "vdrift-${version}-with-data-${toString data.rev}";
in writeTextFile {
name = wrappedName;
text = ''
export VDRIFT_DATA_DIRECTORY="${data}"
exec ${bin}/bin/vdrift "$@"
'';
installPhase = "scons install";
meta = {
description = "Car racing game";
homepage = http://vdrift.net/;
license = stdenv.lib.licenses.gpl2Plus;
maintainers = with stdenv.lib.maintainers; [viric];
platforms = stdenv.lib.platforms.linux;
destination = "/bin/vdrift";
executable = true;
checkPhase = ''
${stdenv.shell} -n $out/bin/vdrift
'';
} // {
meta = bin.meta // {
hydraPlatforms = [];
};
unwrapped = bin;
inherit bin data;
}

View File

@ -18719,6 +18719,9 @@ with pkgs;
vdrift = callPackage ../games/vdrift { };
# To ensure vdrift's code is built on hydra
vdrift-bin = vdrift.bin;
vectoroids = callPackage ../games/vectoroids { };
vessel = callPackage_i686 ../games/vessel { };