diff options
-rw-r--r-- | dev-libs/soprano/ChangeLog | 8 | ||||
-rw-r--r-- | dev-libs/soprano/files/soprano-2.4.0-socketMutex.unlock.patch | 20 | ||||
-rw-r--r-- | dev-libs/soprano/soprano-2.4.0-r1.ebuild | 104 |
3 files changed, 131 insertions, 1 deletions
diff --git a/dev-libs/soprano/ChangeLog b/dev-libs/soprano/ChangeLog index 4d5b71afd94e..49d42e5da280 100644 --- a/dev-libs/soprano/ChangeLog +++ b/dev-libs/soprano/ChangeLog @@ -1,6 +1,12 @@ # ChangeLog for dev-libs/soprano # Copyright 1999-2010 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/dev-libs/soprano/ChangeLog,v 1.40 2010/02/09 23:32:33 reavertm Exp $ +# $Header: /var/cvsroot/gentoo-x86/dev-libs/soprano/ChangeLog,v 1.41 2010/02/11 12:47:53 ssuominen Exp $ + +*soprano-2.4.0-r1 (11 Feb 2010) + + 11 Feb 2010; Samuli Suominen <ssuominen@gentoo.org> + +soprano-2.4.0-r1.ebuild, +files/soprano-2.4.0-socketMutex.unlock.patch: + Apply upstream "unlock the mutex before deleting it" patch. *soprano-2.4.0 (09 Feb 2010) diff --git a/dev-libs/soprano/files/soprano-2.4.0-socketMutex.unlock.patch b/dev-libs/soprano/files/soprano-2.4.0-socketMutex.unlock.patch new file mode 100644 index 000000000000..a346e5bfa507 --- /dev/null +++ b/dev-libs/soprano/files/soprano-2.4.0-socketMutex.unlock.patch @@ -0,0 +1,20 @@ +http://bugs.kde.org/show_bug.cgi?id=226218#c2 +http://websvn.kde.org/?view=rev&revision=1088551 + +--- client/clientconnection.cpp ++++ client/clientconnection.cpp +@@ -71,12 +71,13 @@ + + Soprano::Client::ClientConnection::~ClientConnection() + { +- QMutexLocker lock( &d->socketMutex ); ++ d->socketMutex.lock(); + // the sockets need to be deleted in their respective threads. + // this is what d->socketStorage does. We only close them here. + foreach( QIODevice* socket, d->sockets ) { + socket->close(); + } ++ d->socketMutex.unlock(); + delete d; + } + diff --git a/dev-libs/soprano/soprano-2.4.0-r1.ebuild b/dev-libs/soprano/soprano-2.4.0-r1.ebuild new file mode 100644 index 000000000000..a51fec63f3c6 --- /dev/null +++ b/dev-libs/soprano/soprano-2.4.0-r1.ebuild @@ -0,0 +1,104 @@ +# Copyright 1999-2010 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/dev-libs/soprano/soprano-2.4.0-r1.ebuild,v 1.1 2010/02/11 12:47:53 ssuominen Exp $ + +EAPI="2" + +JAVA_PKG_OPT_USE="java" +inherit base cmake-utils flag-o-matic java-pkg-opt-2 + +DESCRIPTION="Library that provides a nice Qt interface to RDF storage solutions" +HOMEPAGE="http://sourceforge.net/projects/soprano" +SRC_URI="mirror://sourceforge/${PN}/${P}.tar.bz2" + +LICENSE="LGPL-2" +KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~ppc ~ppc64 ~sparc ~x86 ~amd64-linux ~x86-linux" +SLOT="0" +IUSE="clucene +dbus debug doc elibc_FreeBSD java +raptor +redland +virtuoso" + +COMMON_DEPEND=" + >=x11-libs/qt-core-4.5.0:4 + clucene? ( dev-cpp/clucene ) + dbus? ( >=x11-libs/qt-dbus-4.5.0:4 ) + raptor? ( >=media-libs/raptor-1.4.16 ) + redland? ( + >=dev-libs/rasqal-0.9.15 + >=dev-libs/redland-1.0.10 + ) + java? ( >=virtual/jdk-1.6.0 ) + virtuoso? ( dev-db/libiodbc:0 ) +" +DEPEND="${COMMON_DEPEND} + doc? ( app-doc/doxygen ) +" +RDEPEND="${COMMON_DEPEND} + virtuoso? ( >=dev-db/virtuoso-server-6.1.0 ) +" + +CMAKE_IN_SOURCE_BUILD="1" + +PATCHES=( "${FILESDIR}/${P}-socketMutex.unlock.patch" ) + +pkg_setup() { + java-pkg-opt-2_pkg_setup + + if [[ ${PV} = *9999* && -z $I_KNOW_WHAT_I_AM_DOING ]]; then + echo + ewarn "WARNING! This is an experimental ebuild of ${PN} SVN tree. Use at your own risk." + ewarn "Do _NOT_ file bugs at bugs.gentoo.org because of this ebuild!" + echo + fi + + if ! use java && ! use virtuoso; then + if ! use redland; then + echo + ewarn "You have explicitly disabled the default soprano backend and haven't chosen" + ewarn "a different one. Applications using soprano may need at least one backend" + ewarn "to be functional. If you experience any problems, enable any of those USE" + ewarn "flags:" + ewarn "java, redland, virtuoso (recommended)" + echo + else + echo + ewarn "You selected redland as the only backend for soprano." + ewarn "Be advised that it's known to be broken (bug #275326)." + echo + fi + fi +} + +src_prepare() { + base_src_prepare +} + +src_configure() { + # Fix for missing pthread.h linking + # NOTE: temporarily fix until a better cmake files patch will be provided. + use elibc_FreeBSD && append-flags -pthread + + mycmakeargs=( + -DSOPRANO_BUILD_TESTS=OFF + -DCMAKE_SKIP_RPATH=OFF + $(cmake-utils_use !clucene SOPRANO_DISABLE_CLUCENE_INDEX) + $(cmake-utils_use !dbus SOPRANO_DISABLE_DBUS) + $(cmake-utils_use !raptor SOPRANO_DISABLE_RAPTOR_PARSER) + $(cmake-utils_use !redland SOPRANO_DISABLE_RAPTOR_SERIALIZER) + $(cmake-utils_use !redland SOPRANO_DISABLE_REDLAND_BACKEND) + $(cmake-utils_use !java SOPRANO_DISABLE_SESAME2_BACKEND) + $(cmake-utils_use !virtuoso SOPRANO_DISABLE_VIRTUOSO_BACKEND) + $(cmake-utils_use doc SOPRANO_BUILD_API_DOCS) + ) + + cmake-utils_src_configure +} + +src_compile() { + cmake-utils_src_compile +} + +src_test() { + mycmakeargs+=(-DSOPRANO_BUILD_TESTS=ON) + cmake-utils_src_configure + cmake-utils_src_compile + ctest --extra-verbose || die "Tests failed." +} |