diff options
author | Alexey Dokuchaev <danfe@FreeBSD.org> | 2017-03-12 13:35:29 +0000 |
---|---|---|
committer | Alexey Dokuchaev <danfe@FreeBSD.org> | 2017-03-12 13:35:29 +0000 |
commit | 7e20f336e56aa20bac843c094edeb4595f5f3fb9 (patch) | |
tree | 908855d238e690a16552c6bb1d7f38f790bedafb | |
parent | b07727defd03d542dc3d2214bb05ea9dc275a717 (diff) | |
download | freebsd-ports-7e20f336e56aa20bac843c094edeb4595f5f3fb9.zip |
net-p2p/mktorrent: increase max piece size and make tracker optional
Optimal piece count is ~1500. mktorrent allows up to 2^28 currently, thus
providing ability to create torrents for 375 GiB of data with optimal piece
count. Increase maximum piece size to 2^30 thus allowing torrents for 1.5
TiB of data (again, with optimal piece count).
mktorrent currently can't create torrents without announce URL. Since DHT
works perfectly well nowadays, this limitation doesn't make much sense.
Change to require tracker only when creating private torrent (i.e. DHT,
PEX, etc. disabled).
While here: define LICENSE (GPLv2+), make options actually work, remove
redundant THREADS_DESC, and clean up Makefile a bit.
PR: 210374
Submitted by: Anton Sayetsky
Approved by: maintainer timeout
-rw-r--r-- | net-p2p/mktorrent/Makefile | 28 | ||||
-rw-r--r-- | net-p2p/mktorrent/files/patch-init.c | 112 | ||||
-rw-r--r-- | net-p2p/mktorrent/files/patch-output.c | 32 |
3 files changed, 153 insertions, 19 deletions
diff --git a/net-p2p/mktorrent/Makefile b/net-p2p/mktorrent/Makefile index 995a3cb4580c..08397e1a706f 100644 --- a/net-p2p/mktorrent/Makefile +++ b/net-p2p/mktorrent/Makefile @@ -3,24 +3,24 @@ PORTNAME= mktorrent PORTVERSION= 1.0 +PORTREVISION= 1 CATEGORIES= net-p2p MASTER_SITES= SF MAINTAINER= dgerow@afflictions.org COMMENT= Command-line utility for creating BitTorrent metainfo files -.if defined(.PARSEDIR) -USES= gmake -.else +LICENSE= GPLv2+ +LICENSE_FILE= ${WRKSRC}/COPYING + MAKEFILE= BSDmakefile -.endif -MAKE_FLAGS= USE_LONG_OPTIONS=1 +MAKE_ARGS= USE_LONG_OPTIONS=1 PLIST_FILES= bin/mktorrent OPTIONS_DEFINE= THREADS OPENSSL HASHCHECK OPTIONS_DEFAULT= THREADS OPENSSL HASHCHECK -THREADS_DESC= Enable support for pthreads + OPENSSL_DESC= Use OpenSSL for hashing HASHCHECK_DESC= Verify file hashes @@ -28,19 +28,9 @@ OPENSSL_USES= ssl OPENSSL_CFLAGS= -I${OPENSSLINC} OPENSSL_LDFLAGS= -L${OPENSSLLIB} -.include <bsd.port.options.mk> - -.if ${PORT_OPTIONS:MTHREADS} -MAKE_FLAGS+= USE_PTHREADS=1 -.endif - -.if ${PORT_OPTIONS:MOPENSSL} -MAKE_FLAGS+= USE_OPENSSL=1 -.endif - -.if ! ${PORT_OPTIONS:MHASHCHECK} -MAKE_FLAGS+= NO_HASH_CHECK=1 -.endif +THREADS_MAKE_ARGS= USE_PTHREADS=1 +OPENSSL_MAKE_ARGS= USE_OPENSSL=1 +HASHCHECK_MAKE_ARGS= NO_HASH_CHECK=1 do-install: ${INSTALL_PROGRAM} ${WRKSRC}/${PORTNAME} ${STAGEDIR}${PREFIX}/bin diff --git a/net-p2p/mktorrent/files/patch-init.c b/net-p2p/mktorrent/files/patch-init.c new file mode 100644 index 000000000000..1ab23cf6e8cc --- /dev/null +++ b/net-p2p/mktorrent/files/patch-init.c @@ -0,0 +1,112 @@ +--- init.c.orig 2009-08-25 18:53:22 UTC ++++ init.c +@@ -277,7 +277,7 @@ static void print_help() + "Options:\n" + #ifdef USE_LONG_OPTIONS + "-a, --announce=<url>[,<url>]* : specify the full announce URLs\n" +- " at least one is required\n" ++ " at least one is required on private torrent\n" + " additional -a adds backup trackers\n" + "-c, --comment=<comment> : add a comment to the metainfo\n" + "-d, --no-date : don't write the creation date\n" +@@ -298,7 +298,7 @@ static void print_help() + " additional -w adds more URLs\n" + #else + "-a <url>[,<url>]* : specify the full announce URLs\n" +- " at least one is required\n" ++ " at least one is required on private torrent\n" + " additional -a adds backup trackers\n" + "-c <comment> : add a comment to the metainfo\n" + "-d : don't write the creation date\n" +@@ -343,7 +343,7 @@ static void print_announce_list(llist_t + */ + static void print_web_seed_list(slist_t *list) + { +- printf(" Web Seed URL: "); ++ printf(" Web Seed URLs: "); + + if (list == NULL) { + printf("none\n"); +@@ -361,17 +361,20 @@ static void print_web_seed_list(slist_t + static void dump_options(metafile_t *m) + { + printf("Options:\n" +- " Announce URLs:\n"); ++ " Announce URLs:"); + +- print_announce_list(m->announce_list); ++ if (m->announce_list) { ++ printf("\n"); ++ print_announce_list(m->announce_list); ++ } else ++ printf(" none\n"); + +- printf(" Torrent name: %s\n" +- " Metafile: %s\n" +- " Piece length: %u\n" +- " Be verbose: yes\n", ++ printf(" Torrent name: %s\n" ++ " Metafile: %s\n" ++ " Piece length: %u\n", + m->torrent_name, m->metainfo_file_path, m->piece_length); + +- printf(" Write date: "); ++ printf(" Write date: "); + if (m->no_creation_date) + printf("no\n"); + else +@@ -379,11 +382,17 @@ static void dump_options(metafile_t *m) + + print_web_seed_list(m->web_seed_list); + +- printf(" Comment: "); ++ printf(" Comment: "); + if (m->comment == NULL) +- printf("none\n\n"); ++ printf("none\n"); + else +- printf("\"%s\"\n\n", m->comment); ++ printf("\"%s\"\n", m->comment); ++ ++ printf(" Private: "); ++ if (m->private) ++ printf("yes\n\n"); ++ else ++ printf("no\n\n"); + } + + /* +@@ -495,22 +504,25 @@ EXPORT void init(metafile_t *m, int argc + + /* set the correct piece length. + default is 2^18 = 256kb. */ +- if (m->piece_length < 15 || m->piece_length > 28) { ++ if (m->piece_length < 15 || m->piece_length > 30) { + fprintf(stderr, + "The piece length must be a number between " +- "15 and 28.\n"); ++ "15 and 30.\n"); + exit(EXIT_FAILURE); + } + m->piece_length = 1 << m->piece_length; + +- /* user must specify at least one announce URL as it wouldn't make +- * any sense to have a default for this */ ++ /* user must specify at least one announce URL when private flag set ++ as it wouldn't make any sense to have a default for this */ + if (m->announce_list == NULL) { +- fprintf(stderr, "Must specify an announce URL. " +- "Use -h for help.\n"); +- exit(EXIT_FAILURE); ++ if (m->private == 1) { ++ fprintf(stderr, "Must specify an announce URL. " ++ "Use -h for help.\n"); ++ exit(EXIT_FAILURE); ++ } ++ } else { ++ announce_last->next = NULL; + } +- announce_last->next = NULL; + + /* ..and a file or directory from which to create the torrent */ + if (optind >= argc) { diff --git a/net-p2p/mktorrent/files/patch-output.c b/net-p2p/mktorrent/files/patch-output.c new file mode 100644 index 000000000000..d9ca4ee8babb --- /dev/null +++ b/net-p2p/mktorrent/files/patch-output.c @@ -0,0 +1,32 @@ +--- output.c.orig 2009-08-25 18:53:22 UTC ++++ output.c +@@ -119,15 +119,20 @@ EXPORT void write_metainfo(FILE *f, meta + printf("Writing metainfo file... "); + fflush(stdout); + +- /* every metainfo file is one big dictonary +- and the first entry is the announce URL */ +- fprintf(f, "d8:announce%lu:%s", +- (unsigned long)strlen(m->announce_list->l->s), +- m->announce_list->l->s); +- /* write the announce-list entry if we have +- more than one announce URL */ +- if (m->announce_list->next || m->announce_list->l->next) +- write_announce_list(f, m->announce_list); ++ /* every metainfo file is one big dictonary */ ++ fprintf(f, "d"); ++ ++ /* first entry is the announce URL (optional) */ ++ if (m->announce_list != NULL) { ++ fprintf(f, "8:announce%lu:%s", ++ (unsigned long)strlen(m->announce_list->l->s), ++ m->announce_list->l->s); ++ /* write the announce-list entry if we have ++ more than one announce URL */ ++ if (m->announce_list->next || m->announce_list->l->next) ++ write_announce_list(f, m->announce_list); ++ } ++ + /* add the comment if one is specified */ + if (m->comment != NULL) + fprintf(f, "7:comment%lu:%s", |