Newer
Older
/***************************************************************************
* Copyright (C) 2011-2017 by Tomasz Bojczuk *
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 3 of the License, or *
* (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program. If not, see <http://www.gnu.org/licenses/>. *
***************************************************************************/
//#include <tmtr.h>
#include <QtGui/qguiapplication.h>
#include <QtGui/qicon.h>
#include <QtQml/qqmlapplicationengine.h>
#include <QtQml/qqmlcontext.h>
#include <QtCore/qdebug.h>
#include <QtCore/qtranslator.h>
#include <QtCore/qdatetime.h>
#include <QtCore/qpointer.h>
#include <QtCore/qfile.h>
#include <QtCore/qsettings.h>
#include "tnootkaqml.h"
SeeLook
committed
#if defined (Q_OS_ANDROID)
#include <Android/tandroid.h>
#endif
/** It allows to grab all debug messages into nootka-log.txt file */
void myMessageOutput(QtMsgType type, const QMessageLogContext &context, const QString &msg) {
Q_UNUSED(context)
Q_UNUSED(type)
// if (type == QtDebugMsg) {
#if defined (Q_OS_ANDROID)
#else
QFile outFile(QStringLiteral("nootka-log.txt"));
#endif
outFile.open(QIODevice::WriteOnly | QIODevice::Append);
QTextStream ts(&outFile);
ts << msg << endl;
}
{
#if defined (Q_OS_ANDROID)
qputenv("QT_ANDROID_VOLUME_KEYS", "1"); // Handle volume keys by Qt, lock native Android behavior
logFile = Tandroid::getExternalPath() + QStringLiteral("/nootka-log.txt");
if (QFile::exists(logFile))
QFile::remove(logFile);
qInstallMessageHandler(myMessageOutput);
qDebug() << "==== NOOTKA LOG =======\n" << QDateTime::currentDateTime().toString();
SeeLook
committed
QTranslator qtTranslator;
QTranslator nooTranslator;
QPointer<QGuiApplication> a = nullptr;
QQmlApplicationEngine *e = nullptr;
Tpath pathObj;
TnootkaQML nooObj;
int exitCode;
bool firstTime = true;
QString confFile;
resetConfig = false;
do {
SeeLook
committed
#if !defined (Q_OS_ANDROID)
if (a) delete a;
if (resetConfig) { // delete config file - new Nootka instance will start with first run wizard
QFile f(confFile);
f.remove();
}
resetConfig = false;
SeeLook
committed
#endif
a = new QGuiApplication(argc, argv);
// Tmtr::init(a);
SeeLook
committed
gl = new Tglobals();
gl->path = Tglobals::getInstPath(qApp->applicationDirPath());
confFile = gl->config->fileName();
if (!initCoreLibrary())
return 110;
prepareTranslations(a, qtTranslator, nooTranslator);
if (!loadNootkaFont(a))
return 111;
a->setWindowIcon(QIcon(Tpath::img("nootka")));
SeeLook
committed
e = new QQmlApplicationEngine;
e->rootContext()->setContextProperty(QStringLiteral("Tpath"), &pathObj);
e->rootContext()->setContextProperty(QStringLiteral("GLOB"), GLOB);
e->rootContext()->setContextProperty(QStringLiteral("Noo"), &nooObj);
e->load(QUrl(QStringLiteral("qrc:/MainWindow.qml")));
// #if defined (Q_OS_ANDROID)
// w->showFullScreen(); // TODO
// #endif
if (firstTime) {
#if defined (Q_OS_ANDROID)
// QString androidArg = Tandroid::getRunArgument();
// if (!androidArg.isEmpty())
// w->openFile(androidArg);
#else // TODO
// if (argc > 1)
// w->openFile(QString::fromLocal8Bit(argv[argc - 1]));
#endif
}
firstTime = false;
exitCode = a->exec();
delete e;
SeeLook
committed
delete gl;
SeeLook
committed
if (resetConfig) { // delete config file - new Nootka instance will start with first run wizard
QFile f(confFile);
f.remove();
Tandroid::restartNootka(); // and call Nootka after delay
SeeLook
committed
}
resetConfig = false; // do - while loop doesn't work with Android
qApp->quit(); // HACK: calling QApplication::quick() solves hang on x86 when Qt uses native (usually obsolete) SSL libraries