Fixed issue 19 "xbps-src cannot fetch source with unknown Content-Length".
This commit is contained in:
parent
7d631c5d11
commit
c83a77c1b5
5
NEWS
5
NEWS
@ -1,5 +1,10 @@
|
|||||||
xbps-0.12.0 (???):
|
xbps-0.12.0 (???):
|
||||||
|
|
||||||
|
* It's now possible to fetch files thru xbps_fetch_file() from HTTP
|
||||||
|
servers that don't set the Content-Length header. This fixes issue 19:
|
||||||
|
"xbps-src cannot fetch source with unknown Content-Length" reported
|
||||||
|
by ojab.
|
||||||
|
|
||||||
* Renamed some options in xbps.conf to not have dashes, such as:
|
* Renamed some options in xbps.conf to not have dashes, such as:
|
||||||
fetch-timeout-connection -> FetchTimeoutConnection
|
fetch-timeout-connection -> FetchTimeoutConnection
|
||||||
fetch-cache-connections-host -> FetchCacheConnections
|
fetch-cache-connections-host -> FetchCacheConnections
|
||||||
|
@ -68,6 +68,9 @@ stat_eta(const struct xbps_fetch_cb_data *xfpd, void *cbdata)
|
|||||||
long elapsed, eta;
|
long elapsed, eta;
|
||||||
off_t received, expected;
|
off_t received, expected;
|
||||||
|
|
||||||
|
if (xfpd->file_size == -1)
|
||||||
|
return "unknown";
|
||||||
|
|
||||||
elapsed = xfer->last.tv_sec - xfer->start.tv_sec;
|
elapsed = xfer->last.tv_sec - xfer->start.tv_sec;
|
||||||
received = xfpd->file_dloaded - xfpd->file_offset;
|
received = xfpd->file_dloaded - xfpd->file_offset;
|
||||||
expected = xfpd->file_size - xfpd->file_dloaded;
|
expected = xfpd->file_size - xfpd->file_dloaded;
|
||||||
@ -126,17 +129,24 @@ stat_display(const struct xbps_fetch_cb_data *xfpd, void *cbdata)
|
|||||||
struct xferstat *xfer = cbdata;
|
struct xferstat *xfer = cbdata;
|
||||||
struct timeval now;
|
struct timeval now;
|
||||||
char totsize[8], recvsize[8];
|
char totsize[8], recvsize[8];
|
||||||
|
int percentage;
|
||||||
|
|
||||||
get_time(&now);
|
get_time(&now);
|
||||||
if (now.tv_sec <= xfer->last.tv_sec)
|
if (now.tv_sec <= xfer->last.tv_sec)
|
||||||
return;
|
return;
|
||||||
xfer->last = now;
|
xfer->last = now;
|
||||||
|
|
||||||
|
if (xfpd->file_size == -1) {
|
||||||
|
percentage = 0;
|
||||||
|
snprintf(totsize, 3, "0B");
|
||||||
|
} else {
|
||||||
|
percentage = (int)((double)(100.0 *
|
||||||
|
(double)xfpd->file_dloaded) / (double)xfpd->file_size);
|
||||||
(void)xbps_humanize_number(totsize, (int64_t)xfpd->file_size);
|
(void)xbps_humanize_number(totsize, (int64_t)xfpd->file_size);
|
||||||
|
}
|
||||||
(void)xbps_humanize_number(recvsize, (int64_t)xfpd->file_dloaded);
|
(void)xbps_humanize_number(recvsize, (int64_t)xfpd->file_dloaded);
|
||||||
fprintf(stderr,"\r%s: %s [%d%% of %s]", xfpd->file_name, recvsize,
|
fprintf(stderr,"\r%s: %s [%d%% of %s]", xfpd->file_name, recvsize,
|
||||||
(int)((double)(100.0 *
|
percentage, totsize);
|
||||||
(double)xfpd->file_dloaded) / (double)xfpd->file_size), totsize);
|
|
||||||
fprintf(stderr," %s", stat_bps(xfpd, xfer));
|
fprintf(stderr," %s", stat_bps(xfpd, xfer));
|
||||||
fprintf(stderr," ETA: %s", stat_eta(xfpd, xfer));
|
fprintf(stderr," ETA: %s", stat_eta(xfpd, xfer));
|
||||||
fprintf(stderr,"\033[K");
|
fprintf(stderr,"\033[K");
|
||||||
@ -157,7 +167,7 @@ fetch_file_progress_cb(const struct xbps_fetch_cb_data *xfpd, void *cbdata)
|
|||||||
stat_display(xfpd, xfer);
|
stat_display(xfpd, xfer);
|
||||||
} else if (xfpd->cb_end) {
|
} else if (xfpd->cb_end) {
|
||||||
/* end transfer stats */
|
/* end transfer stats */
|
||||||
(void)xbps_humanize_number(size, (int64_t)xfpd->file_size);
|
(void)xbps_humanize_number(size, (int64_t)xfpd->file_dloaded);
|
||||||
fprintf(stderr,"\rDownloaded %s for %s [avg rate: %s]",
|
fprintf(stderr,"\rDownloaded %s for %s [avg rate: %s]",
|
||||||
size, xfpd->file_name, stat_bps(xfpd, xfer));
|
size, xfpd->file_name, stat_bps(xfpd, xfer));
|
||||||
fprintf(stderr,"\033[K\n");
|
fprintf(stderr,"\033[K\n");
|
||||||
|
@ -56,7 +56,7 @@
|
|||||||
*/
|
*/
|
||||||
#define XBPS_PKGINDEX_VERSION "1.3"
|
#define XBPS_PKGINDEX_VERSION "1.3"
|
||||||
|
|
||||||
#define XBPS_API_VERSION "20120104-1"
|
#define XBPS_API_VERSION "20120105"
|
||||||
#define XBPS_VERSION "0.12"
|
#define XBPS_VERSION "0.12"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -226,10 +226,9 @@ xbps_fetch_file(const char *uri,
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
if (url_st.size == -1) {
|
if (url_st.size == -1) {
|
||||||
xbps_dbg_printf("Remote file size is unknown!\n");
|
xbps_dbg_printf("Remote file size is unknown, resume "
|
||||||
errno = EINVAL;
|
"not possible...\n");
|
||||||
rv = -1;
|
restart = false;
|
||||||
goto out;
|
|
||||||
} else if (st.st_size > url_st.size) {
|
} else if (st.st_size > url_st.size) {
|
||||||
/*
|
/*
|
||||||
* Remove local file if bigger than remote, and refetch the
|
* Remove local file if bigger than remote, and refetch the
|
||||||
|
Loading…
x
Reference in New Issue
Block a user