/***************************************************************************
- * Copyright (C) 2005-07 by The Quassel IRC Development Team *
+ * Copyright (C) 2005-08 by the Quassel Project *
* devel@quassel-irc.org *
* *
* 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 2 of the License, or *
- * (at your option) any later version. *
+ * (at your option) version 3. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/
-#include <iostream>
-
-#include "global.h"
-#include "settings.h"
-
-#if defined BUILD_CORE
-#include <QCoreApplication>
-#include "core.h"
-
-#elif defined BUILD_QTGUI
-#include <QApplication>
-#include "style.h"
-#include "client.h"
-#include "clientproxy.h"
-#include "mainwin.h"
+#include <cstdlib>
+#ifdef BUILD_CORE
+# include "../core/coreapplication.h"
+#elif defined BUILD_QTUI
+# include "qtuiapplication.h"
#elif defined BUILD_MONO
-#include <QApplication>
-#include "core.h"
-#include "coreproxy.h"
-#include "style.h"
-#include "client.h"
-#include "clientproxy.h"
-#include "mainwin.h"
+# include "monoapplication.h"
#else
#error "Something is wrong - you need to #define a build mode!"
#endif
-int main(int argc, char **argv) {
-#if defined BUILD_CORE
- Global::runMode = Global::CoreOnly;
- QCoreApplication app(argc, argv);
-#elif defined BUILD_QTGUI
- Global::runMode = Global::ClientOnly;
- QApplication app(argc, argv);
-#else
- Global::runMode = Global::Monolithic;
- QApplication app(argc, argv);
-#endif
-
- QCoreApplication::setOrganizationDomain("quassel-irc.org");
- QCoreApplication::setApplicationName("Quassel IRC");
- QCoreApplication::setOrganizationName("Quassel IRC Development Team");
-
- Global::quasselDir = QDir::homePath() + "/.quassel";
- Core::instance();
-#ifdef BUILD_MONO
- QObject::connect(Core::localSession(), SIGNAL(proxySignal(CoreSignal, QVariant, QVariant, QVariant)), ClientProxy::instance(), SLOT(recv(CoreSignal, QVariant, QVariant, QVariant)));
- QObject::connect(ClientProxy::instance(), SIGNAL(send(ClientSignal, QVariant, QVariant, QVariant)), Core::localSession(), SLOT(processSignal(ClientSignal, QVariant, QVariant, QVariant)));
-#endif
-
- Settings::init();
+#include "quassel.h"
-#ifndef BUILD_CORE
- Style::init();
- MainWin *mainWin = new MainWin();
- Client::init(mainWin);
- mainWin->init();
-#else
- Core::instance(); // create and init the core object
-#endif
+int main(int argc, char **argv) {
- int exitCode = app.exec();
+# ifdef BUILD_CORE
+ CoreApplication app(argc, argv);
+# elif BUILD_QTUI
+ QtUiApplication app(argc, argv);
+# elif BUILD_MONO
+ MonolithicApplication app(argc, argv);
+# endif
-#ifndef BUILD_CORE
- // the mainWin has to be deleted before the Core
- // if not Quassel will crash on exit under certain conditions since the gui
- // still wants to access clientdata
- delete mainWin;
- Client::destroy();
-#endif
-#ifndef BUILD_QTGUI
- Core::destroy();
-#endif
-
- return exitCode;
-}
+# include "version.gen"
+ buildinfo.append(QString(",%1,%2").arg(__DATE__, __TIME__));
+ app.setupBuildInfo(buildinfo);
-#ifndef BUILD_CORE
-void Client::syncToCore() {
- //Q_ASSERT(Global::data("CoreReady").toBool());
- coreBuffers = Core::localSession()->buffers();
- // NOTE: We don't need to request server states, because in the monolithic version there can't be
- // any servers connected at this stage...
+ if(!app.init()) return EXIT_FAILURE;
+ return app.exec();
}
-#endif