1
0
Fork 0
mirror of https://github.com/transmission/transmission synced 2024-12-27 01:57:52 +00:00

(trunk libt) #4437 'multi file webseeds do not work' -- revert r12740, which was a bad patch.

This commit is contained in:
Jordan Lee 2011-09-06 16:10:27 +00:00
parent 6373e27d78
commit b3db349c83

View file

@ -41,7 +41,6 @@ struct tr_webseed_task
struct tr_web_task * web_task; struct tr_web_task * web_task;
long response_code; long response_code;
int torrent_id; int torrent_id;
bool bad_range;
}; };
struct tr_webseed struct tr_webseed
@ -415,8 +414,6 @@ web_response_func( tr_session * session,
/* now wait a while until retrying to establish a connection */ /* now wait a while until retrying to establish a connection */
++w->retry_tickcount; ++w->retry_tickcount;
t->bad_range = response_code == 416;
tr_list_remove_data( &w->tasks, t ); tr_list_remove_data( &w->tasks, t );
evbuffer_free( t->content ); evbuffer_free( t->content );
tr_free( t ); tr_free( t );
@ -459,18 +456,15 @@ web_response_func( tr_session * session,
} }
static struct evbuffer * static struct evbuffer *
make_url( struct tr_webseed_task * t, const tr_file * file ) make_url( tr_webseed * w, const tr_file * file )
{ {
struct evbuffer * buf = evbuffer_new( ); struct evbuffer * buf = evbuffer_new( );
struct tr_webseed * w = t->webseed;
evbuffer_add( buf, w->base_url, w->base_url_len ); evbuffer_add( buf, w->base_url, w->base_url_len );
if( t->bad_range || ( w->base_url[w->base_url_len - 1] == '/' && file->name ) ) { /* if url ends with a '/', add the torrent name */
if( t->bad_range ) if( w->base_url[w->base_url_len - 1] == '/' && file->name )
evbuffer_add( buf, "/", 1 );
tr_http_escape( buf, file->name, strlen(file->name), false ); tr_http_escape( buf, file->name, strlen(file->name), false );
}
return buf; return buf;
} }
@ -505,7 +499,7 @@ task_request_next_chunk( struct tr_webseed_task * t )
this_pass = MIN( remain, file->length - file_offset ); this_pass = MIN( remain, file->length - file_offset );
if( !urls[file_index] ) if( !urls[file_index] )
urls[file_index] = evbuffer_free_to_str( make_url( t, file ) ); urls[file_index] = evbuffer_free_to_str( make_url( t->webseed, file ) );
tr_snprintf( range, sizeof range, "%"PRIu64"-%"PRIu64, tr_snprintf( range, sizeof range, "%"PRIu64"-%"PRIu64,
file_offset, file_offset + this_pass - 1 ); file_offset, file_offset + this_pass - 1 );