From da9c1ac36b76e17e3473427585686720f6f84cba Mon Sep 17 00:00:00 2001 From: Peter Volkov Date: Tue, 7 Dec 2010 07:16:54 +0000 Subject: Respect ldflags, bug #331085 thank Olivier Huber for report and fix. Bug build issue, #343041 thank Ming-Wei for report and Hamlet for draft fix. Package-Manager: portage-2.1.9.25/cvs/Linux x86_64 --- net-libs/opal/ChangeLog | 9 +- net-libs/opal/Manifest | 15 +- net-libs/opal/files/opal-3.6.8-build-fix.patch | 39 ++++ net-libs/opal/files/opal-3.6.8-ldflags.patch | 237 +++++++++++++++++++++ net-libs/opal/opal-3.6.8-r1.ebuild | 274 +++++++++++++++++++++++++ 5 files changed, 562 insertions(+), 12 deletions(-) create mode 100644 net-libs/opal/files/opal-3.6.8-build-fix.patch create mode 100644 net-libs/opal/files/opal-3.6.8-ldflags.patch create mode 100644 net-libs/opal/opal-3.6.8-r1.ebuild (limited to 'net-libs/opal') diff --git a/net-libs/opal/ChangeLog b/net-libs/opal/ChangeLog index 53c42a6c2b75..efa2dc4af7a7 100644 --- a/net-libs/opal/ChangeLog +++ b/net-libs/opal/ChangeLog @@ -1,6 +1,13 @@ # ChangeLog for net-libs/opal # Copyright 1999-2010 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/net-libs/opal/ChangeLog,v 1.69 2010/11/01 22:40:14 halcy0n Exp $ +# $Header: /var/cvsroot/gentoo-x86/net-libs/opal/ChangeLog,v 1.70 2010/12/07 07:16:54 pva Exp $ + +*opal-3.6.8-r1 (07 Dec 2010) + + 07 Dec 2010; Peter Volkov +opal-3.6.8-r1.ebuild, + +files/opal-3.6.8-build-fix.patch, +files/opal-3.6.8-ldflags.patch: + Respect ldflags, bug #331085 thank Olivier Huber for report and fix. Bug + build issue, #343041 thank Ming-Wei for report and Hamlet for draft fix. 01 Nov 2010; Mark Loeser opal-3.6.8.ebuild: Add ~ppc64; bug #276355 diff --git a/net-libs/opal/Manifest b/net-libs/opal/Manifest index e76aa6169395..36b66eef83d9 100644 --- a/net-libs/opal/Manifest +++ b/net-libs/opal/Manifest @@ -1,19 +1,12 @@ ------BEGIN PGP SIGNED MESSAGE----- -Hash: SHA1 - AUX opal-2.1.1-notrace.diff 263 RMD160 17b6887acd196af52de8dfec8d5accfd654d1fc7 SHA1 079474507fe63a9019a293a5a529c23788221196 SHA256 3abf99ab2a7bde2e1a2380e22a9c5e15240439bdf7766b4715c78cacd46961c0 AUX opal-3.6.4-jdkroot.patch 507 RMD160 eeda20caf4697efa51dd24527c619f3ec0e2d3ca SHA1 72c4d9ea9f5867567a24f5a92cd66d1394b58129 SHA256 c2e930565cd91a7ec75a1ed1657ba524dad810ec934ef854c39331388661f2f6 +AUX opal-3.6.8-build-fix.patch 992 RMD160 102a98bd4a255d6414f4adc4713eb8ffa9a08e67 SHA1 cd33c6524be1ee8d65e2f3929d6a9608c84a63eb SHA256 cbd011cf42b7d691f5b8d71e02f5b317d50ea8c51a7b03e38887119dc07b58c8 +AUX opal-3.6.8-ldflags.patch 7240 RMD160 37464f1726a0b1b017e7a02a414299a8f81626cd SHA1 eb9920c53d2613d5789bf1e24c8b626cdd54d55b SHA256 557a2b406b446cbeceea21445b972b667837cb4585a5613b72e4acf8e2e544e3 DIST opal-2.2.11.tar.gz 4165191 RMD160 7ef2d505cc52eca9136ca10a865c7b7f3a8dc2b5 SHA1 f8638a7dce8e9c32abd8c69c69ba2d61dfca05f0 SHA256 0990ead39728f23a1ce39997f41a8484c59809ccec0e770b9bc4f795a85a29c4 DIST opal-3.6.7-htmldoc.tar.bz2 5842269 RMD160 039b138991334e0ecdc243d73a8dbca6d13c4df4 SHA1 cb2c5ee78f8461a2e027f0142c96c0c5a70a55c1 SHA256 d6c11b162b4b26cfc3df2c2c12b5d8a0e1b2dfa5c6869995b0fafa2f2a716e7b DIST opal-3.6.8.tar.bz2 6837993 RMD160 3a1693de75cfe1e6d6c1f6f4635cb7447d43a2e9 SHA1 c43826bc3e273df048f47a77c4affb36614f2b7e SHA256 8cbfabb33e5c5563fdafacf1adde536c78638d6d020fae496a52e19e2be6a90c EBUILD opal-2.2.11.ebuild 2604 RMD160 2dadccb1206d340d3c33987aa1147a43ab622463 SHA1 b3b29f137eae3437cc19118ea59d6d8ee8adba3a SHA256 8595bd00d707830cfc52f7de3b8993c0658f50306ddef296dea97c74d0285ba7 +EBUILD opal-3.6.8-r1.ebuild 8366 RMD160 db84b3c318575a57e7655563ef5b1fdda148310d SHA1 03be560a183ef94d8f46f280e69313985d6e581e SHA256 c1ef5ec6cfbaab4d6a8086f99d1bdcd8bec04dba225725df52d93eb38ff6605e EBUILD opal-3.6.8.ebuild 8274 RMD160 7d367f3e5ae3ae9c811130fb5792ccf2c179dcb4 SHA1 407247f8dc3f7ff031217ef992d2fdf7dc54c0e3 SHA256 93081463a9c4938b1a457febb4eca992ca4f552ef4facefd63869503ee9a0748 -MISC ChangeLog 9404 RMD160 4a8184b8d8ede361bb6e0d690ba84b56a8987777 SHA1 f2849279d210bde94fe33473c34b78af0d3f50cd SHA256 30093024843cc64e87e73ba62c5989f78b6441b47e485305d84355915151c12e +MISC ChangeLog 9719 RMD160 9ef203b0b185ead114b5d6e4154885a6bfa7fda5 SHA1 8c5d0e754a7defd79eaabd795114f031c7f76c35 SHA256 381cac818e09394ad07c62e5356813fed6a50b4091dc65a0b40ae8d7a50eec55 MISC metadata.xml 2065 RMD160 72f5b31577c61334a802fa85c51b4163c81aced1 SHA1 d1b558b04691f19a9eccc648708487c8d169db82 SHA256 065bbfbad937a4e217f16a4d2f410f4ff282ca5f869ca9387986d85a99add8b4 ------BEGIN PGP SIGNATURE----- -Version: GnuPG v2.0.16 (GNU/Linux) - -iEYEARECAAYFAkzPQdQACgkQCRZPokWLroTC5ACePEJsI38/PtwwTCAcGhHQ1F3o -pBQAniIEQ6DkQbMqFyE5PxkvcRe/rVco -=DmF1 ------END PGP SIGNATURE----- diff --git a/net-libs/opal/files/opal-3.6.8-build-fix.patch b/net-libs/opal/files/opal-3.6.8-build-fix.patch new file mode 100644 index 000000000000..2a052e145afc --- /dev/null +++ b/net-libs/opal/files/opal-3.6.8-build-fix.patch @@ -0,0 +1,39 @@ +=== modified file 'plugins/video/H.263-1998/h263-1998.cxx' +--- plugins/video/H.263-1998/h263-1998.cxx 2010-12-06 15:18:06 +0000 ++++ plugins/video/H.263-1998/h263-1998.cxx 2010-12-06 15:18:46 +0000 +@@ -51,6 +51,8 @@ + + #include "plugin-config.h" + ++#define __STDC_CONSTANT_MACROS ++ + #include "h263-1998.h" + #include + #include + +=== modified file 'plugins/video/H.263-1998/h263pframe.h' +--- plugins/video/H.263-1998/h263pframe.h 2010-12-06 15:18:06 +0000 ++++ plugins/video/H.263-1998/h263pframe.h 2010-12-06 15:19:56 +0000 +@@ -25,6 +25,8 @@ + + #include "plugin-config.h" + ++#define __STDC_CONSTANT_MACROS ++ + #include + #include + #include + +=== modified file 'plugins/video/common/trace.h' +--- plugins/video/common/trace.h 2010-12-06 15:18:06 +0000 ++++ plugins/video/common/trace.h 2010-12-06 15:18:46 +0000 +@@ -34,6 +34,8 @@ + + #define TRACING 1 + ++#define __STDC_CONSTANT_MACROS ++ + #include + #include + using namespace std; + diff --git a/net-libs/opal/files/opal-3.6.8-ldflags.patch b/net-libs/opal/files/opal-3.6.8-ldflags.patch new file mode 100644 index 000000000000..5268b5be1535 --- /dev/null +++ b/net-libs/opal/files/opal-3.6.8-ldflags.patch @@ -0,0 +1,237 @@ +=== modified file 'plugins/audio/G722/Makefile.in' +--- plugins/audio/G722/Makefile.in 2010-12-07 05:39:18 +0000 ++++ plugins/audio/G722/Makefile.in 2010-12-07 05:49:21 +0000 +@@ -71,11 +71,9 @@ + + $(PLUGIN): $(OBJECTS) + ifeq (solaris,$(findstring solaris,$(target_os))) +- +- $(Q_LD)$(CC) $(LDSO) $@ -o $@ $^ $(EXTRALIBS) ++ $(Q_LD)$(CC) $(LDFLAGS) $(LDSO) $@ -o $@ $^ $(EXTRALIBS) + else +- $(Q_LD)$(CC) $(LDSO) -o $@ $^ $(EXTRALIBS) +- ++ $(Q_LD)$(CC) $(LDFLAGS) $(LDSO) -o $@ $^ $(EXTRALIBS) + endif + + install: + +=== modified file 'plugins/audio/G726/Makefile.in' +--- plugins/audio/G726/Makefile.in 2010-12-07 05:39:18 +0000 ++++ plugins/audio/G726/Makefile.in 2010-12-07 05:49:51 +0000 +@@ -100,11 +100,9 @@ + $(PLUGIN): $(OBJECTS) + + ifeq (solaris,$(findstring solaris,$(target_os))) +- +- $(Q_LD)$(CC) $(LDSO) $@ -o $@ $^ $(EXTRALIBS) ++ $(Q_LD)$(CC) $(LDFLAGS) $(LDSO) $@ -o $@ $^ $(EXTRALIBS) + else +- $(Q_LD)$(CC) $(LDSO) -o $@ $^ $(EXTRALIBS) +- ++ $(Q_LD)$(CC) $(LDFLAGS) $(LDSO) -o $@ $^ $(EXTRALIBS) + endif + + install: + +=== modified file 'plugins/audio/GSM0610/Makefile.in' +--- plugins/audio/GSM0610/Makefile.in 2010-12-07 05:39:18 +0000 ++++ plugins/audio/GSM0610/Makefile.in 2010-12-07 05:50:09 +0000 +@@ -160,11 +160,9 @@ + $(PLUGIN): $(OBJECTS) + + ifeq (solaris,$(findstring solaris,$(target_os))) +- +- $(Q_LD)$(CC) $(LDSO) $@ -o $@ $^ $(EXTRALIBS) ++ $(Q_LD)$(CC) $(LDFLAGS) $(LDSO) $@ -o $@ $^ $(EXTRALIBS) + else +- $(Q_LD)$(CC) $(LDSO) -o $@ $^ $(EXTRALIBS) +- ++ $(Q_LD)$(CC) $(LDFLAGS) $(LDSO) -o $@ $^ $(EXTRALIBS) + endif + + endif + +=== modified file 'plugins/audio/IMA_ADPCM/Makefile.in' +--- plugins/audio/IMA_ADPCM/Makefile.in 2010-12-07 05:39:18 +0000 ++++ plugins/audio/IMA_ADPCM/Makefile.in 2010-12-07 05:50:53 +0000 +@@ -90,11 +90,9 @@ + $(PLUGIN): $(OBJECTS) + + ifeq (solaris,$(findstring solaris,$(target_os))) +- +- $(Q_LD)$(CC) $(LDSO) $@ -o $@ $^ $(EXTRALIBS) ++ $(Q_LD)$(CC) $(LDFLAGS) $(LDSO) $@ -o $@ $^ $(EXTRALIBS) + else +- $(Q_LD)$(CC) $(LDSO) -o $@ $^ $(EXTRALIBS) +- ++ $(Q_LD)$(CC) $(LDFLAGS) $(LDSO) -o $@ $^ $(EXTRALIBS) + endif + + install: + +=== modified file 'plugins/audio/LPC_10/Makefile.in' +--- plugins/audio/LPC_10/Makefile.in 2010-12-07 05:39:18 +0000 ++++ plugins/audio/LPC_10/Makefile.in 2010-12-07 05:51:07 +0000 +@@ -128,11 +128,9 @@ + $(PLUGIN): $(OBJECTS) + + ifeq (solaris,$(findstring solaris,$(target_os))) +- +- $(Q_LD)$(CC) $(LDSO) $@ -o $@ $^ $(EXTRALIBS) ++ $(Q_LD)$(CC) $(LDFLAGS) $(LDSO) $@ -o $@ $^ $(EXTRALIBS) + else +- $(Q_LD)$(CC) $(LDSO) -o $@ $^ $(EXTRALIBS) +- ++ $(Q_LD)$(CC) $(LDFLAGS) $(LDSO) -o $@ $^ $(EXTRALIBS) + endif + + install: + +=== modified file 'plugins/audio/SBC/Makefile.in' +--- plugins/audio/SBC/Makefile.in 2010-12-07 05:39:18 +0000 ++++ plugins/audio/SBC/Makefile.in 2010-12-07 05:51:28 +0000 +@@ -78,7 +78,7 @@ + OBJECTS = $(addprefix $(OBJDIR)/,$(patsubst %.cxx,%.o,$(patsubst %.c,%.o,$(notdir $(SRCS))))) + + $(PLUGIN): $(OBJECTS) +- $(Q_LD)$(CXX) $(LDSO) -o $@ $^ $(EXTRALIBS) ++ $(Q_LD)$(CXX) $(LDFLAGS) $(LDSO) -o $@ $^ $(EXTRALIBS) + + $(SRCDIR)/g711a1_plc.cxx: ../../../src/codec/g711a1_plc.cxx + @ln -s ../../../src/codec/g711a1_plc.cxx $(SRCDIR)/g711a1_plc.cxx + +=== modified file 'plugins/audio/Speex/Makefile.in' +--- plugins/audio/Speex/Makefile.in 2010-12-07 05:39:18 +0000 ++++ plugins/audio/Speex/Makefile.in 2010-12-07 05:51:51 +0000 +@@ -166,11 +166,9 @@ + + $(PLUGIN): $(OBJECTS) + ifeq (solaris,$(findstring solaris,$(target_os))) +- +- $(Q_LD)$(CXX) $(LDSO) $@ -o $@ $^ $(EXTRALIBS) ++ $(Q_LD)$(CXX) $(LDFLAGS) $(LDSO) $@ -o $@ $^ $(EXTRALIBS) + else +- $(Q_LD)$(CXX) $(LDSO) -o $@ $^ $(EXTRALIBS) +- ++ $(Q_LD)$(CXX) $(LDFLAGS) $(LDSO) -o $@ $^ $(EXTRALIBS) + endif + + install: + +=== modified file 'plugins/audio/celt/Makefile.in' +--- plugins/audio/celt/Makefile.in 2010-12-07 05:39:18 +0000 ++++ plugins/audio/celt/Makefile.in 2010-12-07 05:48:49 +0000 +@@ -47,11 +47,9 @@ + $(PLUGIN): $(OBJECTS) + + ifeq (solaris,$(findstring solaris,$(target_os))) +- +- $(Q_LD)$(CC) $(LDSO) $@ -o $@ $^ $(LIBS) ++ $(Q_LD)$(CC) $(LDFLAGS) $(LDSO) $@ -o $@ $^ $(LIBS) + else +- $(Q_LD)$(CC) $(LDSO) -o $@ $^ $(LIBS) +- ++ $(Q_LD)$(CC) $(LDFLAGS) $(LDSO) -o $@ $^ $(LIBS) + endif + + install: + +=== modified file 'plugins/audio/gsm-amr/Makefile.in' +--- plugins/audio/gsm-amr/Makefile.in 2010-12-07 05:39:18 +0000 ++++ plugins/audio/gsm-amr/Makefile.in 2010-12-07 05:50:25 +0000 +@@ -59,11 +59,9 @@ + $(PLUGIN): $(OBJECTS) + + ifeq (solaris,$(findstring solaris,$(target_os))) +- +- $(Q_LD)$(CC) $(LDSO) $@ -o $@ $^ ++ $(Q_LD)$(CC) $(LDFLAGS) $(LDSO) $@ -o $@ $^ + else +- $(Q_LD)$(CC) $(LDSO) -o $@ $^ +- ++ $(Q_LD)$(CC) $(LDFLAGS) $(LDSO) -o $@ $^ + endif + + install: + +=== modified file 'plugins/audio/iLBC/Makefile.in' +--- plugins/audio/iLBC/Makefile.in 2010-12-07 05:39:18 +0000 ++++ plugins/audio/iLBC/Makefile.in 2010-12-07 05:50:41 +0000 +@@ -119,9 +119,9 @@ + + $(PLUGIN): $(OBJECTS) + ifeq (solaris,$(findstring solaris,$(target_os))) +- $(Q_LD)$(CC) $(LDSO) $@ -o $@ $^ $(EXTRALIBS) ++ $(Q_LD)$(CC) $(LDFLAGS) $(LDSO) $@ -o $@ $^ $(EXTRALIBS) + else +- $(Q_LD)$(CC) $(LDSO) -o $@ $^ $(EXTRALIBS) ++ $(Q_LD)$(CC) $(LDFLAGS) $(LDSO) -o $@ $^ $(EXTRALIBS) + endif + + install: + +=== modified file 'plugins/video/H.261-vic/Makefile.in' +--- plugins/video/H.261-vic/Makefile.in 2010-12-07 05:39:18 +0000 ++++ plugins/video/H.261-vic/Makefile.in 2010-12-07 05:45:17 +0000 +@@ -116,9 +116,9 @@ + + $(PLUGIN): $(OBJECTS) + ifeq (,$(findstring solaris,$(target_os))) +- $(Q_LD)$(CXX) $(LDSO) -o $@ $^ ++ $(Q_LD)$(CXX) $(LDFLAGS) $(LDSO) $(LDFLAGS) -o $@ $^ + else +- $(Q_LD)$(CXX) $(LDSO) $@ -o $@ $^ ++ $(Q_LD)$(CXX) $(LDFLAGS) $(LDSO) $@ -o $@ $^ + endif + + install: + +=== modified file 'plugins/video/H.263-1998/Makefile.in' +--- plugins/video/H.263-1998/Makefile.in 2010-12-07 05:39:18 +0000 ++++ plugins/video/H.263-1998/Makefile.in 2010-12-07 05:45:53 +0000 +@@ -86,9 +86,9 @@ + + $(PLUGIN): $(OBJECTS) + ifeq (,$(findstring solaris,$(target_os))) +- $(Q_LD)$(CXX) $(LDSO) $(DL_LIBS) -o $@ $^ $(LDFLAGS) ++ $(Q_LD)$(CXX) $(LDFLAGS) $(LDSO) -o $@ $^ $(DL_LIBS) + else +- $(Q_LD)$(CXX) $(LDSO) $(DL_LIBS) $@ -o $@ $^ $(LDFLAGS) ++ $(Q_LD)$(CXX) $(LDFLAGS) $(LDSO) $@ -o $@ $^ $(DL_LIBS) + endif + + install: $(PLUGIN) + +=== modified file 'plugins/video/H.264/Makefile.in' +--- plugins/video/H.264/Makefile.in 2010-12-07 05:39:18 +0000 ++++ plugins/video/H.264/Makefile.in 2010-12-07 05:46:27 +0000 +@@ -130,9 +130,9 @@ + $(PLUGIN): $(OBJECTS) + @set -e; $(foreach dir,$(SUBDIRS),if test -d ${dir} ; then $(MAKE) -C $(dir); fi ; ) + ifeq (,$(findstring solaris,$(target_os))) +- $(Q_LD)$(CXX) $(LDSO) $(LDFLAGS) $(DL_LIBS) -o $@ $^ ++ $(Q_LD)$(CXX) $(LDFLAGS) $(LDSO) $(LDFLAGS) -o $@ $^ $(DL_LIBS) + else +- $(Q_LD)$(CXX) $(LDSO) $(LDFLAGS) $(DL_LIBS) $@ -o $@ $^ ++ $(Q_LD)$(CXX) $(LDFLAGS) $(LDSO) $(LDFLAGS) $@ -o $@ $^ $(DL_LIBS) + endif + + + +=== modified file 'plugins/video/MPEG4-ffmpeg/Makefile.in' +--- plugins/video/MPEG4-ffmpeg/Makefile.in 2010-12-07 05:39:18 +0000 ++++ plugins/video/MPEG4-ffmpeg/Makefile.in 2010-12-07 05:47:12 +0000 +@@ -101,9 +101,9 @@ + + $(PLUGIN): $(OBJECTS) + ifeq (,$(findstring solaris,$(target_os))) +- $(Q_LD)$(CXX) $(LDSO) $(DL_LIBS) -o $@ $^ ++ $(Q_LD)$(CXX) $(LDFLAGS) $(LDSO) -o $@ $^ $(DL_LIBS) + else +- $(Q_LD)$(CXX) $(LDSO) $(DL_LIBS) $@ -o $@ $^ ++ $(Q_LD)$(CXX) $(LDFLAGS) $(LDSO) $@ -o $@ $^ $(DL_LIBS) + endif + + install: + diff --git a/net-libs/opal/opal-3.6.8-r1.ebuild b/net-libs/opal/opal-3.6.8-r1.ebuild new file mode 100644 index 000000000000..5745cb4c8baa --- /dev/null +++ b/net-libs/opal/opal-3.6.8-r1.ebuild @@ -0,0 +1,274 @@ +# Copyright 1999-2010 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/net-libs/opal/opal-3.6.8-r1.ebuild,v 1.1 2010/12/07 07:16:54 pva Exp $ + +EAPI="2" + +inherit eutils autotools toolchain-funcs java-pkg-opt-2 flag-o-matic + +HTMLV="3.6.7" # There is no 3.6.8 release of htmldoc +DESCRIPTION="C++ class library normalising numerous telephony protocols" +HOMEPAGE="http://www.opalvoip.org/" +SRC_URI="mirror://sourceforge/opalvoip/${P}.tar.bz2 + doc? ( mirror://sourceforge/opalvoip/${PN}-${HTMLV}-htmldoc.tar.bz2 )" + +LICENSE="MPL-1.0" +SLOT="0" +KEYWORDS="~alpha ~amd64 ~ia64 ~ppc ~ppc64 ~sparc ~x86" +IUSE="+audio capi celt debug doc dtmf examples fax ffmpeg h224 h281 h323 iax +ipv6 ivr ixj java ldap lid +plugins sbc sip sipim srtp ssl stats swig theora ++video vpb vxml wav x264 x264-static xml" + +RDEPEND=">=net-libs/ptlib-2.6.6[stun,debug=,audio?,dtmf?,ipv6?,ldap?,ssl?,video?,vxml?,wav?,xml?] + >=media-libs/speex-1.2_beta + fax? ( net-libs/ptlib[asn] ) + h323? ( net-libs/ptlib[asn] ) + ivr? ( net-libs/ptlib[xml,vxml] ) + java? ( >=virtual/jre-1.4 ) + plugins? ( dev-libs/ilbc-rfc3951 + media-sound/gsm + capi? ( net-dialup/capi4k-utils ) + celt? ( media-libs/celt ) + ffmpeg? ( >=media-video/ffmpeg-0.5[encode] ) + ixj? ( sys-kernel/linux-headers ) + sbc? ( media-libs/libsamplerate ) + theora? ( media-libs/libtheora ) + x264? ( >=media-video/ffmpeg-0.4.7 + media-libs/x264 ) ) + srtp? ( net-libs/libsrtp )" +DEPEND="${RDEPEND} + dev-util/pkgconfig + >=sys-devel/gcc-3 + java? ( swig? ( dev-lang/swig ) + >=virtual/jdk-1.4 )" + +# NOTES: +# ffmpeg[encode] is for h263 and mpeg4 +# ssl, xml, vxml, ipv6, dtmf, ldap, audio, wav, and video are use flags +# herited from ptlib: feature is enabled if ptlib has enabled it +# however, disabling it if ptlib has it looks hard (coz of buildopts.h) +# forcing ptlib to disable it for opal is not a solution too +# atm, accepting the "auto-feature" looks like a good solution +# (asn is used for fax and config _only_ for examples) +# OPALDIR should not be used anymore but if a package still need it, create it + +pkg_setup() { + # workaround for bug 282838 + append-flags "-fno-visibility-inlines-hidden" + + append-flags -D__STDC_CONSTANT_MACROS #324323 + + # need >=gcc-3 + if [[ $(gcc-major-version) -lt 3 ]]; then + eerror "You need to use gcc-3 at least." + eerror "Please change gcc version with 'gcc-config'." + die "You need to use gcc-3 at least." + fi + + if use h281 && ! use h224; then + ewarn "You have enabled h281 but h224 is disabled." + ewarn "H.281 is over H.224 so you should enable h224 if you want h281." + fi + + if use x264-static && ! use x264; then + ewarn "You have enabled x264-static but x264 is disabled." + ewarn "x264-static is going to be useless if x264 is not enabled." + fi + + java-pkg-opt-2_pkg_setup +} + +src_prepare() { + # 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 + + # upstream patch 2808915 + epatch "${FILESDIR}"/${PN}-3.6.4-jdkroot.patch + + epatch "${FILESDIR}"/${P}-build-fix.patch #343041 + epatch "${FILESDIR}"/${P}-ldflags.patch + + # h224 really needs h323 ? + # TODO: get a confirmation in ml + sed -i -e "s:\(.*HAS_H224.*\), \[OPAL_H323\]:\1:" configure.ac \ + || die "sed failed" + + eaclocal + eautoconf + + # in plugins + cd plugins/ + eaclocal + eautoconf + cd .. + + # disable srtp if srtp is not enabled (prevent auto magic dep) + # upstream bug 2686485 (fixed in 3.7) + if ! use srtp; then + sed -i -e "s/OPAL_SRTP=yes/OPAL_SRTP=no/" configure \ + || die "patching configure failed" + fi + + # disable theora if theora is not enabled (prevent auto magic dep) + # upstream bug 2686488 (fixed in 3.7) + if ! use theora; then + sed -i -e "s/HAVE_THEORA=yes/HAVE_THEORA=no/" plugins/configure \ + || die "patching plugins/configure failed" + fi + + # disable mpeg4 and h263p if ffmpeg is not enabled (prevent auto magic dep) + # upstream bug 2686495 (fixed in 3.7) + if ! use ffmpeg; then + sed -i -e "s/HAVE_H263P=yes/HAVE_H263P=no/" plugins/configure \ + || die "patching plugins/configure failed" + sed -i -e "s/HAVE_MPEG4=yes/HAVE_MPEG4=no/" plugins/configure \ + || die "patching plugins/configure failed" + fi + + # disable celt if celt is not enabled (prevent auto magic dep) + # already in repository + if ! use celt; then + sed -i -e "s/HAVE_CELT=yes/HAVE_CELT=no/" plugins/configure \ + || die "sed failed" + fi + + # fix gsm wav49 support check, upstream bug 2686500 (fixed in 3.7) + if use plugins; then + sed -i -e "s:gsm\.h:gsm/gsm.h:" plugins/configure \ + || die "patching plugins/configure failed" + fi + + # fix automatic swig detection, upstream bug 2712521 (upstream reject it) + if ! use swig; then + sed -i -e "/^SWIG=/d" configure || die "patching configure failed" + fi + + java-pkg-opt-2_src_prepare +} + +src_configure() { + local forcedconf="" + + # fix bug 277233, upstream bug 2820939 + if use fax; then + forcedconf="${forcedconf} --enable-statistics" + fi + + # --with-libavcodec-source-dir should _not_ be set, it's for trunk sources + # versioncheck: check for ptlib version + # shared: should always be enabled for a lib + # localspeex, localspeexdsp, localgsm, localilbc: never use bundled libs + # samples: only build some samples, useless + # libavcodec-stackalign-hack: prevent hack (default disable by upstream) + # default-to-full-capabilties: default enable by upstream + # aec: atm, only used when bundled speex, so it's painless for us + # zrtp doesn't depend on net-libs/libzrtpcpp but on libzrtp from + # http://zfoneproject.com/ wich is not in portage + # msrp: highly experimental + # spandsp: doesn't work with newest spandsp, upstream bug 2796047 + # g711plc: force enable + # rfc4103: not really used, upstream bug 2795831 + # t38, spandsp: merged in fax + # h450, h460, h501: merged in h323 (they are additional features of h323) + econf \ + --enable-versioncheck \ + --enable-shared \ + --disable-zrtp \ + --disable-localspeex \ + --disable-localspeexdsp \ + --disable-localgsm \ + --disable-localilbc \ + --disable-samples \ + --disable-libavcodec-stackalign-hack \ + --enable-default-to-full-capabilties \ + --enable-aec \ + --disable-msrp \ + --disable-spandsp \ + --enable-g711plc \ + --enable-rfc4103 \ + $(use_enable debug) \ + $(use_enable capi) \ + $(use_enable fax) \ + $(use_enable fax t38) \ + $(use_enable h224) \ + $(use_enable h281) \ + $(use_enable h323) \ + $(use_enable h323 h450) \ + $(use_enable h323 h460) \ + $(use_enable h323 h501) \ + $(use_enable iax) \ + $(use_enable ivr) \ + $(use_enable ixj) \ + $(use_enable java) \ + $(use_enable lid) \ + $(use_enable plugins) \ + $(use_enable sbc) \ + $(use_enable sip) \ + $(use_enable sipim) \ + $(use_enable stats statistics) \ + $(use_enable video) $(use_enable video rfc4175) \ + $(use_enable vpb) \ + $(use_enable x264 h264) \ + $(use_enable x264-static x264-link-static) \ + ${forcedconf} +} + +src_compile() { + local makeopts="" + + use debug && makeopts="debug" + + emake ${makeopts} || die "emake failed" +} + +src_install() { + emake DESTDIR="${D}" install || die "emake install failed" + + if use doc; then + dohtml -r "${WORKDIR}"/html/* docs/* || die "dohtml failed" + fi + + # 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 ${basedir} --hide=configure* \ + --hide=opal_samples.mak.in`" + + # first, install files + insinto ${exampledir}/ + doins ${basedir}/{configure*,opal_samples*} \ + || die "doins failed" + + # now, all examples + for x in ${sampledirs}; do + insinto ${exampledir}/${x}/ + doins ${basedir}/${x}/* || die "doins failed" + done + + # some examples need version.h + insinto "/usr/share/doc/${PF}/" + doins version.h || die "doins failed" + 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 in ptlib and opal" + fi + + if ! use plugins || ! use audio || ! use video; then + ewarn "You have disabled audio, video or plugins USE flags." + ewarn "Most audio/video features or plugins have been disabled silently" + ewarn "even if enabled via USE flags." + ewarn "Having a feature enabled via USE flag but disabled can lead to issues." + fi +} -- cgit v1.2.3-65-gdbad