From 12223720a8ed8e947def8385003ef3c0256a8378 Mon Sep 17 00:00:00 2001 From: Gregor Kleen Date: Tue, 13 Sep 2016 05:00:26 +0200 Subject: more up to date factorio --- customized/factorio.nix | 148 ++++++++++++++++++++++++++++++++++++++++++++++++ ymir/factorio.nix | 1 + 2 files changed, 149 insertions(+) create mode 100644 customized/factorio.nix diff --git a/customized/factorio.nix b/customized/factorio.nix new file mode 100644 index 00000000..616c8aae --- /dev/null +++ b/customized/factorio.nix @@ -0,0 +1,148 @@ +{ stdenv, callPackage, fetchurl, makeWrapper +, alsaLib, libX11, libXcursor, libXinerama, libXrandr, libXi, mesa_noglu +, factorio-utils +, releaseType +, mods ? [] +, username ? "" , password ? "" +}: + +assert releaseType == "alpha" || releaseType == "headless"; + +with stdenv.lib; +let + version = "0.14.5"; + isHeadless = releaseType == "headless"; + + arch = if stdenv.system == "x86_64-linux" then { + inUrl = "linux64"; + inTar = "x64"; + } else if stdenv.system == "i686-linux" then { + inUrl = "linux32"; + inTar = "i386"; + } else abort "Unsupported platform"; + + 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"; + x64 = { + headless = fetchurl { inherit name url; sha256 = "1ip0h2kh16s07nk6xqpm0i0yb0x32zn306414j15gqg3j0j0mzpn"; }; + alpha = authenticatedFetch { inherit url; sha256 = "1hvj51cggp6cbxyndbl4z07kadzxxk3diiqkkv0jm9s0nrwvq9zr"; }; + }; + i386 = { + headless = abort "Factorio 32-bit headless binaries are not available for download."; + alpha = authenticatedFetch { inherit url; sha256 = "14dwlakn7z8jziy0hgm3nskr7chp7753z1dakxlymz9h5653cx8b"; }; + }; + }; + + configBaseCfg = '' + use-system-read-write-data-directories=false + [path] + read-data=$out/share/factorio/data/ + [other] + check_updates=false + ''; + + 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 + ''; + + modDir = factorio-utils.mkModDirDrv mods; + + base = { + name = "factorio-${releaseType}-${version}"; + + src = fetch.${arch.inTar}.${releaseType}; + + preferLocalBuild = true; + dontBuild = true; + + installPhase = '' + mkdir -p $out/{bin,share/factorio} + cp -a data $out/share/factorio + cp -a bin/${arch.inTar}/factorio $out/bin/factorio + patchelf \ + --set-interpreter $(cat $NIX_CC/nix-support/dynamic-linker) \ + $out/bin/factorio + ''; + + meta = { + description = "A game in which you build and maintain factories"; + longDescription = '' + Factorio is a game in which you build and maintain factories. + + You will be mining resources, researching technologies, building + infrastructure, automating production and fighting enemies. Use your + imagination to design your factory, combine simple elements into + ingenious structures, apply management skills to keep it working and + finally protect it from the creatures who don't really like you. + + Factorio has been in development since spring of 2012 and it is + currently in late alpha. + ''; + homepage = https://www.factorio.com/; + license = stdenv.lib.licenses.unfree; + maintainers = with stdenv.lib.maintainers; [ Baughn elitak ]; + platforms = [ "i686-linux" "x86_64-linux" ]; + }; + }; + headless = base; + alpha = base // { + + buildInputs = [ makeWrapper ]; + + libPath = stdenv.lib.makeLibraryPath [ + alsaLib + libX11 + libXcursor + libXinerama + libXrandr + libXi + mesa_noglu + ]; + + installPhase = base.installPhase + '' + wrapProgram $out/bin/factorio \ + --prefix LD_LIBRARY_PATH : /run/opengl-driver/lib:$libPath \ + --run "$out/share/factorio/update-config.sh" \ + --add-flags "-c \$HOME/.factorio/config.cfg ${optionalString (mods != []) "--mod-directory=${modDir}"}" + + # TODO Currently, every time a mod is changed/added/removed using the + # modlist, a new derivation will take up the entire footprint of the + # client. The only way to avoid this is to remove the mods arg from the + # package function. The modsDir derivation will have to be built + # separately and have the user specify it in the .factorio config or + # right along side it using a symlink into the store I think i will + # just remove mods for the client derivation entirely. this is much + # cleaner and more useful for headless mode. + + # TODO: trying to toggle off a mod will result in read-only-fs-error. + # not much we can do about that except warn the user somewhere. In + # fact, no exit will be clean, since this error will happen on close + # regardless. just prints an ugly stacktrace but seems to be otherwise + # harmless, unless maybe the user forgets and tries to use the mod + # manager. + + 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 + ''; + }; +in stdenv.mkDerivation (if isHeadless then headless else alpha) diff --git a/ymir/factorio.nix b/ymir/factorio.nix index 3e021e8d..7c67eb66 100644 --- a/ymir/factorio.nix +++ b/ymir/factorio.nix @@ -83,5 +83,6 @@ in { nixpkgs.config.packageOverrides = pkgs: { factorio-mkModDirDrv = pkgs.factorio-utils.mkModDirDrv; + factorio = pkgs.callPackage ../customized/factorio.nix {}; }; } -- cgit v1.2.3