libbt-1.01, c reimplementation of the bittorrent core protocols
This commit is contained in:
parent
fff9a09019
commit
fadcc408eb
37
devel/libbt/Makefile
Normal file
37
devel/libbt/Makefile
Normal file
@ -0,0 +1,37 @@
|
||||
# $OpenBSD: Makefile,v 1.1.1.1 2004/04/15 03:37:43 jolan Exp $
|
||||
|
||||
COMMENT= "c reimplementation of the BitTorrent core protocols"
|
||||
DISTNAME= libbt-1.01
|
||||
CATEGORIES= devel net
|
||||
MASTER_SITES= ${MASTER_SITE_SOURCEFORGE:=libbt/}
|
||||
|
||||
HOMEPAGE= http://libbt.sourceforge.net/
|
||||
|
||||
MAINTAINER= Jolan Luff <jolan@openbsd.org>
|
||||
|
||||
# GPL
|
||||
PERMIT_DISTFILES_CDROM= Yes
|
||||
PERMIT_DISTFILES_FTP= Yes
|
||||
PERMIT_PACKAGE_CDROM= Yes
|
||||
PERMIT_PACKAGE_FTP= Yes
|
||||
|
||||
NO_REGRESS= Yes
|
||||
|
||||
LIB_DEPENDS= curl.2.2::net/curl
|
||||
|
||||
CONFIGURE_STYLE=gnu
|
||||
CONFIGURE_ENV+= LDFLAGS="-L${LOCALBASE}/lib"
|
||||
|
||||
do-install:
|
||||
${INSTALL_DATA_DIR} ${PREFIX}/include/libbt
|
||||
${INSTALL_DATA} ${WRKBUILD}/src/libbt.a ${PREFIX}/lib
|
||||
.for p in btcheck btget btlist
|
||||
${INSTALL_PROGRAM} ${WRKBUILD}/src/${p} ${PREFIX}/bin
|
||||
.endfor
|
||||
.for i in benc bitset bterror bts context peer random segmenter strbuf stream \
|
||||
types util
|
||||
${INSTALL_DATA} ${WRKSRC}/include/${i}.h ${PREFIX}/include/libbt
|
||||
.endfor
|
||||
${INSTALL_MAN} ${WRKSRC}/man/*.1 ${PREFIX}/man/man1
|
||||
|
||||
.include <bsd.port.mk>
|
3
devel/libbt/distinfo
Normal file
3
devel/libbt/distinfo
Normal file
@ -0,0 +1,3 @@
|
||||
MD5 (libbt-1.01.tar.gz) = 6a22db0d4db9036afbb5af94b8fdd526
|
||||
RMD160 (libbt-1.01.tar.gz) = 2e44d3db9e2623d517aaa5f780b3c2c514fc11f8
|
||||
SHA1 (libbt-1.01.tar.gz) = be72b6d80fdd4e9140239184241e7d0f8109e8ad
|
12
devel/libbt/patches/patch-configure
Normal file
12
devel/libbt/patches/patch-configure
Normal file
@ -0,0 +1,12 @@
|
||||
$OpenBSD: patch-configure,v 1.1.1.1 2004/04/15 03:37:43 jolan Exp $
|
||||
--- configure.orig 2004-03-21 23:58:02.000000000 -0600
|
||||
+++ configure 2004-04-14 21:03:14.000000000 -0500
|
||||
@@ -2495,7 +2495,7 @@ if { (eval echo "$as_me:$LINENO: \"$ac_l
|
||||
ac_status=$?
|
||||
echo "$as_me:$LINENO: \$? = $ac_status" >&5
|
||||
(exit $ac_status); }; }; then
|
||||
- ac_cv_lib_uuid_uuid_generate=yes
|
||||
+ ac_cv_lib_uuid_uuid_generate=no
|
||||
else
|
||||
echo "$as_me: failed program was:" >&5
|
||||
sed 's/^/| /' conftest.$ac_ext >&5
|
25
devel/libbt/patches/patch-src_Makefile_in
Normal file
25
devel/libbt/patches/patch-src_Makefile_in
Normal file
@ -0,0 +1,25 @@
|
||||
$OpenBSD: patch-src_Makefile_in,v 1.1.1.1 2004/04/15 03:37:43 jolan Exp $
|
||||
--- src/Makefile.in.orig 2004-04-07 00:05:07.000000000 -0500
|
||||
+++ src/Makefile.in 2004-04-14 21:01:24.000000000 -0500
|
||||
@@ -25,17 +25,17 @@ SRCS:=\
|
||||
bterror.c
|
||||
OBJS:= ${SRCS:.c=.o}
|
||||
|
||||
-CPPFLAGS:=@CPPFLAGS@
|
||||
-CFLAGS:=-g -Wall -I../include -I$(top_srcdir)/include
|
||||
+CPPFLAGS+=@CPPFLAGS@ `curl-config --cflags`
|
||||
+CFLAGS+=-Wall -I../include -I$(top_srcdir)/include
|
||||
|
||||
LIBS:=@LIBS@ `curl-config --libs` -lm
|
||||
-LDFLAGS:=-g -L. @LDFLAGS@
|
||||
+LDFLAGS:=-L. @LDFLAGS@
|
||||
|
||||
all: ${LIBBT} ${PROGRAMS}
|
||||
docs:
|
||||
doxygen *.c
|
||||
depend:
|
||||
- makedepend -- ${CFLAGS} - ${SRCS}
|
||||
+ makedepend -- ${CPPFLAGS} ${CFLAGS} - ${SRCS}
|
||||
btcheck: libbt.a btcheck.o
|
||||
${CC} ${LDFLAGS} -o btcheck btcheck.o -lbt ${LIBS}
|
||||
|
32
devel/libbt/patches/patch-src_context_c
Normal file
32
devel/libbt/patches/patch-src_context_c
Normal file
@ -0,0 +1,32 @@
|
||||
$OpenBSD: patch-src_context_c,v 1.1.1.1 2004/04/15 03:37:43 jolan Exp $
|
||||
--- src/context.c.orig 2004-04-02 23:19:47.000000000 -0600
|
||||
+++ src/context.c 2004-04-14 20:56:49.000000000 -0500
|
||||
@@ -45,6 +45,14 @@
|
||||
# define snprintf _snprintf
|
||||
#endif
|
||||
|
||||
+const struct addrinfo ai_template={
|
||||
+ .ai_family=AF_INET, /* PF_INET */
|
||||
+ .ai_socktype=SOCK_STREAM,
|
||||
+ /*.ai_protocol=IPPROTO_TCP,*/
|
||||
+};
|
||||
+
|
||||
+struct addrinfo *ai=NULL;
|
||||
+
|
||||
static int parse_config_digest(
|
||||
const char *file, int lineno, const char *token,
|
||||
unsigned char *digest, int len,
|
||||
@@ -227,13 +235,6 @@ btresponse( btContext *ctx, int download
|
||||
|
||||
skip=0;
|
||||
|
||||
- const struct addrinfo ai_template={
|
||||
- .ai_family=AF_INET, /* PF_INET */
|
||||
- .ai_socktype=SOCK_STREAM,
|
||||
- /*.ai_protocol=IPPROTO_TCP,*/
|
||||
- };
|
||||
- struct addrinfo *ai=NULL;
|
||||
-
|
||||
if (memcmp(ctx->myid, peerid->buf, IDSIZE)==0) {
|
||||
printf("Skipping myself %s:%d\n", ip->buf, iport);
|
||||
continue;
|
133
devel/libbt/patches/patch-src_peer_c
Normal file
133
devel/libbt/patches/patch-src_peer_c
Normal file
@ -0,0 +1,133 @@
|
||||
$OpenBSD: patch-src_peer_c,v 1.1.1.1 2004/04/15 03:37:43 jolan Exp $
|
||||
--- src/peer.c.orig 2004-04-06 23:14:44.000000000 -0500
|
||||
+++ src/peer.c 2004-04-14 20:52:25.000000000 -0500
|
||||
@@ -46,6 +46,8 @@
|
||||
#define REQUEST_SIZE 16384 /* Default request size */
|
||||
char g_filebuffer[MAXREQUEST]; /* This should be moved to context or allocated in process_queue */
|
||||
|
||||
+int interest;
|
||||
+
|
||||
btPeerset* btPeerset_create( btPeerset *pset) {
|
||||
if (!pset) {
|
||||
pset = (btPeerset *)malloc(sizeof(btPeerset));
|
||||
@@ -458,6 +460,13 @@ static int rate_timer( btPeerStatus *ps,
|
||||
return total;
|
||||
}
|
||||
|
||||
+#define SHIFT_INT32(ptr,nbo,ival) \
|
||||
+ (nbo=htonl(ival), memcpy(ptr,&nbo,sizeof(int32_t)), ptr+=sizeof(int32_t))
|
||||
+#define SHIFT_BYTE(ptr,ival) ((*((unsigned char *)(ptr))++) = ival)
|
||||
+
|
||||
+#define UNSHIFT_INT32(ptr,nbo,ival) \
|
||||
+ (memcpy(&nbo,ptr,sizeof(int32_t)), ival=ntohl(nbo), ptr+=sizeof(int32_t))
|
||||
+#define UNSHIFT_BYTE(ptr,ival) (ival = (*((unsigned char *)(ptr))++)
|
||||
/*
|
||||
* Return 1 if there are more messages waiting
|
||||
* Return 0 on success,
|
||||
@@ -470,9 +479,10 @@ recv_peermsg( btContext *ctx, btPeer *pe
|
||||
int32_t nbo_len;
|
||||
int len;
|
||||
char msg[80];
|
||||
- char *nmsg;
|
||||
+ char *nmsg, *param;
|
||||
int res = 0;
|
||||
int err;
|
||||
+ int32_t nbo;
|
||||
|
||||
assert(peer->download<ctx->downloadcount);
|
||||
|
||||
@@ -507,6 +517,7 @@ recv_peermsg( btContext *ctx, btPeer *pe
|
||||
#endif
|
||||
|
||||
/* got message */
|
||||
+ param = nmsg+5;
|
||||
switch (nmsg[4]) {
|
||||
case BT_MSG_CHOKE:
|
||||
{
|
||||
@@ -557,8 +568,9 @@ recv_peermsg( btContext *ctx, btPeer *pe
|
||||
break;
|
||||
case BT_MSG_HAVE:
|
||||
{
|
||||
- int block = ntohl(*(int *)(nmsg+5));
|
||||
- int interest;
|
||||
+ int block;
|
||||
+
|
||||
+ UNSHIFT_INT32(param,nbo,block);
|
||||
bs_set( &peer->blocks, block);
|
||||
interest = update_interested( ctx, peer);
|
||||
if (interest &&
|
||||
@@ -576,9 +588,13 @@ recv_peermsg( btContext *ctx, btPeer *pe
|
||||
break;
|
||||
case BT_MSG_REQUEST:
|
||||
{
|
||||
- int piece = ntohl(*(int *)(nmsg+5));
|
||||
- int offs = ntohl(*(int *)(nmsg+9));
|
||||
- int len = ntohl(*(int *)(nmsg+13));
|
||||
+ int piece;
|
||||
+ int offs;
|
||||
+ int len;
|
||||
+
|
||||
+ UNSHIFT_INT32(param,nbo,piece);
|
||||
+ UNSHIFT_INT32(param,nbo,offs);
|
||||
+ UNSHIFT_INT32(param,nbo,len);
|
||||
if (peer->local.choked) {
|
||||
/* ignore requests from choked peers */
|
||||
break;
|
||||
@@ -599,16 +615,13 @@ recv_peermsg( btContext *ctx, btPeer *pe
|
||||
break;
|
||||
case BT_MSG_PIECE:
|
||||
{
|
||||
- int32_t ibuf;
|
||||
|
||||
btPartialPiece *pp=peer->currentPiece;
|
||||
int piece;
|
||||
int offs;
|
||||
|
||||
- memcpy(&ibuf,nmsg+5,sizeof(int32_t));
|
||||
- piece = ntohl(ibuf);
|
||||
- memcpy(&ibuf,nmsg+9,sizeof(int32_t));
|
||||
- offs = ntohl(ibuf);
|
||||
+ UNSHIFT_INT32(param,nbo,piece);
|
||||
+ UNSHIFT_INT32(param,nbo,offs);
|
||||
|
||||
#if 0
|
||||
printf("%d: got piece %d, offs %d, len %d\n",
|
||||
@@ -670,14 +683,10 @@ recv_peermsg( btContext *ctx, btPeer *pe
|
||||
case BT_MSG_CANCEL:
|
||||
{
|
||||
int piece, offs, len;
|
||||
- int32_t ibuf;
|
||||
/* this cancels a specific request */
|
||||
- memcpy(&ibuf,nmsg+5,sizeof(int32_t));
|
||||
- piece = ntohl(ibuf);
|
||||
- memcpy(&ibuf,nmsg+9,sizeof(int32_t));
|
||||
- offs = ntohl(ibuf);
|
||||
- memcpy(&ibuf,nmsg+13,sizeof(int32_t));
|
||||
- len = ntohl(ibuf);
|
||||
+ UNSHIFT_INT32(param,nbo,piece);
|
||||
+ UNSHIFT_INT32(param,nbo,offs);
|
||||
+ UNSHIFT_INT32(param,nbo,len);
|
||||
|
||||
#if 0
|
||||
printf("%d: got cancel %d, offs %d, len %d\n",
|
||||
@@ -729,9 +738,6 @@ cleanup:
|
||||
* -1 - permanent error sending msg size
|
||||
* -2 - permanent error sending message
|
||||
*/
|
||||
-#define SHIFT_INT32(ptr,nbo,ival) \
|
||||
- (nbo=htonl(ival), memcpy(ptr,&nbo,sizeof(int32_t)), ptr+=sizeof(int32_t))
|
||||
-#define SHIFT_BYTE(ptr,ival) ((*((unsigned char *)(ptr))++) = ival)
|
||||
int
|
||||
send_message( btPeer *peer, char *buf, int len) {
|
||||
int nslen = htonl( len);
|
||||
@@ -1046,7 +1052,9 @@ int
|
||||
update_interested( btContext *ctx, btPeer *p) {
|
||||
btDownload *dl=ctx->downloads[p->download];
|
||||
assert (p->download<ctx->downloadcount);
|
||||
- int interest = bs_hasInteresting( &dl->fileset.completed, &p->blocks, &dl->interested);
|
||||
+
|
||||
+ interest = bs_hasInteresting( &dl->fileset.completed, &p->blocks, &dl->interested);
|
||||
+
|
||||
if (interest != p->local.interested) {
|
||||
if (send_interested( p, interest)) return -1;
|
||||
if (interest == 0 && !p->remote.choked) {
|
4
devel/libbt/pkg/DESCR
Normal file
4
devel/libbt/pkg/DESCR
Normal file
@ -0,0 +1,4 @@
|
||||
LibBT is a C reimplementation of the BitTorrent core protocols. The
|
||||
goal for the project is to develop a low overhead library version of
|
||||
the protocols so that BitTorrent transfers can easily be built in to
|
||||
any existing application.
|
21
devel/libbt/pkg/PLIST
Normal file
21
devel/libbt/pkg/PLIST
Normal file
@ -0,0 +1,21 @@
|
||||
@comment $OpenBSD: PLIST,v 1.1.1.1 2004/04/15 03:37:43 jolan Exp $
|
||||
bin/btcheck
|
||||
bin/btget
|
||||
bin/btlist
|
||||
include/libbt/benc.h
|
||||
include/libbt/bitset.h
|
||||
include/libbt/bterror.h
|
||||
include/libbt/bts.h
|
||||
include/libbt/context.h
|
||||
include/libbt/peer.h
|
||||
include/libbt/random.h
|
||||
include/libbt/segmenter.h
|
||||
include/libbt/strbuf.h
|
||||
include/libbt/stream.h
|
||||
include/libbt/types.h
|
||||
include/libbt/util.h
|
||||
lib/libbt.a
|
||||
man/man1/btcheck.1
|
||||
man/man1/btget.1
|
||||
man/man1/btlist.1
|
||||
@dirrm include/libbt
|
Loading…
Reference in New Issue
Block a user