From 5f20e4fc039b0c1acbeef55008761438bb2aa133 Mon Sep 17 00:00:00 2001 From: Bertrand Jacquin Date: Wed, 2 Nov 2005 18:35:40 +0000 Subject: add e eclass for new CVS servers --- eclass/enlightenment.eclass | 163 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 163 insertions(+) create mode 100644 eclass/enlightenment.eclass (limited to 'eclass') diff --git a/eclass/enlightenment.eclass b/eclass/enlightenment.eclass new file mode 100644 index 00000000..e2364cde --- /dev/null +++ b/eclass/enlightenment.eclass @@ -0,0 +1,163 @@ +# Copyright 1999-2005 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/eclass/enlightenment.eclass,v 1.56 2005/08/23 23:53:26 vapier Exp $ +# +# Author: vapier@gentoo.org + +inherit eutils + +# ECVS_STATE's: +# release [default] +# KEYWORDS arch +# SRC_URI $P.tar.gz +# S $WORKDIR/$P +# +# snap $PV has .200##### datestamp or .### counter +# KEYWORDS ~arch +# SRC_URI $P.tar.bz2 +# S $WORKDIR/$P +# +# live $PV has a 9999 marker +# KEYWORDS -* +# SRC_URI `cvs up` +# S $WORKDIR/$ECVS_MODULE +# +# Overrides: +# KEYWORDS EKEY_STATE +# SRC_URI EURI_STATE +# S EURI_STATE + +EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install pkg_postinst + +ECVS_STATE="release" +if [[ ${PV/9999} != ${PV} ]] ; then + if [[ -z ${ECVS_MODULE} ]] ; then + ECVS_MODULE=${PN} + if [[ ${CATEGORY/libs} != ${CATEGORY} ]] ; then + ECVS_MODULE="e17/libs/${PN}" + else + ECVS_MODULE="e17/apps/${PN}" + fi + fi + + if [[ ${ECVS_MODULE/\/*} == "e17" ]]; then + ECVS_SERVER="-thinktux.net:/root" + elif [[ ${ECVS_MODULE/\/*} == "misc" ]]; then + ECVS_SERVER="-thinktux.net:/root" + fi + + ECVS_SERVER=${ECVS_SERVER:-cvs.sourceforge.net:/cvsroot/enlightenment} + ECVS_STATE="live" + inherit cvs +elif [[ ${PV/.200[3-9][0-1][0-9][0-3][0-9]/} != ${PV} ]] ; then + ECVS_STATE="snap" +elif [[ ${PV%%.[0-9][0-9][0-9]} != ${PV} ]] ; then + ECVS_STATE="snap" + EURI_STATE="release" +fi + +DESCRIPTION="A DR17 production" +HOMEPAGE="http://www.enlightenment.org/" +case ${EURI_STATE:-${ECVS_STATE}} in + release) SRC_URI="http://enlightenment.freedesktop.org/files/${P}.tar.gz mirror://sourceforge/enlightenment/${P}.tar.gz";; + snap) SRC_URI="mirror://gentoo/${P}.tar.bz2";; + live) SRC_URI="";; +esac + +LICENSE="BSD" +SLOT="0" +case ${EKEY_STATE:-${ECVS_STATE}} in + release) KEYWORDS="alpha amd64 arm hppa ia64 mips ppc ppc64 sparc x86";; + snap) KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~mips ~ppc ~ppc64 ~sparc ~x86";; + live) KEYWORDS="-*";; +esac +IUSE="nls doc" + +DEPEND="doc? ( app-doc/doxygen )" +RDEPEND="nls? ( sys-devel/gettext )" + +case ${EURI_STATE:-${ECVS_STATE}} in + release) S=${WORKDIR}/${P};; + snap) S=${WORKDIR}/${PN};; + live) S=${WORKDIR}/${ECVS_MODULE};; +esac + +enlightenment_warning_msg() { + if [[ ${ECVS_STATE} == "snap" ]] ; then + ewarn "Please do not contact the E team about bugs in Gentoo." + ewarn "Only contact vapier@gentoo.org via e-mail or bugzilla." + ewarn "Remember, this stuff is CVS only code so dont cry when" + ewarn "I break you :)." + elif [[ ${ECVS_STATE} == "live" ]] ; then + eerror "This is a LIVE CVS ebuild." + eerror "That means there are NO promises it will work." + eerror "If it fails to build, FIX THE CODE YOURSELF" + eerror "before reporting any issues." + fi +} + +enlightenment_die() { + enlightenment_warning_msg + die "$@"$'\n'"!!! SEND BUG REPORTS TO vapier@gentoo.org NOT THE E TEAM" +} + +enlightenment_pkg_setup() { + enlightenment_warning_msg +} + +# the stupid gettextize script prevents non-interactive mode, so we hax it +gettext_modify() { + use nls || return 0 + cp $(which gettextize) "${T}"/ || die "could not copy gettextize" + sed -i \ + -e 's:read dummy < /dev/tty::' \ + "${T}"/gettextize +} + +enlightenment_src_unpack() { + if [[ ${ECVS_STATE} == "live" ]] ; then + cvs_src_unpack + else + unpack ${A} + fi + gettext_modify + [[ -s gendoc ]] && chmod a+rx gendoc +} + +enlightenment_src_compile() { + if [[ ! -e configure ]] ; then + export WANT_AUTOMAKE=${EAUTOMAKE:-1.8} + env \ + PATH="${T}:${PATH}" \ + NOCONFIGURE=yes \ + USER=blah \ + ./autogen.sh \ + || enlightenment_die "autogen failed" + # symlinked files will cause sandbox violation + for x in config.{guess,sub} ; do + [[ ! -L ${x} ]] && continue + rm -f ${x} + touch ${x} + done + if [[ ! -z ${EHACKLIBLTDL} ]] ; then + cd libltdl + autoconf || enlightenment_die "autogen in libltdl failed" + cd .. + fi + fi + epunt_cxx + econf ${MY_ECONF} || enlightenment_die "econf failed" + emake || enlightenment_die "emake failed" + use doc && [[ -x ./gendoc ]] && { ./gendoc || enlightenment_die "gendoc failed" ; } +} + +enlightenment_src_install() { + make install DESTDIR="${D}" || enlightenment_die + find "${D}" -name CVS -type d -exec rm -rf '{}' \; 2>/dev/null + dodoc AUTHORS ChangeLog NEWS README TODO ${EDOCS} + use doc && [[ -d doc ]] && dohtml -r doc/* +} + +enlightenment_pkg_postinst() { + enlightenment_warning_msg +} -- cgit v1.2.3