summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--net-libs/ptlib/ChangeLog11
-rw-r--r--net-libs/ptlib/files/ptlib-2.6.2-gcc-allocator.patch16
-rw-r--r--net-libs/ptlib/metadata.xml35
-rw-r--r--net-libs/ptlib/ptlib-2.6.2.ebuild307
4 files changed, 369 insertions, 0 deletions
diff --git a/net-libs/ptlib/ChangeLog b/net-libs/ptlib/ChangeLog
new file mode 100644
index 000000000000..d260711b9d8b
--- /dev/null
+++ b/net-libs/ptlib/ChangeLog
@@ -0,0 +1,11 @@
+# ChangeLog for net-libs/ptlib
+# Copyright 1999-2009 Gentoo Foundation; Distributed under the GPL v2
+# $Header: /var/cvsroot/gentoo-x86/net-libs/ptlib/ChangeLog,v 1.1 2009/07/03 09:57:10 volkmar Exp $
+
+*ptlib-2.6.2 (03 Jul 2009)
+
+ 03 Jul 2009; Mounir Lamouri <volkmar@gentoo.org>
+ +files/ptlib-2.6.2-gcc-allocator.patch, +metadata.xml,
+ +ptlib-2.6.2.ebuild:
+ Initial commit. Actually, somewhat bump of dev-libs/pwlib. Fix bug 238617
+
diff --git a/net-libs/ptlib/files/ptlib-2.6.2-gcc-allocator.patch b/net-libs/ptlib/files/ptlib-2.6.2-gcc-allocator.patch
new file mode 100644
index 000000000000..f80c3a186a59
--- /dev/null
+++ b/net-libs/ptlib/files/ptlib-2.6.2-gcc-allocator.patch
@@ -0,0 +1,16 @@
+--- src/ptlib/common/contain.cxx.old 2009-05-21 08:24:13.000000000 +0200
++++ src/ptlib/common/contain.cxx 2009-05-21 08:24:24.000000000 +0200
+@@ -56,13 +56,6 @@
+ #define __CLASS__ GetClass()
+
+
+-#ifdef __GNUC__
+-
+-#include <ext/pool_allocator.h>
+-#include <ext/mt_allocator.h>
+-
+-#endif
+-
+ ///////////////////////////////////////////////////////////////////////////////
+ //
+ // Use a custom allocator for PContainer references
diff --git a/net-libs/ptlib/metadata.xml b/net-libs/ptlib/metadata.xml
new file mode 100644
index 000000000000..d685b89c82cb
--- /dev/null
+++ b/net-libs/ptlib/metadata.xml
@@ -0,0 +1,35 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE pkgmetadata SYSTEM "http://www.gentoo.org/dtd/metadata.dtd">
+<pkgmetadata>
+ <herd>voip</herd>
+ <maintainer>
+ <email>volkmar@gentoo.org</email>
+ <name>Mounir Lamouri</name>
+ </maintainer>
+ <use>
+ <flag name="asn">Enable ASN decoding/encoding support</flag>
+ <flag name="audio">Enable audio support</flag>
+ <flag name="config-file">Enable config file support</flag>
+ <flag name="dns">Enable DNS resolver support</flag>
+ <flag name="dtmf">Enable DTMF encoding/decoding support</flag>
+ <flag name="http">Enable HTTP support</flag>
+ <flag name="http-forms">Enable http forms support</flag>
+ <flag name="http-server">Enable http server support</flag>
+ <flag name="mail">Enable mail protocols (POP3/SMTP)</flag>
+ <flag name="pipechan">Enable pipechannel support</flag>
+ <flag name="qos">Enable QOS support</flag>
+ <flag name="remote">Enable remote connection support</flag>
+ <flag name="serial">Enable serial port support</flag>
+ <flag name="shmvideo">Enable shared memory video devices</flag>
+ <flag name="socks">Enable SOCKS protocol support</flag>
+ <flag name="stun">Enable STUN support</flag>
+ <flag name="telnet">Enable telnet protocol support</flag>
+ <flag name="tts">Enable Text-To-Speech server support</flag>
+ <flag name="url">Enable URL support</flag>
+ <flag name="video">Enable video support</flag>
+ <flag name="video-file">Enable video file support</flag>
+ <flag name="vxml">Enable VoiceXML support</flag>
+ <flag name="wav">Enable WAVFILE support</flag>
+ </use>
+</pkgmetadata>
+
diff --git a/net-libs/ptlib/ptlib-2.6.2.ebuild b/net-libs/ptlib/ptlib-2.6.2.ebuild
new file mode 100644
index 000000000000..3994a30d2510
--- /dev/null
+++ b/net-libs/ptlib/ptlib-2.6.2.ebuild
@@ -0,0 +1,307 @@
+# Copyright 1999-2009 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/net-libs/ptlib/ptlib-2.6.2.ebuild,v 1.1 2009/07/03 09:57:10 volkmar Exp $
+
+EAPI="2"
+
+inherit eutils
+
+DESCRIPTION="Network focused portable C++ class library providing high level functions"
+HOMEPAGE="http://www.opalvoip.org/"
+SRC_URI="mirror://sourceforge/opalvoip/${P}.tar.bz2
+ doc? ( mirror://sourceforge/opalvoip/${P}-htmldoc.tar.bz2 )"
+
+LICENSE="MPL-1.0"
+SLOT="0"
+KEYWORDS="~ppc ~x86"
+# default enabled are features from 'minsize', the most used according to ptlib
+IUSE="alsa +asn +audio config-file debug dns doc dtmf esd examples ffmpeg ftp
++http http-forms http-server ieee1394 ipv6 jabber ldap mail pipechan odbc oss
+pch qos remote sasl sdl serial shmvideo snmp soap socks ssl +stun telnet tts
++url v4l v4l2 +video video-file vxml wav xml xmlrpc"
+
+COMMON_DEP="audio? ( alsa? ( media-libs/alsa-lib )
+ esd? ( media-sound/esound ) )
+ ldap? ( net-nds/openldap )
+ odbc? ( dev-db/unixODBC )
+ sasl? ( dev-libs/cyrus-sasl:2 )
+ sdl? ( media-libs/libsdl )
+ ssl? ( dev-libs/openssl )
+ video? ( ieee1394? ( media-libs/libdc1394:1
+ media-libs/libdv
+ sys-libs/libavc1394
+ sys-libs/libraw1394 )
+ v4l2? ( media-libs/libv4l ) )
+ xml? ( dev-libs/expat )"
+RDEPEND="${COMMON_DEP}
+ ffmpeg? ( media-video/ffmpeg )"
+DEPEND="${COMMON_DEP}
+ dev-util/pkgconfig
+ sys-devel/bison
+ sys-devel/flex
+ video? ( v4l? ( sys-kernel/linux-headers )
+ v4l2? ( sys-kernel/linux-headers ) )
+ !!dev-libs/pwlib"
+
+# NOTES:
+# media-libs/libdc1394:2 should be supported but headers location have changed
+# tools/ directory is ignored
+# looks to have an auto-magic dep with medialibs, but not in the tree so...
+# upstream bug 2794736
+
+# TODO:
+# manage in a better way the conditional use flags (with eapi-3 ?)
+
+conditional_use_error_msg() {
+ eerror "To enable ${1} USE flag, you need ${2} USE flag to be enabled"
+ eerror "Please, enable ${2} or disable ${1}"
+}
+
+pkg_setup() {
+ local use_error=false
+
+ # stop emerge if a conditional use flag is not respected
+
+ if ! use video; then
+ if use sdl; then
+ conditional_use_error_msg "sdl" "video"
+ use_error=true
+ fi
+ if use video-file; then
+ conditional_use_error_msg "video-file" "video"
+ use_error=true
+ fi
+ fi
+
+ if use jabber && ! use xml; then
+ conditional_use_error_msg "jabber" "xml"
+ use_error=true
+ fi
+
+ if use ldap && ! use dns; then
+ conditional_use_error_msg "ldap" "dns"
+ use_error=true
+ fi
+
+ if use ffmpeg && ! use pipechan; then
+ conditional_use_error_msg "ffmpeg" "pipechan"
+ use_error=true
+ fi
+
+ if use http && ! use url; then
+ conditional_use_error_msg "http" "url"
+ use_error=true
+ fi
+
+ if use http-forms; then
+ if ! use http; then
+ conditional_use_error_msg "http-forms" "http"
+ use_error=true
+ fi
+ if ! use config-file; then
+ conditional_use_error_msg "http-forms" "config-file"
+ use_error=true
+ fi
+ fi
+
+ if use http-server && ! use http-forms; then
+ conditional_use_error_msg "http-server" "http-forms"
+ use_error=true
+ fi
+
+ if use vxml; then
+ if ! use xml; then
+ conditional_use_error_msg "vxml" "xml"
+ use_error=true
+ fi
+ if ! use http; then
+ conditional_use_error_msg "vxml" "http"
+ use_error=true
+ fi
+ fi
+
+ if use xmlrpc; then
+ if ! use xml; then
+ conditional_use_error_msg "xmlrpc" "xml"
+ use_error=true
+ fi
+ if ! use http; then
+ conditional_use_error_msg "xmlrpc" "http"
+ use_error=true
+ fi
+ fi
+
+ if use soap; then
+ if ! use xml; then
+ conditional_use_error_msg "soap" "xml"
+ use_error=true
+ fi
+ if ! use http; then
+ conditional_use_error_msg "soap" "http"
+ use_error=true
+ fi
+ fi
+
+ if ${use_error}; then
+ echo
+ eerror "Please see messages above and re-emerge ${PN} accordingly."
+ die
+ fi
+}
+
+src_prepare() {
+ # move files from doc tarball into ${S}
+ if use doc; then
+ mv ../html . || die "moving doc files failed"
+ fi
+
+ # remove visual studio related files from samples/
+ if use examples; then
+ rm -f samples/*/*.vcproj
+ rm -f samples/*/*.sln
+ rm -f samples/*/*.dsp
+ rm -f samples/*/*.dsw
+ fi
+
+ # workaround for a compilation issue in contain.cxx, upstream bug 2794741
+ epatch "${FILESDIR}"/${P}-gcc-allocator.patch
+}
+
+src_configure() {
+ local myconf=""
+
+ # plugins are disabled only if ! audio and ! video
+ if ! use audio && ! use video; then
+ myconf="${myconf} --disable-plugins"
+ else
+ myconf="${myconf} --enable-plugins"
+ fi
+
+ # minsize, openh323, opal: presets of features (overwritten by use flags)
+ # ansi-bool, atomicity: there is no reason to disable those features
+ # internalregex: we want to use system one
+ # sunaudio and bsdvideo are respectively for SunOS and BSD's
+ # appshare, vfw: only for windows
+ # sockagg: not used anymore, upstream bug 2794755
+ # samples: no need to build samples
+ econf ${myconf} \
+ --disable-minsize \
+ --disable-openh323 \
+ --disable-opal \
+ --enable-ansi-bool \
+ --enable-atomicity \
+ --disable-internalregex \
+ --disable-sunaudio \
+ --disable-bsdvideo \
+ --disable-appshare \
+ --disable-vfw \
+ --disable-sockagg \
+ --disable-samples \
+ $(use_enable audio) \
+ $(use_enable alsa) \
+ $(use_enable asn) \
+ $(use_enable config-file configfile) \
+ $(use_enable debug exceptions) \
+ $(use_enable debug memcheck) \
+ $(use_enable debug tracing) \
+ $(use_enable dns resolver) \
+ $(use_enable dtmf) \
+ $(use_enable esd) \
+ $(use_enable ffmpeg ffvdev) \
+ $(use_enable ftp) \
+ $(use_enable http) \
+ $(use_enable http-forms httpforms) \
+ $(use_enable http-server httpsvc) \
+ $(use_enable ieee1394 avc) \
+ $(use_enable ieee1394 dc) \
+ $(use_enable ipv6) \
+ $(use_enable jabber) \
+ $(use_enable ldap openldap) \
+ $(use_enable mail pop3smtp) \
+ $(use_enable odbc) \
+ $(use_enable oss) \
+ $(use_enable pch) \
+ $(use_enable pipechan) \
+ $(use_enable qos) \
+ $(use_enable remote remconn) \
+ $(use_enable sasl) \
+ $(use_enable sdl) \
+ $(use_enable serial) \
+ $(use_enable shmvideo) \
+ $(use_enable snmp) \
+ $(use_enable soap) \
+ $(use_enable socks) \
+ $(use_enable ssl openssl) \
+ $(use_enable stun) \
+ $(use_enable telnet) \
+ $(use_enable tts) \
+ $(use_enable url) \
+ $(use_enable v4l) \
+ $(use_enable v4l2) \
+ $(use_enable video) \
+ $(use_enable video-file vidfile) \
+ $(use_enable vxml) \
+ $(use_enable wav wavfile) \
+ $(use_enable xml expat) \
+ $(use_enable xmlrpc)
+}
+
+src_compile() {
+ local makeopts=""
+
+ use debug && makeopts="debug"
+
+ emake ${makeopts} || die "emake failed"
+}
+
+src_install() {
+ local makeopts=""
+
+ use debug && makeopts="DEBUG=1"
+
+ emake DESTDIR="${D}" ${makeopts} install || die "emake install failed"
+
+ if use doc; then
+ dohtml -r html/* || die "dohtml failed"
+ fi
+
+ dodoc History.txt ReadMe.txt ReadMe_QOS.txt || die "dodoc failed"
+
+ # ChangeLog is not standard
+ dodoc ChangeLog-${PN}-v${PV//./_}.txt || die "dodoc failed"
+
+ if use examples; then
+ local exampledir="/usr/share/doc/${PF}/examples"
+ local basedir="samples"
+ local sampledirs="`ls samples --hide=Makefile`"
+
+ # first, install Makefile
+ insinto ${exampledir}/
+ doins ${basedir}/Makefile || die "doins failed"
+
+ # now, all examples
+ for x in ${sampledirs}; do
+ insinto ${exampledir}/${x}/
+ doins ${basedir}/${x}/* || die "doins failed"
+ done
+ fi
+}
+
+pkg_postinst() {
+ if use examples; then
+ ewarn "All examples have been installed, some of them will not work on your system"
+ ewarn "it will depend of the enabled USE flags."
+ ewarn "To test examples, you have to run PTLIBDIR=/usr/share/ptlib make"
+ fi
+
+ if ! use audio || ! use video; then
+ ewarn "You have disabled audio or video USE flags."
+ ewarn "Most audio/video have been disabled silently even if enabled via USE flags."
+ ewarn "Having a feature enabled via use flag but disabled can lead to issues."
+ fi
+
+ ewarn "If you've just removed pwlib to install ptlib, some packages will be broken."
+ ewarn "Please use 'revdep-rebuild' from app-portage/gentoolkit to check."
+ ewarn "If some packages need pwlib, consider removing ptlib and re-installing pwlib"
+ ewarn "or help us to make them live together."
+}