diff options
author | Christian Parpart <trapni@gentoo.org> | 2009-02-14 07:51:02 +0000 |
---|---|---|
committer | Christian Parpart <trapni@gentoo.org> | 2009-02-14 07:51:02 +0000 |
commit | d2ca3e7335a81fda1bc5a2114775b11801d3f823 (patch) | |
tree | 7e6e163a41463de41609ef8bbd7f6e6b592f4ea9 /games-rpg/mangos/mangos-9999.1.ebuild | |
parent | Fix implicit strsep() prototype in x509 code #258795 by orlin. (diff) | |
download | gentoo-2-d2ca3e7335a81fda1bc5a2114775b11801d3f823.tar.gz gentoo-2-d2ca3e7335a81fda1bc5a2114775b11801d3f823.tar.bz2 gentoo-2-d2ca3e7335a81fda1bc5a2114775b11801d3f823.zip |
adapted to changes in built management; and updated project uri.
(Portage version: 2.2_rc23/cvs/Linux x86_64)
Diffstat (limited to 'games-rpg/mangos/mangos-9999.1.ebuild')
-rw-r--r-- | games-rpg/mangos/mangos-9999.1.ebuild | 155 |
1 files changed, 155 insertions, 0 deletions
diff --git a/games-rpg/mangos/mangos-9999.1.ebuild b/games-rpg/mangos/mangos-9999.1.ebuild new file mode 100644 index 000000000000..5c42c4c21463 --- /dev/null +++ b/games-rpg/mangos/mangos-9999.1.ebuild @@ -0,0 +1,155 @@ +# Copyright 1999-2009 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/games-rpg/mangos/mangos-9999.1.ebuild,v 1.1 2009/02/14 07:51:02 trapni Exp $ + +# TODO: +# - make use of system's zlib/zthread ebuilds instead of mangos' packaged +# - create ebuilds for specific releases (and related patchsets, if desired) + +inherit eutils git subversion autotools + +MANGOS_REPO_URI="git://github.com/mangos/mangos.git" +SD2_REPO_URI="https://scriptdev2.svn.sourceforge.net/svnroot/scriptdev2" + +EGIT_REPO_URI="${MANGOS_REPO_URI}" +ESVN_REPO_URI="${SD2_REPO_URI}" + +DESCRIPTION="Massive Network Game Object Server" +HOMEPAGE="http://getmangos.com/" + +LICENSE="GPL-2" +SLOT="0" +KEYWORDS="~amd64 ~x86" +IUSE="cli ra sd2 debug mysql postgres" + +RDEPEND="postgres? ( virtual/postgresql-server ) + mysql? ( >=virtual/mysql-4.1 ) + !mysql? ( !postgres? ( >=virtual/mysql-4.1 ) )" + +DEPEND="${RDEPEND} + >=sys-devel/gcc-3.2 + sys-devel/make + sys-devel/automake + sys-devel/autoconf + dev-libs/glib + dev-libs/openssl" + +## setup some env vars we use everywhere (but might change from ebuild to ebuild) +setup_env() { +# export PREFIX='/usr' +# export SYSCONFDIR='/etc/mangos' +# export LOGDIR='/var/log/mangos' + + export PREFIX='/opt/mangos' + export SYSCONFDIR='/opt/mangos/etc' + export LOGDIR='/opt/mangos/log' + + export PV_FILES='9999' +} + +pkg_setup() { + if useq mysql && useq postgres; then + eerror "Please decide with database you want to use for this ebuild by" + eerror "explicitely enabling/disabling the mysql and postgres USE-flags!" + die "Both useflags - mysql and postgres - has been specified. Choose one of them only!" + fi + enewgroup mangos + enewuser mangos +} + +## unpacks SD2 (ScriptDev2) into mangos workdir +sd2_src_unpack() { + S="${S}/src/bindings/ScriptDev2" ESVN_REPO_URI="${SD2_REPO_URI}" subversion_src_unpack || die + + local PATCHES_DIR="${S}/src/bindings/ScriptDev2/patches" + local FILE=$(ls ${PATCHES_DIR} | sort -f -r | awk "NR == 1") + + EPATCH_OPTS="-d ${S}" EPATCH_FORCE="yes" epatch "${PATCHES_DIR}/${FILE}" || die +} + +src_unpack() { + git_src_unpack + + useq sd2 && sd2_src_unpack + + cd "${S}" || die + eautoreconf --force --install || die "eautoreconf failed" +} + +src_compile() { + setup_env + local myconf + + if ! useq mysql && ! useq postgres; then + # defaulth to mysql in case nothing has been specified. + myconf="${myconf} --with-mysql" + fi + + mkdir obj || die + cd obj + + ECONF_SOURCE=.. econf \ + --with-gnu-ld \ + ${myconf} \ + --prefix=${PREFIX} \ + --sysconfdir=${SYSCONFDIR} \ + $(use_with mysql) \ + $(use_with postgres postgresql) \ + $(use_enable cli) \ + $(use_enable ra) \ + $(use_enable doc doxygen) \ + $(use_enable debug debug-info) \ + || die "econf failed" + + emake || die "emake with current options failed" +} + +src_install() { + setup_env + + cd obj + + emake DESTDIR="${D}" install || die "emake install failed" + + rm -f "${D}${PREFIX}/bin/genrevision" # not really part of mangos dist + + doinitd "${FILESDIR}/${PV_FILES}/mangos-realmd" || die + doinitd "${FILESDIR}/${PV_FILES}/mangos-worldd" || die + + dodir ${PREFIX}/share/mangos/dbc + dodir ${PREFIX}/share/mangos/maps + dodir ${PREFIX}/share/mangos/vmaps + + if useq sd2; then + local DIRS=(sql sql/Updates sql/Updates/0.0.1 sql/Updates/0.0.2) + + for dir in ${DIRS[*]}; do + dodir ${PREFIX}/share/sd2/${dir} || die + cp -r ../src/bindings/ScriptDev2/${dir}/*.sql ${D}${PREFIX}/share/sd2/${dir} || die + done + fi + + dodir ${LOGDIR} + + fowners root.mangos /etc/mangos + fowners mangos.mangos /var/log/mangos +} + +pkg_postinst() { + setup_env + + ewarn "You need to manually configure MaNGOS." + ewarn "See /etc/mangos/ for config files." + ewarn "Remember to move you maps, DBC and vmaps files to your data folder - ${PREFIX}/share/mangos/" + ewarn + ewarn "Don't forget to run SQL scripts for:" + ewarn "\t- MaNGOS databases : ${PREFIX}/share/mangos/sql" + + useq sd2 && ewarn "\t- ScriptDev2 database: /usr/share/scriptdev2/sql" + + ewarn + einfo "If you want Mangos to start automatically on boot execute :" + einfo "\t- rc-update add mangos-realmd default" + einfo "\t- rc-update add mangos-worldd default" + einfo +} |