factorio: refactor in preparation for headless version
This commit is contained in:
parent
ff44872c77
commit
c6750d2f46
|
@ -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" ];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -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 {};
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue