factorio: refactor in preparation for headless version

This commit is contained in:
Eric Litak 2016-04-11 21:19:14 -07:00
parent ff44872c77
commit c6750d2f46
2 changed files with 78 additions and 50 deletions

View File

@ -4,35 +4,64 @@
# Begin download parameters # Begin download parameters
, username ? "" , username ? ""
, password ? "" , password ? ""
, releaseType
}: }:
assert releaseType == "alpha" || releaseType == "headless";
with stdenv.lib;
let let
version = "0.12.28"; version = "0.12.28";
isHeadless = releaseType == "headless";
fetch = callPackage ./fetch.nix { username = username; password = password; }; arch = if stdenv.system == "x86_64-linux" then {
arch = if stdenv.system == "x86_64-linux" then "x64" inUrl = "linux64";
else if stdenv.system == "i686-linux" then "x32" inTar = "x64";
else abort "Unsupported platform"; } else if stdenv.system == "i686-linux" then {
inUrl = "linux32";
inTar = "i386";
} else abort "Unsupported platform";
variants = { authenticatedFetch = callPackage ./fetch.nix { inherit username password; };
fetch = rec {
url = "https://www.factorio.com/get-download/${version}/${releaseType}/${arch.inUrl}";
name = "factorio_${releaseType}_${arch.inTar}-${version}.tar.gz"; # TODO take this from 302 redirection somehow? fetchurl doesn't help.
x64 = { x64 = {
url = "https://www.factorio.com/get-download/${version}/alpha/linux64"; alpha = authenticatedFetch { inherit url; sha256 = "0vngfrjjib99k6czhg32rikfi36i3p3adx4mxc1z8bi5n70dbwqb"; };
sha256 = "01si5n9hb2h0c5q8k3hr3nphsakp9kki84qyp70dgddwqsn8wfjl"; };
i386 = {
alpha = authenticatedFetch { inherit url; sha256 = "10135rd9103x79i89p6fh5ssmw612012yyx3yyhb3nzl554zqzbm"; };
};
}; };
x32 = { configBaseCfg = ''
url = "https://www.factorio.com/get-download/${version}/alpha/linux32"; use-system-read-write-data-directories=false
sha256 = "13h013ixyhv4rpvh0jv5jry3mrwv65v57nqn16bjh3hr8ip70lkq"; [path]
}; read-data=$out/share/factorio/data/
}; '';
updateConfigSh = ''
#! $SHELL
if [[ -e ~/.factorio/config.cfg ]]; then
# Config file exists, but may have wrong path.
# Try to edit it. I'm sure this is perfectly safe and will never go wrong.
sed -i 's|^read-data=.*|read-data=$out/share/factorio/data/|' ~/.factorio/config.cfg
else
# Config file does not exist. Phew.
install -D $out/share/factorio/config-base.cfg ~/.factorio/config.cfg
fi
'';
in in
stdenv.mkDerivation rec { stdenv.mkDerivation rec {
name = "factorio-${version}"; name = "factorio-${releaseType}-${version}";
src = fetch variants.${arch}; src = fetch.${arch.inTar}.${releaseType};
libPath = stdenv.lib.makeLibraryPath [ libPath = stdenv.lib.makeLibraryPath (
optionals (! isHeadless) [
alsaLib alsaLib
libX11 libX11
libXcursor libXcursor
@ -40,44 +69,43 @@ stdenv.mkDerivation rec {
libXrandr libXrandr
libXi libXi
mesa_noglu mesa_noglu
]; ]
);
buildInputs = [ makeWrapper ]; buildInputs = [ makeWrapper ];
dontBuild = true;
# TODO detangle headless/normal mode wrapping, libs, etc. test all urls 32/64/headless/gfx
installPhase = '' installPhase = ''
mkdir -p $out/{bin,share/factorio} mkdir -p $out/{bin,share/factorio}
cp -a bin/${arch}/factorio $out/bin/factorio.${arch} cp -a data $out/share/factorio
cp -a doc-html data $out/share/factorio/ cp -a bin/${arch.inTar}/factorio $out/bin/factorio
# Fortunately, Factorio already supports system-wide installs.
# Unfortunately it's a bit inconvenient to set the paths.
cat > $out/share/factorio/config-base.cfg <<EOF
use-system-read-write-data-directories=false
[path]
read-data=$out/share/factorio/data/
EOF
cat > $out/share/factorio/update-config.sh <<EOF
if [[ -e ~/.factorio/config.cfg ]]; then
# Config file exists, but may have wrong path.
# Try to edit it. I'm sure this is perfectly safe and will never go wrong.
sed -i 's|^read-data=.*|read-data=$out/share/factorio/data/|' ~/.factorio/config.cfg
else
# Config file does not exist. Phew.
install -D $out/share/factorio/config-base.cfg ~/.factorio/config.cfg
fi
EOF
chmod a+x $out/share/factorio/update-config.sh
patchelf \ patchelf \
--set-interpreter $(cat $NIX_CC/nix-support/dynamic-linker) \ --set-interpreter $(cat $NIX_CC/nix-support/dynamic-linker) \
$out/bin/factorio.${arch} $out/bin/factorio
makeWrapper $out/bin/factorio.${arch} $out/bin/factorio \ '' + optionalString (! isHeadless) (''
mv $out/bin/factorio $out/bin/factorio.${arch.inTar}
makeWrapper $out/bin/factorio.${arch.inTar} $out/bin/factorio \
--prefix LD_LIBRARY_PATH : /run/opengl-driver/lib:$libPath \ --prefix LD_LIBRARY_PATH : /run/opengl-driver/lib:$libPath \
--run "$out/share/factorio/update-config.sh" \ --run "$out/share/factorio/update-config.sh" \
--add-flags "-c \$HOME/.factorio/config.cfg" --add-flags "-c \$HOME/.factorio/config.cfg"
''; # Fortunately, Factorio already supports system-wide installs.
# Unfortunately it's a bit inconvenient to set the paths.
install -m0644 <(cat << EOF
'' + configBaseCfg + ''
EOF
) $out/share/factorio/config-base.cfg
install -m0755 <(cat << EOF
'' + updateConfigSh + ''
EOF
) $out/share/factorio/update-config.sh
cp -a doc-html $out/share/factorio
'');
preferLocalBuild = true;
meta = { meta = {
description = "A game in which you build and maintain factories"; description = "A game in which you build and maintain factories";
@ -95,7 +123,7 @@ EOF
''; '';
homepage = https://www.factorio.com/; homepage = https://www.factorio.com/;
license = stdenv.lib.licenses.unfree; license = stdenv.lib.licenses.unfree;
maintainers = [ stdenv.lib.maintainers.Baughn ]; maintainers = with stdenv.maintainers; [ Baughn elitak ];
platforms = [ "i686-linux" "x86_64-linux" ]; platforms = [ "i686-linux" "x86_64-linux" ];
}; };
} }

View File

@ -14729,7 +14729,7 @@ in
exult = callPackage ../games/exult { }; exult = callPackage ../games/exult { };
factorio = callPackage ../games/factorio {}; factorio = callPackage ../games/factorio { releaseType = "alpha"; };
fairymax = callPackage ../games/fairymax {}; fairymax = callPackage ../games/fairymax {};