Skip to content
Snippets Groups Projects
main.cpp 4.85 KiB
Newer Older
SeeLook's avatar
SeeLook committed
/***************************************************************************
 *   Copyright (C) 2011-2017 by Tomasz Bojczuk                             *
 *   seelook@gmail.com                                                     *
SeeLook's avatar
SeeLook committed
 *                                                                         *
 *   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/>.  *
 ***************************************************************************/

SeeLook's avatar
SeeLook committed
#include <tinitcorelib.h>
#include <tpath.h>
#include <QtGui/qicon.h>
#include <QtQml/qqmlapplicationengine.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>

#if defined (Q_OS_ANDROID)
  #include <Android/tandroid.h>
#endif
static QString logFile;
SeeLook's avatar
SeeLook committed

/** It allows to grab all debug messages into nootka-log.txt file */
void myMessageOutput(QtMsgType type, const QMessageLogContext &context, const QString &msg) {
  Q_UNUSED(type)
//   if (type == QtDebugMsg) {
#if defined (Q_OS_ANDROID)
    QFile outFile(logFile);
#else
    QFile outFile(QStringLiteral("nootka-log.txt"));
#endif
    outFile.open(QIODevice::WriteOnly | QIODevice::Append);
    QTextStream ts(&outFile);
    ts << msg << endl;
SeeLook's avatar
SeeLook committed
Tglobals *gl;
bool resetConfig;

SeeLook's avatar
SeeLook committed
int main(int argc, char *argv[])
{
#if defined (Q_OS_ANDROID)
  qputenv("QT_ANDROID_VOLUME_KEYS", "1"); // Handle volume keys by Qt, lock native Android behavior

  // log to any writable storage
 logFile = Tandroid::getExternalPath() + QStringLiteral("/nootka-log.txt");
  if (QFile::exists(logFile))
    QFile::remove(logFile);
 qInstallMessageHandler(myMessageOutput);
  qDebug() << "==== NOOTKA LOG =======\n" << QDateTime::currentDateTime().toString();
  QTranslator qtTranslator;
  QTranslator nooTranslator;
  QPointer<QGuiApplication> a = nullptr;
  QQmlApplicationEngine *e = nullptr;

  int exitCode;
  bool firstTime = true;
  QString confFile;
  resetConfig = false;
  do {
    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;
    a = new QGuiApplication(argc, argv);
//     Tmtr::init(a);
    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's avatar
SeeLook committed
// creating main window
    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")));
SeeLook's avatar
SeeLook committed

// #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]));
    firstTime = false;
    exitCode = a->exec();
    delete e;
#if defined (Q_OS_ANDROID)
    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
    resetConfig = false; // do - while loop doesn't work with Android
SeeLook's avatar
SeeLook committed
    qApp->quit(); // HACK: calling QApplication::quick() solves hang on x86 when Qt uses native (usually obsolete) SSL libraries
  } while (resetConfig);
  delete a;
  return exitCode;
SeeLook's avatar
SeeLook committed
}