diff options
-rw-r--r-- | net-misc/aria2/ChangeLog | 8 | ||||
-rw-r--r-- | net-misc/aria2/aria2-1.10.0.ebuild | 86 | ||||
-rw-r--r-- | net-misc/aria2/files/1.6.3-unaligned_pointers.patch | 62 |
3 files changed, 93 insertions, 63 deletions
diff --git a/net-misc/aria2/ChangeLog b/net-misc/aria2/ChangeLog index 6713bbbe621e..57eef971f8c8 100644 --- a/net-misc/aria2/ChangeLog +++ b/net-misc/aria2/ChangeLog @@ -1,6 +1,12 @@ # ChangeLog for net-misc/aria2 # Copyright 1999-2010 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/net-misc/aria2/ChangeLog,v 1.63 2010/06/05 05:40:52 dev-zero Exp $ +# $Header: /var/cvsroot/gentoo-x86/net-misc/aria2/ChangeLog,v 1.64 2010/07/19 09:21:48 dev-zero Exp $ + +*aria2-1.10.0 (19 Jul 2010) + + 19 Jul 2010; Tiziano Müller <dev-zero@gentoo.org> + -files/1.6.3-unaligned_pointers.patch, +aria2-1.10.0.ebuild: + Version bump. Dropped old patch. *aria2-1.9.4 (05 Jun 2010) diff --git a/net-misc/aria2/aria2-1.10.0.ebuild b/net-misc/aria2/aria2-1.10.0.ebuild new file mode 100644 index 000000000000..bcd6c36b9819 --- /dev/null +++ b/net-misc/aria2/aria2-1.10.0.ebuild @@ -0,0 +1,86 @@ +# Copyright 1999-2010 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/net-misc/aria2/aria2-1.10.0.ebuild,v 1.1 2010/07/19 09:21:48 dev-zero Exp $ + +EAPI="2" + +DESCRIPTION="A download utility with resuming and segmented downloading with HTTP/HTTPS/FTP/BitTorrent support." +HOMEPAGE="http://aria2.sourceforge.net/" +SRC_URI="mirror://sourceforge/${PN}/${P}.tar.bz2" +LICENSE="GPL-2" +KEYWORDS="~amd64 ~ppc ~ppc64 ~sparc ~x86" +SLOT="0" +IUSE="ares bittorrent expat gnutls metalink nls scripts sqlite ssl test xmlrpc" + +CDEPEND="sys-libs/zlib + ssl? ( + gnutls? ( >=net-libs/gnutls-1.2.9 ) + !gnutls? ( dev-libs/openssl ) ) + ares? ( >=net-dns/c-ares-1.5.0 ) + bittorrent? ( + gnutls? ( >=net-libs/gnutls-1.2.9 >=dev-libs/libgcrypt-1.2.2 ) + !gnutls? ( dev-libs/openssl ) ) + metalink? ( + !expat? ( >=dev-libs/libxml2-2.6.26 ) + expat? ( dev-libs/expat ) ) + sqlite? ( dev-db/sqlite:3 ) + xmlrpc? ( + !expat? ( >=dev-libs/libxml2-2.6.26 ) + expat? ( dev-libs/expat ) )" +DEPEND="${CDEPEND} + dev-util/pkgconfig + nls? ( sys-devel/gettext ) + test? ( >=dev-util/cppunit-1.12.0 )" +RDEPEND="${CDEPEND} + scripts? ( dev-lang/ruby ) + nls? ( virtual/libiconv virtual/libintl )" + +pkg_setup() { + if use scripts && use !xmlrpc && use !metalink; then + ewarn "Please also enable the 'xmlrpc' USE flag to actually use the additional scripts" + fi +} + +src_prepare() { + sed -i -e "s|/tmp|${T}|" test/*.cc test/*.txt || die "sed failed" +} + +src_configure() { + local myconf="--without-gnutls --without-openssl" + use ssl && \ + myconf="$(use_with gnutls) $(use_with !gnutls openssl)" + + local xmllib="--without-libexpat --without-libxml2" + if use metalink || use xmlrpc ; then + xmllib="$(use_with expat libexpat) $(use_with !expat libxml2)" + fi + + # Note: + # - depends on libgcrypt only when using gnutls + # - if --without-libexpat or --without-libxml2 are not given, it links against + # one of them to provide xmlrpc-functionality + # - always enable gzip/http compression since zlib should always be available anyway + # - always enable epoll since we can assume kernel 2.6.x + # - other options for threads: solaris, pth, win32 + econf \ + --enable-epoll \ + --enable-threads=posix \ + --with-libz \ + $(use_enable nls) \ + $(use_enable metalink) \ + $(use_with sqlite sqlite3) \ + $(use_enable bittorrent) \ + $(use_with ares libcares) \ + ${xmllib} \ + ${myconf} +} + +src_install() { + emake DESTDIR="${D}" install || die "emake install failed" + + rm -rf "${D}/usr/share/doc/aria2" + dodoc ChangeLog README AUTHORS NEWS + dohtml README.html doc/aria2c.1.html + + use scripts && dobin doc/xmlrpc/aria2{mon,rpc} +} diff --git a/net-misc/aria2/files/1.6.3-unaligned_pointers.patch b/net-misc/aria2/files/1.6.3-unaligned_pointers.patch deleted file mode 100644 index a19a0dcfe3ea..000000000000 --- a/net-misc/aria2/files/1.6.3-unaligned_pointers.patch +++ /dev/null @@ -1,62 +0,0 @@ -diff -Naur aria2-1.6.3.orig/src/bittorrent_helper.cc aria2-1.6.3/src/bittorrent_helper.cc ---- aria2-1.6.3.orig/src/bittorrent_helper.cc 2009-11-02 15:22:22.000000000 +0100 -+++ aria2-1.6.3/src/bittorrent_helper.cc 2009-11-14 18:56:29.461122621 +0100 -@@ -774,9 +774,9 @@ - } - struct sockaddr_in* in = reinterpret_cast<struct sockaddr_in*>(res->ai_addr); - uint32_t* addrp = (uint32_t*)compact; -- *addrp = in->sin_addr.s_addr; -- uint16_t* portp = (uint16_t*)(compact+4); -- *portp = htons(port); -+ memcpy(addrp, &(in->sin_addr.s_addr), sizeof(uint32_t)); -+ uint16_t port_nworder(htons(port)); -+ memcpy(compact+4, &port_nworder, sizeof(uint16_t)); - freeaddrinfo(res); - return true; - } -@@ -790,7 +790,7 @@ - in.sin_len = sizeof(in); - #endif // HAVE_SOCKADDR_IN_SIN_LEN - in.sin_family = AF_INET; -- in.sin_addr.s_addr = *reinterpret_cast<const uint32_t*>(compact); -+ memcpy(&(in.sin_addr.s_addr), compact, sizeof(uint32_t)); - in.sin_port = 0; - char host[NI_MAXHOST]; - int s; -@@ -800,7 +800,9 @@ - if(s) { - return std::pair<std::string, uint16_t>(); - } -- uint16_t port = ntohs(*(uint16_t*)(compact+sizeof(uint32_t))); -+ uint16_t port_nworder; -+ memcpy(&port_nworder, compact+sizeof(uint32_t), sizeof(uint16_t)); -+ uint16_t port = ntohs(port_nworder); - return std::pair<std::string, uint16_t>(host, port); - } - -diff -Naur aria2-1.6.3.orig/src/PeerListProcessor.h aria2-1.6.3/src/PeerListProcessor.h ---- aria2-1.6.3.orig/src/PeerListProcessor.h 2009-11-02 15:22:22.000000000 +0100 -+++ aria2-1.6.3/src/PeerListProcessor.h 2009-11-14 17:12:40.000000000 +0100 -@@ -40,6 +40,8 @@ - #include "bencode.h" - #include "Peer.h" - -+#include <cstring> -+ - namespace aria2 { - - class PeerListProcessor { -@@ -83,9 +85,11 @@ - if(length%6 == 0) { - for(size_t i = 0; i < length; i += 6) { - struct in_addr in; -- in.s_addr = *(uint32_t*)(peerData.s().c_str()+i); -+ memcpy(&in.s_addr, peerData.s().c_str()+i, sizeof(uint32_t)); - std::string ipaddr = inet_ntoa(in); -- uint16_t port = ntohs(*(uint16_t*)(peerData.s().c_str()+i+4)); -+ uint16_t port_nworder; -+ memcpy(&port_nworder, peerData.s().c_str()+i+4, sizeof(uint16_t)); -+ uint16_t port = ntohs(port_nworder); - *dest = SharedHandle<Peer>(new Peer(ipaddr, port)); - ++dest; - } |