summaryrefslogtreecommitdiff
path: root/src/gui/updatewindow.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/gui/updatewindow.cpp')
-rw-r--r--src/gui/updatewindow.cpp62
1 files changed, 35 insertions, 27 deletions
diff --git a/src/gui/updatewindow.cpp b/src/gui/updatewindow.cpp
index 7fc80dd7..044a1a5c 100644
--- a/src/gui/updatewindow.cpp
+++ b/src/gui/updatewindow.cpp
@@ -39,6 +39,7 @@ std::string updateHost = "themanaworld.org/files";
std::string currentFile = "news.txt";
bool downloadComplete = true;
int downloadStatus = UPDATE_NEWS;
+std::string basePath = "";
UpdaterWindow::UpdaterWindow()
: Window("Updating...")
@@ -120,9 +121,6 @@ void UpdaterWindow::action(const std::string& eventId)
else if (eventId == "play") {
state = LOGIN;
}
- else if (eventId == "ok") {
- state = LOGIN;
- }
}
void UpdaterWindow::loadNews()
@@ -141,6 +139,12 @@ void UpdaterWindow::loadNews()
setVisible(true);
}
+void UpdaterWindow::setText(std::string row) {
+ browserBox->addRow(row);
+ scrollArea->setVerticalScrollAmount(
+ scrollArea->getVerticalMaxScroll());
+}
+
int updateProgress(void *ptr,
double t, /* dltotal */
double d, /* dlnow */
@@ -177,8 +181,9 @@ int downloadThread(void *ptr)
{
// Download current file as a temp file
logger->log("Downloading: %s", url.c_str());
- // Download in the proper folder : ./data under win, /home/user/.tmw/data for unices
- std::string outFilename = config.getValue("homeDir", "") + "/data/download.temp";
+ // Download in the proper folder : ./data under win,
+ // /home/user/.tmw/data for unices
+ std::string outFilename = basePath + "/data/download.temp";
outfile = fopen(outFilename.c_str(), "wb");
curl_easy_setopt(curl, CURLOPT_URL, url.c_str());
curl_easy_setopt(curl, CURLOPT_WRITEDATA, outfile);
@@ -197,8 +202,8 @@ int downloadThread(void *ptr)
else {
// If the download was successful give the file the proper name
// else it will be deleted later
- std::string newName(config.getValue("homeDir", "") + "/data/");
- newName += currentFile.c_str();
+ std::string newName(basePath + "/data/" + currentFile.c_str());
+ logger->log("Renaming: %s -> %s", outFilename.c_str(), newName.c_str());
rename(outFilename.c_str(), newName.c_str());
}
}
@@ -215,9 +220,6 @@ void download()
logger->log("Unable to create thread");
downloadStatus = UPDATE_ERROR;
}
- else {
- logger->log("Starting download of %s", currentFile.c_str());
- }
}
void checkFile(std::ifstream &in) {
@@ -240,15 +242,16 @@ void checkFile(std::ifstream &in) {
void updateData()
{
+
updaterWindow = new UpdaterWindow();
state = UPDATE;
- std::string updateHost =
- config.getValue("updatehost", "themanaworld.org/files");
+ updateHost = config.getValue("updatehost", "themanaworld.org/files");
+ basePath = config.getValue("homeDir", ".");
// Try to download the updates list
download();
std::ifstream in;
-
+
while (state == UPDATE)
{
// Handle SDL events
@@ -273,13 +276,12 @@ void updateData()
switch (downloadStatus) {
case UPDATE_ERROR:
SDL_WaitThread(thread, NULL);
- new OkDialog(
- "Error",
- "The update process is incomplete.\n"
- "It is strongly recommended that you try again later",
- updaterWindow);
- logger->log("Error during the update process");
- downloadStatus = UPDATE_IDLE;
+ //cancellare tutto, rimettere browser box protected, creare metodi per aggiungere linee e cancellare tutto
+ updaterWindow->setText("");
+ updaterWindow->setText("##1 The update process is incomplete.");
+ updaterWindow->setText("##1 It is strongly recommended that");
+ updaterWindow->setText("##1 you try again later");
+ downloadStatus = UPDATE_COMPLETE;
break;
case UPDATE_NEWS:
// If not already downloading another file
@@ -300,7 +302,7 @@ void updateData()
if (!in.is_open())
{
// Try to open resources.txt
- in.open(TMW_DATADIR "data/resources.txt");
+ in.open((basePath + "/data/resources.txt").c_str(), std::ifstream::in);
if (!in.is_open())
{
logger->log("Unable to open resources.txt");
@@ -312,14 +314,20 @@ void updateData()
}
else {
SDL_WaitThread(thread, NULL);
- if (!in.eof())
+ if (in.is_open() && !in.eof())
{
// Download each update
std::string line("");
getline(in, line);
- // TODO: it should check if file already exists
currentFile = line;
- download();
+ std::ifstream temp((basePath + "/data" + line).c_str(), std::ifstream::in);
+ if (temp.is_open()) {
+ temp.close();
+ download();
+ }
+ else {
+ logger->log("%s is already here", line.c_str());
+ }
}
else {
// Download of updates completed
@@ -345,9 +353,9 @@ void updateData()
in.close();
// Remove downloaded files
- remove(TMW_DATADIR "data/news.txt");
- remove(TMW_DATADIR "data/resources.txt");
- remove(TMW_DATADIR "data/download.temp");
+ remove((basePath + "/data/news.txt").c_str());
+ remove((basePath + "/data/resources.txt").c_str());
+ remove((basePath + "/data/download.temp").c_str());
delete updaterWindow;
}