summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEugenio Favalli <elvenprogrammer@gmail.com>2005-07-15 10:32:27 +0000
committerEugenio Favalli <elvenprogrammer@gmail.com>2005-07-15 10:32:27 +0000
commitb8f8c1bd367edd983924e60a61965290dd5c5325 (patch)
treebe5ccd7b660a7d52e77760f89ac6a774655cd480
parent13cb522b404a97172255df898d7674fe6b16cedd (diff)
downloadmana-b8f8c1bd367edd983924e60a61965290dd5c5325.tar.gz
mana-b8f8c1bd367edd983924e60a61965290dd5c5325.tar.bz2
mana-b8f8c1bd367edd983924e60a61965290dd5c5325.tar.xz
mana-b8f8c1bd367edd983924e60a61965290dd5c5325.zip
- Bugfixes and better error checking in the updater
- Now the download is stopped when pressing cancel - news and resources files are now deleted as well as not completed files
-rw-r--r--src/gui/updatewindow.cpp54
1 files changed, 32 insertions, 22 deletions
diff --git a/src/gui/updatewindow.cpp b/src/gui/updatewindow.cpp
index 42a68afa..e571f3fc 100644
--- a/src/gui/updatewindow.cpp
+++ b/src/gui/updatewindow.cpp
@@ -156,21 +156,18 @@ int updateProgress(void *ptr,
double ultotal,
double ulnow)
{
- std::string labelString(currentFile);
float progress = d/t;
- if (d < 0)
+ if (progress < 0)
{
- d = 0.0f;
+ progress = 0.0f;
}
- std::stringstream progressString("");
- progressString << ((int)(progress*100));
- labelString += " (" + progressString.str() + "%)";
- updaterWindow->setLabel(labelString.c_str());
+ std::stringstream progressString;
+ progressString << currentFile << " (" << ((int)(progress*100)) << "%)";
+ updaterWindow->setLabel(progressString.str().c_str());
updaterWindow->setProgress(progress);
- if (state != UPDATE && downloadStatus != UPDATE_ERROR) {
+ if (state != UPDATE || downloadStatus == UPDATE_ERROR) {
// If the action was canceled return an error code to stop the thread
- downloadStatus = UPDATE_ERROR;
return -1;
}
@@ -182,20 +179,20 @@ int downloadThread(void *ptr)
CURL *curl;
CURLcode res;
FILE *outfile;
- std::string fileName(currentFile);
- std::string url(updateHost);
- url += "/" + fileName;
+ std::string url(updateHost + "/" + currentFile);
curl = curl_easy_init();
if (curl)
{
+ // Download current file as a temp file
+ logger->log("Downloading: %s", url.c_str());
// TODO: download in the proper folder (data?)
- outfile = fopen(fileName.c_str(), "wb");
+ outfile = fopen("download.temp", "wb");
curl_easy_setopt(curl, CURLOPT_URL, url.c_str());
curl_easy_setopt(curl, CURLOPT_WRITEDATA, outfile);
curl_easy_setopt(curl, CURLOPT_NOPROGRESS, 0);
curl_easy_setopt(curl, CURLOPT_PROGRESSFUNCTION, updateProgress);
- curl_easy_setopt(curl, CURLOPT_PROGRESSDATA, fileName.c_str());
+ curl_easy_setopt(curl, CURLOPT_PROGRESSDATA, NULL);
res = curl_easy_perform(curl);
@@ -205,12 +202,17 @@ int downloadThread(void *ptr)
if (res != 0) {
downloadStatus = UPDATE_ERROR;
}
+ else {
+ // If the download was successful give the file the proper name
+ // else it will be deleted later
+ rename("download.temp", currentFile.c_str());
+ }
}
return 0;
}
-int download()
+void download()
{
downloadComplete = false;
thread = SDL_CreateThread(downloadThread, NULL);
@@ -219,8 +221,9 @@ int download()
logger->log("Unable to create thread");
downloadStatus = UPDATE_ERROR;
}
-
- return 0;
+ else {
+ logger->log("Starting download of %s", currentFile.c_str());
+ }
}
void checkFile(std::ifstream &in) {
@@ -275,10 +278,12 @@ void updateData()
switch (downloadStatus) {
case UPDATE_ERROR:
+ SDL_WaitThread(thread, NULL);
new OkDialog(
"Error", ("The update process is incomplete. ",
"It is strongly recommended that you try again later"),
updaterWindow);
+ logger->log("Error during the update process");
downloadStatus = UPDATE_IDLE;
break;
case UPDATE_NEWS:
@@ -311,6 +316,7 @@ void updateData()
}
}
else {
+ SDL_WaitThread(thread, NULL);
if (!in.eof())
{
// Download each update
@@ -323,16 +329,18 @@ void updateData()
else {
// Download of updates completed
downloadStatus = UPDATE_COMPLETE;
- updaterWindow->enable();
- updaterWindow->setLabel("Completed");
}
}
}
break;
+ case UPDATE_COMPLETE:
+ updaterWindow->enable();
+ updaterWindow->setLabel("Completed");
+ break;
case UPDATE_IDLE:
break;
}
-
+
gui->logic();
login_wallpaper->draw(screen, 0, 0);
@@ -341,8 +349,10 @@ void updateData()
}
in.close();
-
- SDL_WaitThread(thread, NULL);
+ // Remove downloaded files
+ remove("news.txt");
+ remove("resources.txt");
+ remove("download.temp");
delete updaterWindow;
}