mirror of
https://github.com/OpenTTD/OpenTTD.git
synced 2025-03-06 22:28:56 +00:00
Fix: reset content download progress to zero if falling back to TCP
Otherwise this chain of events can happen: - You already have a (partial) file downloaded - You start the download, and HTTP fails - This resets the download progress to the current size of the file - The TCP download starts at a very large value (UINT32_MAX - filesize) It now resets to 0% done when any negative value is being given. As added bonus, we no longer have to query how much was already downloaded.
This commit is contained in:
parent
1c17556f96
commit
dea2dea881
@ -586,9 +586,7 @@ void ClientNetworkContentSocketHandler::OnFailure()
|
||||
this->http_response_index = -2;
|
||||
|
||||
if (this->curFile != nullptr) {
|
||||
/* Revert the download progress when we are going for the old system. */
|
||||
long size = ftell(this->curFile);
|
||||
if (size > 0) this->OnDownloadProgress(this->curInfo, (int)-size);
|
||||
this->OnDownloadProgress(this->curInfo, -1);
|
||||
|
||||
fclose(this->curFile);
|
||||
this->curFile = nullptr;
|
||||
|
@ -100,7 +100,7 @@ static WindowDesc _network_content_download_status_window_desc(
|
||||
);
|
||||
|
||||
BaseNetworkContentDownloadStatusWindow::BaseNetworkContentDownloadStatusWindow(WindowDesc *desc) :
|
||||
Window(desc), cur_id(UINT32_MAX)
|
||||
Window(desc), downloaded_bytes(0), downloaded_files(0), cur_id(UINT32_MAX)
|
||||
{
|
||||
_network_content_client.AddCallback(this);
|
||||
_network_content_client.DownloadSelectedContent(this->total_files, this->total_bytes);
|
||||
@ -174,7 +174,13 @@ void BaseNetworkContentDownloadStatusWindow::OnDownloadProgress(const ContentInf
|
||||
this->downloaded_files++;
|
||||
}
|
||||
|
||||
this->downloaded_bytes += bytes;
|
||||
/* A negative value means we are resetting; for example, when retrying or using a fallback. */
|
||||
if (bytes < 0) {
|
||||
this->downloaded_bytes = 0;
|
||||
} else {
|
||||
this->downloaded_bytes += bytes;
|
||||
}
|
||||
|
||||
this->SetDirty();
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user