* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/
-#include <iostream>
-
-#include "global.h"
#include "settings.h"
-#include "quasselui.h"
+#include <QString>
#if defined BUILD_CORE
#include <QCoreApplication>
+#include <QDir>
#include "core.h"
+#include "message.h"
#elif defined BUILD_QTGUI
#include <QApplication>
-#include "style.h"
#include "client.h"
-#include "clientproxy.h"
-#include "mainwin.h"
+//#include "clientproxy.h"
+#include "qtgui.h"
+#include "style.h"
#elif defined BUILD_MONO
#include <QApplication>
+#include "client.h"
+//#include "clientproxy.h"
#include "core.h"
-#include "coreproxy.h"
+#include "coresession.h"
+#include "qtgui.h"
#include "style.h"
-#include "client.h"
-#include "clientproxy.h"
-#include "mainwin.h"
#else
#error "Something is wrong - you need to #define a build mode!"
#endif
+#include <signal.h>
+
+//! Signal handler for graceful shutdown.
+void handle_signal(int sig) {
+ qWarning(QString("Caught signal %1 - exiting.").arg(sig).toAscii());
+ QCoreApplication::quit();
+}
+
int main(int argc, char **argv) {
+ // We catch SIGTERM and SIGINT (caused by Ctrl+C) to graceful shutdown Quassel.
+ signal(SIGTERM, handle_signal);
+ signal(SIGINT, handle_signal);
+
+ qRegisterMetaType<QVariant>("QVariant");
+ qRegisterMetaType<Message>("Message");
+ qRegisterMetaType<BufferId>("BufferId");
+ qRegisterMetaTypeStreamOperators<QVariant>("QVariant");
+ qRegisterMetaTypeStreamOperators<Message>("Message");
+ qRegisterMetaTypeStreamOperators<BufferId>("BufferId");
+
#if defined BUILD_CORE
Global::runMode = Global::CoreOnly;
QCoreApplication app(argc, argv);
Global::runMode = Global::Monolithic;
QApplication app(argc, argv);
#endif
- //AbstractUi *foo = new AbstractUi();
- //foo->init();
QCoreApplication::setOrganizationDomain("quassel-irc.org");
QCoreApplication::setApplicationName("Quassel IRC");
QCoreApplication::setOrganizationName("Quassel IRC Development Team");
Core::instance(); // create and init the core
#endif
- Settings::init();
+ //Settings::init();
#ifndef BUILD_CORE
Style::init();
QtGui *gui = new QtGui();
Client::init(gui);
gui->init();
-//#else
-// Core::instance(); // create and init the core object
#endif
int exitCode = app.exec();
#ifdef BUILD_QTGUI
QVariant Client::connectToLocalCore(QString, QString) { return QVariant(); }
void Client::disconnectFromLocalCore() {}
-#elif defined BUILD_MONO
+#elif defined BUILD_MONO
QVariant Client::connectToLocalCore(QString user, QString passwd) {
// TODO catch exceptions
+ /*
QVariant reply = Core::connectLocalClient(user, passwd);
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)));
return reply;
+ */
+ return QVariant();
}
void Client::disconnectFromLocalCore() {
+ /*
disconnect(Core::localSession(), 0, ClientProxy::instance(), 0);
disconnect(ClientProxy::instance(), 0, Core::localSession(), 0);
Core::disconnectLocalClient();
+ */
}
#endif