mirror of
https://github.com/transmission/transmission
synced 2024-12-26 09:37:56 +00:00
(trunk libt) #4437 'multi file webseeds do not work' -- revert r12740, which was a bad patch.
This commit is contained in:
parent
6373e27d78
commit
b3db349c83
1 changed files with 4 additions and 10 deletions
|
@ -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 );
|
||||||
|
|
Loading…
Reference in a new issue