summaryrefslogtreecommitdiffstats
path: root/MultiMC.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'MultiMC.cpp')
-rw-r--r--MultiMC.cpp60
1 files changed, 60 insertions, 0 deletions
diff --git a/MultiMC.cpp b/MultiMC.cpp
index c93701b8..b49773a1 100644
--- a/MultiMC.cpp
+++ b/MultiMC.cpp
@@ -3,6 +3,8 @@
#include <iostream>
#include <QDir>
#include <QNetworkAccessManager>
+#include <QTranslator>
+#include <QLibraryInfo>
#include "gui/mainwindow.h"
#include "logic/lists/InstanceList.h"
@@ -25,6 +27,8 @@ MultiMC::MultiMC ( int& argc, char** argv )
setOrganizationName("Forkk");
setApplicationName("MultiMC 5");
+ initTranslations();
+
// Print app header
std::cout << "MultiMC 5" << std::endl;
std::cout << "(c) 2013 MultiMC Contributors" << std::endl << std::endl;
@@ -142,10 +146,64 @@ MultiMC::MultiMC ( int& argc, char** argv )
MultiMC::~MultiMC()
{
+ if(m_mmc_translator)
+ {
+ removeTranslator(m_mmc_translator);
+ delete m_mmc_translator;
+ m_mmc_translator = nullptr;
+ }
+ if(m_qt_translator)
+ {
+ removeTranslator(m_qt_translator);
+ delete m_qt_translator;
+ m_qt_translator = nullptr;
+ }
delete m_settings;
delete m_metacache;
}
+void MultiMC::initTranslations()
+{
+ m_qt_translator = new QTranslator();
+ if(m_qt_translator->load("qt_" + QLocale::system().name(), QLibraryInfo::location(QLibraryInfo::TranslationsPath)))
+ {
+ std::cout
+ << "Loading Qt Language File for "
+ << QLocale::system().name().toLocal8Bit().constData()
+ << "...";
+ if(!installTranslator(m_qt_translator))
+ {
+ std::cout << " failed.";
+ }
+ std::cout << std::endl;
+ }
+ else
+ {
+ delete m_qt_translator;
+ m_qt_translator = nullptr;
+ }
+
+ m_mmc_translator = new QTranslator();
+ if(m_mmc_translator->load("mmc_" + QLocale::system().name(), QDir("translations").absolutePath()))
+ {
+ std::cout
+ << "Loading MMC Language File for "
+ << QLocale::system().name().toLocal8Bit().constData()
+ << "...";
+ if(!installTranslator(m_mmc_translator))
+ {
+ std::cout << " failed.";
+ }
+ std::cout << std::endl;
+ }
+ else
+ {
+ delete m_mmc_translator;
+ m_mmc_translator = nullptr;
+ }
+}
+
+
void MultiMC::initGlobalSettings()
{
m_settings = new INISettingsObject("multimc.cfg", this);
@@ -228,6 +286,8 @@ int main(int argc, char *argv[])
MainWindow mainWin;
mainWin.show();
+
+
switch(app.status())
{
case MultiMC::Initialized: