1
0
mirror of https://github.com/qTox/qTox.git synced 2024-03-22 14:00:36 +08:00

Merge pull request #3668

Diadlo (1):
      fix: Fixed crash on profile import
This commit is contained in:
Nils Fenner 2016-08-31 11:51:25 +02:00
commit b7d12222ae
No known key found for this signature in database
GPG Key ID: 9591A163FF9BE04C
2 changed files with 64 additions and 25 deletions

View File

@ -18,34 +18,67 @@
*/ */
#include "profileimporter.h" #include "profileimporter.h"
#include <QString>
#include <QFile> #include <QApplication>
#include <QDir>
#include <QFileDialog> #include <QFileDialog>
#include <QFileInfo>
#include "src/persistence/settings.h"
#include "src/core/core.h"
#include "src/widget/gui.h"
#include <QDebug>
#include <QMessageBox> #include <QMessageBox>
#include <QPushButton>
#include "src/core/core.h"
#include "src/persistence/settings.h"
/**
* @class ProfileImporter
* @brief This class provides the ability to import profile.
* @note This class can be used before @a Nexus instance will be created,
* consequently it can't use @a GUI class. Therefore it should use QMessageBox
* to create dialog forms.
*/
ProfileImporter::ProfileImporter(QWidget *parent) : QWidget(parent) ProfileImporter::ProfileImporter(QWidget *parent) : QWidget(parent)
{ {
} }
/**
* @brief Show a file dialog. Selected file will be imported as Tox profile.
* @return True, if the import was succesful. False otherwise.
*/
bool ProfileImporter::importProfile() bool ProfileImporter::importProfile()
{ {
QString path = QFileDialog::getOpenFileName(this, QString title = tr("Import profile", "import dialog title");
tr("Import profile", "import dialog title"), QString filter = tr("Tox save file (*.tox)", "import dialog filter");
QDir::homePath(), QString dir = QDir::homePath();
tr("Tox save file (*.tox)", "import dialog filter"), QString path = QFileDialog::getOpenFileName(this, title, dir, filter, 0,
0,
QFileDialog::DontUseNativeDialog); QFileDialog::DontUseNativeDialog);
return importProfile(path); return importProfile(path);
} }
/**
* @brief Asks the user a question with Yes/No choices.
* @param title Title of question window.
* @param message Text in question window.
* @return True if the answer is positive, false otherwise.
*/
bool ProfileImporter::askQuestion(QString title, QString message)
{
QMessageBox::Icon icon = QMessageBox::Warning;
QMessageBox box(icon, title, message, QMessageBox::NoButton, this);
QPushButton* pushButton1 = box.addButton(QApplication::tr("Yes"), QMessageBox::AcceptRole);
QPushButton* pushButton2 = box.addButton(QApplication::tr("No"), QMessageBox::RejectRole);
box.setDefaultButton(pushButton2);
box.setEscapeButton(pushButton2);
box.exec();
return box.clickedButton() == pushButton1;
}
/**
* @brief Try to import Tox profile.
* @param path Path to Tox profile.
* @return True, if the import was succesful. False otherwise.
*/
bool ProfileImporter::importProfile(const QString &path) bool ProfileImporter::importProfile(const QString &path)
{ {
if (path.isEmpty()) if (path.isEmpty())
@ -54,8 +87,8 @@ bool ProfileImporter::importProfile(const QString &path)
QFileInfo info(path); QFileInfo info(path);
if (!info.exists()) if (!info.exists())
{ {
GUI::showWarning(tr("File doesn't exist"), QMessageBox::warning(this, tr("File doesn't exist"),
tr("Profile doesn't exist")); tr("Profile doesn't exist"), QMessageBox::Ok);
return false; return false;
} }
@ -63,18 +96,23 @@ bool ProfileImporter::importProfile(const QString &path)
if (info.suffix() != "tox") if (info.suffix() != "tox")
{ {
GUI::showWarning(tr("Ignoring non-Tox file", "popup title"), QMessageBox::warning(this, tr("Ignoring non-Tox file", "popup title"),
tr("Warning: You have chosen a file that is not a Tox save file; ignoring.", "popup text")); tr("Warning: You have chosen a file that is not a "
"Tox save file; ignoring.", "popup text"),
QMessageBox::Ok);
return false; //ingore importing non-tox file return false; //ingore importing non-tox file
} }
QString profilePath = QDir(Settings::getInstance().getSettingsDirPath()).filePath(profile + Core::TOX_EXT); QString settingsPath = Settings::getInstance().getSettingsDirPath();
QString profilePath = QDir(settingsPath).filePath(profile + Core::TOX_EXT);
if (QFileInfo(profilePath).exists()) if (QFileInfo(profilePath).exists())
{ {
QString title = tr("Profile already exists", "import confirm title"); QString title = tr("Profile already exists", "import confirm title");
QString message = tr("A profile named \"%1\" already exists. Do you want to erase it?", "import confirm text").arg(profile); QString message = tr("A profile named \"%1\" already exists. "
bool erase = GUI::askQuestion(title, message); "Do you want to erase it?",
"import confirm text").arg(profile);
bool erase = askQuestion(title, message);
if (!erase) if (!erase)
return false; //import canelled return false; //import canelled
@ -85,7 +123,9 @@ bool ProfileImporter::importProfile(const QString &path)
QFile::copy(path, profilePath); QFile::copy(path, profilePath);
// no good way to update the ui from here... maybe we need a Widget:refreshUi() function... // no good way to update the ui from here... maybe we need a Widget:refreshUi() function...
// such a thing would simplify other code as well I believe // such a thing would simplify other code as well I believe
GUI::showInfo(tr("Profile imported"), QMessageBox::information(this, tr("Profile imported"),
tr("%1.tox was successfully imported").arg(profile)); tr("%1.tox was successfully imported").arg(profile),
QMessageBox::Ok);
return true; //import successfull return true; //import successfull
} }

View File

@ -31,9 +31,8 @@ public:
bool importProfile(const QString &path); bool importProfile(const QString &path);
bool importProfile(); bool importProfile();
signals: private:
bool askQuestion(QString title, QString message);
public slots:
}; };
#endif // PROFILEIMPORTER_H #endif // PROFILEIMPORTER_H