/***************************************************************************
- * Copyright (C) 2005-2015 by the Quassel Project *
+ * Copyright (C) 2005-2018 by the Quassel Project *
* devel@quassel-irc.org *
* *
* This program is free software; you can redistribute it and/or modify *
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
***************************************************************************/
-#include "coreapplication.h"
-
#include "core.h"
-#include "logger.h"
-
-CoreApplicationInternal::CoreApplicationInternal()
- : _coreCreated(false)
-{
-}
-
-
-CoreApplicationInternal::~CoreApplicationInternal()
-{
- if (_coreCreated) {
- Core::saveState();
- Core::destroy();
- }
-}
-
-
-bool CoreApplicationInternal::init()
-{
- /* FIXME
- This is an initial check if logfile is writable since the warning would spam stdout if done
- in current Logger implementation. Can be dropped whenever the logfile is only opened once.
- */
- QFile logFile;
- if (!Quassel::optionValue("logfile").isEmpty()) {
- logFile.setFileName(Quassel::optionValue("logfile"));
- if (!logFile.open(QIODevice::Append | QIODevice::Text))
- qWarning("Warning: Couldn't open logfile '%s' - will log to stdout instead", qPrintable(logFile.fileName()));
- else logFile.close();
- }
-
- Core::instance(); // create and init the core
- _coreCreated = true;
-
- if (!Quassel::isOptionSet("norestore"))
- Core::restoreState();
-
- return true;
-}
-
+#include "coreapplication.h"
-/*****************************************************************************/
CoreApplication::CoreApplication(int &argc, char **argv)
- : QCoreApplication(argc, argv), Quassel()
+ : QCoreApplication(argc, argv)
{
#ifdef Q_OS_MAC
- disableCrashhandler();
+ Quassel::disableCrashHandler();
#endif /* Q_OS_MAC */
- setRunMode(Quassel::CoreOnly);
- _internal = new CoreApplicationInternal();
+ Quassel::setRunMode(Quassel::CoreOnly);
}
CoreApplication::~CoreApplication()
{
- delete _internal;
+ _core.reset();
+ Quassel::destroy();
}
-bool CoreApplication::init()
+void CoreApplication::init()
{
- if (Quassel::init() && _internal->init()) {
-#if QT_VERSION < 0x050000
- qInstallMsgHandler(Logger::logMessage);
-#else
- qInstallMessageHandler(Logger::logMessage);
-#endif
- return true;
+ if (!Quassel::init()) {
+ throw ExitException{EXIT_FAILURE, tr("Could not initialize Quassel!")};
}
- return false;
+
+ _core.reset(new Core{}); // FIXME C++14: std::make_unique
+ _core->init();
}