summaryrefslogtreecommitdiff
path: root/net-p2p/retroshare/retroshare-scm.ebuild~
diff options
context:
space:
mode:
Diffstat (limited to 'net-p2p/retroshare/retroshare-scm.ebuild~')
-rw-r--r--net-p2p/retroshare/retroshare-scm.ebuild~189
1 files changed, 189 insertions, 0 deletions
diff --git a/net-p2p/retroshare/retroshare-scm.ebuild~ b/net-p2p/retroshare/retroshare-scm.ebuild~
new file mode 100644
index 0000000..ac96b7b
--- /dev/null
+++ b/net-p2p/retroshare/retroshare-scm.ebuild~
@@ -0,0 +1,189 @@
+# Copyright 1999-2015 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+EAPI=6
+
+inherit eutils gnome2-utils multilib qmake-utils git-r3
+
+MY_PV="${PV/_rc/.RC}"
+MY_PV="${MY_PV/_pre/$'\x7e'}" # bug #557276
+
+DESCRIPTION="P2P private sharing application"
+HOMEPAGE="http://retroshare.sourceforge.net"
+SRC_URI=""
+EGIT_REPO_URI="https://github.com/RetroShare/RetroShare.git"
+
+# pegmarkdown can also be used with MIT
+LICENSE="GPL-2 GPL-3 Apache-2.0 LGPL-2.1"
+SLOT="0"
+KEYWORDS=""
+
+IUSE="cli feedreader libressl qt4 +qt5 voip +sqlcipher"
+REQUIRED_USE="|| ( cli qt5 qt4 )
+ feedreader? ( || ( qt5 qt4 ) )
+ voip? ( || ( qt5 qt4 ) )
+ qt4? ( !qt5 )
+ qt5? ( !qt4 )
+ "
+
+RDEPEND="
+ app-arch/bzip2
+ sqlcipher? (
+ dev-db/sqlcipher
+ )
+ !libressl? ( dev-libs/openssl:0[static-libs(+)?] )
+ libressl? ( dev-libs/libressl[static-libs(+)?] )
+ gnome-base/libgnome-keyring
+ net-libs/libmicrohttpd
+ net-libs/libupnp
+ sys-libs/zlib
+ cli? (
+ dev-libs/protobuf
+ net-libs/libssh[server]
+ )
+ feedreader? (
+ dev-libs/libxml2
+ dev-libs/libxslt
+ net-misc/curl
+ )
+ qt5? (
+ x11-libs/libX11
+ x11-libs/libXScrnSaver
+ dev-qt/designer:5
+ dev-qt/qtcore:5
+ dev-qt/qtgui:5
+ dev-qt/qtmultimedia:5
+ dev-qt/qtnetwork:5
+ dev-qt/qtprintsupport:5
+ dev-qt/qtscript:5
+ dev-qt/qtwidgets:5
+ dev-qt/qtx11extras:5
+ dev-qt/qtxml:5
+ )
+ qt4? (
+ x11-libs/libX11
+ x11-libs/libXScrnSaver
+ dev-qt/designer:4
+ dev-qt/qtcore:4
+ dev-qt/qtgui:4
+ dev-qt/qtmultimedia:4
+ dev-qt/qtscript:4
+ )
+ voip? (
+ media-libs/opencv
+ media-libs/speex
+ )"
+DEPEND="${RDEPEND}
+ qt5? ( dev-qt/qtcore:5 )
+ qt4? ( dev-qt/qtcore:4 )
+ virtual/pkgconfig"
+
+PATCHES=(
+ "${FILESDIR}/hidden_service.patch"
+ "${FILESDIR}/cflags.patch"
+ "${FILESDIR}/disable_key_array_redraw.patch"
+)
+
+
+src_prepare() {
+ default
+ local dir
+
+ sed -i \
+ -e "s|/usr/lib/retroshare/extensions6/|/usr/$(get_libdir)/${PN}/extensions6/|" \
+ libretroshare/src/rsserver/rsinit.cc \
+ || die "sed on libretroshare/src/rsserver/rsinit.cc failed"
+
+ rs_src_dirs="libbitdht/src openpgpsdk/src libresapi/src libretroshare/src supportlibs/pegmarkdown"
+ use cli && rs_src_dirs="${rs_src_dirs} retroshare-nogui/src"
+ use feedreader && rs_src_dirs="${rs_src_dirs} plugins/FeedReader"
+ use qt5 && rs_src_dirs="${rs_src_dirs} retroshare-gui/src"
+ use qt4 && rs_src_dirs="${rs_src_dirs} retroshare-gui/src"
+ use voip && rs_src_dirs="${rs_src_dirs} plugins/VOIP"
+
+ # Force linking to sqlcipher ONLY
+ sed -i \
+ -e '/isEmpty(SQLCIPHER_OK) {/aerror(libsqlcipher not found)' \
+ retroshare-gui/src/retroshare-gui.pro \
+ retroshare-nogui/src/retroshare-nogui.pro || die 'sed on retroshare-gui/src/retroshare-gui.pro failed'
+
+ #regenerate translations in case developers just forgot to do so
+ local use_qt4
+ use qt4 && use_qt4="1"
+ if [ use_qt4 == "1" ]; then
+ qtchooser -run-tool=lupdate -qt=4 retroshare-gui/src/retroshare-gui.pro
+ qtchooser -run-tool=lrelease -qt=4 retroshare-gui/src/retroshare-gui.pro
+ else
+ qtchooser -run-tool=lupdate -qt=5 retroshare-gui/src/retroshare-gui.pro
+ qtchooser -run-tool=lrelease -qt=5 retroshare-gui/src/retroshare-gui.pro
+ fi
+
+ epatch_user
+}
+
+src_configure() {
+ local conf_add="release no-debug c++11"
+ use sqlcipher || conf_add="${conf_add} no_sqlcipher"
+ for dir in ${rs_src_dirs} ; do
+ pushd "${S}/${dir}" 2>/dev/null || die
+ use qt5 && eqmake5 CONFIG+="${conf_add}"
+ use qt4 && eqmake4 CONFIG+="${conf_add}"
+ popd 2>/dev/null || die
+ done
+ sed "s/= gcc/= ${CC}/g" -i supportlibs/pegmarkdown/Makefile
+}
+
+src_compile() {
+ local dir
+
+ for dir in ${rs_src_dirs} ; do
+ emake -C "${dir}"
+ done
+
+ unset rs_src_dirs
+}
+
+src_install() {
+ local i
+ local extension_dir="/usr/$(get_libdir)/${PN}/extensions6/"
+
+ use cli && dobin retroshare-nogui/src/retroshare-nogui
+ use qt5 && dobin retroshare-gui/src/retroshare
+ use qt4 && dobin retroshare-gui/src/retroshare
+
+ exeinto "${extension_dir}"
+ use feedreader && doexe plugins/FeedReader/*.so*
+ use voip && doexe plugins/VOIP/*.so*
+
+ insinto /usr/share/retroshare
+ doins libbitdht/src/bitdht/bdboot.txt
+
+ insinto /usr/share/retroshare/webui
+ doins libresapi/src/webui-src/*
+
+ make_desktop_entry RetroShare
+ for i in 24 48 64 ; do
+ doicon -s ${i} "data/${i}x${i}/apps/${PN}.png"
+ done
+ doicon -s 128 "data/${PN}.xpm"
+}
+
+pkg_preinst() {
+ if [[ "${REPLACING_VERSIONS}" = "0.5*" ]]; then
+ elog "You are upgrading from Retroshare 0.5.* to ${PV}"
+ elog "Version 0.6.* is backward-incompatible with 0.5 branch"
+ elog "and clients with 0.6.* can not connect to clients that have 0.5.*"
+ elog "It's recommended to drop all your configuration and either"
+ elog "generate a new certificate or import existing from a backup"
+ fi
+ gnome2_icon_savelist
+}
+
+pkg_postinst() {
+ gnome2_icon_cache_update
+}
+
+pkg_postrm() {
+ gnome2_icon_cache_update
+}