summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--net-libs/libtorrent/Manifest1
-rw-r--r--net-libs/libtorrent/files/libtorrent-0.15.3-unbundle_udns.patch54
-rw-r--r--net-libs/libtorrent/libtorrent-0.15.3.ebuild80
3 files changed, 135 insertions, 0 deletions
diff --git a/net-libs/libtorrent/Manifest b/net-libs/libtorrent/Manifest
index 40fdff284841..10edbfb0c9ea 100644
--- a/net-libs/libtorrent/Manifest
+++ b/net-libs/libtorrent/Manifest
@@ -1,3 +1,4 @@
DIST libtorrent-0.13.8.tar.gz 834027 BLAKE2B 374f33af52a45c244182d36bacd6b42eea9edc179e42fb40f4170a47a0cdd39cfb3f42f82fc26ab36718afb9a28a8dd72ca139b3646bbc1c2887444905438cdd SHA512 417177df5b27cd8c6a6317063b0846da2690de4633836466728605c2edad2de407d29d321cc481b8d1352dd0ff6dd89f4566a830424a8cf986f2fddb04704da4
DIST libtorrent-0.14.0.tar.gz 809617 BLAKE2B 321a3911e22b148744439ceb87adb470036516bef6c75f55f860b1f985d7b61bced11c93aaf0a703bd6d0089816dbfdaaa9420b28619ed9dafa4d1495b6763bc SHA512 d61b93778068849a706fa46b5b1c4fbab9246d8a1b45e574987d987eaba50145dd98be65cf969fb4d38a1e4c3bae03b283103163d415506598b8673740d8ac58
DIST libtorrent-0.15.1.tar.gz 805722 BLAKE2B 7b4b9aba8133a2a20a5dd39d451c9478c44f133ae3b5929b79cbd25fb0754b4bc64291a75da898ed335a808b992d67ffa7a3a431420da7073d2fb3c927109649 SHA512 e7d607fc3e31e2d6f4643c6760a271324a4f8f102e07228aca13427073426a393b12006329206fa14108d93c2f378a8db3761b0e14ff3ae391551777b4b04a6a
+DIST libtorrent-0.15.3.tar.gz 872751 BLAKE2B e1a851273e9341f1e71806ada0417d0123f6a7d0fc0965f6a957bbc55981072385d8ae1c59af18c64d5157457532d39af037cbd9313e2646020bdfb70fc48323 SHA512 795a1ff115b37df5899a59ff23524cde95380c323b5a11f369d7f43eb250843cf57ed4a2f39880992ecc05d5724c149cd2955ee6c621193f95d13875af341cec
diff --git a/net-libs/libtorrent/files/libtorrent-0.15.3-unbundle_udns.patch b/net-libs/libtorrent/files/libtorrent-0.15.3-unbundle_udns.patch
new file mode 100644
index 000000000000..d5c0b6838eb5
--- /dev/null
+++ b/net-libs/libtorrent/files/libtorrent-0.15.3-unbundle_udns.patch
@@ -0,0 +1,54 @@
+diff --git a/src/net/udns_library.cc b/src/net/udns_library.cc
+index 788e7eee..73b7e210 100644
+--- a/src/net/udns_library.cc
++++ b/src/net/udns_library.cc
+@@ -12,23 +12,6 @@
+
+ extern "C" {
+
+-#include "net/udns/udns.h"
+-
+-#include "net/udns/udns_XtoX.c"
+-#include "net/udns/udns_bl.c"
+-#include "net/udns/udns_codes.c"
+-#include "net/udns/udns_dn.c"
+-#include "net/udns/udns_dntosp.c"
+-#include "net/udns/udns_init.c"
+-#include "net/udns/udns_jran.c"
+-#include "net/udns/udns_misc.c"
+-#include "net/udns/udns_parse.c"
+-#include "net/udns/udns_resolver.c"
+-#include "net/udns/udns_rr_a.c"
+-#include "net/udns/udns_rr_mx.c"
+-#include "net/udns/udns_rr_naptr.c"
+-#include "net/udns/udns_rr_ptr.c"
+-#include "net/udns/udns_rr_srv.c"
+-#include "net/udns/udns_rr_txt.c"
++#include <udns.h>
+
+ }
+diff --git a/src/net/udns_library.h b/src/net/udns_library.h
+index b09b398a..bdb1bcdf 100644
+--- a/src/net/udns_library.h
++++ b/src/net/udns_library.h
+@@ -1,6 +1,6 @@
+ #ifndef TORRENT_NET_UDNS_LIBRARY_H
+ #define TORRENT_NET_UDNS_LIBRARY_H
+
+-#include "net/udns/udns.h"
++#include <udns.h>
+
+ #endif
+diff --git a/src/net/udns_resolver.cc b/src/net/udns_resolver.cc
+index e35e5fc1..f697112d 100644
+--- a/src/net/udns_resolver.cc
++++ b/src/net/udns_resolver.cc
+@@ -8,7 +8,7 @@
+
+ #include "globals.h"
+ #include "manager.h"
+-#include "net/udns/udns.h"
++#include <udns.h>
+ #include "torrent/common.h"
+ #include "torrent/poll.h"
+ #include "torrent/net/socket_address.h"
diff --git a/net-libs/libtorrent/libtorrent-0.15.3.ebuild b/net-libs/libtorrent/libtorrent-0.15.3.ebuild
new file mode 100644
index 000000000000..39e7965bf314
--- /dev/null
+++ b/net-libs/libtorrent/libtorrent-0.15.3.ebuild
@@ -0,0 +1,80 @@
+# Copyright 1999-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+inherit autotools toolchain-funcs
+
+DESCRIPTION="BitTorrent library written in C++ for *nix"
+HOMEPAGE="https://rakshasa.github.io/rtorrent/"
+SRC_URI="https://github.com/rakshasa/rtorrent/releases/download/v${PV}/${P}.tar.gz"
+
+LICENSE="GPL-2"
+# The README says that the library ABI is not yet stable and dependencies on
+# the library should be an explicit, syncronized version until the library
+# has had more time to mature. Until it matures we should not include a soname
+# subslot.
+SLOT="0"
+KEYWORDS="~amd64 ~hppa ~ppc ~ppc64 ~sparc ~x86 ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos ~x64-solaris"
+IUSE="debug test"
+RESTRICT="!test? ( test )"
+
+RDEPEND="
+ dev-libs/openssl:=
+ net-libs/udns
+ sys-libs/zlib
+"
+DEPEND="${RDEPEND}"
+BDEPEND="
+ virtual/pkgconfig
+ test? ( dev-util/cppunit )
+"
+
+PATCHES=(
+ "${FILESDIR}"/${PN}-0.14.0-tests-address.patch
+ "${FILESDIR}"/${PN}-0.15.3-unbundle_udns.patch
+)
+
+src_prepare() {
+ default
+
+ # use system-udns
+ rm -r src/net/udns || die
+
+ if [[ ${CHOST} != *-darwin* ]]; then
+ # syslibroot is only for macos, change to sysroot for others
+ sed -i 's/Wl,-syslibroot,/Wl,--sysroot,/' "${S}/scripts/common.m4" || die
+ fi
+ eautoreconf
+}
+
+src_configure() {
+ # bug 518582
+ local disable_instrumentation
+ echo -e "#include <inttypes.h>\nint main(){ int64_t var = 7; __sync_add_and_fetch(&var, 1); return 0;}" \
+ > "${T}/sync_add_and_fetch.c" || die
+ $(tc-getCC) ${CFLAGS} -o /dev/null -x c "${T}/sync_add_and_fetch.c" >/dev/null 2>&1
+ if [[ $? -ne 0 ]]; then
+ einfo "Disabling instrumentation"
+ disable_instrumentation="--disable-instrumentation"
+ fi
+
+ # configure needs bash or script bombs out on some null shift, bug #291229
+ export CONFIG_SHELL=${BASH}
+
+ local myeconfargs=(
+ LIBS="-ludns"
+ --enable-aligned
+ $(use_enable debug)
+ ${disable_instrumentation}
+ --with-posix-fallocate
+ )
+
+ econf "${myeconfargs[@]}"
+}
+
+src_install() {
+ default
+
+ find "${ED}" -type f -name '*.la' -delete || die
+}