diff options
-rw-r--r-- | net-misc/axel/ChangeLog | 10 | ||||
-rw-r--r-- | net-misc/axel/axel-1.0b-r1.ebuild | 51 | ||||
-rw-r--r-- | net-misc/axel/axel-1.0b-r2.ebuild | 54 | ||||
-rw-r--r-- | net-misc/axel/axel-1.0b.ebuild | 31 | ||||
-rw-r--r-- | net-misc/axel/files/axel-1.0b-strcpy-fix.patch | 1715 |
5 files changed, 8 insertions, 1853 deletions
diff --git a/net-misc/axel/ChangeLog b/net-misc/axel/ChangeLog index 07a83354ebd2..26e6a057ec68 100644 --- a/net-misc/axel/ChangeLog +++ b/net-misc/axel/ChangeLog @@ -1,6 +1,12 @@ # ChangeLog for net-misc/axel -# Copyright 2002-2008 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/net-misc/axel/ChangeLog,v 1.43 2008/07/17 18:48:05 corsair Exp $ +# Copyright 2002-2009 Gentoo Foundation; Distributed under the GPL v2 +# $Header: /var/cvsroot/gentoo-x86/net-misc/axel/ChangeLog,v 1.44 2009/01/25 01:56:11 darkside Exp $ + + 25 Jan 2009; Jeremy Olexa <darkside@gentoo.org> + -files/axel-1.0b-strcpy-fix.patch, -axel-1.0b.ebuild, + -axel-1.0b-r1.ebuild, -axel-1.0b-r2.ebuild: + (non maintainer commit) [QA] remove old to fix bug 248997 (large file not on + mirror) 17 Jul 2008; Markus Rothe <corsair@gentoo.org> axel-1.1.ebuild: Stable on ppc64; bug #214731 diff --git a/net-misc/axel/axel-1.0b-r1.ebuild b/net-misc/axel/axel-1.0b-r1.ebuild deleted file mode 100644 index e51b867bad17..000000000000 --- a/net-misc/axel/axel-1.0b-r1.ebuild +++ /dev/null @@ -1,51 +0,0 @@ -# Copyright 1999-2008 Gentoo Foundation -# Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/net-misc/axel/axel-1.0b-r1.ebuild,v 1.7 2008/02/03 16:13:18 grobian Exp $ - -inherit toolchain-funcs - -DESCRIPTION="light Unix download accelerator" -HOMEPAGE="http://wilmer.gaast.net/main.php/axel.html" -SRC_URI="http://wilmer.gaast.net/downloads/${P}.tar.gz" - -LICENSE="GPL-2" -SLOT="0" -KEYWORDS="~amd64 ppc ppc64 sparc x86 ~x86-fbsd" -IUSE="debug nls" - -RDEPEND="nls? ( virtual/libintl )" -DEPEND="${RDEPEND} - nls? ( sys-devel/gettext )" - -src_unpack() { - unpack ${A} - cd "${S}" - # Set LDFLAGS and fix expr - sed -i -e 's/expr/& --/' -e "s/^LFLAGS=$/&${LDFLAGS}/" configure -} - -src_compile() { - local myconf - - use debug && myconf="--debug=1" - use nls && myconf="--i18n=1" - econf \ - --strip=0 \ - --etcdir=/etc \ - ${myconf} \ - || die - - emake CFLAGS="${CFLAGS}" CC="$(tc-getCC)" || die "emake failed" -} - -src_install() { - emake DESTDIR="${D}" install || die "emake install failed" - dodoc API CHANGES CREDITS README axelrc.example -} - -pkg_postinst() { - einfo 'To use axel with portage, try these settings in your make.conf' - einfo - einfo ' FETCHCOMMAND="/usr/bin/axel -a -o \${DISTDIR}/\${FILE} \${URI}"' - einfo ' RESUMECOMMAND="${FETCHCOMMAND}"' -} diff --git a/net-misc/axel/axel-1.0b-r2.ebuild b/net-misc/axel/axel-1.0b-r2.ebuild deleted file mode 100644 index 14fa74256117..000000000000 --- a/net-misc/axel/axel-1.0b-r2.ebuild +++ /dev/null @@ -1,54 +0,0 @@ -# Copyright 1999-2008 Gentoo Foundation -# Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/net-misc/axel/axel-1.0b-r2.ebuild,v 1.8 2008/02/03 16:13:18 grobian Exp $ - -inherit eutils toolchain-funcs - -DESCRIPTION="light Unix download accelerator" -HOMEPAGE="http://wilmer.gaast.net/main.php/axel.html" -SRC_URI="http://wilmer.gaast.net/downloads/${P}.tar.gz" - -LICENSE="GPL-2" -SLOT="0" -KEYWORDS="~amd64 hppa ppc ppc64 sparc x86 ~x86-fbsd" -IUSE="debug nls" - -RDEPEND="nls? ( virtual/libintl )" -DEPEND="${RDEPEND} - nls? ( sys-devel/gettext )" - -src_unpack() { - unpack ${A} - cd "${S}" - - # Patch to fix buffer overflows #162005 - epatch "${FILESDIR}"/${P}-strcpy-fix.patch - # Set LDFLAGS and fix expr - sed -i -e 's/expr/& --/' -e "s/^LFLAGS=$/&${LDFLAGS}/" configure -} - -src_compile() { - local myconf - - use debug && myconf="--debug=1" - use nls && myconf="--i18n=1" - econf \ - --strip=0 \ - --etcdir=/etc \ - ${myconf} \ - || die - - emake CFLAGS="${CFLAGS}" CC="$(tc-getCC)" || die "emake failed" -} - -src_install() { - emake DESTDIR="${D}" install || die "emake install failed" - dodoc API CHANGES CREDITS README axelrc.example -} - -pkg_postinst() { - einfo 'To use axel with portage, try these settings in your make.conf' - einfo - einfo ' FETCHCOMMAND="/usr/bin/axel -a -o \${DISTDIR}/\${FILE} \${URI}"' - einfo ' RESUMECOMMAND="${FETCHCOMMAND}"' -} diff --git a/net-misc/axel/axel-1.0b.ebuild b/net-misc/axel/axel-1.0b.ebuild deleted file mode 100644 index 276035e7dce0..000000000000 --- a/net-misc/axel/axel-1.0b.ebuild +++ /dev/null @@ -1,31 +0,0 @@ -# Copyright 1999-2008 Gentoo Foundation -# Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/net-misc/axel/axel-1.0b.ebuild,v 1.7 2008/02/03 16:13:18 grobian Exp $ - -DESCRIPTION="light Unix download accelerator" -HOMEPAGE="http://wilmer.gaast.net/main.php/axel.html" -SRC_URI="http://wilmer.gaast.net/downloads/${P}.tar.gz" - -LICENSE="GPL-2" -SLOT="0" -KEYWORDS="~amd64 ppc ppc64 sparc x86" -IUSE="debug" - -DEPEND="virtual/libc" - -src_compile() { - local myconf - - use debug && myconf="--debug=1" - econf \ - --strip=0 \ - --etcdir=/etc \ - ${myconf} \ - || die - emake CFLAGS="${CFLAGS}" || die "emake failed" -} - -src_install() { - make DESTDIR="${D}" install || die "make install failed" - dodoc API CHANGES CREDITS README axelrc.example -} diff --git a/net-misc/axel/files/axel-1.0b-strcpy-fix.patch b/net-misc/axel/files/axel-1.0b-strcpy-fix.patch deleted file mode 100644 index 27e047b826fb..000000000000 --- a/net-misc/axel/files/axel-1.0b-strcpy-fix.patch +++ /dev/null @@ -1,1715 +0,0 @@ -diff -Nurp axel-1.0b/axel.c axel-1.0b-r1/axel.c ---- axel-1.0b/axel.c 2002-05-03 14:45:11.000000000 +0200 -+++ axel-1.0b-r1/axel.c 2007-08-05 23:03:30.000000000 +0200 -@@ -41,7 +41,7 @@ axel_t *axel_new( conf_t *conf, int coun - url_t *u; - char *s; - int i; -- -+ - axel = malloc( sizeof( axel_t ) ); - memset( axel, 0, sizeof( axel_t ) ); - *axel->conf = *conf; -@@ -59,12 +59,13 @@ axel_t *axel_new( conf_t *conf, int coun - } - if( buffer == NULL ) - buffer = malloc( max( MAX_STRING, axel->conf->buffer_size ) ); -- -+ - if( count == 0 ) - { - axel->url = malloc( sizeof( url_t ) ); - axel->url->next = axel->url; -- strcpy( axel->url->text, (char *) url ); -+ strncpy( axel->url->text, (char *) url, MAX_STRING - 1); -+ axel->url->text[MAX_STRING - 1] = '\0'; - } - else - { -@@ -72,7 +73,8 @@ axel_t *axel_new( conf_t *conf, int coun - u = axel->url = malloc( sizeof( url_t ) ); - for( i = 0; i < count; i ++ ) - { -- strcpy( u->text, res[i].url ); -+ strncpy( u->text, res[i].url, MAX_STRING - 1); -+ u->text[MAX_STRING - 1] = '\0'; - if( i < count - 1 ) - { - u->next = malloc( sizeof( url_t ) ); -@@ -84,7 +86,7 @@ axel_t *axel_new( conf_t *conf, int coun - } - } - } -- -+ - axel->conn[0].conf = axel->conf; - if( !conn_set( &axel->conn[0], axel->url->text ) ) - { -@@ -95,21 +97,22 @@ axel_t *axel_new( conf_t *conf, int coun - - axel->conn[0].local_if = axel->conf->interfaces->text; - axel->conf->interfaces = axel->conf->interfaces->next; -- -- strcpy( axel->filename, axel->conn[0].file ); -+ -+ strncpy( axel->filename, axel->conn[0].file, MAX_STRING - 1 ); -+ axel->filename[MAX_STRING - 1] = '\0'; - http_decode( axel->filename ); - if( *axel->filename == 0 ) /* Index page == no fn */ - strcpy( axel->filename, axel->conf->default_filename ); - if( ( s = strchr( axel->filename, '?' ) ) != NULL && axel->conf->strip_cgi_parameters ) - *s = 0; /* Get rid of CGI parameters */ -- -+ - if( !conn_init( &axel->conn[0] ) ) - { - axel_message( axel, axel->conn[0].message ); - axel->ready = -1; - return( axel ); - } -- -+ - /* This does more than just checking the file size, it all depends - on the protocol used. */ - if( !conn_info( &axel->conn[0] ) ) -@@ -119,17 +122,20 @@ axel_t *axel_new( conf_t *conf, int coun - return( axel ); - } - s = conn_url( axel->conn ); -- strcpy( axel->url->text, s ); -+ strncpy( axel->url->text, s, MAX_STRING - 1); -+ axel->url->text[MAX_STRING - 1] = '\0'; - if( ( axel->size = axel->conn[0].size ) != INT_MAX ) - { - if( axel->conf->verbose > 0 ) - axel_message( axel, _("File size: %i bytes"), axel->size ); - } -- -+ - /* Wildcards in URL --> Get complete filename */ - if( strchr( axel->filename, '*' ) || strchr( axel->filename, '?' ) ) -- strcpy( axel->filename, axel->conn[0].file ); -- -+ { -+ strncpy( axel->filename, axel->conn[0].file, MAX_STRING - 1 ); -+ axel->filename[MAX_STRING - 1] = '\0'; -+ } - return( axel ); - } - -@@ -137,13 +143,13 @@ axel_t *axel_new( conf_t *conf, int coun - int axel_open( axel_t *axel ) - { - int i, fd; -- -+ - if( axel->conf->verbose > 0 ) - axel_message( axel, _("Opening output file %s"), axel->filename ); - snprintf( buffer, MAX_STRING, "%s.st", axel->filename ); -- -+ - axel->outfd = -1; -- -+ - /* Check whether server knows about RESTart and switch back to - single connection download if necessary */ - if( !axel->conn[0].supported ) -@@ -157,21 +163,21 @@ int axel_open( axel_t *axel ) - else if( ( fd = open( buffer, O_RDONLY ) ) != -1 ) - { - read( fd, &axel->conf->num_connections, sizeof( axel->conf->num_connections ) ); -- -+ - axel->conn = realloc( axel->conn, sizeof( conn_t ) * axel->conf->num_connections ); - memset( axel->conn + 1, 0, sizeof( conn_t ) * ( axel->conf->num_connections - 1 ) ); - - axel_divide( axel ); -- -+ - read( fd, &axel->bytes_done, sizeof( axel->bytes_done ) ); - for( i = 0; i < axel->conf->num_connections; i ++ ) - read( fd, &axel->conn[i].currentbyte, sizeof( axel->conn[i].currentbyte ) ); - - axel_message( axel, _("State file found: %i bytes downloaded, %i to go."), - axel->bytes_done, axel->size - axel->bytes_done ); -- -+ - close( fd ); -- -+ - if( ( axel->outfd = open( axel->filename, O_WRONLY, 0666 ) ) == -1 ) - { - axel_message( axel, _("Error opening local file") ); -@@ -183,13 +189,13 @@ int axel_open( axel_t *axel ) - if( axel->outfd == -1 ) - { - axel_divide( axel ); -- -+ - if( ( axel->outfd = open( axel->filename, O_CREAT | O_WRONLY, 0666 ) ) == -1 ) - { - axel_message( axel, _("Error opening local file") ); - return( 0 ); - } -- -+ - /* And check whether the filesystem can handle seeks to - past-EOF areas.. Speeds things up. :) AFAIK this - should just not happen: */ -@@ -209,7 +215,7 @@ int axel_open( axel_t *axel ) - } - } - } -- -+ - return( 1 ); - } - -@@ -217,7 +223,7 @@ int axel_open( axel_t *axel ) - void axel_start( axel_t *axel ) - { - int i; -- -+ - /* HTTP might've redirected and FTP handles wildcards, so - re-scan the URL for every conn */ - for( i = 0; i < axel->conf->num_connections; i ++ ) -@@ -229,10 +235,10 @@ void axel_start( axel_t *axel ) - axel->conn[i].conf = axel->conf; - if( i ) axel->conn[i].supported = 1; - } -- -+ - if( axel->conf->verbose > 0 ) - axel_message( axel, _("Starting download") ); -- -+ - for( i = 0; i < axel->conf->num_connections; i ++ ) - if( axel->conn[i].currentbyte <= axel->conn[i].lastbyte ) - { -@@ -250,7 +256,7 @@ void axel_start( axel_t *axel ) - axel->conn[i].state = 1; - } - } -- -+ - /* The real downloading will start now, so let's start counting */ - axel->start_time = gettime(); - axel->ready = 0; -@@ -262,14 +268,14 @@ void axel_do( axel_t *axel ) - fd_set fds[1]; - int hifd, i, j, size; - struct timeval timeval[1]; -- -+ - /* Create statefile if necessary */ - if( gettime() > axel->next_state ) - { - save_state( axel ); - axel->next_state = gettime() + axel->conf->save_state_interval; - } -- -+ - /* Wait for data on (one of) the connections */ - FD_ZERO( fds ); - hifd = 0; -@@ -297,7 +303,7 @@ void axel_do( axel_t *axel ) - return; - } - } -- -+ - /* Handle connections which need attention */ - for( i = 0; i < axel->conf->num_connections; i ++ ) - if( axel->conn[i].enabled ) { -@@ -355,7 +361,7 @@ void axel_do( axel_t *axel ) - lseek( axel->outfd, axel->conn[i].currentbyte, SEEK_SET ); - if( write( axel->outfd, buffer, size ) != size ) - { -- -+ - axel_message( axel, _("Write error!") ); - axel->ready = -1; - return; -@@ -373,10 +379,10 @@ void axel_do( axel_t *axel ) - axel->conn[i].enabled = 0; - } - } } -- -+ - if( axel->ready ) - return; -- -+ - conn_check: - /* Look for aborted connections and attempt to restart them. */ - for( i = 0; i < axel->conf->num_connections; i ++ ) -@@ -430,7 +436,7 @@ conn_check: - axel->delay_time = 0; - usleep( axel->delay_time ); - } -- -+ - /* Ready? */ - if( axel->bytes_done == axel->size ) - axel->ready = 1; -@@ -441,11 +447,12 @@ void axel_close( axel_t *axel ) - { - int i; - message_t *m; -- -+ - /* Terminate any thread still running */ - for( i = 0; i < axel->conf->num_connections; i ++ ) -- pthread_cancel( *axel->conn[i].setup_thread ); -- -+ if (*axel->conn[i].setup_thread) -+ pthread_cancel( *axel->conn[i].setup_thread ); -+ - /* Delete state file if necessary */ - if( axel->ready == 1 ) - { -@@ -465,7 +472,7 @@ void axel_close( axel_t *axel ) - axel->message = axel->message->next; - free( m ); - } -- -+ - /* Close all connections and local file */ - close( axel->outfd ); - for( i = 0; i < axel->conf->num_connections; i ++ ) -@@ -479,7 +486,7 @@ void axel_close( axel_t *axel ) - double gettime() - { - struct timeval time[1]; -- -+ - gettimeofday( time, 0 ); - return( (double) time->tv_sec + (double) time->tv_usec / 1000000 ); - } -@@ -494,7 +501,7 @@ void save_state( axel_t *axel ) - resuming anyway.. */ - if( !axel->conn[0].supported ) - return; -- -+ - snprintf( fn, MAX_STRING, "%s.st", axel->filename ); - if( ( fd = open( fn, O_CREAT | O_TRUNC | O_WRONLY, 0666 ) ) == -1 ) - { -@@ -514,11 +521,11 @@ void *setup_thread( void *c ) - { - conn_t *conn = c; - int oldstate; -- -+ - /* Allow this thread to be killed at any time. */ - pthread_setcancelstate( PTHREAD_CANCEL_ENABLE, &oldstate ); - pthread_setcanceltype( PTHREAD_CANCEL_ASYNCHRONOUS, &oldstate ); -- -+ - if( conn_setup( conn ) ) - { - conn->last_transfer = gettime(); -@@ -530,7 +537,7 @@ void *setup_thread( void *c ) - return( NULL ); - } - } -- -+ - conn_disconnect( conn ); - conn->state = 0; - return( NULL ); -@@ -541,12 +548,12 @@ static void axel_message( axel_t *axel, - { - message_t *m = malloc( sizeof( message_t ) ), *n = axel->message; - va_list params; -- -+ - memset( m, 0, sizeof( message_t ) ); - va_start( params, format ); - vsnprintf( m->text, MAX_STRING, format, params ); - va_end( params ); -- -+ - if( axel->message == NULL ) - { - axel->message = m; -@@ -563,7 +570,7 @@ static void axel_message( axel_t *axel, - static void axel_divide( axel_t *axel ) - { - int i; -- -+ - axel->conn[0].currentbyte = 0; - axel->conn[0].lastbyte = axel->size / axel->conf->num_connections - 1; - for( i = 1; i < axel->conf->num_connections; i ++ ) -diff -Nurp axel-1.0b/conf.c axel-1.0b-r1/conf.c ---- axel-1.0b/conf.c 2002-02-19 19:10:37.000000000 +0100 -+++ axel-1.0b-r1/conf.c 2007-08-05 22:49:21.000000000 +0200 -@@ -30,7 +30,8 @@ - if( strcmp( key, #name ) == 0 ) \ - { \ - st = 1; \ -- strcpy( conf->name, value ); \ -+ strncpy( conf->name, value, MAX_STRING -1 ); \ -+ conf->name[MAX_STRING - 1] = '\0'; \ - } - #define get_config_number( name ) \ - if( strcmp( key, #name ) == 0 ) \ -@@ -38,7 +39,7 @@ - st = 1; \ - sscanf( value, "%i", &conf->name ); \ - } -- -+ - int parse_interfaces( conf_t *conf, char *s ); - - int conf_loadfile( conf_t *conf, char *file ) -@@ -46,17 +47,17 @@ int conf_loadfile( conf_t *conf, char *f - int i, line = 0; - FILE *fp; - char s[MAX_STRING], key[MAX_STRING], value[MAX_STRING]; -- -+ - fp = fopen( file, "r" ); - if( fp == NULL ) - return( 1 ); /* Not a real failure */ -- -+ - while( !feof( fp ) ) - { - int st; -- -+ - line ++; -- -+ - *s = 0; - fscanf( fp, "%100[^\n#]s", s ); - fscanf( fp, "%*[^\n]s" ); -@@ -70,12 +71,13 @@ int conf_loadfile( conf_t *conf, char *f - for( i ++; isspace( (int) s[i] ) && s[i]; i ++ ); - break; - } -- strcpy( value, &s[i] ); -+ strncpy( value, &s[i], MAX_STRING - 1); -+ value[MAX_STRING - 1] = '\0'; - for( i = strlen( value ) - 1; isspace( (int) value[i] ); i -- ) - value[i] = 0; -- -+ - st = 0; -- -+ - /* Long live macros!! */ - get_config_string( default_filename ); - get_config_string( http_proxy ); -@@ -89,26 +91,26 @@ int conf_loadfile( conf_t *conf, char *f - get_config_number( max_speed ); - get_config_number( verbose ); - get_config_number( alternate_output ); -- -+ - get_config_number( search_timeout ); - get_config_number( search_threads ); - get_config_number( search_amount ); - get_config_number( search_top ); -- -+ - /* Option defunct but shouldn't be an error */ - if( strcmp( key, "speed_type" ) == 0 ) - st = 1; -- -+ - if( strcmp( key, "interfaces" ) == 0 ) - st = parse_interfaces( conf, value ); -- -+ - if( !st ) - { - fprintf( stderr, _("Error in %s line %i.\n"), file, line ); - return( 0 ); - } - } -- -+ - fclose( fp ); - return( 1 ); - } -@@ -117,7 +119,7 @@ int conf_init( conf_t *conf ) - { - char s[MAX_STRING], *s2; - int i; -- -+ - /* Set defaults */ - memset( conf, 0, sizeof( conf_t ) ); - strcpy( conf->default_filename, "default" ); -@@ -132,35 +134,38 @@ int conf_init( conf_t *conf ) - conf->max_speed = 0; - conf->verbose = 1; - conf->alternate_output = 0; -- -+ - conf->search_timeout = 10; - conf->search_threads = 3; - conf->search_amount = 15; - conf->search_top = 3; -- -+ - conf->interfaces = malloc( sizeof( if_t ) ); - memset( conf->interfaces, 0, sizeof( if_t ) ); - conf->interfaces->next = conf->interfaces; -- -+ - if( ( s2 = getenv( "HTTP_PROXY" ) ) != NULL ) -- strncpy( conf->http_proxy, s2, MAX_STRING ); -- -+ { -+ strncpy( conf->http_proxy, s2, MAX_STRING - 1); -+ conf->http_proxy[MAX_STRING - 1] = '\0'; -+ } -+ - if( !conf_loadfile( conf, ETCDIR "/axelrc" ) ) - return( 0 ); -- -+ - if( ( s2 = getenv( "HOME" ) ) != NULL ) - { - sprintf( s, "%s/%s", s2, ".axelrc" ); - if( !conf_loadfile( conf, s ) ) - return( 0 ); - } -- -+ - /* Convert no_proxy to a 0-separated-and-00-terminated list.. */ - for( i = 0; conf->no_proxy[i]; i ++ ) - if( conf->no_proxy[i] == ',' ) - conf->no_proxy[i] = 0; - conf->no_proxy[i+1] = 0; -- -+ - return( 1 ); - } - -@@ -168,18 +173,18 @@ int parse_interfaces( conf_t *conf, char - { - char *s2; - if_t *iface; -- -+ - iface = conf->interfaces->next; - while( iface != conf->interfaces ) - { - if_t *i; -- -+ - i = iface->next; - free( iface ); - iface = i; - } - free( conf->interfaces ); -- -+ - if( !*s ) - { - conf->interfaces = malloc( sizeof( if_t ) ); -@@ -187,7 +192,7 @@ int parse_interfaces( conf_t *conf, char - conf->interfaces->next = conf->interfaces; - return( 1 ); - } -- -+ - s[strlen(s)+1] = 0; - conf->interfaces = iface = malloc( sizeof( if_t ) ); - while( 1 ) -@@ -198,7 +203,10 @@ int parse_interfaces( conf_t *conf, char - if( *s < '0' || *s > '9' ) - get_if_ip( s, iface->text ); - else -- strcpy( iface->text, s ); -+ { -+ strncpy( iface->text, s, MAX_STRING - 1); -+ iface->text[MAX_STRING - 1] = '\0'; -+ } - s = s2 + 1; - if( *s ) - { -@@ -211,6 +219,6 @@ int parse_interfaces( conf_t *conf, char - break; - } - } -- -+ - return( 1 ); - } -diff -Nurp axel-1.0b/conf.h axel-1.0b-r1/conf.h ---- axel-1.0b/conf.h 2002-02-16 12:27:47.000000000 +0100 -+++ axel-1.0b-r1/conf.h 2007-08-05 21:07:59.000000000 +0200 -@@ -37,9 +37,9 @@ typedef struct - int max_speed; - int verbose; - int alternate_output; -- -+ - if_t *interfaces; -- -+ - int search_timeout; - int search_threads; - int search_amount; -diff -Nurp axel-1.0b/conn.c axel-1.0b-r1/conn.c ---- axel-1.0b/conn.c 2005-04-06 20:18:28.000000000 +0200 -+++ axel-1.0b-r1/conn.c 2007-08-05 23:11:19.000000000 +0200 -@@ -32,12 +32,13 @@ int conn_set( conn_t *conn, char *set_ur - { - char url[MAX_STRING]; - char *i, *j; -- -+ - /* protocol:// */ - if( ( i = strstr( set_url, "://" ) ) == NULL ) - { - conn->proto = PROTO_DEFAULT; -- strncpy( url, set_url, MAX_STRING ); -+ strncpy( url, set_url, MAX_STRING - 1); -+ url[MAX_STRING - 1] = '\0'; - } - else - { -@@ -49,9 +50,10 @@ int conn_set( conn_t *conn, char *set_ur - { - return( 0 ); - } -- strncpy( url, i + 3, MAX_STRING ); -+ strncpy( url, i + 3, MAX_STRING - 1); -+ url[MAX_STRING - 1] = '\0'; - } -- -+ - /* Split */ - if( ( i = strchr( url, '/' ) ) == NULL ) - { -@@ -60,11 +62,13 @@ int conn_set( conn_t *conn, char *set_ur - else - { - *i = 0; -- snprintf( conn->dir, MAX_STRING, "/%s", i + 1 ); -+ snprintf( conn->dir, MAX_STRING - 1, "/%s", i + 1 ); -+ conn->dir[MAX_STRING - 1] = '\0'; - if( conn->proto == PROTO_HTTP ) - http_encode( conn->dir ); - } -- strncpy( conn->host, url, MAX_STRING ); -+ strncpy( conn->host, url, MAX_STRING - 1); -+ conn->host[MAX_STRING - 1] = '\0'; - j = strchr( conn->dir, '?' ); - if( j != NULL ) - *j = 0; -@@ -82,11 +86,12 @@ int conn_set( conn_t *conn, char *set_ur - strcpy( conn->file, i + 1 ); - strcat( conn->dir, "/" ); - } -- -+ - /* Check for username in host field */ - if( strrchr( conn->host, '@' ) != NULL ) - { -- strncpy( conn->user, conn->host, MAX_STRING ); -+ strncpy( conn->user, conn->host, MAX_STRING - 1); -+ conn->user[MAX_STRING - 1] = '\0'; - i = strrchr( conn->user, '@' ); - *i = 0; - strcpy( conn->host, i + 1 ); -@@ -107,7 +112,7 @@ int conn_set( conn_t *conn, char *set_ur - *conn->user = *conn->pass = 0; - } - } -- -+ - /* Password? */ - if( ( i = strchr( conn->user, ':' ) ) != NULL ) - { -@@ -125,12 +130,12 @@ int conn_set( conn_t *conn, char *set_ur - { - #ifndef DARWIN - struct servent *serv; -- -+ - if( conn->proto == PROTO_FTP ) - serv = getservbyname( "ftp", "tcp" ); - else - serv = getservbyname( "www", "tcp" ); -- -+ - if( serv ) - conn->port = ntohs( serv->s_port ); - else -@@ -140,7 +145,7 @@ int conn_set( conn_t *conn, char *set_ur - else - conn->port = 21; - } -- -+ - return( conn->port > 0 ); - } - -@@ -151,14 +156,14 @@ char *conn_url( conn_t *conn ) - strcpy( string, "ftp://" ); - else - strcpy( string, "http://" ); -- -+ - if( *conn->user != 0 && strcmp( conn->user, "anonymous" ) != 0 ) - sprintf( string + strlen( string ), "%s:%s@", - conn->user, conn->pass ); - - sprintf( string + strlen( string ), "%s:%i%s%s", - conn->host, conn->port, conn->dir, conn->file ); -- -+ - return( string ); - } - -@@ -176,7 +181,7 @@ int conn_init( conn_t *conn ) - { - char *proxy = conn->conf->http_proxy, *host = conn->conf->no_proxy; - int i; -- -+ - if( *conn->conf->http_proxy == 0 ) - { - proxy = NULL; -@@ -193,9 +198,9 @@ int conn_init( conn_t *conn ) - break; - } - } -- -+ - conn->proxy = proxy != NULL; -- -+ - if( conn->proto == PROTO_FTP && !conn->proxy ) - { - conn->ftp->local_if = conn->local_if; -@@ -233,13 +238,13 @@ int conn_setup( conn_t *conn ) - if( conn->ftp->fd <= 0 && conn->http->fd <= 0 ) - if( !conn_init( conn ) ) - return( 0 ); -- -+ - if( conn->proto == PROTO_FTP && !conn->proxy ) - { - if( !ftp_data( conn->ftp ) ) /* Set up data connnection */ - return( 0 ); - conn->fd = conn->ftp->data_fd; -- -+ - if( conn->currentbyte ) - { - ftp_command( conn->ftp, "REST %i", conn->currentbyte ); -@@ -251,7 +256,7 @@ int conn_setup( conn_t *conn ) - else - { - char s[MAX_STRING]; -- -+ - snprintf( s, MAX_STRING, "%s%s", conn->dir, conn->file ); - conn->http->firstbyte = conn->currentbyte; - conn->http->lastbyte = conn->lastbyte; -@@ -294,7 +299,7 @@ int conn_info( conn_t *conn ) - { - conn->supported = 0; - } -- -+ - if( !ftp_cwd( conn->ftp, conn->dir ) ) - return( 0 ); - conn->size = ftp_size( conn->ftp, conn->file, MAX_REDIR ); -@@ -309,7 +314,7 @@ int conn_info( conn_t *conn ) - { - char s[MAX_STRING], *t; - int i = 0; -- -+ - do - { - conn->currentbyte = 1; -@@ -326,25 +331,27 @@ int conn_info( conn_t *conn ) - { - sprintf( conn->http->headers, "%s%s", - conn_url( conn ), s ); -- strncpy( s, conn->http->headers, MAX_STRING ); -+ strncpy( s, conn->http->headers, MAX_STRING - 1); -+ s[MAX_STRING - 1] = '\0'; - } - else if( s[0] == '/' ) - { - sprintf( conn->http->headers, "http://%s:%i%s", - conn->host, conn->port, s ); -- strncpy( s, conn->http->headers, MAX_STRING ); -+ strncpy( s, conn->http->headers, MAX_STRING - 1); -+ s[MAX_STRING - 1] = '\0'; - } - conn_set( conn, s ); - i ++; - } - while( conn->http->status / 100 == 3 && i < MAX_REDIR ); -- -+ - if( i == MAX_REDIR ) - { - sprintf( conn->message, _("Too many redirects.\n") ); - return( 0 ); - } -- -+ - conn->size = http_size( conn->http ); - if( conn->http->status == 206 && conn->size >= 0 ) - { -@@ -366,6 +373,6 @@ int conn_info( conn_t *conn ) - return( 0 ); - } - } -- -+ - return( 1 ); - } -diff -Nurp axel-1.0b/conn.h axel-1.0b-r1/conn.h ---- axel-1.0b/conn.h 2001-12-15 18:28:38.000000000 +0100 -+++ axel-1.0b-r1/conn.h 2007-08-05 20:58:15.000000000 +0200 -@@ -30,7 +30,7 @@ - typedef struct - { - conf_t *conf; -- -+ - int proto; - int port; - int proxy; -@@ -39,7 +39,7 @@ typedef struct - char file[MAX_STRING]; - char user[MAX_STRING]; - char pass[MAX_STRING]; -- -+ - ftp_t ftp[1]; - http_t http[1]; - int size; /* File size, not 'connection size'.. */ -diff -Nurp axel-1.0b/ftp.c axel-1.0b-r1/ftp.c ---- axel-1.0b/ftp.c 2001-12-15 18:59:03.000000000 +0100 -+++ axel-1.0b-r1/ftp.c 2007-08-05 23:03:56.000000000 +0200 -@@ -29,16 +29,16 @@ int ftp_connect( ftp_t *conn, char *host - { - conn->data_fd = -1; - conn->message = malloc( MAX_STRING ); -- -+ - if( ( conn->fd = tcp_connect( host, port, conn->local_if ) ) == -1 ) - { -- sprintf( conn->message, _("Unable to connect to server %s:%i\n"), host, port ); -+ snprintf( conn->message, MAX_STRING, _("Unable to connect to server %s:%i\n"), host, port ); - return( 0 ); - } -- -+ - if( ftp_wait( conn ) / 100 != 2 ) - return( 0 ); -- -+ - ftp_command( conn, "USER %s", user ); - if( ftp_wait( conn ) / 100 != 2 ) - { -@@ -47,18 +47,18 @@ int ftp_connect( ftp_t *conn, char *host - ftp_command( conn, "PASS %s", pass ); - if( ftp_wait( conn ) / 100 != 2 ) - return( 0 ); -- } -+ } - else - { - return( 0 ); - } - } -- -+ - /* ASCII mode sucks. Just use Binary.. */ - ftp_command( conn, "TYPE I" ); - if( ftp_wait( conn ) / 100 != 2 ) - return( 0 ); -- -+ - return( 1 ); - } - -@@ -84,13 +84,14 @@ int ftp_cwd( ftp_t *conn, char *cwd ) - /* Necessary at all? */ - if( strncmp( conn->cwd, cwd, MAX_STRING ) == 0 ) - return( 1 ); -- -+ - ftp_command( conn, "CWD %s", cwd ); - if( ftp_wait( conn ) / 100 != 2 ) - return( 0 ); -- -- strncpy( conn->cwd, cwd, MAX_STRING ); -- -+ -+ strncpy( conn->cwd, cwd, MAX_STRING - 1); -+ conn->cwd[MAX_STRING - 1] = '\0'; -+ - return( 1 ); - } - -@@ -99,7 +100,7 @@ int ftp_size( ftp_t *conn, char *file, i - { - int i, j, size = MAX_STRING; - char *reply, *s, fn[MAX_STRING]; -- -+ - /* Try the SIZE command first, if possible */ - if( !strchr( file, '*' ) && !strchr( file, '?' ) ) - { -@@ -115,20 +116,20 @@ int ftp_size( ftp_t *conn, char *file, i - return( -1 ); - } - } -- -+ - if( maxredir == 0 ) - { - sprintf( conn->message, _("Too many redirects.\n") ); - return( -1 ); - } -- -+ - if( !ftp_data( conn ) ) - return( -1 ); -- -+ - ftp_command( conn, "LIST %s", file ); - if( ftp_wait( conn ) / 100 != 1 ) - return( -1 ); -- -+ - /* Read reply from the server. */ - reply = malloc( size ); - memset( reply, 0, size ); -@@ -147,17 +148,17 @@ int ftp_size( ftp_t *conn, char *file, i - } - close( conn->data_fd ); - conn->data_fd = -1; -- -+ - if( ftp_wait( conn ) / 100 != 2 ) - { - free( reply ); - return( -1 ); - } -- -+ - #ifdef DEBUG - fprintf( stderr, reply ); - #endif -- -+ - /* Count the number of probably legal matches: Files&Links only */ - j = 0; - for( i = 1; reply[i] && reply[i+1]; i ++ ) -@@ -166,7 +167,7 @@ int ftp_size( ftp_t *conn, char *file, i - else - while( reply[i] != '\n' && reply[i] ) - i ++; -- -+ - /* No match or more than one match */ - if( j != 1 ) - { -@@ -183,10 +184,12 @@ int ftp_size( ftp_t *conn, char *file, i - { - /* Get the real filename */ - sscanf( s, "%*s %*i %*s %*s %*i %*s %*i %*s %100s", fn ); -- strcpy( file, fn ); -- -+ strncpy( file, fn, MAX_STRING -1 ); -+ file[MAX_STRING -1] = '\0'; -+ - /* Get size of the file linked to */ -- strncpy( fn, strstr( s, "->" ) + 3, MAX_STRING ); -+ strncpy( fn, strstr( s, "->" ) + 3, MAX_STRING - 1); -+ fn[MAX_STRING - 1] = '\0'; - free( reply ); - if( ( reply = strchr( fn, '\r' ) ) != NULL ) - *reply = 0; -@@ -208,8 +211,9 @@ int ftp_size( ftp_t *conn, char *file, i - return( -2 ); - } - } -- strcpy( file, fn ); -- -+ strncpy( file, fn, MAX_STRING - 1); -+ file[MAX_STRING - 1] = '\0'; -+ - free( reply ); - return( size ); - } -@@ -220,11 +224,11 @@ int ftp_data( ftp_t *conn ) - { - int i, info[6]; - char host[MAX_STRING]; -- -+ - /* Already done? */ - if( conn->data_fd > 0 ) - return( 0 ); -- -+ - /* if( conn->ftp_mode == FTP_PASSIVE ) - { - */ ftp_command( conn, "PASV" ); -@@ -253,7 +257,7 @@ int ftp_data( ftp_t *conn ) - sprintf( conn->message, _("Error opening passive data connection.\n") ); - return( 0 ); - } -- -+ - return( 1 ); - /* } - else -@@ -268,16 +272,16 @@ int ftp_command( ftp_t *conn, char *form - { - va_list params; - char cmd[MAX_STRING]; -- -+ - va_start( params, format ); - vsnprintf( cmd, MAX_STRING - 3, format, params ); - strcat( cmd, "\r\n" ); - va_end( params ); -- -+ - #ifdef DEBUG - fprintf( stderr, "fd(%i)<--%s", conn->fd, cmd ); - #endif -- -+ - if( write( conn->fd, cmd, strlen( cmd ) ) != strlen( cmd ) ) - { - sprintf( conn->message, _("Error writing command %s\n"), format ); -@@ -295,9 +299,9 @@ int ftp_wait( ftp_t *conn ) - { - int size = MAX_STRING, r = 0, complete, i, j; - char *s; -- -+ - conn->message = realloc( conn->message, size ); -- -+ - do - { - do -@@ -321,7 +325,7 @@ int ftp_wait( ftp_t *conn ) - complete = 1; - else - complete = 0; -- -+ - for( i = 0; conn->message[i]; i ++ ) if( conn->message[i] == '\n' ) - { - if( complete == 1 ) -@@ -340,15 +344,15 @@ int ftp_wait( ftp_t *conn ) - } - while( complete != 2 ); - --#ifdef DEBUG -+#ifdef DEBUG - fprintf( stderr, "fd(%i)-->%s", conn->fd, conn->message ); - #endif -- -+ - if( ( s = strchr( conn->message, '\n' ) ) != NULL ) - *s = 0; - if( ( s = strchr( conn->message, '\r' ) ) != NULL ) - *s = 0; - conn->message = realloc( conn->message, max( strlen( conn->message ) + 1, MAX_STRING ) ); -- -+ - return( conn->status ); - } -diff -Nurp axel-1.0b/http.c axel-1.0b-r1/http.c ---- axel-1.0b/http.c 2002-01-25 15:26:40.000000000 +0100 -+++ axel-1.0b-r1/http.c 2007-08-05 23:02:19.000000000 +0200 -@@ -32,10 +32,11 @@ int http_connect( http_t *conn, int prot - char auth[MAX_STRING]; - conn_t tconn[1]; - int i; -- -- strncpy( conn->host, host, MAX_STRING ); -+ -+ strncpy( conn->host, host, MAX_STRING - 1); -+ conn->host[MAX_STRING - 1] = '\0'; - conn->proto = proto; -- -+ - if( proxy != NULL ) { if( *proxy != 0 ) - { - sprintf( conn->host, "%s:%i", host, port ); -@@ -52,13 +53,13 @@ int http_connect( http_t *conn, int prot - { - conn->proxy = 0; - } } -- -+ - if( ( conn->fd = tcp_connect( host, port, conn->local_if ) ) == -1 ) - { - sprintf( conn->request, _("Unable to connect to server %s:%i\n"), host, port ); - return( 0 ); - } -- -+ - if( *user == 0 ) - { - *conn->auth = 0; -@@ -77,7 +78,7 @@ int http_connect( http_t *conn, int prot - if( auth[i*3+1] == 0 ) conn->auth[i*4+2] = '='; - } - } -- -+ - return( 1 ); - } - -@@ -117,12 +118,12 @@ void http_addheader( http_t *conn, char - { - char s[MAX_STRING]; - va_list params; -- -+ - va_start( params, format ); - vsnprintf( s, MAX_STRING - 3, format, params ); - strcat( s, "\r\n" ); - va_end( params ); -- -+ - strncat( conn->request, s, MAX_QUERY ); - } - -@@ -137,7 +138,7 @@ int http_exec( http_t *conn ) - - http_addheader( conn, "" ); - write( conn->fd, conn->request, strlen( conn->request ) ); -- -+ - *conn->headers = 0; - /* Read the headers byte by byte to make sure we don't touch the - actual data */ -@@ -168,12 +169,13 @@ int http_exec( http_t *conn ) - #ifdef DEBUG - fprintf( stderr, "--- Reply headers ---\n%s--- End of headers ---\n", conn->headers ); - #endif -- -+ - sscanf( conn->headers, "%*s %3i", &conn->status ); - s2 = strchr( conn->headers, '\n' ); *s2 = 0; -- strcpy( conn->request, conn->headers ); -+ strncpy( conn->request, conn->headers, MAX_QUERY - 1); -+ conn->request[MAX_QUERY - 1] = '\0'; - *s2 = '\n'; -- -+ - return( 1 ); - } - -@@ -181,7 +183,7 @@ char *http_header( http_t *conn, char *h - { - char s[32]; - int i; -- -+ - for( i = 1; conn->headers[i]; i ++ ) - if( conn->headers[i-1] == '\n' ) - { -@@ -189,7 +191,7 @@ char *http_header( http_t *conn, char *h - if( strcasecmp( s, header ) == 0 ) - return( &conn->headers[i+strlen(header)] ); - } -- -+ - return( NULL ); - } - -@@ -197,10 +199,10 @@ int http_size( http_t *conn ) - { - char *i; - int j; -- -+ - if( ( i = http_header( conn, "Content-Length:" ) ) == NULL ) - return( -2 ); -- -+ - sscanf( i, "%i", &j ); - return( j ); - } -@@ -210,8 +212,8 @@ void http_decode( char *s ) - { - char t[MAX_STRING]; - int i, j, k; -- -- for( i = j = 0; s[i]; i ++, j ++ ) -+ -+ for( i = j = 0; s[i] && j < MAX_STRING - 3; i ++, j ++ ) - { - t[j] = s[i]; - if( s[i] == '%' ) -@@ -222,7 +224,7 @@ void http_decode( char *s ) - } - } - t[j] = 0; -- -+ - strcpy( s, t ); - } - -@@ -230,8 +232,8 @@ void http_encode( char *s ) - { - char t[MAX_STRING]; - int i, j; -- -- for( i = j = 0; s[i]; i ++, j ++ ) -+ -+ for( i = j = 0; s[i] && j < MAX_STRING - 3; i ++, j ++ ) - { - t[j] = s[i]; - if( s[i] == ' ' ) -@@ -241,6 +243,6 @@ void http_encode( char *s ) - } - } - t[j] = 0; -- -+ - strcpy( s, t ); - } -diff -Nurp axel-1.0b/search.c axel-1.0b-r1/search.c ---- axel-1.0b/search.c 2001-12-06 19:29:58.000000000 +0100 -+++ axel-1.0b-r1/search.c 2007-08-05 22:53:09.000000000 +0200 -@@ -35,19 +35,19 @@ int main( int argc, char *argv[] ) - conf_t conf[1]; - search_t *res; - int i, j; -- -+ - if( argc != 2 ) - { - fprintf( stderr, "Incorrect amount of arguments\n" ); - return( 1 ); - } -- -+ - conf_init( conf ); -- -+ - res = malloc( sizeof( search_t ) * ( conf->search_amount + 1 ) ); - memset( res, 0, sizeof( search_t ) * ( conf->search_amount + 1 ) ); - res->conf = conf; -- -+ - i = search_makelist( res, argv[1] ); - if( i == -1 ) - { -@@ -58,7 +58,7 @@ int main( int argc, char *argv[] ) - search_sortlist( res, i ); - for( j = 0; j < i; j ++ ) - printf( "%-70.70s %5i\n", res[j].url, res[j].speed ); -- -+ - return( 0 ); - } - #endif -@@ -69,9 +69,9 @@ int search_makelist( search_t *results, - char *s, *s1, *s2, *s3; - conn_t conn[1]; - double t; -- -+ - memset( conn, 0, sizeof( conn_t ) ); -- -+ - conn->conf = results->conf; - t = gettime(); - if( !conn_set( conn, url ) ) -@@ -80,22 +80,23 @@ int search_makelist( search_t *results, - return( -1 ); - if( !conn_info( conn ) ) - return( -1 ); -- -- strcpy( results[0].url, url ); -+ -+ strncpy( results[0].url, url, MAX_STRING - 1); -+ results[0].url[MAX_STRING - 1] = '\0'; - results[0].speed = 1 + 1000 * ( gettime() - t ); - results[0].size = conn->size; -- -+ - s = malloc( size ); -- -+ - sprintf( s, "http://www.filesearching.com/cgi-bin/s?q=%s&w=a&l=en&" - "t=f&e=on&m=%i&o=n&s1=%i&s2=%i&x=15&y=15", - conn->file, results->conf->search_amount, - conn->size, conn->size ); -- -+ - conn_disconnect( conn ); - memset( conn, 0, sizeof( conn_t ) ); - conn->conf = results->conf; -- -+ - if( !conn_set( conn, s ) ) - { - free( s ); -@@ -111,7 +112,7 @@ int search_makelist( search_t *results, - free( s ); - return( 1 ); - } -- -+ - while( ( i = read( conn->fd, s + j, size - j ) ) > 0 ) - { - j += i; -@@ -124,7 +125,7 @@ int search_makelist( search_t *results, - } - - conn_disconnect( conn ); -- -+ - s1 = strstr( s, "<pre class=list" ); - s1 = strchr( s1, '\n' ) + 1; - if( strstr( s1, "</pre>" ) == NULL ) -@@ -141,7 +142,8 @@ int search_makelist( search_t *results, - s3 = strchr( s2, ' ' ); *s3 = 0; - if( strcmp( results[0].url, s2 ) ) - { -- strncpy( results[i].url, s2, MAX_STRING ); -+ strncpy( results[i].url, s2, MAX_STRING - 1); -+ results[i].url[MAX_STRING - 1] = '\0'; - results[i].size = results[0].size; - results[i].conf = results->conf; - } -@@ -153,9 +155,9 @@ int search_makelist( search_t *results, - for( s1 = s3; *s1 != '\n'; s1 ++ ); - s1 ++; - } -- -+ - free( s ); -- -+ - return( i ); - } - -@@ -166,7 +168,7 @@ int search_makelist( search_t *results, - int search_getspeeds( search_t *results, int count ) - { - int i, running = 0, done = 0, correct = 0; -- -+ - for( i = 0; i < count; i ++ ) if( results[i].speed ) - { - results[i].speed_start_time = 0; -@@ -174,7 +176,7 @@ int search_getspeeds( search_t *results, - if( results[i].speed > 0 ) - correct ++; - } -- -+ - while( done < count ) - { - for( i = 0; i < count; i ++ ) -@@ -233,11 +235,11 @@ void *search_speedtest( void *r ) - search_t *results = r; - conn_t conn[1]; - int oldstate; -- -+ - /* Allow this thread to be killed at any time. */ - pthread_setcancelstate( PTHREAD_CANCEL_ENABLE, &oldstate ); - pthread_setcanceltype( PTHREAD_CANCEL_ASYNCHRONOUS, &oldstate ); -- -+ - memset( conn, 0, sizeof( conn_t ) ); - conn->conf = results->conf; - if( !conn_set( conn, results->url ) ) -@@ -253,21 +255,21 @@ void *search_speedtest( void *r ) - results->speed = SPEED_ERROR; - - conn_disconnect( conn ); -- -+ - return( NULL ); - } - - char *strrstr( char *haystack, char *needle ) - { - int i, j; -- -+ - for( i = strlen( haystack ) - strlen( needle ); i > 0; i -- ) - { - for( j = 0; needle[j] && haystack[i+j] == needle[j]; j ++ ); - if( !needle[j] ) - return( haystack + i ); - } -- -+ - return( NULL ); - } - -diff -Nurp axel-1.0b/tcp.c axel-1.0b-r1/tcp.c ---- axel-1.0b/tcp.c 2001-12-16 19:05:27.000000000 +0100 -+++ axel-1.0b-r1/tcp.c 2007-08-05 23:04:37.000000000 +0200 -@@ -35,10 +35,10 @@ int tcp_connect( char *hostname, int por - - #ifdef DEBUG - socklen_t i = sizeof( local ); -- -+ - fprintf( stderr, "tcp_connect( %s, %i ) = ", hostname, port ); - #endif -- -+ - /* Why this loop? Because the call might return an empty record. - At least it very rarely does, on my system... */ - for( fd = 0; fd < 5; fd ++ ) -@@ -49,10 +49,10 @@ int tcp_connect( char *hostname, int por - } - if( !host || !host->h_name || !*host->h_name ) - return( -1 ); -- -+ - if( ( fd = socket( AF_INET, SOCK_STREAM, 0 ) ) == -1 ) - return( -1 ); -- -+ - if( local_if && *local_if ) - { - local.sin_family = AF_INET; -@@ -64,22 +64,22 @@ int tcp_connect( char *hostname, int por - return( -1 ); - } - } -- -+ - addr.sin_family = AF_INET; - addr.sin_port = htons( port ); - addr.sin_addr = *( (struct in_addr *) host->h_addr ); -- -+ - if( connect( fd, (struct sockaddr *) &addr, sizeof( struct sockaddr_in ) ) == -1 ) - { - close( fd ); - return( -1 ); - } -- -+ - #ifdef DEBUG - getsockname( fd, &local, &i ); - fprintf( stderr, "%i\n", ntohs( local.sin_port ) ); - #endif -- -+ - return( fd ); - } - -@@ -87,10 +87,10 @@ int get_if_ip( char *iface, char *ip ) - { - struct ifreq ifr; - int fd = socket( PF_INET, SOCK_DGRAM, IPPROTO_IP ); -- -+ - memset( &ifr, 0, sizeof( struct ifreq ) ); -- -- strcpy( ifr.ifr_name, iface ); -+ -+ strncpy( ifr.ifr_name, iface, IFNAMSIZ ); - ifr.ifr_addr.sa_family = AF_INET; - if( ioctl( fd, SIOCGIFADDR, &ifr ) == 0 ) - { -diff -Nurp axel-1.0b/text.c axel-1.0b-r1/text.c ---- axel-1.0b/text.c 2002-02-19 20:45:55.000000000 +0100 -+++ axel-1.0b-r1/text.c 2007-08-05 23:04:11.000000000 +0200 -@@ -69,29 +69,29 @@ int main( int argc, char *argv[] ) - axel_t *axel; - int i, j; - char *s; -- -+ - #ifdef I18N - setlocale( LC_ALL, "" ); - bindtextdomain( PACKAGE, LOCALE ); - textdomain( PACKAGE ); - #endif -- -+ - if( !conf_init( conf ) ) - { - return( 1 ); - } -- -+ - opterr = 0; -- -+ - j = -1; - while( 1 ) - { - int option; -- -+ - option = getopt_long( argc, argv, "s:n:o:S::NqvhHVa", axel_options, NULL ); - if( option == -1 ) - break; -- -+ - switch( option ) - { - case 's': -@@ -109,7 +109,8 @@ int main( int argc, char *argv[] ) - } - break; - case 'o': -- strncpy( fn, optarg, MAX_STRING ); -+ strncpy( fn, optarg, MAX_STRING - 1); -+ fn[MAX_STRING - 1] = '\0'; - break; - case 'S': - do_search = 1; -@@ -152,10 +153,10 @@ int main( int argc, char *argv[] ) - return( 1 ); - } - } -- -+ - if( j > -1 ) - conf->verbose = j; -- -+ - if( argc - optind == 0 ) - { - print_help(); -@@ -170,7 +171,7 @@ int main( int argc, char *argv[] ) - { - s = argv[optind]; - } -- -+ - printf( _("Initializing download: %s\n"), s ); - if( do_search ) - { -@@ -222,7 +223,10 @@ int main( int argc, char *argv[] ) - search = malloc( sizeof( search_t ) * ( argc - optind ) ); - memset( search, 0, sizeof( search_t ) * ( argc - optind ) ); - for( i = 0; i < ( argc - optind ); i ++ ) -- strncpy( search[i].url, argv[optind+i], MAX_STRING ); -+ { -+ strncpy( search[i].url, argv[optind+i], MAX_STRING - 1); -+ search[i].url[MAX_STRING - 1] = '\0'; -+ } - axel = axel_new( conf, argc - optind, search ); - free( search ); - if( axel->ready == -1 ) -@@ -232,16 +236,18 @@ int main( int argc, char *argv[] ) - return( 1 ); - } - } -+ -+ - print_messages( axel ); - if( s != argv[optind] ) - { - free( s ); - } -- -+ - if( *fn ) - { - struct stat buf; -- -+ - if( stat( fn, &buf ) == 0 ) - { - if( S_ISDIR( buf.st_mode ) ) -@@ -261,7 +267,8 @@ int main( int argc, char *argv[] ) - printf( _("State file found, but no downloaded data. Starting from scratch.\n" ) ); - unlink( string ); - } -- strcpy( axel->filename, fn ); -+ strncpy( axel->filename, fn, MAX_STRING - 1); -+ axel->filename[MAX_STRING - 1] = '\0'; - } - else - { -@@ -288,7 +295,7 @@ int main( int argc, char *argv[] ) - i ++; - } - } -- -+ - if( !axel_open( axel ) ) - { - print_messages( axel ); -@@ -301,7 +308,7 @@ int main( int argc, char *argv[] ) - if( conf->alternate_output ) - { - putchar('\n'); -- } -+ } - else - { - if( axel->bytes_done > 0 ) /* Print first dots if resuming */ -@@ -311,20 +318,20 @@ int main( int argc, char *argv[] ) - } - } - axel->start_byte = axel->bytes_done; -- -+ - /* Install save_state signal handler for resuming support */ - signal( SIGINT, stop ); - signal( SIGTERM, stop ); -- -+ - while( !axel->ready && run ) - { - int prev, done; -- -+ - prev = axel->bytes_done; - axel_do( axel ); -- -+ - if( conf->alternate_output ) -- { -+ { - if( !axel->message && prev != axel->bytes_done ) - print_alternate_output( axel ); - } -@@ -356,7 +363,7 @@ int main( int argc, char *argv[] ) - fflush( stdout ); - } - } -- -+ - if( axel->message ) - { - if(conf->alternate_output==1) -@@ -385,19 +392,19 @@ int main( int argc, char *argv[] ) - putchar( '\n' ); - } - } -- -+ - strcpy( string + MAX_STRING / 2, - size_human( axel->bytes_done - axel->start_byte ) ); -- -+ - printf( _("\nDownloaded %s in %s. (%.2f KB/s)\n"), - string + MAX_STRING / 2, - time_human( gettime() - axel->start_time ), - (double) axel->bytes_per_second / 1024 ); -- -+ - i = axel->ready ? 0 : 2; -- -+ - axel_close( axel ); -- -+ - return( i ); - } - -@@ -418,7 +425,7 @@ char *size_human( int value ) - sprintf( string, _("%.1f kilobytes"), (float) value / 1024 ); - else - sprintf( string, _("%.1f megabytes"), (float) value / 1048576 ); -- -+ - return( string ); - } - -@@ -433,7 +440,7 @@ char *time_human( int value ) - sprintf( string, _("%i:%02i seconds"), value / 60, value % 60 ); - else - sprintf( string, _("%i:%02i:%02i seconds"), value / 3600, ( value / 60 ) % 60, value % 60 ); -- -+ - return( string ); - } - -@@ -442,7 +449,7 @@ char *time_human( int value ) - void print_commas( int bytes_done ) - { - int i, j; -- -+ - printf( " " ); - j = ( bytes_done / 1024 ) % 50; - if( j == 0 ) j = 50; -@@ -455,15 +462,15 @@ void print_commas( int bytes_done ) - fflush( stdout ); - } - --static void print_alternate_output(axel_t *axel) -+static void print_alternate_output(axel_t *axel) - { - int done=axel->bytes_done; - int total=axel->size; - int i,j=0; - double now = gettime(); -- -+ - printf("\r[%3ld%%] [", min(100,(long)(done*100./total+.5) ) ); -- -+ - for(i=0;i<axel->conf->num_connections;i++) - { - for(;j<((double)axel->conn[i].currentbyte/(total+1)*50)-1;j++) -@@ -475,17 +482,17 @@ static void print_alternate_output(axel_ - putchar(i+'0'); - else - putchar('#'); -- } else -+ } else - putchar('.'); - - j++; -- -+ - for(;j<((double)axel->conn[i].lastbyte/(total+1)*50);j++) - putchar(' '); - } -- -+ - printf( "] [%6.1fKB/s]", (double) axel->bytes_per_second / 1024 ); -- -+ - if(done<total) - { - int seconds,minutes,hours,days; -@@ -500,7 +507,7 @@ static void print_alternate_output(axel_ - else - printf(" [%02d:%02d]",minutes,seconds); - } -- -+ - fflush( stdout ); - } - -@@ -549,7 +556,7 @@ void print_version() - void print_messages( axel_t *axel ) - { - message_t *m; -- -+ - while( axel->message ) - { - printf( "%s\n", axel->message->text ); |