diff options
author | Richard Freeman <rich0@gentoo.org> | 2008-07-18 02:54:12 +0000 |
---|---|---|
committer | Richard Freeman <rich0@gentoo.org> | 2008-07-18 02:54:12 +0000 |
commit | b633b1194f9282680e95f9a6604a20ef9db22886 (patch) | |
tree | c6097ae37370c8da9b3b69a3e36a9d9b652c4e25 /games-rpg/eternal-lands | |
parent | Fix broken Manifest, bug #222925 (diff) | |
download | gentoo-2-b633b1194f9282680e95f9a6604a20ef9db22886.tar.gz gentoo-2-b633b1194f9282680e95f9a6604a20ef9db22886.tar.bz2 gentoo-2-b633b1194f9282680e95f9a6604a20ef9db22886.zip |
fixed upstream segfault error
(Portage version: 2.1.4.4)
Diffstat (limited to 'games-rpg/eternal-lands')
-rw-r--r-- | games-rpg/eternal-lands/ChangeLog | 8 | ||||
-rw-r--r-- | games-rpg/eternal-lands/eternal-lands-1.7.0-r1.ebuild | 157 | ||||
-rw-r--r-- | games-rpg/eternal-lands/files/eternal-lands-1.7.0-errors.patch | 17 |
3 files changed, 181 insertions, 1 deletions
diff --git a/games-rpg/eternal-lands/ChangeLog b/games-rpg/eternal-lands/ChangeLog index 43dbfa98a76d..97e3af93ec8e 100644 --- a/games-rpg/eternal-lands/ChangeLog +++ b/games-rpg/eternal-lands/ChangeLog @@ -1,6 +1,12 @@ # ChangeLog for games-rpg/eternal-lands # Copyright 1999-2008 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/games-rpg/eternal-lands/ChangeLog,v 1.44 2008/07/17 21:10:03 rich0 Exp $ +# $Header: /var/cvsroot/gentoo-x86/games-rpg/eternal-lands/ChangeLog,v 1.45 2008/07/18 02:54:11 rich0 Exp $ + +*eternal-lands-1.7.0-r1 (18 Jul 2008) + + 18 Jul 2008; Richard Freeman <rich0@gentoo.org> + +files/eternal-lands-1.7.0-errors.patch, +eternal-lands-1.7.0-r1.ebuild: + fixed upstream segfault error *eternal-lands-1.7.0 (17 Jul 2008) diff --git a/games-rpg/eternal-lands/eternal-lands-1.7.0-r1.ebuild b/games-rpg/eternal-lands/eternal-lands-1.7.0-r1.ebuild new file mode 100644 index 000000000000..69e02853c444 --- /dev/null +++ b/games-rpg/eternal-lands/eternal-lands-1.7.0-r1.ebuild @@ -0,0 +1,157 @@ +# Copyright 1999-2008 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/games-rpg/eternal-lands/eternal-lands-1.7.0-r1.ebuild,v 1.1 2008/07/18 02:54:11 rich0 Exp $ + +inherit cvs eutils flag-o-matic games + +DESCRIPTION="An online MMORPG written in C and SDL" +HOMEPAGE="http://www.eternal-lands.com" +SRC_URI="mirror://gentoo/eternal-lands.png" + +LICENSE="eternal_lands" +SLOT="0" +KEYWORDS="~amd64 ~x86 ~x86-fbsd" +IUSE="debug doc kernel_linux" + +RDEPEND="x11-libs/libX11 + x11-libs/libXau + x11-libs/libXdmcp + x11-libs/libXext + virtual/opengl + virtual/glu + media-libs/libsdl + media-libs/sdl-net + media-libs/sdl-image + media-libs/openal + media-libs/freealut + media-libs/libvorbis + dev-libs/libxml2 + media-libs/cal3d + !=media-libs/cal3d-0.11.0_pre20050823 + media-libs/libpng + =games-rpg/eternal-lands-data-1.7.0" + +DEPEND="${RDEPEND} + >=app-admin/eselect-opengl-1.0.6-r1 + app-arch/unzip + doc? ( app-doc/doxygen + media-gfx/graphviz )" + +ECVS_SERVER="cvs.elc.berlios.de:/cvsroot/elc" +ECVS_MODULE="elc" +ECVS_USER="anonymous" +#ECVS_LOCALNAME="elc" +ECVS_PASS="" +ECVS_CVS_OPTIONS="-dP -z3" +ECVS_BRANCH="elc_1_7_0" + +S="${WORKDIR}/${ECVS_MODULE}" + +pkg_setup() { + games_pkg_setup + if built_with_use media-libs/cal3d 16bit-indices ; then + eerror "${PN} won't work if media-libs/cal3d has been built with 16bit-indices" + die "re-emerge media-libs/cal3d without the 16bit-indices USE flag" + fi +} + +src_unpack() { + cvs_src_unpack + OPTIONS="-DDATA_DIR="\\\\\"${GAMES_DATADIR}/${PN}/\\\\\""" + S_CLIENT="${WORKDIR}/elc" + BROWSER="firefox" + + + cd "${S}" + + epatch "${FILESDIR}/eternal-lands-1.7.0-errors.patch" + + + # Add debugging options + if use debug ; then + OPTIONS="${OPTIONS} -DMEMORY_DEBUG" + append-flags -ggdb + fi + + # Clean compile flags (make Gentoo friendly) + sed -i \ + -e "s@CFLAGS=\$(PLATFORM) \$(CWARN) -O0 -ggdb -pipe@CFLAGS = ${CFLAGS} ${OPTIONS} @g" \ + -e "s@CXXFLAGS=\$(PLATFORM) \$(CXXWARN) -O0 -ggdb -pipe@CXXFLAGS = ${CXXFLAGS} ${OPTIONS} @g" \ + -e 's/lopenal/lopenal -l alut/' \ + Makefile.linux || die "sed failed" + + sed -i \ + -e 's/#browser/browser/g' \ + -e "s/browser = mozilla/#browser = ${BROWSER}/g" \ + -e "s@#data_dir = /usr/local/games/el/@#data_dir = ${GAMES_DATADIR}/${PN}/@g" \ + el.ini || die "sed failed" + + # Support BSD in the Linux makefile - it's easier + use kernel_linux || sed -i \ + -e 's/^CFLAGS=.*/& -DBSD/' \ + Makefile.linux || die "sed failed" + + # Gah (anybody know why this is here?) +# sed -i \ +# -e 's/CXX=g++/CXX=gcc/' \ +# Makefile.linux || die "sed failed" + + # Finally, update the server + sed -i -e '/#server_address =/ s/.*/#server_address = game.eternal-lands.com/' \ + el.ini || die "sed failed" + + sed -i -e 's:FEATURES:EL_FEATURES:' make.defaults + sed -i -e 's:FEATURES:EL_FEATURES:' Makefile.linux + + if use debug; then + sed -i -e 's/#\(EL_FEATURES += MEMORY_DEBUG\)/\1/' make.defaults + sed -i -e 's/#\(EL_FEATURES += MEMORY_DEBUG\)/\1/' Makefile.linux + fi + + cp Makefile.linux Makefile +} + +src_compile() { + emake || die "make failed" + + if use doc; then + emake docs || die "Failed to create documentation, try with USE=-doc" + mv ./docs/html/ ../client || die "Failed to move documentation directory" + fi +} + +src_install() { + doicon "${DISTDIR}/eternal-lands.png" ${PN}.png + + newgamesbin el.x86.linux.bin el \ + || die "newgamesbin failed" + make_desktop_entry el "Eternal Lands" \ + || die "make_desktop_entry failed" + insopts -m 0660 + insinto "${GAMES_DATADIR}/${PN}" + + doins -r *.ini *.txt commands.lst \ + || die "doins failed" + + if use doc ; then + dohtml -r client/* + fi + + prepgamesdirs +} + +pkg_postinst() { + games_pkg_postinst + elog "Auto Update is now enabled in Eternal Lands" + elog "If an update occurs then the client will suddenly exit" + elog "Updates only happen when the game first loads" + elog "Please don't report this behaviour as a bug" + + # Ensure that the files are writable by the game group for auto + # updating. + chmod -R g+rw "${ROOT}/${GAMES_DATADIR}/${PN}" + + # Make sure new files stay in games group + find "${ROOT}/${GAMES_DATADIR}/${PN}" -type d -exec chmod g+sx {} \; + +} diff --git a/games-rpg/eternal-lands/files/eternal-lands-1.7.0-errors.patch b/games-rpg/eternal-lands/files/eternal-lands-1.7.0-errors.patch new file mode 100644 index 000000000000..7af126db0b9a --- /dev/null +++ b/games-rpg/eternal-lands/files/eternal-lands-1.7.0-errors.patch @@ -0,0 +1,17 @@ +--- errors.c.orig 2008-07-17 22:43:28.791326638 -0400 ++++ errors.c 2008-07-17 22:44:37.258432153 -0400 +@@ -68,12 +68,12 @@ + time(&c_time); + l_time = localtime(&c_time); + strftime(logmsg, sizeof(logmsg), "[%H:%M:%S] ", l_time); +- strcat(logmsg, errmsg); ++ strncat(logmsg, errmsg, sizeof(logmsg)-strlen(logmsg)-2); + + if(message[strlen(message)-1] != '\n') { + strcat(logmsg, "\n"); + } +- fprintf(err_file, logmsg); ++ fputs(logmsg, err_file); + fflush (err_file); + } + |