diff options
author | Michał Górny <mgorny@gentoo.org> | 2010-10-08 18:18:59 +0000 |
---|---|---|
committer | Michał Górny <mgorny@gentoo.org> | 2010-10-08 18:18:59 +0000 |
commit | 8ac3a4d0eeb7c4dfbcdd10e078931fdc21b0f2e3 (patch) | |
tree | 4f172cd4c1d2555f6ac92fd4620c5ca9aef3881f /net-im | |
parent | Bug #339634: version bump. Package.masked. (diff) | |
download | gentoo-2-8ac3a4d0eeb7c4dfbcdd10e078931fdc21b0f2e3.tar.gz gentoo-2-8ac3a4d0eeb7c4dfbcdd10e078931fdc21b0f2e3.tar.bz2 gentoo-2-8ac3a4d0eeb7c4dfbcdd10e078931fdc21b0f2e3.zip |
Introduce today's snapshot ebuild.
(Portage version: 2.2_rc91_p1/cvs/Linux x86_64)
Diffstat (limited to 'net-im')
-rw-r--r-- | net-im/ekg2/ChangeLog | 8 | ||||
-rw-r--r-- | net-im/ekg2/ekg2-0.3_pre20101008.ebuild | 221 |
2 files changed, 228 insertions, 1 deletions
diff --git a/net-im/ekg2/ChangeLog b/net-im/ekg2/ChangeLog index b09a0a86f31c..2c7ffe0b2b7c 100644 --- a/net-im/ekg2/ChangeLog +++ b/net-im/ekg2/ChangeLog @@ -1,6 +1,12 @@ # ChangeLog for net-im/ekg2 # Copyright 1999-2010 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/net-im/ekg2/ChangeLog,v 1.31 2010/10/08 13:53:08 mgorny Exp $ +# $Header: /var/cvsroot/gentoo-x86/net-im/ekg2/ChangeLog,v 1.32 2010/10/08 18:18:59 mgorny Exp $ + +*ekg2-0.3_pre20101008 (08 Oct 2010) + + 08 Oct 2010; Michał Górny <mgorny@gentoo.org> + +ekg2-0.3_pre20101008.ebuild: + Introduce today's snapshot ebuild. *ekg2-9999 (08 Oct 2010) diff --git a/net-im/ekg2/ekg2-0.3_pre20101008.ebuild b/net-im/ekg2/ekg2-0.3_pre20101008.ebuild new file mode 100644 index 000000000000..f64cb1aaa125 --- /dev/null +++ b/net-im/ekg2/ekg2-0.3_pre20101008.ebuild @@ -0,0 +1,221 @@ +# Copyright 1999-2010 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/net-im/ekg2/ekg2-0.3_pre20101008.ebuild,v 1.1 2010/10/08 18:18:59 mgorny Exp $ + +EAPI=2 + +inherit multilib perl-module scons-utils toolchain-funcs + +DESCRIPTION="Text-based, multi-protocol instant messenger" +HOMEPAGE="http://www.ekg2.org" +SRC_URI="http://github.com/downloads/mgorny/${PN}-scons/${P}.tar.bz2" + +LICENSE="GPL-2" +SLOT="0" +KEYWORDS="~amd64" +IUSE="dbus extra gadu gif gnutls gpg gpm gsm gtk icq idn inotify irc + jabber jogger jpeg mail minimal ncurses nls nntp oracle oss pcap + perl python readline remote rss ruby sim sms spell + sqlite sqlite3 srv ssl static unicode web xosd zlib" + +# -- non-obvious plugin mappings -- +# extra -> autoresponder, polchat, rivchat, rot13, xmsg +# !minimal -> ioctld, logs, rc +# any sound -> pcm +# web -> httprc_xajax + +RDEPEND=" + dbus? ( sys-apps/dbus ) + gpg? ( app-crypt/gpgme ) + gsm? ( media-sound/gsm ) + gtk? ( x11-libs/gtk+:2 ) + idn? ( net-dns/libidn ) + nls? ( virtual/libintl ) + oracle? ( dev-db/oracle-instantclient-basic ) + pcap? ( net-libs/libpcap ) + perl? ( dev-lang/perl ) + python? ( dev-lang/python ) + readline? ( sys-libs/readline ) + rss? ( dev-libs/expat ) + ruby? ( dev-lang/ruby ) + sim? ( dev-libs/openssl ) + xosd? ( x11-libs/xosd ) + gadu? ( net-libs/libgadu + gif? ( media-libs/giflib ) + jpeg? ( media-libs/jpeg ) ) + irc? ( ssl? ( dev-libs/openssl ) ) + jabber? ( dev-libs/expat + gnutls? ( net-libs/gnutls ) + !gnutls? ( ssl? ( dev-libs/openssl ) ) + zlib? ( sys-libs/zlib ) ) + !minimal? ( + zlib? ( sys-libs/zlib ) ) + ncurses? ( sys-libs/ncurses[unicode?] + gpm? ( sys-libs/gpm ) + spell? ( app-text/aspell ) ) + sqlite3? ( dev-db/sqlite:3 ) + !sqlite3? ( sqlite? ( dev-db/sqlite:0 ) )" + +DEPEND="${RDEPEND} + nls? ( sys-devel/gettext )" + +pkg_setup() { + if ! use gtk && ! use ncurses && ! use readline && ! use remote && ! use web; then + ewarn 'ekg2 is being compiled without any frontend, you should consider' + ewarn 'enabling at least one of following USEflags:' + ewarn ' gtk, ncurses, readline, remote, web.' + fi +} + +use_plug() { + use ${1} && echo -n ,${2:-${1}} +} + +# Build comma-separated plugin list based on USE +# We can put the same plugin few times if it's referenced by more than one flag + +build_plugin_list() { + echo '@none' \ + $(use_plug dbus) \ + $(use_plug extra autoresponder,polchat,rivchat,rot13,xmsg) \ + $(use_plug gadu gg) \ + $(use_plug gpg) \ + $(use_plug gsm) \ + $(use_plug gtk) \ + $(use_plug icq) \ + $(use_plug irc) \ + $(use_plug jabber jabber) \ + $(use_plug jogger jogger) \ + $(use_plug mail) \ + $(use_plug !minimal ioctld,logs,rc) \ + $(use_plug ncurses) \ + $(use_plug nntp feed) \ + $(use_plug oracle logsoracle) \ + $(use_plug oss oss,pcm) \ + $(use_plug pcap sniff) \ + $(use_plug perl) \ + $(use_plug python) \ + $(use_plug readline) \ + $(use_plug remote) \ + $(use_plug rss feed) \ + $(use_plug ruby) \ + $(use_plug sim) \ + $(use_plug sms) \ + $(use_plug sqlite logsqlite) \ + $(use_plug sqlite3 logsqlite) \ + $(use_plug web httprc_xajax) \ + $(use_plug xosd) \ + | tr -d '[[:space:]]' +} + +# create DEPS list for plugin +# + means dep forced (fail if unavailable, prioritize over other one-of) +# - means dep disabled (don't even check for it) +# use:opt maps USEflag to specified opt +# usea|useb|usec makes one-of opt + +make_deps() { + local spls spll flag fopt out + + echo -n " ${1}_DEPS=" + shift + + # loop over different opts + while [[ -n ${1} ]]; do + spls=${1} + out= + # loop over one-of opts + while true; do + # get next one-of, make sure spls gets empty if last + spll=${spls%%|*} + spls=${spls:$(( ${#spll} + 1 ))} + # parse use:opt, if no :opt specified fopt=flag + flag=${spll%:*} + fopt=${spll#*:} + + # if one of one-of opt matches, we output only it + # else we need to output all of them disabled + use ${flag} && out=+ || out=${out}- + out=${out}${fopt} + + # got more one-of opts? parse them only if this didn't match + if [[ -n ${spls} ]] && ! use ${flag}; then + out=${out}, + continue + fi + + echo -n ${out} + shift + [[ -n ${1} ]] && echo -n , + break + done + done +} + +# create all DEPS lists + +build_addopts_list() { + use extra && make_deps XMSG inotify + use gadu && make_deps GG gif jpeg + use irc && make_deps IRC 'ssl:openssl' + use jabber && make_deps JABBER zlib 'gnutls|ssl:openssl' + use mail && make_deps MAIL inotify + use !minimal && make_deps LOGS zlib + use ncurses && make_deps NCURSES gpm spell:aspell + use rss || use nntp && make_deps FEED rss:expat + use sqlite3 || use sqlite && make_deps LOGSQLITE 'sqlite3|sqlite' +} + +# SCons doesn't build perl modules, perl-module.eclass does it better + +foreach_perl_module() { + if use perl; then + local d + for d in "${S}"/plugins/perl/*/; do + cd "${d}" || die + ${1} + + # workaround perl-module.eclass + unset SRC_PREP + done + fi +} + +src_configure() { + # HARDDEPS -> build should fail if some dep is unsatisfied + # DISTNOTES -> are displayed with /version, helpful for upstream bug reports + + tc-export CC + escons PLUGINS=$(build_plugin_list) $(build_addopts_list) \ + HARDDEPS=1 SKIPCHECKS=1 RELPLUGINS=0 \ + $(use_scons unicode UNICODE) $(use_scons nls NLS) \ + $(use_scons static STATIC) $(use_scons idn IDN) \ + $(use_scons srv RESOLV) \ + PREFIX=/usr LIBDIR="\$EPREFIX/$(get_libdir)" \ + DOCDIR="\$DATAROOTDIR/doc/${PF}" \ + DISTNOTES="Gentoo ebuild ${PVR}, USE='${USE}'" \ + ${MAKEOPTS} conf || die "escons conf failed" + + foreach_perl_module perl-module_src_configure +} + +src_compile() { + # SKIPCONF -> no need to reconfigure + + escons SKIPCONF=1 ${MAKEOPTS} || die + + foreach_perl_module perl-module_src_compile +} + +src_test() { + foreach_perl_module perl-module_src_test +} + +src_install() { + escons DESTDIR="${D}" ${MAKEOPTS} install || die + + foreach_perl_module perl-module_src_install + + # XXX: replace it when an alternative is available + prepalldocs +} |