games-fps/eduke32: version bump to 20180809.6969.
authorConrad Kostecki <conrad@kostecki.com>
Wed, 15 Aug 2018 21:14:59 +0000 (23:14 +0200)
committerPatrice Clement <monsieurp@gentoo.org>
Tue, 21 Aug 2018 21:55:34 +0000 (23:55 +0200)
Closes: https://bugs.gentoo.org/663742
Package-Manager: Portage-2.3.45, Repoman-2.3.10
Closes: https://github.com/gentoo/gentoo/pull/9585

games-fps/eduke32/Manifest
games-fps/eduke32/eduke32-20180809.6969.ebuild [new file with mode: 0644]

index 6b9657506e03a509bffedc71d8f4c765c830688f..181a3189444749e6fc949ba640b78da2040667d7 100644 (file)
@@ -6,3 +6,4 @@ DIST duke3d_voxels-1.21.zip 2997999 BLAKE2B dcb3103a82b45cfcf906d00147a57fe47997
 DIST duke3d_xxx-1.33.zip 26586453 BLAKE2B 7e3c46172d3db1b2eb49eb07f243a9ead4f260d6b1dcae9f8bd599b8e9ba3a19068032afeb4ec2cf61742b6216e3a06c24f2b7e8903f9636f9d00f4d57ada47f SHA512 4783d159610fc178e748446b7a5f9c13d90e1aca3cef34deb82e99655b7f4a254f1130e16dbcfad9013b95bc07161d5c5dccfcc552fbb7a88404b4b9cedbadbf
 DIST eduke32_classic.png 5129 BLAKE2B 332ad44b7f6b4f51362387aa6870e7db54423ca5a1f0586cb5019322fb72317d8e88e0bbf46ac89b56290db7e2e4a8442179a6eb87a615fd741b5f00ce96a1c8 SHA512 b41dece8f1ddcadde3367a83f6029ffdc5805811b40380e270169684fb3b368258bd8caeb55623dadffb6fb9d72faf9a3d75907722623f4fac94a4347f8ce833
 DIST eduke32_src_20180802-6963.tar.xz 14704448 BLAKE2B f121667d424ffac60f3239f260b65faaaf3b11377ebffc60b14c08494451f03151ab46c4fcb984e1abe45e6fa3fd5d3df04c3c557e0679e25d41de87ee42f4f7 SHA512 5afc34889f41b2fe2469b787a799c66a6bbc20b15552c052f21017a30ed9ecefabd94222b8e5bbc4745ab736e69143ea4c0f3b031713c17f70215907d10c746b
+DIST eduke32_src_20180809-6969.tar.xz 14708992 BLAKE2B 64a7f8ef6c6772634ed376d59322d75da6eb3e4993a2123c86280ed95ffd562e452cad88b50833b0b77753c365b9d366f4bb392b947ac45819a10908cc505d2f SHA512 5c1d6e151fbd8bdbeed3ed94073e4a53170a79036b86e4303663b842f2fd2ddc2ee45e0685887c56a0321638b69d9a40b880f5a33e69115ed7f9fa89a18bc321
diff --git a/games-fps/eduke32/eduke32-20180809.6969.ebuild b/games-fps/eduke32/eduke32-20180809.6969.ebuild
new file mode 100644 (file)
index 0000000..c42e95c
--- /dev/null
@@ -0,0 +1,247 @@
+# Copyright 1999-2018 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=6
+
+inherit desktop eapi7-ver gnome2-utils toolchain-funcs
+
+MY_BUILD="$(ver_cut 2)"
+MY_DATE="$(ver_cut 1)"
+
+MY_PN_HRP="duke3d_hrp"
+MY_PN_OPL="duke3d_musopl"
+MY_PN_PSX="duke3d_psx"
+MY_PN_SC55="duke3d_music-sc55"
+MY_PN_VOXELS="duke3d_voxels"
+MY_PN_XXX="duke3d_xxx"
+
+MY_PV_HRP="5.4"
+MY_PV_OPL="2.01"
+MY_PV_PSX="1.11"
+MY_PV_SC55="4.02"
+MY_PV_VOXELS="1.21"
+MY_PV_XXX="1.33"
+
+DESCRIPTION="An open source engine port of the classic PC first person shooter Duke Nukem 3D"
+HOMEPAGE="http://www.eduke32.com/"
+SRC_URI="http://dukeworld.com/eduke32/synthesis/${MY_DATE}-${MY_BUILD}/${PN}_src_${MY_DATE}-${MY_BUILD}.tar.xz
+       http://www.eduke32.com/images/eduke32_classic.png
+       hrp? ( http://www.duke4.org/files/nightfright/hrp/duke3d_hrp.zip -> ${MY_PN_HRP}-${MY_PV_HRP}.zip )
+       offensive? ( http://www.duke4.org/files/nightfright/related/${MY_PN_XXX}.zip -> ${MY_PN_XXX}-${MY_PV_XXX}.zip )
+       opl? ( http://www.moddb.com/downloads/mirror/95750/102/ce9e8f422c6cccdb297852426e96740a -> ${MY_PN_OPL}-${MY_PV_OPL}.zip )
+       psx? ( http://www.duke4.org/files/nightfright/related/duke3d_psx.zip -> ${MY_PN_PSX}-${MY_PV_PSX}.zip )
+       sc-55? ( http://www.duke4.org/files/nightfright/music/${MY_PN_SC55}.zip -> ${MY_PN_SC55}-${MY_PV_SC55}.zip )
+       voxels? ( https://www.dropbox.com/s/yaxfahyvskyvt4r/duke3d_voxels.zip -> ${MY_PN_VOXELS}-${MY_PV_VOXELS}.zip )"
+
+KEYWORDS="~amd64 ~hppa ~x86"
+LICENSE="BUILDLIC GPL-2 HRP"
+SLOT="0"
+IUSE="cdinstall demo flac fluidsynth gtk hrp offensive opengl opl png psx sc-55 server sdk timidity tools vorbis voxels vpx xmp"
+REQUIRED_USE="cdinstall? ( !demo )
+       demo? ( !cdinstall )
+       hrp? ( ^^ ( demo cdinstall )
+               !voxels )
+       offensive? ( ^^ ( demo cdinstall ) )
+       opl? ( ^^ ( demo cdinstall )
+               !sc-55 )
+       psx? ( ^^ ( demo cdinstall ) )
+       sc-55? ( ^^ ( demo cdinstall )
+               !opl )
+       voxels? ( !hrp )
+       vpx? ( opengl )"
+
+S="${WORKDIR}/${PN}_${MY_DATE}-${MY_BUILD}"
+
+MY_DEPEND_RDEPEND="media-libs/libsdl2[joystick,opengl?,sound,video,X]
+       media-libs/sdl2-mixer[flac?,fluidsynth?,midi,timidity?,vorbis?]
+       sys-libs/zlib:=
+       flac? ( media-libs/flac )
+               gtk? ( x11-libs/gtk+:2 )
+       opengl? ( virtual/glu
+               virtual/opengl )
+       png? ( media-libs/libpng:0= )
+       timidity? ( media-sound/timidity-freepats )
+       vpx? ( media-libs/libvpx:= )
+       vorbis? ( media-libs/libogg
+               media-libs/libvorbis )
+       xmp? ( media-libs/exempi:= )"
+
+RDEPEND="${MY_DEPEND_RDEPEND}
+       cdinstall? ( games-fps/duke3d-data )
+       demo? ( games-fps/duke3d-demodata )"
+
+DEPEND="${MY_DEPEND_RDEPEND}
+       app-arch/unzip
+       x86? ( dev-lang/nasm )"
+
+PATCHES=( "${FILESDIR}/log-to-tmpdir.patch" "${FILESDIR}/search-duke3d-path.patch" )
+
+src_unpack() {
+       # Extract only the eduke32 archive
+       unpack ${PN}_src_${MY_DATE}-${MY_BUILD}.tar.xz
+
+       # Unpack only the documentation
+       if use hrp; then
+               unzip -q "${DISTDIR}"/${MY_PN_HRP}-${MY_PV_HRP}.zip hrp_readme.txt hrp_todo.txt || die
+       fi
+       if use offensive; then
+               unzip -q "${DISTDIR}"/${MY_PN_XXX}-${MY_PV_XXX}.zip xxx_readme.txt || die
+       fi
+       if use opl; then
+               unzip -q "${DISTDIR}"/${MY_PN_OPL}-${MY_PV_OPL}.zip readme.txt || die
+       fi
+       if use sc-55; then
+               unzip -q "${DISTDIR}"/${MY_PN_SC55}-${MY_PV_SC55}.zip readme/music_readme.txt || die
+       fi
+       if use voxels; then
+               unzip -q "${DISTDIR}"/${MY_PN_VOXELS}-${MY_PV_VOXELS}.zip voxelpack_readme.txt || die
+       fi
+}
+
+src_compile() {
+       local myemakeopts=(
+               ALLOCACHE_AS_MALLOC=0
+               AS=$(tc-getAS)
+               CC=$(tc-getCC)
+               CXX=$(tc-getCXX)
+               CLANG=0
+               CPLUSPLUS=1
+               CUSTOMOPT=""
+               DEBUGANYWAY=0
+               F_JUMP_TABLES=""
+               FORCEDEBUG=0
+               HAVE_FLAC=$(usex flac 1 0)
+               HAVE_GTK2=$(usex gtk 1 0)
+               HAVE_VORBIS=$(usex vorbis 1 0)
+               HAVE_XMP=$(usex xmp 1 0)
+               LINKED_GTK=$(usex gtk 1 0)
+               LTO=1
+               LUNATIC=0
+               KRANDDEBUG=0
+               MEMMAP=0
+               MIXERTYPE=SDL
+               NETCODE=$(usex server 1 0)
+               NOASM=0
+               OPTLEVEL=0
+               OPTOPT=""
+               PACKAGE_REPOSITORY=1
+               POLYMER=$(usex opengl 1 0)
+               PRETTY_OUTPUT=0
+               PROFILER=0
+               RELEASE=1
+               RENDERTYPE=SDL
+               SDL_TARGET=2
+               SIMPLE_MENU=0
+               STRIP=""
+               TANDALONE=0
+               STARTUP_WINDOW=$(usex gtk 1 0)
+               USE_OPENGL=$(usex opengl 1 0)
+               USE_LIBVPX=$(usex vpx 1 0)
+               USE_LIBPNG=$(usex png 1 0)
+               USE_LUAJIT_2_1=0
+               WITHOUT_GTK=$(usex gtk 0 1)
+       )
+
+       emake "${myemakeopts[@]}"
+
+       if use tools; then
+               emake utils "${myemakeopts[@]}"
+       fi
+}
+
+src_install() {
+       local binary
+       local binaries=(
+               eduke32
+               mapster32
+               "${FILESDIR}"/eduke32-bin
+       )
+       for binary in "${binaries[@]}"; do
+               dobin "${binary}"
+       done
+
+       if use tools; then
+               local tool
+               local tools=(
+                       arttool
+                       bsuite
+                       cacheinfo
+                       generateicon
+                       givedepth
+                       ivfrate
+                       kextract
+                       kgroup
+                       kmd2tool
+                       makesdlkeytrans
+                       map2stl
+                       md2tool
+                       mkpalette
+                       transpal
+                       unpackssi
+                       wad2art
+                       wad2map
+               )
+               for tool in "${tools[@]}"; do
+                       dobin ${tool}
+               done
+       fi
+
+       keepdir /usr/share/games/eduke32
+       insinto /usr/share/games/eduke32
+       if use hrp; then
+               doins "${DISTDIR}"/${MY_PN_HRP}-${MY_PV_HRP}.zip
+       fi
+       if use offensive; then
+               doins "${DISTDIR}"/${MY_PN_XXX}-${MY_PV_XXX}.zip
+       fi
+       if use opl; then
+               doins "${DISTDIR}"/${MY_PN_OPL}-${MY_PV_OPL}.zip
+       fi
+       if use psx; then
+               doins "${DISTDIR}"/${MY_PN_PSX}-${MY_PV_PSX}.zip
+       fi
+       if use sc-55; then
+               doins "${DISTDIR}"/${MY_PN_SC55}-${MY_PV_SC55}.zip
+       fi
+       if use sdk; then
+               doins -r package/sdk
+       fi
+       if use voxels; then
+               doins "${DISTDIR}"/${MY_PN_VOXELS}-${MY_PV_VOXELS}.zip
+       fi
+
+       newicon "${DISTDIR}"/eduke32_classic.png eduke32.png
+
+       make_desktop_entry eduke32-bin EDuke32 eduke32 Game
+       make_desktop_entry mapster32 Mapster32 eduke32 Game
+
+       local DOCS=( package/sdk/samples/*.txt source/build/doc/*.txt source/duke3d/src/lunatic/doc/*.txt )
+       if use hrp; then
+               DOCS+=( "${WORKDIR}"/hrp_readme.txt "${WORKDIR}"/hrp_todo.txt )
+       fi
+       if use offensive; then
+               DOCS+=( "${WORKDIR}"/xxx_readme.txt )
+       fi
+       if use opl; then
+               DOCS+=( "${WORKDIR}"/readme.txt )
+       fi
+       if use sc-55; then
+               DOCS+=( "${WORKDIR}"/readme/music_readme.txt )
+       fi
+       if use voxels; then
+               DOCS+=( "${WORKDIR}"/voxelpack_readme.txt )
+       fi
+       einstalldocs
+}
+
+pkg_preinst() {
+       gnome2_icon_savelist
+}
+
+pkg_postinst() {
+       gnome2_icon_cache_update
+}
+
+pkg_postrm() {
+       gnome2_icon_cache_update
+}