Fix for single file mode not working
- Fix for not sending ranges which exceed the content-length which will result in an error. - Fix for byte range being set to 1 byte too large, it should be the end index, not the size as described in https://developer.mozilla.org/en-US/docs/Web/HTTP/Range_requests
This commit is contained in:
parent
595c6d275e
commit
35a213942c
11
src/link.c
11
src/link.c
|
@ -799,6 +799,8 @@ LinkTable *path_to_Link_LinkTable_new(const char *path)
|
||||||
if (!next_table) {
|
if (!next_table) {
|
||||||
if (CONFIG.mode == NORMAL) {
|
if (CONFIG.mode == NORMAL) {
|
||||||
next_table = LinkTable_new(tmp_link->f_url);
|
next_table = LinkTable_new(tmp_link->f_url);
|
||||||
|
} else if (CONFIG.mode == SINGLE) {
|
||||||
|
next_table = single_LinkTable_new(tmp_link->f_url);
|
||||||
} else if (CONFIG.mode == SONIC) {
|
} else if (CONFIG.mode == SONIC) {
|
||||||
if (!CONFIG.sonic_id3) {
|
if (!CONFIG.sonic_id3) {
|
||||||
next_table = sonic_LinkTable_new_index(tmp_link->sonic.id);
|
next_table = sonic_LinkTable_new_index(tmp_link->sonic.id);
|
||||||
|
@ -808,7 +810,7 @@ LinkTable *path_to_Link_LinkTable_new(const char *path)
|
||||||
tmp_link->sonic.id);
|
tmp_link->sonic.id);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
lprintf(fatal, "Invalid CONFIG.mode\n");
|
lprintf(fatal, "Invalid CONFIG.mode: %d\n", CONFIG.mode);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (link) {
|
if (link) {
|
||||||
|
@ -981,7 +983,7 @@ static CURL *Link_download_curl_setup(Link *link, size_t req_size, off_t offset,
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t start = offset;
|
size_t start = offset;
|
||||||
size_t end = start + req_size;
|
size_t end = start + req_size - 1;
|
||||||
|
|
||||||
char range_str[64];
|
char range_str[64];
|
||||||
snprintf(range_str, sizeof(range_str), "%lu-%lu", start, end);
|
snprintf(range_str, sizeof(range_str), "%lu-%lu", start, end);
|
||||||
|
@ -1061,6 +1063,11 @@ long Link_download(Link *link, char *output_buf, size_t req_size, off_t offset)
|
||||||
header.curr_size = 0;
|
header.curr_size = 0;
|
||||||
header.data = NULL;
|
header.data = NULL;
|
||||||
|
|
||||||
|
if (offset + req_size > link->content_length) {
|
||||||
|
lprintf(error, "requested size to large, req_size: %lu, recv: %ld, content-length: %ld\n", req_size, recv, link->content_length);
|
||||||
|
req_size = link->content_length - offset;
|
||||||
|
}
|
||||||
|
|
||||||
CURL *curl = Link_download_curl_setup(link, req_size, offset, &header, &ts);
|
CURL *curl = Link_download_curl_setup(link, req_size, offset, &header, &ts);
|
||||||
|
|
||||||
transfer_blocking(curl);
|
transfer_blocking(curl);
|
||||||
|
|
Loading…
Reference in New Issue