Merge pull request #18259 from abbradar/ut2004

Update and refactor UT2004

authored by Nikolay Amiantov and committed by GitHub d997f458 358232f6

+268 -77
+115
pkgs/development/libraries/libstdc++5/default.nix
···
··· 1 + { stdenv, fetchurl, fetchpatch, flex, bison, file }: 2 + 3 + stdenv.mkDerivation rec { 4 + name = "libstdc++5-${version}"; 5 + version = "3.3.6"; 6 + 7 + src = [ 8 + (fetchurl { 9 + url = "mirror://gcc/releases/gcc-${version}/gcc-core-${version}.tar.bz2"; 10 + sha256 = "1dpyrpsgakilz2rnh5f8gvrzq5pwzvndacc0df6m04bpqn5fx6sg"; 11 + }) 12 + (fetchurl { 13 + url = "mirror://gcc/releases/gcc-${version}/gcc-g++-${version}.tar.bz2"; 14 + sha256 = "14lxl81f7adpc9jxfiwzdxsdzs5zv4piv8xh7f9w910hfzrgvsby"; 15 + }) 16 + ]; 17 + 18 + patches = [ 19 + ./no-sys-dirs.patch 20 + (fetchpatch { 21 + name = "siginfo.patch"; 22 + url = "https://git.archlinux.org/svntogit/packages.git/plain/trunk/siginfo.patch?h=packages/libstdc%2B%2B5&id=e36ee8ed9bb5942db14cf6249a2ead14974a2bfa"; 23 + sha256 = "15zldbm33yba293dgrgsbv3j332hkc3iqpyc8fa7zl42mh9qk22j"; 24 + addPrefixes = true; 25 + }) 26 + (fetchpatch { 27 + name = "gcc-3.4.3-no_multilib_amd64.patch"; 28 + url = "https://git.archlinux.org/svntogit/packages.git/plain/trunk/gcc-3.4.3-no_multilib_amd64.patch?h=packages/libstdc%2B%2B5&id=e36ee8ed9bb5942db14cf6249a2ead14974a2bfa"; 29 + sha256 = "11m5lc51b0addhc4yq4rz0dwpv6k73rrj73wya3lqdk8rly6cjpm"; 30 + addPrefixes = true; 31 + }) 32 + ]; 33 + 34 + postPatch = '' 35 + # fix build issue with recent gcc 36 + sed -i "s#O_CREAT#O_CREAT, 0666#" gcc/collect2.c 37 + 38 + # No fixincludes 39 + sed -i -e 's@\./fixinc\.sh@-c true@' gcc/Makefile.in 40 + ''; 41 + 42 + preConfigure = '' 43 + mkdir ../build 44 + cd ../build 45 + configureScript=../$sourceRoot/configure 46 + ''; 47 + 48 + preBuild = '' 49 + # libstdc++ needs this; otherwise it will use /lib/cpp, which is a Bad 50 + # Thing. 51 + export CPP="gcc -E" 52 + 53 + # Use *real* header files, otherwise a limits.h is generated 54 + # that does not include Glibc's limits.h (notably missing 55 + # SSIZE_MAX, which breaks the build). 56 + export NIX_FIXINC_DUMMY="$(cat $NIX_CC/nix-support/orig-libc-dev)/include" 57 + 58 + # The path to the Glibc binaries such as `crti.o'. 59 + glibc_libdir="$(cat $NIX_CC/nix-support/orig-libc)/lib" 60 + 61 + # Figure out what extra flags to pass to the gcc compilers 62 + # being generated to make sure that they use our glibc. 63 + EXTRA_FLAGS="-I$NIX_FIXINC_DUMMY $(cat $NIX_CC/nix-support/libc-cflags) -O2" 64 + 65 + extraLDFlags="-L$glibc_libdir -rpath $glibc_libdir $(cat $NIX_CC/nix-support/libc-ldflags) $(cat $NIX_CC/nix-support/libc-ldflags-before)" 66 + for i in $extraLDFlags; do 67 + EXTRA_FLAGS="$EXTRA_FLAGS -Wl,$i" 68 + done 69 + 70 + # CFLAGS_FOR_TARGET are needed for the libstdc++ configure script to find 71 + # the startfiles. 72 + # FLAGS_FOR_TARGET are needed for the target libraries to receive the -Bxxx 73 + # for the startfiles. 74 + makeFlagsArray=( \ 75 + "''${makeFlagsArray[@]}" \ 76 + NATIVE_SYSTEM_HEADER_DIR="$NIX_FIXINC_DUMMY" \ 77 + SYSTEM_HEADER_DIR="$NIX_FIXINC_DUMMY" \ 78 + CFLAGS_FOR_BUILD="$EXTRA_FLAGS" \ 79 + CFLAGS_FOR_TARGET="$EXTRA_FLAGS" \ 80 + CXXFLAGS_FOR_BUILD="$EXTRA_FLAGS" \ 81 + CXXFLAGS_FOR_TARGET="$EXTRA_FLAGS" \ 82 + FLAGS_FOR_TARGET="$EXTRA_FLAGS" \ 83 + LDFLAGS_FOR_BUILD="$EXTRA_FLAGS" \ 84 + LDFLAGS_FOR_TARGET="$EXTRA_FLAGS" \ 85 + BOOT_CFLAGS="$EXTRA_FLAGS" \ 86 + BOOT_LDFLAGS="$EXTRA_FLAGS" 87 + ) 88 + ''; 89 + 90 + hardeningDisable = [ "format" ]; 91 + 92 + nativeBuildInputs = [ flex bison file ]; 93 + 94 + configureFlags = [ "--disable-multilib" "--enable-__cxa-atexit" "--enable-threads=posix" "--enable-languages=c++" "--enable-clocale=gnu" ]; 95 + 96 + buildFLags = [ "all-target-libstdc++-v3" ]; 97 + 98 + installFlags = [ "install-target-libstdc++-v3" ]; 99 + 100 + postInstall = '' 101 + # Remove includefiles and libs provided by gcc 102 + shopt -s extglob 103 + rm -rf $out/{bin,include,share,man,info} 104 + rm -f $out/lib/*.a 105 + rm -rf $out/lib/!(libstdc++*) 106 + ''; 107 + 108 + meta = with stdenv.lib; { 109 + homepage = http://gcc.gnu.org/; 110 + license = licenses.lgpl3Plus; 111 + description = "GNU Compiler Collection, version ${version} -- C++ standard library"; 112 + platforms = platforms.linux; 113 + maintainers = with maintainers; [ abbradar ]; 114 + }; 115 + }
+53
pkgs/development/libraries/libstdc++5/no-sys-dirs.patch
···
··· 1 + diff -ru3 gcc-3.3.6-old/gcc/cppdefault.c gcc-3.3.6/gcc/cppdefault.c 2 + --- gcc-3.3.6-old/gcc/cppdefault.c 2003-11-07 02:13:31.000000000 +0300 3 + +++ gcc-3.3.6/gcc/cppdefault.c 2016-09-02 16:00:03.492484016 +0300 4 + @@ -26,6 +26,10 @@ 5 + #include "system.h" 6 + #include "cppdefault.h" 7 + 8 + +#undef LOCAL_INCLUDE_DIR 9 + +#undef SYSTEM_INCLUDE_DIR 10 + +#undef STANDARD_INCLUDE_DIR 11 + + 12 + const struct default_include cpp_include_defaults[] 13 + #ifdef INCLUDE_DEFAULTS 14 + = INCLUDE_DEFAULTS; 15 + diff -ru3 gcc-3.3.6-old/gcc/gcc.c gcc-3.3.6/gcc/gcc.c 16 + --- gcc-3.3.6-old/gcc/gcc.c 2004-04-01 20:55:17.000000000 +0400 17 + +++ gcc-3.3.6/gcc/gcc.c 2016-09-02 16:01:24.843520114 +0300 18 + @@ -6130,10 +6130,6 @@ 19 + NULL, PREFIX_PRIORITY_LAST, 0, NULL, 1); 20 + } 21 + 22 + - add_sysrooted_prefix (&startfile_prefixes, standard_startfile_prefix_1, 23 + - "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL, 1); 24 + - add_sysrooted_prefix (&startfile_prefixes, standard_startfile_prefix_2, 25 + - "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL, 1); 26 + #if 0 /* Can cause surprises, and one can use -B./ instead. */ 27 + add_prefix (&startfile_prefixes, "./", NULL, 28 + PREFIX_PRIORITY_LAST, 1, NULL, 0); 29 + diff -ru3 gcc-3.3.6-old/gcc/Makefile.in gcc-3.3.6/gcc/Makefile.in 30 + --- gcc-3.3.6-old/gcc/Makefile.in 2004-04-01 20:55:23.000000000 +0400 31 + +++ gcc-3.3.6/gcc/Makefile.in 2016-09-02 16:00:03.493484017 +0300 32 + @@ -260,7 +260,11 @@ 33 + PARTITION_H = $(srcdir)/../include/partition.h 34 + 35 + # Default native SYSTEM_HEADER_DIR, to be overridden by targets. 36 + -NATIVE_SYSTEM_HEADER_DIR = /usr/include 37 + +# Nix: we override NATIVE_SYSTEM_HEADER_DIR in order to prevent 38 + +# `fixinc' from fixing header files in /usr/include. However, 39 + +# NATIVE_SYSTEM_HEADER_DIR must point to an existing directory, so set 40 + +# it to some dummy directory. 41 + +NATIVE_SYSTEM_HEADER_DIR = $(NIX_FIXINC_DUMMY) 42 + # Default cross SYSTEM_HEADER_DIR, to be overridden by targets. 43 + CROSS_SYSTEM_HEADER_DIR = @CROSS_SYSTEM_HEADER_DIR@ 44 + 45 + @@ -2201,7 +2205,7 @@ 46 + -DGPLUSPLUS_INCLUDE_DIR=\"$(gcc_gxx_include_dir)\" \ 47 + -DGPLUSPLUS_TOOL_INCLUDE_DIR=\"$(gcc_gxx_include_dir)/$(target_alias)\" \ 48 + -DGPLUSPLUS_BACKWARD_INCLUDE_DIR=\"$(gcc_gxx_include_dir)/backward\" \ 49 + - -DLOCAL_INCLUDE_DIR=\"$(local_includedir)\" \ 50 + + -DLOCAL_INCLUDE_DIR=\"/no-such-dir\" \ 51 + -DCROSS_INCLUDE_DIR=\"$(CROSS_SYSTEM_HEADER_DIR)\" \ 52 + -DTOOL_INCLUDE_DIR=\"$(gcc_tooldir)/include\" \ 53 + @TARGET_SYSTEM_ROOT_DEFINE@
+9
pkgs/games/ut2004/default.nix
···
··· 1 + { callPackage }: 2 + 3 + { 4 + ut2004-demo = callPackage ./demo.nix { }; 5 + 6 + ut2004 = gamePacks: callPackage ./wrapper.nix { 7 + inherit gamePacks; 8 + }; 9 + }
+40
pkgs/games/ut2004/demo.nix
···
··· 1 + { stdenv, fetchurl }: 2 + 3 + let 4 + arch = 5 + if stdenv.system == "x86_64-linux" then "amd64" 6 + else if stdenv.system == "i686-linux" then "x86" 7 + else throw "Unsupported architecture"; 8 + 9 + in stdenv.mkDerivation rec { 10 + name = "ut2004-demo-${version}"; 11 + version = "3334"; 12 + 13 + src = fetchurl { 14 + url = "http://treefort.icculus.org/ut2004/UT2004-LNX-Demo${version}.run.gz"; 15 + sha256 = "0d5f84qz8l1rg16yzx2k4ikr46n9iwj68na1bqi87wrww7ck6jh7"; 16 + }; 17 + 18 + buildCommand = '' 19 + cat $src | gunzip > setup.run 20 + chmod +x setup.run 21 + ./setup.run --noexec --target . 22 + mkdir $out 23 + tar -xaf ut2004demo.tar.bz2 -C $out 24 + tar -xaf linux-${arch}.tar.bz2 -C $out 25 + 26 + rm $out/System/libSDL-1.2.so.0 27 + rm $out/System/openal.so 28 + ''; 29 + 30 + dontStrip = true; 31 + dontPatchELF = true; 32 + 33 + meta = with stdenv.lib; { 34 + description = "A first-person shooter video game developed by Epic Games and Digital Extreme -- demo version"; 35 + homepage = "http://www.unrealtournament2004.com"; 36 + license = licenses.unfree; 37 + maintainers = with maintainers; [ abbradar ]; 38 + platforms = [ "x86_64-linux" "i686-linux" ]; 39 + }; 40 + }
+46
pkgs/games/ut2004/wrapper.nix
···
··· 1 + { stdenv, lib, runCommand, buildEnv, makeWrapper, makeDesktopItem, gamePacks, libstdcxx5, SDL, openal }: 2 + 3 + let 4 + game = buildEnv { 5 + name = "ut2004-game"; 6 + paths = gamePacks; 7 + ignoreCollisions = true; 8 + pathsToLink = [ "/" "/System" ]; 9 + postBuild = '' 10 + ln -s ${lib.getLib SDL}/lib/libSDL-1.2.so.0 $out/System 11 + ln -s ${lib.getLib openal}/lib/libopenal.so $out/System/openal.so 12 + for i in $out/System/*-bin; do 13 + path="$(readlink -f "$i")" 14 + rm "$i" 15 + cp "$path" "$i" 16 + chmod +w "$i" 17 + patchelf \ 18 + --set-interpreter $(cat ${stdenv.cc}/nix-support/dynamic-linker) \ 19 + --set-rpath "$out/System:${lib.makeLibraryPath [ libstdcxx5 ]}" \ 20 + "$i" 21 + done 22 + ''; 23 + }; 24 + 25 + desktop = makeDesktopItem { 26 + name = "ut2004"; 27 + desktopName = "Unreal Tournament 2004"; 28 + comment = "A first-person shooter video game developed by Epic Games and Digital Extreme"; 29 + genericName = "First-person shooter"; 30 + categories = "Application;Game;"; 31 + exec = "ut2004"; 32 + }; 33 + 34 + in runCommand "ut2004" { 35 + nativeBuildInputs = [ makeWrapper ]; 36 + } '' 37 + mkdir -p $out/bin 38 + for i in ${game}/System/*-bin; do 39 + name="$(basename "$i")" 40 + makeWrapper $i $out/bin/''${name%-bin} \ 41 + --run "cd ${game}/System" 42 + done 43 + 44 + mkdir -p $out/share/applications 45 + ln -s ${desktop}/share/applications/* $out/share/applications 46 + ''
-29
pkgs/games/ut2004demo/builder.sh
··· 1 - source $stdenv/setup 2 - 3 - skip=7976 4 - 5 - bunzip2 < $src | (dd bs=1 count=$skip of=/dev/null && dd bs=1M) | tar xvf - ut2004demo.tar 6 - 7 - mkdir $out 8 - 9 - (cd $out && tar xvf -) < ut2004demo.tar 10 - 11 - 12 - # Patch the executable from ELF OS/ABI type `Linux' (3) to `SVR4' (0). 13 - # This doesn't seem to matter to ld-linux.so.2 at all, except that it 14 - # refuses to load `Linux' executables when invokes explicitly, that 15 - # is, when we do `ld-linux.so.2 $out/System/ut2004-bin', which we need 16 - # to override the hardcoded ELF interpreter with our own. 17 - 18 - # This is a horrible hack, of course. A better solution would be to 19 - # patch Glibc so it accepts the `Linux' ELF type as well (why doesn't 20 - # it?); or to use FreeBSD's `brandelf' program to set to ELF type 21 - # (which is a bit cleaner than patching using `dd' :-) ). 22 - 23 - #(cd $out/System && (echo -en "\000" | dd bs=1 seek=7 of=ut2004-bin conv=notrunc)) 24 - 25 - 26 - # Set the ELF interpreter to our own Glibc. 27 - for i in "$out/System/ucc-bin" "$out/System/ut2004-bin"; do 28 - patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" "$i" 29 - done
···
-34
pkgs/games/ut2004demo/default.nix
··· 1 - {stdenv, fetchurl, xorg, mesa}: 2 - 3 - assert stdenv.system == "i686-linux"; 4 - 5 - let { 6 - 7 - raw = stdenv.mkDerivation { 8 - name = "ut2004-demo-3120"; 9 - src = fetchurl { 10 - urls = [ 11 - ("http://store.node-10.ds-servers.com/file/BcFLgoIgAADQA7kw0qZctDAF+4cj" 12 - + "mbnDMFOJTAyM0-cejkEIuDvQ6Uv9ZbvcWMnRmXXxhA0LyvzoKdvsnXne0D1DGTLiR0" 13 - + "I1CmM2M-E5ryH-tD3yweCXyNyH1WGI3Wh09ja29mHtzGF1rxEyhRfQ7ggCKdfCrhvz" 14 - + "H9oTJXSCAtGuSKdVDhe6tNtrqa151MIircZtRLPxQcGmJ+n3-iUeWYgHuqbmrK4ur7" 15 - + "Qcy6QrAhYa+e5jcfYjgPF3VGsw4qx+0ilxJUCiuYCX2H8A6X3rxJILa26w3O425W2G" 16 - + "kHPiQWrhFT8cIOyqSr8+dMO5Xi5-/ut2004-lnx-demo-3120.run.bz2") 17 - http://ftp.gameaholic.com/pub/demos/ut2004-lnx-demo-3120.run.bz2 18 - ]; 19 - sha256 = "1lravfkb1gsallqqird5dcbz42vwjg36m1qk76nmmnyyyghwqnli"; 20 - }; 21 - builder = ./builder.sh; 22 - }; 23 - 24 - body = stdenv.mkDerivation { 25 - name = raw.name; 26 - builder = ./make-wrapper.sh; 27 - inherit raw mesa; 28 - inherit (xorg) libX11 libXext; 29 - }; 30 - 31 - } 32 - 33 - # http://mirror1.icculus.org/ut2004/ut2004-lnxpatch3204.tar.bz2 34 - # 5f659552095b878a029b917d216d9664
···
-13
pkgs/games/ut2004demo/make-wrapper.sh
··· 1 - source $stdenv/setup 2 - 3 - mkdir -p $out/bin 4 - 5 - cat > $out/bin/ut2004demo <<EOF 6 - #! $SHELL -e 7 - 8 - cd $raw/System 9 - 10 - LD_LIBRARY_PATH=$libX11/lib:$libXext/lib\${LD_LIBRARY_PATH:+:}\$LD_LIBRARY_PATH ./ut2004-bin "\$@" 11 - EOF 12 - 13 - chmod +x $out/bin/ut2004demo
···
+5 -1
pkgs/top-level/all-packages.nix
··· 6360 libcxx = llvmPackages.libcxx; 6361 libcxxabi = llvmPackages.libcxxabi; 6362 6363 libsigrok = callPackage ../development/tools/libsigrok { }; 6364 # old version: 6365 libsigrok-0-3-0 = libsigrok.override { ··· 16197 16198 ue4demos = recurseIntoAttrs (callPackage ../games/ue4demos { }); 16199 16200 - ut2004demo = callPackage_i686 ../games/ut2004demo { }; 16201 16202 vapor = callPackage ../games/vapor { love = love_0_8; }; 16203
··· 6360 libcxx = llvmPackages.libcxx; 6361 libcxxabi = llvmPackages.libcxxabi; 6362 6363 + libstdcxx5 = callPackage ../development/libraries/libstdc++5 { }; 6364 + 6365 libsigrok = callPackage ../development/tools/libsigrok { }; 6366 # old version: 6367 libsigrok-0-3-0 = libsigrok.override { ··· 16199 16200 ue4demos = recurseIntoAttrs (callPackage ../games/ue4demos { }); 16201 16202 + ut2004Packages = callPackage ../games/ut2004 { }; 16203 + 16204 + ut2004demo = self.ut2004Packages.ut2004 [ self.ut2004Packages.ut2004-demo ]; 16205 16206 vapor = callPackage ../games/vapor { love = love_0_8; }; 16207