diff options
author | mi <mi@FreeBSD.org> | 2012-07-29 04:48:23 +0800 |
---|---|---|
committer | mi <mi@FreeBSD.org> | 2012-07-29 04:48:23 +0800 |
commit | 790a7f92813810d8ecf1b07fe3b8c6bf891ee974 (patch) | |
tree | d07fcfacd289629bf14ff3b8e443141553d71bbb /devel | |
parent | d22b04c33451148ce2d5fb261d97da3d1f555602 (diff) | |
download | freebsd-ports-gnome-790a7f92813810d8ecf1b07fe3b8c6bf891ee974.tar.gz freebsd-ports-gnome-790a7f92813810d8ecf1b07fe3b8c6bf891ee974.tar.zst freebsd-ports-gnome-790a7f92813810d8ecf1b07fe3b8c6bf891ee974.zip |
Add implementation of Kademlia Distributed Hash Table (DHT) used
in the Bittorrent network (``mainline'' variant).
Diffstat (limited to 'devel')
-rw-r--r-- | devel/Makefile | 1 | ||||
-rw-r--r-- | devel/jech-dht/Makefile | 25 | ||||
-rw-r--r-- | devel/jech-dht/distinfo | 2 | ||||
-rw-r--r-- | devel/jech-dht/files/BSDmakefile | 14 | ||||
-rw-r--r-- | devel/jech-dht/files/patch-warns | 121 | ||||
-rw-r--r-- | devel/jech-dht/pkg-descr | 6 | ||||
-rw-r--r-- | devel/jech-dht/pkg-plist | 5 |
7 files changed, 174 insertions, 0 deletions
diff --git a/devel/Makefile b/devel/Makefile index e3d42cb0f685..9d5dc71255d7 100644 --- a/devel/Makefile +++ b/devel/Makefile @@ -314,6 +314,7 @@ SUBDIR += devhelp SUBDIR += devtodo SUBDIR += dfuife-curses + SUBDIR += jech-dht SUBDIR += dia2code SUBDIR += diffuse SUBDIR += ding-libs diff --git a/devel/jech-dht/Makefile b/devel/jech-dht/Makefile new file mode 100644 index 000000000000..134173adaed9 --- /dev/null +++ b/devel/jech-dht/Makefile @@ -0,0 +1,25 @@ +# New ports collection makefile for: jech-dht +# Date created: July 28, 2012 +# Whom: Mikhail Teterin <mi@aldan.algebra.com> +# +# $FreeBSD$ +# + +PORTNAME= dht +PORTVERSION= 0.21 +CATEGORIES= net devel +MASTER_SITES= http://www.pps.univ-paris-diderot.fr/~jch/software/files/ + +MAINTAINER= mi@aldan.algebra.com +COMMENT= Mainline variant of Kademlia Distributed Hash Table (DHT) + +LICENSE= MIT + +MAKEFILE= ${FILESDIR}/BSDmakefile +MAKE_JOBS_SAFE= yes +USE_LDCONFIG= yes + +pre-su-install: + ${MKDIR} ${PREFIX}/include/dht + +.include <bsd.port.mk> diff --git a/devel/jech-dht/distinfo b/devel/jech-dht/distinfo new file mode 100644 index 000000000000..87d93eb60992 --- /dev/null +++ b/devel/jech-dht/distinfo @@ -0,0 +1,2 @@ +SHA256 (dht-0.21.tar.gz) = edf8fd9bf6225bbced38a74bb40592d46876fdfb74e9ebddecbdc1e805bdf44f +SIZE (dht-0.21.tar.gz) = 27578 diff --git a/devel/jech-dht/files/BSDmakefile b/devel/jech-dht/files/BSDmakefile new file mode 100644 index 000000000000..8ec2782c5070 --- /dev/null +++ b/devel/jech-dht/files/BSDmakefile @@ -0,0 +1,14 @@ +LIB= dht +SHLIB_MAJOR= 0 +SHLIB_MINOR= 21 + +SRCS= dht.c + +CFLAGS+=-DHAVE_MEMMEM +WARNS= 3 + +INCS= dht.h +INCLUDEDIR=${PREFIX}/include/dht +LIBDIR= ${PREFIX}/lib + +.include <bsd.lib.mk> diff --git a/devel/jech-dht/files/patch-warns b/devel/jech-dht/files/patch-warns new file mode 100644 index 000000000000..a2a8c2c737b1 --- /dev/null +++ b/devel/jech-dht/files/patch-warns @@ -0,0 +1,121 @@ +--- dht.c 2011-07-25 17:59:36.000000000 -0400 ++++ dht.c 2012-07-28 16:21:07.000000000 -0400 +@@ -356,5 +356,5 @@ + switch(sa->sa_family) { + case AF_INET: { +- struct sockaddr_in *sin = (struct sockaddr_in*)sa; ++ const struct sockaddr_in *sin = (const struct sockaddr_in*)sa; + const unsigned char *address = (const unsigned char*)&sin->sin_addr; + return sin->sin_port == 0 || +@@ -364,5 +364,5 @@ + } + case AF_INET6: { +- struct sockaddr_in6 *sin6 = (struct sockaddr_in6*)sa; ++ const struct sockaddr_in6 *sin6 = (const struct sockaddr_in6*)sa; + const unsigned char *address = (const unsigned char*)&sin6->sin6_addr; + return sin6->sin6_port == 0 || +@@ -687,5 +687,5 @@ + int i; + +- if(salen > sizeof(struct sockaddr_storage)) ++ if((unsigned)salen > sizeof(struct sockaddr_storage)) + abort(); + +@@ -1281,13 +1281,13 @@ + int i, len; + struct storage *st; +- unsigned char *ip; ++ const unsigned char *ip; + + if(sa->sa_family == AF_INET) { +- struct sockaddr_in *sin = (struct sockaddr_in*)sa; +- ip = (unsigned char*)&sin->sin_addr; ++ const struct sockaddr_in *sin = (const struct sockaddr_in*)sa; ++ ip = (const unsigned char*)&sin->sin_addr; + len = 4; + } else if(sa->sa_family == AF_INET6) { +- struct sockaddr_in6 *sin6 = (struct sockaddr_in6*)sa; +- ip = (unsigned char*)&sin6->sin6_addr; ++ const struct sockaddr_in6 *sin6 = (const struct sockaddr_in6*)sa; ++ ip = (const unsigned char*)&sin6->sin6_addr; + len = 16; + } else { +@@ -1406,15 +1406,15 @@ + make_token(const struct sockaddr *sa, int old, unsigned char *token_return) + { +- void *ip; ++ const void *ip; + int iplen; + unsigned short port; + + if(sa->sa_family == AF_INET) { +- struct sockaddr_in *sin = (struct sockaddr_in*)sa; ++ const struct sockaddr_in *sin = (const struct sockaddr_in*)sa; + ip = &sin->sin_addr; + iplen = 4; + port = htons(sin->sin_port); + } else if(sa->sa_family == AF_INET6) { +- struct sockaddr_in6 *sin6 = (struct sockaddr_in6*)sa; ++ const struct sockaddr_in6 *sin6 = (const struct sockaddr_in6*)sa; + ip = &sin6->sin6_addr; + iplen = 16; +@@ -1892,5 +1892,5 @@ + } + +- if(((char*)buf)[buflen] != '\0') { ++ if(((const char*)buf)[buflen] != '\0') { + debugf("Unterminated message.\n"); + errno = EINVAL; +@@ -2743,5 +2743,5 @@ + + #define CHECK(ptr, len) \ +- if(((unsigned char*)ptr) + (len) > (buf) + (buflen)) goto overflow; ++ if(((const unsigned char*)ptr) + (len) > (buf) + (buflen)) goto overflow; + + if(tid_return) { +@@ -2750,5 +2750,5 @@ + long l; + char *q; +- l = strtol((char*)p + 3, &q, 10); ++ l = strtol((const char*)p + 3, &q, 10); + if(q && *q == ':' && l > 0 && l < *tid_len) { + CHECK(q + 1, l); +@@ -2782,5 +2782,5 @@ + long l; + char *q; +- l = strtol((char*)p + 5, &q, 10); ++ l = strtol((const char*)p + 5, &q, 10); + if(q && *q == 'e' && l > 0 && l < 0x10000) + *port_return = l; +@@ -2804,5 +2804,5 @@ + long l; + char *q; +- l = strtol((char*)p + 7, &q, 10); ++ l = strtol((const char*)p + 7, &q, 10); + if(q && *q == ':' && l > 0 && l < *token_len) { + CHECK(q + 1, l); +@@ -2820,5 +2820,5 @@ + long l; + char *q; +- l = strtol((char*)p + 7, &q, 10); ++ l = strtol((const char*)p + 7, &q, 10); + if(q && *q == ':' && l > 0 && l < *nodes_len) { + CHECK(q + 1, l); +@@ -2836,5 +2836,5 @@ + long l; + char *q; +- l = strtol((char*)p + 8, &q, 10); ++ l = strtol((const char*)p + 8, &q, 10); + if(q && *q == ':' && l > 0 && l < *nodes6_len) { + CHECK(q + 1, l); +@@ -2855,8 +2855,8 @@ + long l; + char *q; +- l = strtol((char*)buf + i, &q, 10); ++ l = strtol((const char*)buf + i, &q, 10); + if(q && *q == ':' && l > 0) { + CHECK(q + 1, l); +- i = q + 1 + l - (char*)buf; ++ i = q + 1 + l - (const char*)buf; + if(l == 6) { + if(j + l > *values_len) diff --git a/devel/jech-dht/pkg-descr b/devel/jech-dht/pkg-descr new file mode 100644 index 000000000000..b02457a26cf2 --- /dev/null +++ b/devel/jech-dht/pkg-descr @@ -0,0 +1,6 @@ +The files dht.c and dht.h implement the variant of the Kademlia +Distributed Hash Table (DHT) used in the Bittorrent network +(``mainline'' variant). + +WWW: http://www.pps.univ-paris-diderot.fr/~jch/software/bittorrent/ +WWW: https://github.com/jech/dht diff --git a/devel/jech-dht/pkg-plist b/devel/jech-dht/pkg-plist new file mode 100644 index 000000000000..5d87e1c05872 --- /dev/null +++ b/devel/jech-dht/pkg-plist @@ -0,0 +1,5 @@ +lib/libdht.so.0 +lib/libdht.so +lib/libdht.a +include/dht/dht.h +@dirrm include/dht |